我正在获得Resources $ NotFoundException非常类似于thisthis question

错误是这样的-

Caused by android.content.res.Resources$NotFoundException: Unable to find resource ID #0x7f080166
   at android.content.res.ResourcesImpl.getResourceName + 267(ResourcesImpl.java:267)
   at android.content.res.ResourcesImpl.loadDrawableForCookie + 831(ResourcesImpl.java:831)
   at android.content.res.ResourcesImpl.loadDrawable + 677(ResourcesImpl.java:677)
   at android.content.res.Resources.loadDrawable + 912(Resources.java:912)
   at android.content.res.TypedArray.getDrawableForDensity + 955(TypedArray.java:955)
   at android.content.res.TypedArray.getDrawable + 930(TypedArray.java:930)
   at android.widget.TextView.(TextView.java:1317)
   at android.widget.TextView.(TextView.java:1112)
   at android.support.v7.widget.AppCompatTextView.(AppCompatTextView.java:87)
   at android.support.v7.widget.AppCompatTextView.(AppCompatTextView.java:83)
   at com.myapp.myapp.widgetstore.CustomTextView.(CustomTextView.java:24)
   at com.myapp.myapp.widgetstore.roboto.RobotoTextView.(RobotoTextView.java:40)
   at java.lang.reflect.Constructor.newInstance0(Constructor.java)
   at java.lang.reflect.Constructor.newInstance + 343(Constructor.java:343)
   at android.view.LayoutInflater.createView + 686(LayoutInflater.java:686)
   at android.view.LayoutInflater.createViewFromTag + 829(LayoutInflater.java:829)
   at android.view.LayoutInflater.createViewFromTag + 769(LayoutInflater.java:769)
   at android.view.LayoutInflater.rInflate + 902(LayoutInflater.java:902)
   at android.view.LayoutInflater.rInflateChildren + 863(LayoutInflater.java:863)
   at android.view.LayoutInflater.parseInclude + 1034(LayoutInflater.java:1034)
   at android.view.LayoutInflater.rInflate + 898(LayoutInflater.java:898)
   at android.view.LayoutInflater.rInflateChildren + 863(LayoutInflater.java:863)
   at android.view.LayoutInflater.rInflate + 905(LayoutInflater.java:905)
   at android.view.LayoutInflater.rInflateChildren + 863(LayoutInflater.java:863)
   at android.view.LayoutInflater.inflate + 554(LayoutInflater.java:554)
   at android.view.LayoutInflater.inflate + 461(LayoutInflater.java:461)
   at android.view.LayoutInflater.inflate + 383(LayoutInflater.java:383)
   at android.support.v7.app.AppCompatDelegateImpl.setContentView + 469(AppCompatDelegateImpl.java:469)
   at android.support.v7.app.AppCompatActivity.setContentView + 140(AppCompatActivity.java:140)
   at com.myapp.myapp.core.bottomnavigation.BottomNavigationBaseActivity.onCreate + 163(BottomNavigationBaseActivity.java:163)
   at android.app.Activity.performCreate + 7327(Activity.java:7327)
   at android.app.Activity.performCreate + 7318(Activity.java:7318)
   at android.app.Instrumentation.callActivityOnCreate + 1275(Instrumentation.java:1275)
   at android.app.ActivityThread.performLaunchActivity + 3101(ActivityThread.java:3101)
   at android.app.ActivityThread.handleLaunchActivity + 3264(ActivityThread.java:3264)
   at android.app.servertransaction.LaunchActivityItem.execute + 78(LaunchActivityItem.java:78)
   at android.app.servertransaction.TransactionExecutor.executeCallbacks + 108(TransactionExecutor.java:108)
   at android.app.servertransaction.TransactionExecutor.execute + 68(TransactionExecutor.java:68)
   at android.app.ActivityThread$H.handleMessage + 1955(ActivityThread.java:1955)
   at android.os.Handler.dispatchMessage + 106(Handler.java:106)
   at android.os.Looper.loop + 214(Looper.java:214)
   at android.app.ActivityThread.main + 7078(ActivityThread.java:7078)
   at java.lang.reflect.Method.invoke(Method.java)
   at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run + 493(RuntimeInit.java:493)
   at com.android.internal.os.ZygoteInit.main + 964(ZygoteInit.java:964)

在讨论之后,我实现了side-loading check,但是由于某些原因,这还不够,因为第一个 Activity 无法膨胀并引发InflateException。我创建了一个解决方法,并在catch块中添加了manual check。像这样 -
@Override
public void onCreate(Bundle savedInstanceState) {
    try{
        // the regular stuff
    } catch (Exception e){
        if(!isValidInstallation()){
            startInstallFromPlaystoreActivity();
        } else {
            throw e;
        }
    }
}

private boolean isValidInstallation(){
    boolean isValid = true;
    try {
        String installer = this.getPackageManager()
                .getInstallerPackageName(this.getPackageName());
        isValid = !TextUtils.isEmpty(installer);
    } catch (Throwable e) {
        isValid = false;
    }
    return isValid;
}

private void startInstallFromPlaystoreActivity(){
    startActivity(new Intent(this, InstallFromPlaystore.class));
}

这是目前可行的方法,但我正在寻找更清洁的方法。为什么Google推荐的方法不能解决我的问题?

为了对此进行测试,我创建了一个 bundle 包,并使用此规范构建了apk-
{
   "supportedAbis": ["x86"],
   "supportedLocales": ["en-US"],
   "screenDensity": 50,
   "sdkVersion": 24
}

这绝对是导致我的应用程序崩溃并出现相同的错误。根据设备将screenDensity更新为正确的值不再导致崩溃。

如果我使用supportedLocales,则可以触发Google提供的Missing Split APK功能。

我还怀疑对于较低的screenDensity,我拥有的自定义RobotoTextView无法访问支持库中涟漪效应的正确资源。可能是这样吗?

谢谢

最佳答案

更改上传格式后。您是否设置了以下值,特别是density = true。我们通常将所有资源放入所有drawable-hdpi / xhdpi / xxhdpi版本中。但是,如果说只有 hdpi 文件夹中只有一种资源,那么您可以使用App Bundle创建一个APK。应用程序 bundle 包为hdpi,xhdpi创建了单独的APK,这意味着在xhdpi设备中,它将仅使用drawable-xhdpi文件夹的资源。因此,如果仅在drawable-hdpi中有资源,则xhdpi设备上将不可用,因此会导致崩溃。

bundle {
   language {
       enableSplit = true
   }
   density {
       enableSplit = true
   }
   abi {
       enableSplit = true
   }
}

解决方案这里我们有两种解决方案:一种是通过将密度设置为false来禁用密度分割,或者确保每个资源在每个可绘制文件夹中均可用,并且还要在具有不同密度的设备上进行测试。 ABI也是如此。

10-08 11:22