android - 从受信任的 Web 活动 (TWA) 启动另一个活动
问题描述
我在尝试通过意图 URI 从 TWA 启动另一个活动时遇到问题。
"intent://#Intent;scheme=subscriptionschemetwa;package=com.package.www.twa;end"
当然,包名在现实中是唯一的。
我玩过它们,在 URI 中添加了主机、动作、附加功能等,但没有任何效果。
由于我是本机开发的新手,我会很感激一些帮助。该应用程序本身尚未在 Google Play 上公开(仅限内部),它使用 Bubblewrap 进行签名和打包,并通过 adb 安装。意图 URI 的后备在将我带到商店的内部列表的意义上确实有效,但我不知道为什么活动没有启动。
XML 块:
<activity android:name="SubscriptionActivity">
<intent-filter>
<data
android:host="com.package.www.twa"
android:scheme="subscriptionschemetwa" />
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
</intent-filter>
</activity>
Activity 与批量创建相同,添加了一个日志以检查它是否曾经进入该方法。它不是。
class SubscriptionActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
println("------test------")
setContentView(R.layout.activity_subscription)
}
}
单击指向意图 URI 的链接后的 logcat 日志似乎显示根本没有尝试启动活动,而是直接进入商店。我可以直接通过 adb shell 运行活动。
09-11 20:57:30.419 1595 25814 I CLP : startActivity sender check. com.android.chrome to Intent { act=android.intent.action.VIEW cat=[android.intent.category.BROWSABLE] dat=market://details?id=com.package.www.twa&referrer=com.android.chrome flg=0x10000000 pkg=com.android.vending cmp=com.android.vending/com.google.android.finsky.activities.MarketDeepLinkHandlerActivity (has extras) }
09-11 20:57:30.607 9562 9804 I AppIconSolution: load=com.package.www.twa, bg=96-96, dr=132-132, forDefault=false, density=0
09-11 20:57:30.611 9562 9804 I AppIconSolution: load=com.package.www.twa-theme2, bg=96-96, dr=132-132, tarScale=0.65, relScale=0.48, mask=false
09-11 20:57:30.786 22165 22165 I Finsky : [2] hze.a(11): Selecting account [xxxxxxxxxxxxxxxxxxxxxxxxxx] for package com.package.www.twa. overriding=[true]
09-11 20:57:30.794 22165 22165 I Finsky : [2] hze.a(11): Selecting account [xxxxxxxxxxxxxxxxxxxxxxxxxx] for package com.package.www.twa. overriding=[true]
09-11 20:57:30.917 22165 22200 I Finsky : [842] lge.run(418): Dropped referrer for com.package.www.twa because dropped_already_installed
09-11 20:57:30.934 22165 22165 I Finsky : [2] hze.a(11): Selecting account [xxxxxxxxxxxxxxxxxxxxxxxxxx] for package com.package.www.twa. overriding=[true]
09-11 20:57:30.940 22165 22165 I Finsky : [2] hze.a(11): Selecting account [xxxxxxxxxxxxxxxxxxxxxxxxxx] for package com.package.www.twa. overriding=[true]
感谢您提供任何意见,我已经研究了好几天了,我只是无法理解它。
解决方案
So it seems that the intent URI was wrong. I actually managed to start the activity without issues using what I thought was a deprecated way to invoke activities via intent URIs. But hey, it works. The URI I ended up using was:
subscriptionschemetwa://www.package.com
or in more general terms
scheme://host
Hope it helps someone avoid wasting time like I did :D
推荐阅读
- google-sheets - 将单元格值提取到仅在第三个“/”和第四个“/”之间
- javascript - 如何在 Open Layers 中调整地图的比例?
- java - Java在通过套接字流发送后不会反序列化对象
- oracle - Oracle Apex:每页的行数未显示
- python - Django的“ValueError:年份超出范围”
- rxjs - 试图理解这个 retryWhen/scan/delay rxjs 序列
- r - ggplot中的成对段
- android - FirebaseUI RecycleView 只显示第一项
- python - 为什么我的代码只循环使用 BeautifulSoup 的第一个网页?
- r - 试图在 R 上的 ds 中查找没有导演的电影