在Android中创建ShortCut大概有两种方法。
第一种方法就是参照api demos中写的那个,通过设置setResult(RESULT_OK, intent);来创建ShortCut,这种方式在稍后分析。
本文以Broadcast方式方式来介绍Android中ShortCut的创建。
在创建或删除ShortCut的时候先需要在AndroidManifest.xml中增加两个权限
<!-- 创建桌面快捷方式的权限 -->
<uses-permission android:name="com.android.launcher.permission.INSTALL_SHORTCUT"/>
<uses-permission android:name="com.android.launcher.permission.UNINSTALL_SHORTCUT"/>

另外记得在创建或删除ShortCut的Intent中设置Action为
com.android.launcher.action.INSTALL_SHORTCUT(创建)
com.android.launcher.action.UNINSTALL_SHORTCUT(删除)

这样发送出去的广播才能被Android系统接受到

package com.zhy.shortcut;import android.app.Activity;import android.content.ComponentName;import android.content.Intent;import android.content.SharedPreferences;import android.content.SharedPreferences.Editor;import android.os.Bundle;import android.preference.PreferenceManager;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;public class ShortCutActivity extends Activity {    private static final String CREATE_SHORTCUT_ACTION = "com.android.launcher.action.INSTALL_SHORTCUT";    private static final String DROP_SHORTCUT_ACTION = "com.android.launcher.action.UNINSTALL_SHORTCUT";    private static final String PREFERENCE_KEY_SHORTCUT_EXISTS = "IsShortCutExists";    Button button;    // 获取默认的SharedPreferences    SharedPreferences sharedPreferences ;    // 从SharedPreferences获取是否存在快捷方式 若不存在返回false 程序第一次进来肯定返回false    boolean exists ;    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);                sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this);        exists = sharedPreferences.getBoolean(PREFERENCE_KEY_SHORTCUT_EXISTS, false);        //创建桌面快捷方式        //若第一次启动则创建,下次启动则不创建        if (!exists) {            setUpShortCut();        }        setContentView(R.layout.main);        button = (Button) findViewById(R.id.dropShortCut);        button.setOnClickListener(new OnClickListener() {            @Override            public void onClick(View v) {                tearDownShortCut();            }        });    }    /**     * 创建桌面快捷方式     */    private void setUpShortCut() {        Intent intent = new Intent(CREATE_SHORTCUT_ACTION);        // 设置快捷方式图片        intent.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE,Intent.ShortcutIconResource.fromContext(this, R.drawable.logo));        // 设置快捷方式名称        intent.putExtra(Intent.EXTRA_SHORTCUT_NAME, "sina");        // 设置是否允许重复创建快捷方式 false表示不允许        intent.putExtra("duplicate", false);                        // 设置快捷方式要打开的intent                // 第一种方法创建快捷方式要打开的目标intent        Intent targetIntent = new Intent();        // 设置应用程序卸载时同时也删除桌面快捷方式        targetIntent.setAction(Intent.ACTION_MAIN);        targetIntent.addCategory("android.intent.category.LAUNCHER");                ComponentName componentName = new ComponentName(getPackageName(), this.getClass().getName());        targetIntent.setComponent(componentName);                // 第二种方法创建快捷方式要打开的目标intent        /*         * Intent         * targetIntent=getPackageManager().getLaunchIntentForPackage(getPackageName         * ());         */        intent.putExtra(Intent.EXTRA_SHORTCUT_INTENT, targetIntent);        // 发送广播        sendBroadcast(intent);        Editor editor = sharedPreferences.edit();        editor.putBoolean(PREFERENCE_KEY_SHORTCUT_EXISTS, true);        editor.commit();    }    /**     * 删除桌面快捷方式     */    private void tearDownShortCut() {        Intent intent = new Intent(DROP_SHORTCUT_ACTION);        // 指定要删除的shortcut名称        intent.putExtra(Intent.EXTRA_SHORTCUT_NAME, "sina");        String appClass = getPackageName() + "." + this.getLocalClassName();        ComponentName component = new ComponentName(getPackageName(), appClass);        intent.putExtra(Intent.EXTRA_SHORTCUT_INTENT,new Intent().setAction(Intent.ACTION_MAIN).setComponent(component));        sendBroadcast(intent);    }}
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="com.zhy.shortcut"    android:versionCode="1"    android:versionName="1.0" >    <uses-sdk android:minSdkVersion="8" />    <!-- 创建桌面快捷方式的权限 -->    <uses-permission android:name="com.android.launcher.permission.INSTALL_SHORTCUT"/>    <uses-permission android:name="com.android.launcher.permission.UNINSTALL_SHORTCUT"/>    <application        android:icon="@drawable/ic_launcher"        android:label="@string/app_name" >        <activity            android:label="@string/app_name"            android:name=".ShortCutActivity" >            <intent-filter >                <action android:name="android.intent.action.MAIN" />                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>    </application></manifest>
对android源码的分析: http://blog.csdn.net/zircon_1973/article/details/7773254


这里需要特别说明的是,关于overridePendingTransition这个函数,有两点需要主意:
1.它必需紧挨着startActivity()或者finish()函数之后调用
2.它只在android2.0以及以上版本上适用




更多相关文章

  1. 怎么让android定时关机
  2. RelativieLayout布局中的android:gravity="center"属性
  3. Android(安卓)之 zygote 与进程创建
  4. android 使用代码方式创建自定义progressBar——自定义控件学习(
  5. android:configChanges属性
  6. android 属性汇总
  7. ubuntu创建wifi热点(android可识别)亲测可用
  8. Android利用Fiddler进行网络数据抓包
  9. 【Android】Android(安卓)UI 开发_问答_3

随机推荐

  1. Android模拟 HTTP multipart/form-data
  2. Android中的几种网络请求方式详解
  3. 对Android体系结构的理解--后续会补充
  4. android应用安全——(数据抓包)跟踪监控and
  5. 解决:android:editable is deprecated: Us
  6. Android(安卓)状态栏透明的一些小结
  7. 详解Android(安卓)TableLayout中stretchC
  8. Android读写XML(下)——创建XML文档
  9. android面试题大全 android面试题总结
  10. Unable to resolve target 'android-18'