【问题标题】:IllegalStateException when using drawable XML使用可绘制 XML 时出现 IllegalStateException
【发布时间】:2011-06-17 16:22:14
【问题描述】:

当使用带有此 XML 的 ImageButton 时:

以及以下可绘制的 XML:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/bruin_s1" android:state_pressed="false" /> 
    <item android:drawable="@drawable/bruin_s2" android:state_pressed="true" /> 
    <item android:drawable="@drawable/bruin_s1" android:state_focused="false" /> 
    <item android:drawable="@drawable/bruin_s2" android:state_focused="true" />
</selector>

当我单击该按钮时它会崩溃,但有以下例外:

06-17 10:18:23.028: ERROR/AndroidRuntime(290): Uncaught handler: thread main exiting due to uncaught exception
06-17 10:18:23.048: ERROR/AndroidRuntime(290): java.lang.IllegalStateException: Could not execute method of the activity
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.View$1.onClick(View.java:2031)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.View.performClick(View.java:2364)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.View.onTouchEvent(View.java:4179)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.View.dispatchTouchEvent(View.java:3709)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1659)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.app.Activity.dispatchTouchEvent(Activity.java:2061)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1643)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.ViewRoot.handleMessage(ViewRoot.java:1691)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.os.Handler.dispatchMessage(Handler.java:99)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.os.Looper.loop(Looper.java:123)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.app.ActivityThread.main(ActivityThread.java:4363)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at java.lang.reflect.Method.invokeNative(Native Method)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at java.lang.reflect.Method.invoke(Method.java:521)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at dalvik.system.NativeStart.main(Native Method)
06-17 10:18:23.048: ERROR/AndroidRuntime(290): Caused by: java.lang.reflect.InvocationTargetException
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at nl.ivaldi.borre.Drawing.onColorClick(Drawing.java:135)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at java.lang.reflect.Method.invokeNative(Native Method)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at java.lang.reflect.Method.invoke(Method.java:521)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     at android.view.View$1.onClick(View.java:2026)
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     ... 20 more
06-17 10:18:23.048: ERROR/AndroidRuntime(290): Caused by: java.lang.ClassCastException: android.graphics.drawable.StateListDrawable
06-17 10:18:23.048: ERROR/AndroidRuntime(290):     ... 24 more

但是,当我将可绘制对象更改为其中一个图像(即 bruin_s1)时,它会正常工作。怎么了?

【问题讨论】:

    标签: android drawable illegalstateexception


    【解决方案1】:

    当您将state_pressedstate_focused 都设置为true 时,这是有可能的。在这种情况下,您的选择器将选择显示哪个图像?

    尝试以下方法

    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:state_focused="true" android:state_pressed="false" android:drawable="@drawable/focused" />
        <item android:state_focused="true" android:state_pressed="true" android:drawable="@drawable/focusedpressed" />
        <item android:state_focused="false" android:state_pressed="true" android:drawable="@drawable/pressed" />
        <item android:drawable="@drawable/defaultbutton" />
    </selector>
    

    谢谢 迪帕克

    【讨论】:

    • 选择器中满足其条件的第一个项目将被选中。如果找到匹配的项目,Android 不会评估所有项目。这就是为什么正常状态drawable总是在最后。即使在您的示例中,匹配项也会不止一项(一项 + 最后一项)。
    【解决方案2】:

    Caused by: java.lang.NoSuchMethodException: Drawing.onColorClick

    在您的布局中,您有一个带有android:onClick='onColorClick' 的视图,但该方法不存在。

    【讨论】:

    • 不,这会导致不同的错误,即: java.lang.IllegalStateException: Could not find a method onColorClick(View) in the Activity 另外,如果我改变drawable也没关系.
    • 答案基于您之前的堆栈跟踪。我看到您已经解决了原始问题并使用新的堆栈跟踪进行了编辑。对于您的新异常,我将查看 nl.ivaldi.borre.Drawing.onColorClick(Drawing.java:135) 处的代码,并查看该调用下方发生了哪种类型的转换。堆栈跟踪没有准确显示异常发生的位置,但它在下面的某个地方。
    【解决方案3】:

    错误出现在我的代码中的其他地方。在 onclick 处理程序中,我正在获取按下按钮的背景,以获取某个像素的颜色,但是,当使用可绘制的 xml 时,这显然会出错。

    【讨论】:

      猜你喜欢
      • 2015-04-14
      • 2013-08-27
      • 2023-03-18
      • 1970-01-01
      • 2015-02-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多