Android TextInputLayout.setError()引发异常。为什么以及如何修复?
我正在使用support Library android-support-v7 Pkg.Revision=23.2.1。为API 23编译并在4.1.2设备上测试。在尝试实现一些现代UI模式时,我遇到了这个问题 activity_test.xml布局Android TextInputLayout.setError()引发异常。为什么以及如何修复?,android,android-support-library,android-textinputlayout,Android,Android Support Library,Android Textinputlayout,我正在使用support Library 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" andro
<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>
如果我试图通过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
正如我所看到的,原因是Illegalacesserror,这确实告诉了我很多。我猜库中的getPorterDuffColorFilter()方法的acces修改器设置不正确。但这是我的猜测。我怎样才能摆脱这个异常,因为这个basiclay否定了我迁移到app compat library的原因?几乎可以肯定,您在运行时使用的类版本与您期望的版本不同 照此
Caused by: java.lang.IllegalAccessError: tried to access method android.support.v7.widget.AppCompatDrawableManager.getPorterDuffColorFilter:()V from class android.support.design.widget.TextInputLayout
我为你找到了一个解决办法。下面是您必须在xml中为textInputLayout应用的样式
<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>
@彩色/彩色文本
14dp
@颜色/颜色重音
@彩色/彩色媒体文本
@颜色/颜色重音
@颜色/颜色
@颜色/颜色
让我知道它是否对您有效。这是一个错误,请参阅:
应通过24.0.0解决此问题。。尝试更新您的android支持,并检查该问题是否仍然存在
如果有稳定的基本解决方案,我强烈建议避免使用任何变通方法
我希望这可能会有所帮助。您的问题与onclick方法有关,我不知道您是否应该尝试不同的方法,请更改布局,省略按钮的onclick属性,并在活动中用完整代码声明它,如: 活动_test.xml中的更改按钮
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/btnSetError"
android:text="TextInputLayout.setError()" />
不,不是。同样的例外。此外,我真的看不出改变颜色会如何解决这个问题。这不是同一个例外。应用程序支持23.2.1是我能找到的在我们的开发环境中工作的最后一个版本。支持库不可下载以测试不同版本。
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/btnSetError"
android:text="TextInputLayout.setError()" />
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");
}
});
}