久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

淺談Android添加快捷方式ShortCut

瀏覽:31日期:2022-09-19 17:01:48

眾所周知application有4種啟動(dòng)方式:

點(diǎn)擊app啟動(dòng) 快捷方式 通知跳轉(zhuǎn) 輸入命令(adb命令等)

今天給大家簡單介紹一下快捷方式啟動(dòng)的用法~

快捷方式介紹

谷歌官方在Android 7.1(API 25)新增了桌面長按彈出菜單,并且在8.0(API 26)以后可以固定快捷方式至桌面上。圍繞桌面快捷方式的需求也比較多,例如微信將聯(lián)系人、小程序都可以添加至桌面;簡書將“寫文章”添加至桌面;高德將“坐標(biāo)信息”添加到桌面。

快捷方式情景再現(xiàn)

將某個(gè)應(yīng)用添加到桌面

淺談Android添加快捷方式ShortCut

長按應(yīng)用打開某一個(gè)功能

淺談Android添加快捷方式ShortCut

快捷方式使用將某個(gè)應(yīng)用添加到桌面

先看代碼,后面我會(huì)將這些代碼寫成工具類供大家使用:

/** * @param context 當(dāng)前content * @param targetClass 快捷圖標(biāo)打開的界面 * @param backClass 打開后按返回鍵返回的界面 * @param shortCutId shortCut 唯一id * @param shortCutIcon 桌面上顯示的圖標(biāo) */ public void AddShortCut(Context context, Class targetClass, Class backClass, int shortCutId, int shortCutIcon) {if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { ShortcutManager shortcutManager = (ShortcutManager) context.getSystemService(Context.SHORTCUT_SERVICE); if (shortcutManager != null && shortcutManager.isRequestPinShortcutSupported()) {Intent shortcutInfoIntent = new Intent(context, targetClass);shortcutInfoIntent.setAction(Intent.ACTION_VIEW);ShortcutInfo info = new ShortcutInfo.Builder(context, 'id' + shortCutId).setIcon(Icon.createWithResource(context, shortCutIcon)).setShortLabel(titles[shortCutId]).setIntent(shortcutInfoIntent).build();PendingIntent shortcutCallbackIntent = PendingIntent.getBroadcast(context, 0, new Intent(context, backClass), PendingIntent.FLAG_UPDATE_CURRENT);shortcutManager.requestPinShortcut(info, shortcutCallbackIntent.getIntentSender()); }} else { Toast.makeText(context, '設(shè)備不支持在桌面創(chuàng)建快捷圖標(biāo)!', Toast.LENGTH_LONG).show();} }

測試:

shortUtil.AddShortCut( this, MainActivity::class.java, MainActivity::class.java, 2, R.drawable.ic_launcher_background)

效果圖(1.1):

淺談Android添加快捷方式ShortCut

修改快捷方式:

/** * @param context 上下文 * @param cls 要跳轉(zhuǎn)的頁面 * @param shortCutId shortCut 唯一id * @param shortCutIcon 桌面上顯示的圖標(biāo) * @param shortCutLabel 桌面圖標(biāo)下方顯示的文字 */ public void updItem(Context context, Class<?> cls, int shortCutId, int shortCutIcon, String shortCutLabel) {Intent intent = new Intent(context, cls);intent.setAction(Intent.ACTION_VIEW);intent.putExtra('msg', titles[shortCutId]);ShortcutInfo info = null;if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N_MR1) { info = new ShortcutInfo.Builder(context, 'id' + shortCutId) .setIcon(Icon.createWithResource(context, shortCutIcon)) .setShortLabel(shortCutLabel) .setIntent(intent) .build(); sm.updateShortcuts(Arrays.asList(info));} }

測試:

shortUtil.updItem( this, ModifyActivity::class.java, 2, R.drawable.ic_launcher_background, '修改快捷方式成功')

效果圖(1.2):

淺談Android添加快捷方式ShortCut

禁用快捷方式:

/** * 禁止使用快捷方式 * * @param index 禁止使用下標(biāo) */ public void remove(int index) {if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N_MR1) { sm.removeAllDynamicShortcuts(); List<String> list = new ArrayList<String>(); list.add('id' + index); sm.disableShortcuts(list);} }

