适用于Android dev的可下载字体和“Chrome已停止”错误

适用于Android dev的可下载字体和“Chrome已停止”错误,第1张

概述作为Oreo和支持库中新的可下载字体支持的一部分,我已经开始将功能集成到我开发的应用程序中.第一个应用程序是成功的 – 只需几个活动的简单应用程序.第二个应用程序没有成功.添加可下载字体(基于此资源: https://developer.android.com/guide/topics/ui/look-and-feel/downloadable-fonts.html)后,我在启动活动时遇到此错误: 作为Oreo和支持库中新的可下载字体支持的一部分,我已经开始将功能集成到我开发的应用程序中.第一个应用程序是成功的 – 只需几个活动的简单应用程序.第二个应用程序没有成功.添加可下载字体(基于此资源: https://developer.android.com/guide/topics/ui/look-and-feel/downloadable-fonts.html)后,我在启动活动时遇到此错误:
01-05 13:48:50.849 1112-16753/? I/ActivityManager: Start proc 22862:com.androID.Chrome:sandBoxed_process0/u0i247 for webvIEw_service edu.bsu.androID.apps.traveler/org.chromium.content.app.SandBoxedProcessService001-05 13:48:51.047 22862-22862/? E/AndroIDRuntime: FATAL EXCEPTION: mainProcess: com.androID.Chrome:sandBoxed_process0,PID: 22862 androID.content.res.Resources$NotFoundException: Array resource ID #0x7f030030at androID.content.res.Resources.obtainTypedArray(Resources.java:618)at androID.content.res.Resources.preloadFonts(Resources.java:380)at androID.app.ActivityThread.handleBindApplication(ActivityThread.java:5769)at androID.app.ActivityThread.-wrap1(UnkNown Source:0)at androID.app.ActivityThread$H.handleMessage(ActivityThread.java:1656)at androID.os.Handler.dispatchMessage(Handler.java:106)at androID.os.Looper.loop(Looper.java:164)at androID.app.ActivityThread.main(ActivityThread.java:6494)at java.lang.reflect.Method.invoke(Native Method)at com.androID.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)at com.androID.internal.os.WebVIEwZygoteInit.main(WebVIEwZygoteInit.java:146)

该应用程序不会崩溃,但d出窗口会出现两次“Chrome已停止” – 再次打开应用程序或发送反馈.

基于堆栈跟踪,资源ID#0x7f030030是R.java中的以下条目(我期望):

public static final int preloaded_Fonts=0x7f030030;

我相信我已经确定了错误的原因 – 再次,错误表明Chrome有问题,但这种情况发生在我的应用中:

>活动的布局包含具有autolink属性“web”,“map”或“all”的TextVIEw.
>我根据上面引用的文档预加载清单中的字体.

消除清单中的预加载声明或删除autolink属性可解决此问题.不使用“web”,“map”或“all”作为autolink属性的TextVIEws不会生成错误(“phone”有效,我期望这是因为它不是基于Web的意图).显然,两者都不是理想的解决方案.这仅在应用程序的初始启动时发生.

同样,第一个应用程序使用相同的字体工作正常,在清单中预加载,并使用autolink属性.但是,工作和非工作应用程序之间存在差异:

>非工作应用程序是一个大型应用程序,因此它使用multIDex库,而工作应用程序则不使用.
>非工作应用程序是本地化的,专为多个设备设计,因此它包括英语和德语语言值目录以及与屏幕大小相关的值目录.工作应用程序不使用多个值资源文件夹.

为了解决这个问题,我尝试了以下方法:

>认为ResourceID与某些东西相冲突,我为字体数组创建了一个全新的资源,它创建了一个新的ID.错误仍然发生.
>将字体数组XML文件添加到项目中的所有值文件夹,无论屏幕大小或本地化如何.错误仍然发生.
>尝试了不同的字体和一种字体.错误仍然发生.
>从TextVIEws中删除“web”,“map”和“all”autolink值.错误消失了.
>从清单中删除了preload_Fonts元标记.错误消失了.

我发现问题跟踪器与此问题有些相关(我是跟踪器上的最新提交,但是在我完全理解问题的复杂性之前):https://issuetracker.google.com/u/1/issues/65575496

我测试了在以下设备上生成错误的应用,并且“Chrome已停止”错误仅出现在Oreo设备上. “简单”应用程序适用于所有设备,不会报告任何错误.

> Pixel 2 XL,8.1.0 – 错误
> Nexus 5X,8.1.0 – 错误
> Nexus 6,7.1.1 – 任何一个应用程序都没有错误

这两个应用程序都有以下gradle配置:

compileSdkVersion 27buildToolsversion '27.0.3'minSdkVersion 16targetSdkVersion 27supportlibraryVersion = "27.0.2"playServicesversion = "11.8.0"

是否有解决此问题的方法(其他不预加载字体或使用网络,地图或所有autolink属性)或者这与前面提到的问题跟踪器有关吗?

解决方法 此问题可能与 this existing bug与Play商店中的WebVIEw更新相关的根本原因相同. TextVIEw / linkify使用WebVIEw进行地址识别.

linkify.MAP_ADDRESSES无法正常工作,仅适用于美国地址.如果可能,请不要使用linkify.MAP_ADDRESSES或linkify.ALL(或它们的属性).

总结

以上是内存溢出为你收集整理的适用于Android dev的可下载字体和“Chrome已停止”错误全部内容,希望文章能够帮你解决适用于Android dev的可下载字体和“Chrome已停止”错误所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1135065.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-30
下一篇 2022-05-30

发表评论

登录后才能评论

评论列表(0条)

保存