NPE 自更新 Activity 以使用 ActionBarActivity 和 supportlibrary

NPE since updating Activity to use ActionBarActivity and supportlibrary

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

我已更新清单以包含在 Activity 条目中。

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

activity 使用 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 [=44= 上工作]

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

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.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.access0(ActionBarActivityDelegateBase.java:79)
03-06 12:44:44.427: E/AndroidRuntime(31153):    at android.support.v7.app.ActionBarActivityDelegateBase.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 设备上。

有人知道为什么吗?

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

如果您的逻辑依赖于 onCreate()onCreateOptionsMenu() 做一些工作,我使用的方法是:

  • 将工作转移到专用的私有方法中

  • 让该方法确认完成工作的时机已经成熟(例如,MenuItem 是从 onCreateOptionsMenu() 中检索到的,并且设置了 whatever-it-was在 onCreate())

  • onCreate()onCreateOptionsMenu() 调用该方法,在每个方法完成其工作后