Android 开发和 "Chrome has Stopped" 错误的可下载字体
Downloadable fonts for Android dev and "Chrome has Stopped" error
作为 Oreo 和支持库中新的可下载字体支持的一部分,我已经开始将这些功能整合到我开发的应用程序中。第一个应用程序是成功的——简单的应用程序,只有一些活动。第二个应用程序没有成功。添加可下载字体后(基于此资源:https://developer.android.com/guide/topics/ui/look-and-feel/downloadable-fonts.html)我在启动 activity:
时遇到此错误
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 has stopped" - 再次打开应用程序或发送反馈。
根据堆栈跟踪,资源 ID #0x7f030030
是 R.java 中的以下条目(我预计):
public static final int preloaded_fonts=0x7f030030;
我相信我已经确定了错误的原因 - 同样,错误状态 Chrome 有问题,但我的应用程序中却出现了这种情况:
- activity 的布局包含
TextView
,其 autoLink
属性为 "web"、"map" 或 "all"。
- 我根据上面引用的文档预加载清单中的字体。
删除清单中的预加载声明或删除 autoLink
属性可解决问题。不为 autoLink
属性使用 "web"、"map" 或 "all" 的 TextViews
不会生成错误("phone" 有效,我会expect 因为它不是基于网络的意图)。显然两者都不是理想的解决方案。这仅发生在应用程序的初始启动时。
同样,第一个应用程序在使用相同字体、在清单中预加载并使用 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 has stopped" 错误仅出现在 Oreo 设备上。 "easy" 应用程序适用于所有设备,没有错误报告。
- Pixel 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 属性)或者这是否与前面提到的问题跟踪器有关?
此问题的根本原因可能与 this existing bug 与 Play 商店中的 WebView 更新有关。 TextView/Linkify 使用 WebView 进行地址识别。
Linkify.MAP_ADDRESSES 无法正常工作,仅适用于美国地址。如果可能,请不要使用 Linkify.MAP_ADDRESSES 或 Linkify.ALL(或它们的属性)。
作为 Oreo 和支持库中新的可下载字体支持的一部分,我已经开始将这些功能整合到我开发的应用程序中。第一个应用程序是成功的——简单的应用程序,只有一些活动。第二个应用程序没有成功。添加可下载字体后(基于此资源:https://developer.android.com/guide/topics/ui/look-and-feel/downloadable-fonts.html)我在启动 activity:
时遇到此错误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 has stopped" - 再次打开应用程序或发送反馈。
根据堆栈跟踪,资源 ID #0x7f030030
是 R.java 中的以下条目(我预计):
public static final int preloaded_fonts=0x7f030030;
我相信我已经确定了错误的原因 - 同样,错误状态 Chrome 有问题,但我的应用程序中却出现了这种情况:
- activity 的布局包含
TextView
,其autoLink
属性为 "web"、"map" 或 "all"。 - 我根据上面引用的文档预加载清单中的字体。
删除清单中的预加载声明或删除 autoLink
属性可解决问题。不为 autoLink
属性使用 "web"、"map" 或 "all" 的 TextViews
不会生成错误("phone" 有效,我会expect 因为它不是基于网络的意图)。显然两者都不是理想的解决方案。这仅发生在应用程序的初始启动时。
同样,第一个应用程序在使用相同字体、在清单中预加载并使用 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 has stopped" 错误仅出现在 Oreo 设备上。 "easy" 应用程序适用于所有设备,没有错误报告。
- Pixel 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 属性)或者这是否与前面提到的问题跟踪器有关?
此问题的根本原因可能与 this existing bug 与 Play 商店中的 WebView 更新有关。 TextView/Linkify 使用 WebView 进行地址识别。
Linkify.MAP_ADDRESSES 无法正常工作,仅适用于美国地址。如果可能,请不要使用 Linkify.MAP_ADDRESSES 或 Linkify.ALL(或它们的属性)。