libary android-support-v7 Pkg.Revision = 23.2.1을 사용하고 있습니다. API 23 용으로 컴파일되고 4.1.2 장치에서 테스트되었습니다. 일부 현대적인 UI 패턴을 구현하는 동안이 문제가 발생했습니다.TextInputLayout.setError()는 예외를 throw합니다. 왜, 어떻게 수정해야합니까?
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에 오류를 설정하려고합니다. 저를 많이 말해 주는가있는 IllegalAccessError이다 나는 원인을 알 수 있듯이
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
:이 BTW 나는이 예외를 얻을 버튼 클릭을 통해 이루어집니다. getPorterDuffColorFilter() 메서드에 대한 액세스 수정 자 라이브러리에서 올바르게 설정되지 않은 것 같아요. 그러나 이것은 내 추측입니다. 이 basiclay가 내가 app compat library로 옮긴 이유를 막았 기 때문에 어떻게이 예외를 제거 할 수 있습니까?
아니, 나던. 같은 예외. 게다가, 나는 변화하는 색깔이 어떻게 문제를 해결할 수 있는지 정말로 볼 수 없다. –