onur taskin
onur taskin

Reputation: 929

Material Design on Nexus 5 with Android L

My app crashes on Android L but it works on android kitkat. Also There is no RippleDrawable on the layout. Here is Exception and layout ;

Xml Layout :

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/page_background">

    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="30dp"
        android:layout_marginRight="30dp"
        android:inputType="textEmailAddress"
        android:ems="10"
        android:id="@+id/usernameET"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="100dp"
        android:hint="@string/username_hint" />

    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="30dp"
        android:layout_marginRight="30dp"
        android:inputType="textPassword"
        android:ems="10"
        android:id="@+id/passwordET"
        android:layout_below="@+id/usernameET"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="20dp"
        android:hint="@string/password_hint" />

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="60dp"
        android:layout_marginRight="60dp"
        android:text="@string/login_text"
        android:id="@+id/loginBtn"
        android:background="@drawable/positive_button_selector"
        android:textColor="#fff"
        android:layout_below="@+id/passwordET"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="40dp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/register_text"
        android:id="@+id/registerText"
        android:layout_below="@+id/loginBtn"
        android:layout_marginLeft="50dp"
        android:layout_marginTop="40dp"
        android:textColor="@color/accent_color"
        android:textSize="16sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/forget_password"
        android:id="@+id/forgetText"
        android:layout_below="@+id/registerText"
        android:layout_marginLeft="50dp"
        android:layout_marginTop="20dp"
        android:textColor="@color/accent_color"
        android:textSize="16sp" />
</RelativeLayout>

Drawable xml 'positive_button_selector' :

<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_pressed="false">
        <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
            <solid android:color="@color/accent_color" />
            <corners android:radius="4dp" />
        </shape>
    </item>
    <item android:state_pressed="true">
        <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
            <solid android:color="@color/teal_light" />
            <corners android:radius="4dp" />
        </shape>
    </item>
</selector>

Exception :

> java.lang.NullPointerException: Attempt to invoke virtual method 'int android.content.res.ColorStateList.getColorForState(int[], int)' on a null object reference
            at android.graphics.drawable.RippleDrawable.activateHotspot(RippleDrawable.java:413)
            at android.graphics.drawable.RippleDrawable.setActive(RippleDrawable.java:229)
            at android.graphics.drawable.RippleDrawable.onStateChange(RippleDrawable.java:207)
            at android.graphics.drawable.Drawable.setState(Drawable.java:566)
            at android.view.View.drawableStateChanged(View.java:15576)
            at android.widget.TextView.drawableStateChanged(TextView.java:3477)
            at android.view.View.refreshDrawableState(View.java:15594)
            at android.view.View.handleFocusGainInternal(View.java:4779)
            at android.view.View.requestFocusNoSearch(View.java:7335)
            at android.view.View.requestFocus(View.java:7314)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2448)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2448)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2448)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2448)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2448)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2448)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2448)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2448)
            at android.view.ViewGroup.onRequestFocusInDescendants(ViewGroup.java:2492)
            at android.view.ViewGroup.requestFocus(ViewGroup.java:2451)
            at android.view.View.requestFocus(View.java:7281)
            at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1898)
            at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1044)
            at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5749)
            at android.view.Choreographer$CallbackRecord.run(Choreographer.java:767)
            at android.view.Choreographer.doCallbacks(Choreographer.java:580)
            at android.view.Choreographer.doFrame(Choreographer.java:550)
            at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:753)
            at android.os.Handler.handleCallback(Handler.java:738)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5070)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:836)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:631)

Upvotes: 3

Views: 832

Answers (1)

Alan Geleynse
Alan Geleynse

Reputation: 25139

This issue is caused by an old preview version of Lollipop. If you update your device to the latest preview version you will not see this crash anymore.

The comments mention that the crash occurred in version LPV81C which was released in July 2014. The latest preview version as of Oct 27 2014 is LPX13D which does not have this issue.

Upvotes: 3

Related Questions