迁移到AndroidX并将所有AndriodX软件包更新为最新版本后,构建将无法向我显示obj
文件夹中生成的XML文件中的三个类似错误:
\obj\Debug\100\lp\117\jl\res\values\values.xml
:在期望项目的位置找到了标签ID XML文件的内容为:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<id name="view_tree_lifecycle_owner"/>
</resources>
\obj\Debug\100\lp\121\jl\res\values\values.xml
:在期望项目的位置找到了标签ID XML文件的内容为:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<id name="view_tree_saved_state_registry_owner"/>
</resources>
\obj\Debug\100\lp\123\jl\res\values\values.xml
:在期望项目的位置找到了标签ID XML文件的内容为:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<id name="view_tree_view_model_store_owner"/>
</resources>
在线查找解决方案后,我只是在每个生成的文件中将<id name="...
更改为<item type="id" name="...
,构建成功(即使每次清洁/重建我都必须重新执行此操作)
但是,在应用程序的启动屏幕之后,该应用程序立即崩溃并显示以下异常:
Java.Lang.RuntimeException:'无法获取提供程序androidx.lifecycle.ProcessLifecycleOwnerInitializer:java.lang.ClassNotFoundException:在路径:DexPathList上找不到类“ androidx.lifecycle.ProcessLifecycleOwnerInitializer”。
我抬起头来,发现了许多解决方案,这些提议建议启用和/或配置multi-dex,但都无济于事。
仅当链接设置为Sdk Assemblies Only
或Sdk and User Assemblies
时问题才会出现。
以下某些配置不适用于我:
我尝试过在项目属性的Enable Multi-Dex
标签中启用/禁用Android Options
。
我尝试将android:name
中application
标签中的AndroidManifest.xml
属性设置为androidx.multidex.MultiDexApplication
。
我尝试使MainApplication
类继承自Android.Support.MultiDex.MultiDexApplication
(在XamarinLibrary.Xamarin.Android.Support.Multidex中定义)而不是Android.App.Application
。
我试图使MainApplication
类继承自为AndroidX MultiDexApplication手动创建的绑定,如下所示:
MultiDex.cs
:
using Android.Content;
using Android.Runtime;
using Java.Interop;
using System;
namespace OnePoint
{
[Register("androidx/multidex/MultiDex", DoNotGenerateAcw = true)]
public sealed class MultiDex : Java.Lang.Object
{
private static readonly JniPeerMembers _members = new XAPeerMembers("androidx/multidex/MultiDex", typeof(MultiDex));
internal static IntPtr class_ref => _members.JniPeerType.PeerReference.Handle;
public override JniPeerMembers JniPeerMembers => _members;
protected override IntPtr ThresholdClass => _members.JniPeerType.PeerReference.Handle;
protected override Type ThresholdType => _members.ManagedPeerType;
internal MultiDex(IntPtr javaReference, JniHandleOwnership transfer)
: base(javaReference, transfer)
{
}
[Register("install", "(Landroid/content/Context;)V", "")]
public static unsafe void Install(Context context)
{
try
{
JniArgumentValue* ptr = stackalloc JniArgumentValue[1];
*ptr = new JniArgumentValue(context?.Handle ?? IntPtr.Zero);
_members.StaticMethods.InvokeVoidMethod("install.(Landroid/content/Context;)V", ptr);
}
finally
{
}
}
[Register("installInstrumentation", "(Landroid/content/Context;Landroid/content/Context;)V", "")]
public static unsafe void InstallInstrumentation(Context instrumentationContext, Context targetContext)
{
try
{
JniArgumentValue* ptr = stackalloc JniArgumentValue[2];
*ptr = new JniArgumentValue(instrumentationContext?.Handle ?? IntPtr.Zero);
ptr[1] = new JniArgumentValue(targetContext?.Handle ?? IntPtr.Zero);
_members.StaticMethods.InvokeVoidMethod("installInstrumentation.(Landroid/content/Context;Landroid/content/Context;)V", ptr);
}
finally
{
}
}
}
}
MultiDexApplication.cs
:
using Android.App;
using Android.Runtime;
using Java.Interop;
using System;
namespace MyNamespace
{
[Register("androidx/multidex/MultiDexApplication", DoNotGenerateAcw = true)]
public class MultiDexApplication : Application
{
internal static readonly JniPeerMembers _members =
new XAPeerMembers("androidx/multidex/MultiDexApplication", typeof(MultiDexApplication));
internal static IntPtr java_class_handle;
private static IntPtr id_ctor;
[Register(".ctor", "()V", "", DoNotGenerateAcw = true)]
public MultiDexApplication()
: base(IntPtr.Zero, JniHandleOwnership.DoNotTransfer)
{
if (Handle != IntPtr.Zero)
return;
try
{
if (GetType() != typeof(MultiDexApplication))
{
SetHandle(
JNIEnv.StartCreateInstance(GetType(), "()V"),
JniHandleOwnership.TransferLocalRef);
JNIEnv.FinishCreateInstance(Handle, "()V");
return;
}
if (id_ctor == IntPtr.Zero)
id_ctor = JNIEnv.GetMethodID(class_ref, "<init>", "()V");
SetHandle(
JNIEnv.StartCreateInstance(class_ref, id_ctor),
JniHandleOwnership.TransferLocalRef);
JNIEnv.FinishCreateInstance(Handle, class_ref, id_ctor);
}
finally
{
}
}
protected MultiDexApplication(IntPtr javaReference, JniHandleOwnership transfer)
: base(javaReference, transfer)
{
}
internal static IntPtr class_ref => JNIEnv.FindClass("androidx/multidex/MultiDexApplication", ref java_class_handle);
protected override IntPtr ThresholdClass => class_ref;
protected override Type ThresholdType => typeof(MultiDexApplication);
public override void OnCreate()
{
base.OnCreate();
MultiDex.Install(this);
}
}
}
update-package -reinstall
。答案 0 :(得分:6)
我遇到了同样的问题,但只针对您提到的第一个XML(<id name="view_tree_lifecycle_owner"/>
)
我找到了一个对我有用的答案(将链接设置为Sdk Assemblies Only
的发布配置)
在Android项目属性中,启用了“ Android选项”下的“使用增量Android打包系统”复选框。这样就解决了问题。
我在this线程中找到了解决方案。
答案 1 :(得分:1)
事实证明,此问题是由r8
dex编译器误导的。当我将dex编译器更改为dx
时,它报告了另一个编译错误:invalid opcode ba - invokedynamic requires --min-sdk-version >= 26 (currently 13)
,尽管min-sdk-version
不是13
。在查找了后一个错误之后,由于有了this thread,我能够通过将Xamarin.AndroidX.Browser
降级为1.0.0.1
(1.2.0
{{3}之前的最新版本)来解决该问题。 })。降级提到的软件包后,我可以成功编译并运行dx
或d8
。
答案 2 :(得分:0)
我必须设置以下内容
<AndroidUseAapt2>true</AndroidUseAapt2>
在Android.csproj文件中使用使其生效。 (将其设置为false,并在csproj文件中多次出现。)