NPE自更新Activity以使用ActionBarActivity和supportlibrary

时间:2015-03-05 15:27:11

标签: android android-actionbar

我有一个通常使用Activity的应用。我正在尝试更新它以使用ActionBarActivity。我已成功将support-v7-appcompat作为项目包含在内。

我已将清单更新为包含在活动条目中。

android:theme="@style/Theme.AppCompat.Light"

该活动使用oncreateOptionsMenu,因此我更新了菜单文件以包含我自己的命名空间:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:com.carefreegroup.rr3="http://schemas.android.com/apk/res-auto" >

    <item
        android:id="@+id/login"
        android:title="Login "
        android:icon="@android:drawable/presence_online"
        com.carefreegroup.rr3:showAsAction="ifRoom"/>
    <item
        android:id="@+id/changeuser"
        android:title="Change User"
        android:icon="@android:drawable/ic_delete"
        com.carefreegroup.rr3:showAsAction="never"/>

    <item
        android:id="@+id/admin"
        android:title="Admin"
        android:icon="@android:drawable/ic_menu_manage"
        com.carefreegroup.rr3:showAsAction="never"/>



</menu>

我已经使EntryActivity扩展了ActionBaractivity,它似乎适用于Android 4.x但不适用于Android 5.x

我在控制台中注意到的一件事是以下一行。

android-support-v7-appcompat] Could not find android-support-v7-appcompat.apk!

我不确定这是不是问题,但它无法解释为什么它在一台设备上而不是另一台设备上运行?

有人可以帮助我吗?

    03-06 12:44:44.427: E/AndroidRuntime(31153): FATAL EXCEPTION: main
03-06 12:44:44.427: E/AndroidRuntime(31153): Process: com.carefreegroup.rr3, PID: 31153
03-06 12:44:44.427: E/AndroidRuntime(31153): java.lang.NullPointerException: Attempt to invoke virtual method 'boolean java.lang.String.equalsIgnoreCase(java.lang.String)' on a null object reference
03-06 12:44:44.427: E/AndroidRuntime(31153):    at com.carefreegroup.rr3.EntryActivity.onCreateOptionsMenu(EntryActivity.java:1225)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.app.Activity.onCreatePanelMenu(Activity.java:2845)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.support.v4.app.FragmentActivity.onCreatePanelMenu(FragmentActivity.java:275)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.support.v7.app.ActionBarActivity.superOnCreatePanelMenu(ActionBarActivity.java:276)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.support.v7.app.ActionBarActivityDelegate$1.onCreatePanelMenu(ActionBarActivityDelegate.java:79)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.support.v7.app.ActionBarActivityDelegateBase.preparePanel(ActionBarActivityDelegateBase.java:979)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.support.v7.app.ActionBarActivityDelegateBase.doInvalidatePanelMenu(ActionBarActivityDelegateBase.java:1182)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.support.v7.app.ActionBarActivityDelegateBase.access$100(ActionBarActivityDelegateBase.java:79)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.support.v7.app.ActionBarActivityDelegateBase$1.run(ActionBarActivityDelegateBase.java:118)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.os.Handler.handleCallback(Handler.java:739)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.os.Handler.dispatchMessage(Handler.java:95)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.os.Looper.loop(Looper.java:155)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.app.ActivityThread.main(ActivityThread.java:5696)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at java.lang.reflect.Method.invoke(Native Method)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at java.lang.reflect.Method.invoke(Method.java:372)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1028)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:823)

清单:

.....
.....

<activity
            android:name=".EntryActivity"
            android:label="@string/app_name"
            android:screenOrientation="portrait"
            android:launchMode="singleTask"
            android:theme="@style/Theme.AppCompat.Light" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>

            <intent-filter>
                <action android:name="com.carefreegroup.rr3.INVALID_CARER_TAG_SCANNED" />

                <category android:name="android.intent.category.DEFAULT" />


            </intent-filter>
        </activity>

public class EntryActivity extends ActionBarActivity{

@Override
    protected void onCreate(final Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

.....


}


@Override
    public boolean onCreateOptionsMenu(Menu menu) {

        MenuInflater inflater = getMenuInflater();
        inflater.inflate(R.layout.menuentryoptionsmenu, menu);

        if(isAllowChangeUser.equalsIgnoreCase("false")){
            MenuItem mi = menu.findItem(R.id.changeuser);
            mi.setVisible(false);
        }
        return true;

    }


}

[编辑] 我做了一个更改,使EntryActivity直接扩展ActionBarActivity。

ActionBar现在显示在Android 4.x设备上,但不会显示在Android 5.x设备上。

有人有什么想法吗?

1 个答案:

答案 0 :(得分:1)

一般来说,假设onCreate()onCreateOptionsMenu()的执行顺序是不安全的。这实际上取决于操作栏的实现。我可以看到onCreateOptionsMenu()处理过程中super.onCreate()onCreate()结束后,或者甚至可以想象在onCreate()开始之前调用onCreate()(尽管最后一个似乎不太可能)。

如果您的逻辑依赖于onCreateOptionsMenu()MenuItem做某些工作,我使用的配方是:

  • 将该工作转移到专用私人方法

  • 让该方法确认完成工作的时机已成熟(例如,onCreateOptionsMenu()已从onCreate()检索到onCreate()并且onCreateOptionsMenu()已设置为{{1}} 1}})

  • 在每个方法完成其工作之后,从{{1}}和{{1}}调用该方法