Apk安装后不显示桌面图标问题

1.问题背景

  最近测试反馈说是一个外国的Tv相关的app,prime video安装后不显示icon,只能从原生setting里面打开这个应用,其他的app安装和显示都是正常的,

2.问题分析

刚拿到这个问题,感觉挺奇怪的,第一次遇到这个问题,

2.1把获取桌面app的方法贴出来
    fun getAllLaunchers(): ArrayList<AppLauncher> {
        val allApps = ArrayList<AppLauncher>()
        val intent = Intent(Intent.ACTION_MAIN, null)
        intent.addCategory(Intent.CATEGORY_LAUNCHER)
        val list = context.packageManager.queryIntentActivities(intent, PackageManager.PERMISSION_GRANTED)
     
        ....

        return unique.filter { it.packageName != "com.vankyo.launcher" } as ArrayList<AppLauncher>
    }

可以看到这个方法:packageManager.queryIntentActivities(..)

源码位置:.\frameworks\base\core\java\android\content\pm\packageManager.java 这个地方定义了抽象方法,具体实现是在PMS中,以下

具体实现:frameworks\base\services\core\java\com\android\server\pm\packagerManagerService.java

这里获取不到刚才安装的app,

如果换成另一个方法:

packageManager.getInstalledApplications(PackageManager.GET_UNINSTALLED_PACKAGES)

可以获取到刚安装的应用,

2.2 桌面应用跳转的代码贴出来:
    //根据点击位置获取app的对象
    val appLauncher = shortcutApps!![position] 
    // 根据对象,获取包名进行跳转
    val launchIntent = packageManager.getLaunchIntentForPackage(appLauncher.packageName)
    if (launchIntent != null) {
        try {
            startActivity(launchIntent)
        } catch (e: Exception) {
            showErrorToast(e)
    }

根据包名跳转app应该是最常用的方法,这没什么问题,

如果是把包名换成刚安装的应用,取到的launchIntent为null,跳转失败,解析这个apk,因为主文件乱码,无法获取有用的信息

2.3 发现问题

 在解决问题的过程中,找到一个网站,这个网站可以快速生成apk,并且打开指定包名的应用,网址贴出来:

Generator for ATV-Launcher Apps

生成的apk,亲测可用,能够打开prime video,反编译这个生成的apk,发现它的跳转方法如下:

   private void goPrime(){
        Intent launchIntentForPackage = getPackageManager().getLaunchIntentForPackage(this.packagePrime);
        if (launchIntentForPackage != null) {
            startActivity(launchIntentForPackage);
        } else {
            Intent leanbackLaunchIntentForPackage = getPackageManager().getLeanbackLaunchIntentForPackage(this.packagePrime);
            if (leanbackLaunchIntentForPackage != null) {
                startActivity(leanbackLaunchIntentForPackage);
            } else {
                Toast.makeText(this, "App \"" + this.packagePrime + "\" not found!", Toast.LENGTH_LONG).show();
            }
        }
        finish();
    }

经过打印,发现最后走的方法是:getLeanbackLaunchIntentForPackage()

这个方法和getLaunchIntentForPackage()的区别从名字中就能看出来:

一个是获取标签为 CATEGORY_LEANBACK_LAUNCHER 的intent,一个是获取标签为
CATEGORY_LAUNCHER 的intent.
3.原因分析
问题到这里也就明白了,Prime Video这个应用的MainActivity的category的值是
"android.intent.category.LEANBACK_LAUNCHER",至于为什么要这么做,网上有相关的文章解释:设置这个属性的谷歌商店商家的需要,否则无法在Google Play的TV应用商店上架。使用CATEGORY_LEANBACK_LAUNCHER意向过滤器将您的应用标识为已启用电视功能,并让Google Play将其标识为电视应用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值