桌面快捷方式的那些事

方案1:使用Google标准接口支持快捷方式(动态固定快捷方式)

   概述:Google标准API 稳定 

   可行性:强依赖手机系统PMS/LAUNCH  手机厂商定制 rom是否支持

   具体实现:(通过使用Google标准接口,调用系统Api(动态固定快捷方式)实现快捷方式创建)

    调用AndroidAPI,shortcutManager.isRequestPinShortcutSupported()校验手机系统是否开放快捷方式创建能力,返回true,调用shortcutManager.requestPinShortcut()交由系统调度创建快捷方式。
    

    缺陷:暂无

方案2:在Manifest定义多个快捷入口,创建桌面快捷方式

    概述:Google标准API 稳定 

    可行性:不受限系统/launch,存在一定缺陷,长按图片无法支持移除,只支持卸载,卸载会全部快捷方式以及应用本身都会卸载掉。

    具体实现:通过在Manifest中定义多个快捷入口,实现快捷方式创建

        1.在Androidmanifest.xml中定义多个快捷入口,从而实现快捷方式创建(PS:可以通过定义targetActivity 启动模式实现跳转内容不一致问题)

<activity android:name="com.sample.shortcut.WebAppActivity"

            android:launchMode="singleInstance"/>

        <activity-alias

            android:name=".WebAppActivityAliasYouTube"

            android:enabled="false"

            android:label="测试YouTube"

            android:exported="true"

            android:icon="@drawable/youtube"

            android:targetActivity="com.sample.shortcut.WebAppActivity">

            <intent-filter>

                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />

            </intent-filter>

        </activity-alias>

        <activity-alias

            android:name=".WebAppActivityAliasDisney"

            android:enabled="false"

            android:label="测试Disney+"

            android:exported="true"

            android:icon="@drawable/disney"

            android:targetActivity="com.sample.shortcut.WebAppActivity">

            <intent-filter>

                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />

            </intent-filter>

        </activity-alias>

        2.动态控制图标是否在桌面可见

            可见:PackageManager.COMPONENT_ENABLED_STATE_ENABLED 

            不可见:PackageManager.COMPONENT_ENABLED_STATE_DISABLED

packageManager.setComponentEnabledSetting(

ComponentName(packageName,"${packageName}.WebAppActivityAliasDisney"),

PackageManager.COMPONENT_ENABLED_STATE_ENABLED, PackageManager.DONT_KILL_APP

)

        3.区分对应跳转

            在Oncrate中调用 or 在onNewIntent中  

            1.intent.component?.className 获取值 

            2.intent?.component?.packageManager.getActivityInfo(intent.component!!,0).loadLabel(packageManager).toString()区分

       4.在Oncrate or 在onNewIntent中(动态更新压后台的进程 Icon 与Labename  )

            
/**

    * 更新任务名字和图标

    */

    fun updateTaskNameAndIcon(activity: Activity, intent: Intent, drawableResId: Int) {

        val packageManager = activity.packageManager

        val activityInfo = intent.component?.let { packageManager.getActivityInfo(it, 0) }

        val tempActivityLabel = activityInfo?.loadLabel(packageManager)?.toString() ?:return

        val taskDescription = ActivityManager.TaskDescription(

            tempActivityLabel,  // 任务名称

            BitmapFactory.decodeResource(activity.resources, drawableResId) // 任务图标

        )

        activity.setTaskDescription(taskDescription) // 修改当前任务栈的名称和图标

    }


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容