測試:

shortUtil.remove(2)

效果圖(1.3):

淺談Android添加快捷方式ShortCut

長按應(yīng)用打開某一個(gè)功能:

這里以Fragment舉例:

先來看看最終的效果:

淺談Android添加快捷方式ShortCut

主要代碼:

private static int[] icons = {R.drawable.ic_launcher_background, R.drawable.ic_launcher_foreground, R.drawable.ic_launcher_background, R.drawable.ic_launcher_foreground,}; private static String[] titles = {'首頁', '我的', '詳情', '設(shè)置'};/** * 設(shè)置默認(rèn)快捷方式 * * @param context 上下文 * @param ast 跳轉(zhuǎn)頁面 */ public void setShortCuts(Context context, Class ast) {if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N_MR1) { ArrayList<ShortcutInfo> list = new ArrayList<>(); for (int i = 0; i < titles.length; i++) {Intent intent = new Intent(context, ast);intent.setAction(Intent.ACTION_VIEW);intent.putExtra('msg', titles[i]);intent.putExtra(SHORTCUT_TAB_INDEX, i);intent.addCategory('android.intent.category.LAUNCHER');ShortcutInfo build = new ShortcutInfo.Builder(context, 'id' + i).setShortLabel(titles[i]).setLongLabel(titles[i]).setIcon(Icon.createWithResource(context, icons[i])).setIntent(intent).build();list.add(build); } sm.setDynamicShortcuts(list);} else { Toast.makeText(context, '該設(shè)備不支持快捷方式', Toast.LENGTH_SHORT).show();} }

在Application中注冊(cè)一下:

淺談Android添加快捷方式ShortCut 

記得在清單文件聲明哦

// 保存按鈕val radiolist = listOf(radioButton1, radioButton2, radioButton3, radioButton4)//快捷方式打開initShort { val arg0 = intent?.extras?.getInt(ShortCutUtil.SHORTCUT_TAB_INDEX) if (arg0 != null) {val let = arg0.let { radioGroup.getChildAt(it)}val bun = Bundle()bun['title'] = (let as RadioButton).text as String//傳值blankFragment.setArguments(bun)radiolist[arg0].isChecked = true }} private fun initShort(arg0: () -> Unit) {arg0.invoke() } private operator fun Bundle.set(key: String, value: String) { this.putString(key, value)}

注意:這段代碼使用kotlin寫的,因?yàn)閯倓?chuàng)建項(xiàng)目的時(shí)候只能創(chuàng)建kotlin,我就懶的改了

Fragment代碼很簡單,通過Arguments獲取到值賦值到TextView上即可這里就不貼代碼了

以上就是淺談Android添加快捷方式ShortCut的詳細(xì)內(nèi)容,更多關(guān)于Android快捷方式的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Android
相關(guān)文章:
主站蜘蛛池模板: 99热新 | 中文字幕在线综合 | 国产精品欧美一区二区三区不卡 | 亚洲高清不卡视频 | 蜜桃视频一区 | 国产在线不卡 | 91精品国产99久久久久久红楼 | 国产精品夜色一区二区三区 | 99热在线观看免费 | 精品久久久久久久久久久久久久 | 一级片在线观看 | 久久久久亚洲 | 91黄色在线观看 | 亚洲精品自在在线观看 | 玖玖玖视频| 激情欧美一区二区 | 亚洲一区 中文字幕 | 超碰国产在线 | 久久免费99精品久久久久久 | 一级做a爰片性色毛片 | 亚洲三区在线观看 | 国产偷录视频叫床高潮对白 | 久久爱综合 | 色爱综合网 | 九九热在线视频免费观看 | 日韩三级在线免费 | 日日夜夜天天干干 | 精品视频在线免费观看 | 久久综合99re88久久爱 | 亚洲欧美精品一区二区三区 | 日韩成人在线播放 | 中文亚洲欧美 | 亚洲免费观看视频 | 日韩电影三级 | 久久99精品一区二区三区三区 | 亚洲狠狠爱一区二区三区 | 精品久久久久久一区二区 | 精品久久久久久亚洲精品 | 每日更新av | 亚洲香蕉精品 | 亚洲精品一区二三区不卡 |