1

Android プロジェクトで OpenCV ライブラリを使用しています。エミュレーターでは、opencv マネージャーを手動でインストールするとすべてが機能しますが、デバイスに問題があります (Samsung Galaxy S Advance with Android 2.3.6)。initAsync 関数を呼び出すと NullPointerException が発生しますが、OpenCV Manager パッケージが見つからず、Google Play からインストールできるというメッセージが表示されるはずです。

LogCat で次のように表示されます。

java.lang.RuntimeException: Unable to resume activity java.lang.NullPointerException
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2124)
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2139)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1672)
at android.app.ActivityThread.access$1500(ActivityThread.java:117)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
at android.os.Handler.dispatchMessage(Handler.java:99
at android.os.Looper.loop(Looper.java:130)
at android.app.ActivityThread.main(ActivityThread.java:3691)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:912)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:670)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at com.android.internal.app.AlertController$AlertParams.<init>(AlertController.java:798)
at android.app.AlertDialog$Builder.<init>(AlertDialog.java:287)
at org.opencv.android.BaseLoaderCallback.onPackageInstall(BaseLoaderCallback.java:90)
at org.opencv.android.AsyncServiceHelper.InstallService(AsyncServiceHelper.java:116)
at org.opencv.android.AsyncServiceHelper.initOpenCV(AsyncServiceHelper.java:31)
at org.opencv.android.OpenCVLoader.initAsync(OpenCVLoader.java:39)
at com.myapp.utils.OpenCV.init(OpenCV.java:51)
at com.myapp.ProcessImageActivity.onResume(ProcessImageActivity.java:199)
at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1153)
at android.app.Activity.performResume(Activity.java:3858)
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2114)

どこが問題になる可能性がありますか?

これは私の ProcessImageActivity の一部です:

public class ProcessImageActivity extends SherlockActivity {
private static final String TAG = "ProcessImageActivity";
public static final String EXTRA_IMAGE = "image";
private ImageView mPhotoView;
private OpenCV mOpenCV;

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

    int theme = R.style.Theme_Sherlock_Light_ForceOverflow;
    setTheme(theme);

    setContentView(R.layout.processimage);

    mOpenCV = new OpenCV(this);

    Bundle extras = getIntent().getExtras();

    if (extras != null) {
        if (extras.containsKey(EXTRA_IMAGE)) {
            mPhotoPath = extras.getString(EXTRA_IMAGE);
        }
    }

    mPhotoView = (ImageView)findViewById(R.id.photo_view);
}

    @Override
protected void onResume() {
    super.onResume();

    mOpenCV.init();
}
}

OpenCV クラスの init 関数:

public void init() {
    if (!OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_3, mContext, mOpenCVLoaderCallback)) {
        Log.e(TAG, "Cannot connect to OpenCV Manager");
    }
}
4

1 に答える 1

0

また、何が間違っているのか正確にはわかりませんが、その初期化をメインのアクティビティに移動したところ、機能しました。

于 2013-02-14T16:43:13.173 に答える