渲染问题渲染期间引发异常:com.android.ide.common.rendering.api.LayoutlibCallback


154

在Android Studio中创建项目时遇到问题。(版本1.5.1)

我将逐步描述我的行动:

  • 打开Android Studio。
  • 创建一个没有任何活动的新项目。
  • 进行空白活动。

在预览模式下可能会出现问题:

我收到此消息:

Rendering Problems Exception raised during rendering: com.android.ide.common.rendering.api.LayoutlibCallback.getXmlFileParser(Ljava/lang/String;)Lorg/xmlpull/v1/XmlPullParser;

在堆栈跟踪中:

java.lang.NoSuchMethodError: com.android.ide.common.rendering.api.LayoutlibCallback.getXmlFileParser(Ljava/lang/String;)Lorg/xmlpull/v1/XmlPullParser;
    at com.android.layoutlib.bridge.impl.ResourceHelper.getInternalComplexColor(ResourceHelper.java:146)
    at com.android.layoutlib.bridge.impl.ResourceHelper.getColorStateList(ResourceHelper.java:231)
    at android.content.res.BridgeTypedArray.getColorStateList(BridgeTypedArray.java:308)
    at android.widget.TextView.<init>(TextView.java:776)
    at android.widget.TextView.<init>(TextView.java:705)
    at android.widget.TextView.<init>(TextView.java:701)
    at com.android.layoutlib.bridge.MockView.<init>(MockView.java:50)
    at com.android.layoutlib.bridge.MockView.<init>(MockView.java:45)
    at com.android.layoutlib.bridge.MockView.<init>(MockView.java:41)
    at android.view.BridgeInflater.createViewFromTag(BridgeInflater.java:163)
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:727)
    at android.view.LayoutInflater.rInflate_Original(LayoutInflater.java:858)
    at android.view.LayoutInflater_Delegate.rInflate(LayoutInflater_Delegate.java:70)
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:834)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:492)
    at com.android.layoutlib.bridge.bars.CustomBar.<init>(CustomBar.java:95)
    at com.android.layoutlib.bridge.bars.StatusBar.<init>(StatusBar.java:67)
    at com.android.layoutlib.bridge.impl.Layout.createStatusBar(Layout.java:222)
    at com.android.layoutlib.bridge.impl.Layout.<init>(Layout.java:144)
    at com.android.layoutlib.bridge.impl.RenderSessionImpl.inflate(RenderSessionImpl.java:213)
    at com.android.layoutlib.bridge.Bridge.createSession(Bridge.java:426)
    at com.android.ide.common.rendering.LayoutLibrary.createSession(LayoutLibrary.java:350)
    at com.android.tools.idea.rendering.RenderTask$2.compute(RenderTask.java:510)
    at com.android.tools.idea.rendering.RenderTask$2.compute(RenderTask.java:498)
    at com.intellij.openapi.application.impl.ApplicationImpl.runReadAction(ApplicationImpl.java:888)
    at com.android.tools.idea.rendering.RenderTask.createRenderSession(RenderTask.java:498)
    at com.android.tools.idea.rendering.RenderTask.access$600(RenderTask.java:72)
    at com.android.tools.idea.rendering.RenderTask$3.call(RenderTask.java:610)
    at com.android.tools.idea.rendering.RenderTask$3.call(RenderTask.java:607)
    at com.android.tools.idea.rendering.RenderService.runRenderAction(RenderService.java:362)
    at com.android.tools.idea.rendering.RenderTask.render(RenderTask.java:607)
    at com.android.tools.idea.rendering.RenderTask.render(RenderTask.java:629)
    at com.intellij.android.designer.designSurface.AndroidDesignerEditorPanel$6.run(AndroidDesignerEditorPanel.java:480)
    at com.intellij.util.ui.update.MergingUpdateQueue.execute(MergingUpdateQueue.java:320)
    at com.intellij.util.ui.update.MergingUpdateQueue.execute(MergingUpdateQueue.java:310)
    at com.intellij.util.ui.update.MergingUpdateQueue$2.run(MergingUpdateQueue.java:254)
    at com.intellij.util.ui.update.MergingUpdateQueue.flush(MergingUpdateQueue.java:269)
    at com.intellij.util.ui.update.MergingUpdateQueue.flush(MergingUpdateQueue.java:227)
    at com.intellij.util.ui.update.MergingUpdateQueue.run(MergingUpdateQueue.java:217)
    at com.intellij.util.concurrency.QueueProcessor.runSafely(QueueProcessor.java:238)
    at com.intellij.util.Alarm$Request$1.run(Alarm.java:351)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)

可能是什么问题呢?

Answers:


414

在几分钟前进行更新后,我遇到了同样的问题,我解决渲染问题的方法是将用于渲染布局的android版本从Android Studio更改回“ API 23:Android 6.0”。

Android工作室


5
是的,那行得通。另外,最好不要选中“自动选择最佳”,因为它只是选择最新的。您应该手动选择要预览的SDK。
阿比舍克(Abhishek)

我这样做了,但是现在出现以下错误。Couldn't resolve resource @android:color/background_material_light
Martin Hoban

只是警告:这是一个经常出现的问题。
marciowb '16

但是,为什么在API级别设置为24时会发生此问题呢?为什么在23级时不会呢?
杰伊·东亚

19

java.lang.NoSuchMethodError:com.android.ide.common.rendering.api.LayoutlibCallback.getXmlFileParser(Ljava / lang / String;)Lorg / xmlpull / v1 / XmlPullParser;

如果应用程序尝试调用类的指定方法(静态或实例)而该类不再具有该方法的定义,则抛出该异常。通常,此错误由编译器捕获;如果类的定义发生了不兼容的更改,则只有在运行时才会发生此错误。

您的应用必须针对Android 6.0(API级别23)才能启用此行为;您无需添加任何其他代码。

只需在“预览”部分中选择 “ API 23:Android 6.0”在此处输入图片说明


2

我在ubuntu 14.04上安装android studio 2.1时遇到了同样的问题。即使显示用于渲染布局的android版本的android机器人图标也仅显示API Level 24版本,而没有其他版本。

我必须通过导航到以下路径来启用API 23的下载

工具-> SDK管理器-> Android SDK-> SDK平台->名称。

选中Android 6.0(Marshwallow)选项。此选项将立即下载。现在,您将能够查看API级别23,并选择我们可以解决的问题。


1

我在Windows 10中使用Android Studio 1.5.1遇到类似的问题。无论选择哪个版本的Android,预览都无法正常工作。stacktrace以以下内容开头:

“ java.lang.NoSuchMethodError:com.android.ide.common.rendering.api.LayoutlibCallback.getXmlFileParser(Ljava / lang / String;)Lorg / xmlpull / v1 / XmlPullParser;”

当我tools:showIn="@layout/activity_main" 从中删除属性时RelativeLayout,所有Android版本(“ N”除外)都会解决问题。我启用了Android 2.2、2.3.3、5.0.1和6.0

我无法解释为什么该操作可以解决问题,或者为什么它适用于版本N。


0

这不是及时的答案,但是对于正在寻找其他遇到相同问题的人来说,更新android studio可以解决问题。尽管以上所有建议均起作用,但您希望获得更新(版本2.1.2)。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.