适用于安卓开发和"Chrome has Stopped"错误的可下载字体



作为奥利奥和支持库中新的可下载字体支持的一部分,我已经开始将该功能整合到我开发的应用程序中。第一个应用程序是成功的 - 简单的应用程序,只有几个活动。第二个应用未成功。添加可下载字体(基于此资源: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.SandboxedProcessService0
01-05 13:48:51.047 22862-22862/? E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.android.chrome:sandboxed_process0, PID: 22862 android.content.res.Resources$NotFoundException: Array resource ID #0x7f030030
at 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)

该应用程序不会崩溃,但会出现两次弹出窗口,指出"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 库,而工作应用程序则不使用。
  • 非工作应用程序已本地化并针对多个设备设计,因此它包括英语和德语values目录以及屏幕大小相关的values目录。工作应用程序不使用多个values资源文件夹。

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

  • 认为 ResourceID 与某些内容冲突,我为字体数组创建了一个全新的资源,该资源创建了一个新 ID。
  • 将字体数组 XML 文件添加到项目中的所有values文件夹中,无论屏幕大小或本地化如何。仍然出现错误。
  • 尝试了不同的字体,只尝试了一种字体。仍然出现错误。
  • TextViews中删除了"web"、"map"和"all"autoLink值。错误消失了。
  • 已从清单中删除preload_fonts元标记。错误消失了。

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

我已经在以下设备上测试了生成错误的应用程序,并且"Chrome已停止"错误仅出现在奥利奥设备上。"简单"的应用程序适用于所有设备,没有报告错误。

  • 像素 2 XL,8.1.0 - 错误
  • Nexus 5X, 8.1.0 - 错误
  • Nexus 6,7.1.1 - 两个应用程序都没有错误

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

compileSdkVersion 27
buildToolsVersion '27.0.3'
minSdkVersion 16
targetSdkVersion 27
supportLibraryVersion = "27.0.2"
playServicesVersion = "11.8.0"

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

此问题可能与 Play 商店中与 Web View 更新相关的现有错误具有相同的根本原因。TextView/Linkify使用WebView进行地址识别。

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

最新更新