startActivity(intent) 未打开 activity

startActivity(intent) is not opening activity

我正在制作一个 android 应用程序,其中包含 2 个活动和一个 Java class reads/writes 使用 NFC 的 RFID 数据。

我正在使用 enableReaderMode() 方法在 mainActivity 中启用 reader/writer 模式,然后在单独的 java class。一旦进入 onTagDiscovered 方法,我将调用 mainActivity.startNewActivity() 打开第二个 activity。我知道我到达 startNewActivity() 因为一条日志消息,但 activity 并没有真正开始。该应用程序没有崩溃,我也没有收到任何错误,只是没有启动。我试过在 mainActivity 中放置一个按钮并以这种方式打开,效果很好。当我从 encode.java 调用方法时,它就不起作用了。

**我知道没有必要从 Encode.java 打开 activity,我可以直接将其编码到 MainActivity 中,但我正准备做一些更复杂的事情我需要从 Encode.java 打开,我想测试 activity 是否会打开。

这是代码

Encode.java

public class Encode implements NfcAdapter.ReaderCallback {
    MainActivity mainActivity = new MainActivity(); 

    public void onTagDiscovered(Tag tag) {
        Log.i(TAG, "New tag discovered"); 
        mainActivity.startNewActivity(); 
    }

主要活动

 public void startNewActivity() {
    Log.v(TAG, "in startNewActivity");
    Intent intent = new Intent(this, Success.class);
    startActivity(intent);
}

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.project" >

    <uses-sdk android:minSdkVersion="10" />
    <uses-permission android:name="android.permission.NFC"/>
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-feature android:name="android.hardware.nfc" android:required="true" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/xband"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >

        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >

            <intent-filter>
                <action android:name="android.nfc.action.NDEF_DISCOVERED" />
                <action android:name="android.nfc.action.TECH_DISCOVERED" />
                <action android:name="android.nfc.action.TAG_DISCOVERED" />
                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>

            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

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

            <meta-data android:name="android.nfc.action.TECH_DISCOVERED"
                android:resource="@xml/nfc_tech" />

        </activity>
        <activity android:name=".Success" >

        </activity>
    </application>

</manifest>

Success.java

package com.project;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;

public class Success extends Activity {
    private static final String TAG = "encode";

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

        setContentView(R.layout.success_activity);
        Log.v(TAG, "in success activity");
    }


}

我尝试添加以下代码,然后收到此错误消息: Encode.java

public void onTagDiscovered(Tag tag) {
        Log.i(TAG, "New Tag Discovered");
        Handler handler = new Handler(Looper.getMainLooper());
        handler.post(new Runnable() {
           @Override
            public void run() {
               mainActivity.startNewActivity();
           }
        });
}


02-20 11:52:27.739  22088-22088/com.project E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: com.project, PID: 22088
    java.lang.NullPointerException
            at android.app.Activity.startActivityForResult(Activity.java:3474)
            at android.app.Activity.startActivityForResult(Activity.java:3435)
            at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:817)
            at android.app.Activity.startActivity(Activity.java:3677)
            at android.app.Activity.startActivity(Activity.java:3645)
            at com.project.MainActivity.startNewActivity(MainActivity.java:110)
            at com.project.encoding.Encode.run(Encode.java:331)
            at android.os.Handler.handleCallback(Handler.java:733)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:157)
            at android.app.ActivityThread.main(ActivityThread.java:5293)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)

而不是: Intent intent = new Intent(this, Success.class);
尝试:Intent intent = new Intent(getApplicationContext(), Success.class);

这对我有用过一次因为它 "Return the context of the single, global Application object of the current process. "

工作人员能够帮助我解决这个问题。 这不起作用,因为我在 Encode 中创建了 MainActivity 的新实例,而不是引用现有的 MainActivity

MainActivity 中我们添加了:

private static MainActivity _instance = null; 

     @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            encode = new Encode();

            enableReaderMode();

           MainActivity._instance = this;
        }

        public static MainActivity getInstance() {
            return _instance;
        }

并且在 Encode 中我们调用了 startNewActivity 方法:

public void onTagDiscovered(Tag tag) {
    Log.i(TAG, "New Tag Discovered");

    MainActivity.getInstance().startNewActivity();

});

现在 Encode 正在使用 MainActivity

的现有实例