TextInputLayout.setError()抛出异常。为什么会抛出异常?如何修复?

3

我正在使用支持库android-support-v7 Pkg.Revision=23.2.1。编译时API版本为23,测试设备为4.1.2。在尝试实现一些现代UI模式时,我遇到了这个问题。

activity_test.xml布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <android.support.design.widget.TextInputLayout
        android:id="@+id/textInputLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >

        <EditText
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="TextInputLayout EditText default - error" />

    </android.support.design.widget.TextInputLayout>

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="onClickButtonSetError"
        android:text="TextInputLayout.setError()" />

</LinearLayout>

ActivityTest.java

public class ActivityTest extends AppCompatActivity
{

    @Override
    public void onCreate(Bundle icicle) {
        super.onCreate(icicle);
        setContentView(R.layout.activity_test);
    }


    public void onClickButtonSetError(View view) {
        TextInputLayout til = (TextInputLayout)findViewById(R.id.textInputLayout);
        til.setErrorEnabled(true);
        til.setError("This is a test error message.");
    }
}

如果我尝试通过setError()方法在TextInputLayout上设置错误。这是通过点击按钮完成的,我会得到以下异常:

10-06 15:47:55.239: E/AndroidRuntime(5780): FATAL EXCEPTION: main
10-06 15:47:55.239: E/AndroidRuntime(5780): java.lang.IllegalStateException: Could not execute method for android:onClick
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:275)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.view.View.performClick(View.java:4232)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.view.View$PerformClick.run(View.java:17298)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.os.Handler.handleCallback(Handler.java:615)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.os.Handler.dispatchMessage(Handler.java:92)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.os.Looper.loop(Looper.java:137)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.app.ActivityThread.main(ActivityThread.java:4921)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at java.lang.reflect.Method.invokeNative(Native Method)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at java.lang.reflect.Method.invoke(Method.java:511)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at dalvik.system.NativeStart.main(Native Method)
10-06 15:47:55.239: E/AndroidRuntime(5780): Caused by: java.lang.reflect.InvocationTargetException
10-06 15:47:55.239: E/AndroidRuntime(5780):     at java.lang.reflect.Method.invokeNative(Native Method)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at java.lang.reflect.Method.invoke(Method.java:511)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:270)
10-06 15:47:55.239: E/AndroidRuntime(5780):     ... 11 more
10-06 15:47:55.239: E/AndroidRuntime(5780): Caused by: java.lang.IllegalAccessError: tried to access method android.support.v7.widget.AppCompatDrawableManager.getPorterDuffColorFilter:()V from class android.support.design.widget.TextInputLayout
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.support.design.widget.TextInputLayout.updateEditTextBackground(TextInputLayout.java:700)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at android.support.design.widget.TextInputLayout.setError(TextInputLayout.java:592)
10-06 15:47:55.239: E/AndroidRuntime(5780):     at com.example.testandroidsupportv7.ActivityEditText.onClickButtonSetError(ActivityEditText.java:30)
10-06 15:47:55.239: E/AndroidRuntime(5780):     ... 14 more

据我所见,问题的原因是IllegalAccessError,但它并没有给我提供太多信息。我猜测方法getPorterDuffColorFilter()的访问修饰符在库中没有正确设置。但这只是我的猜测。我该如何摆脱这个异常呢?因为这基本上是迁移到应用兼容库的原因被打败了。

3个回答

1
您几乎肯定在运行时使用了与您期望的不同版本的类。
根据此文档。
Caused by: java.lang.IllegalAccessError: tried to access method android.support.v7.widget.AppCompatDrawableManager.getPorterDuffColorFilter:()V from class android.support.design.widget.TextInputLayout

我为您找到了一个解决方法。下面是应用于textInputLayout的xml样式。
<style name="TextLabel" parent="TextAppearance.AppCompat">
<item name="android:textColorHint">@color/colorLightText</item>
<item name="android:textSize">14dp</item>
<item name="colorAccent">@color/colorAccent</item>
<item name="colorControlNormal">@color/colorMediumText</item>
<item name="colorControlActivated">@color/colorAccent</item>
<item name="android:textColorHighlight">@color/COLOR</item>
<item name="android:textColorLink">@color/COLOR</item>

请告诉我它是否对您有效。


不,它不会。同样的异常。此外,我真的看不出改变颜色如何解决问题。 - user6694745

0

这是一个bug,请参见: https://code.google.com/p/android/issues/detail?id=78377

它应该在24.0.0中得到解决...尝试更新您的android-support并检查是否仍存在此问题。

我强烈建议避免使用任何变通方法,如果有一个稳定的基本解决方案。

希望这可以帮助,谢谢。


这不是同一个异常。而且,支持23.2.1的应用程序是我能在我们的开发环境中找到的最后一个版本。并且支持库无法下载以测试不同的版本。 - user6694745

0

你的问题与onclick方法有关...,也许你应该尝试不同的方法,请更改布局并省略Button的onclick属性,并通过完整代码在activity中声明它,例如:

在activity_test.xml中更改按钮

   <Button
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:id="@+id/btnSetError"
    android:text="TextInputLayout.setError()" />

ActivityTest.java

public class ActivityTest extends AppCompatActivity
{
  private TextInputLayout txtInput; 
  private Button btnSetError;
  @Override
  public void onCreate(Bundle icicle) {
    super.onCreate(icicle);
    setContentView(R.layout.activity_test);

    txtInput = (TextInputLayout) findViewById(R.id.textInputLayout);
    btnSetError =(Button)findViewById(R.id.btnSetError);
    btnSetError.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {

             txtInput.setError("ERROR");
        }
    });

}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接