в Android studio выполняется распознавание лиц с использованием opencv. E / AndroidRuntime: ФАТАЛЬНОЕ ИСКЛЮЧЕНИЕ: main

#android-studio #opencv

#android-studio #opencv

Вопрос:

Я использую приложение для распознавания лиц с помощью opencv. приложение установлено в телефоне, но из-за фатальной ошибки оно внезапно закрывается. это мой MainActivity.java

 package com.example.oc2;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Context;
import android.os.Bundle;
import org.opencv.android.BaseLoaderCallback;
import org.opencv.android.CameraActivity;
import org.opencv.android.CameraBridgeViewBase;
import org.opencv.android.CameraBridgeViewBase.CvCameraViewFrame;
import org.opencv.android.LoaderCallbackInterface;
import org.opencv.android.OpenCVLoader;
import org.opencv.core.Mat;
import org.opencv.android.CameraBridgeViewBase.CvCameraViewListener2;

import org.opencv.android.CameraBridgeViewBase;
import org.opencv.android.JavaCameraView;
import org.opencv.core.Mat;
import org.opencv.core.MatOfRect;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Scalar;
import org.opencv.imgproc.Imgproc;
import org.opencv.objdetect.CascadeClassifier;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

public class MainActivity extends AppCompatActivity implements CameraBridgeViewBase.CvCameraViewListener2{
    JavaCameraView javaCameraView;
    File cascfile;
    CascadeClassifier facedetector;
    private Mat mRgba,mGrey;



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

        if(!OpenCVLoader.initDebug())
        {
            OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_3_4_0,this, baseCallback);
        }
            else
        {
            try {
                baseCallback.onManagerConnected(LoaderCallbackInterface.SUCCESS);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
            javaCameraView.setCvCameraViewListener(this);
    }

    @Override
    public void onCameraViewStarted(int width, int height) {
        mRgba=new Mat();
        mGrey=new Mat();

    }

    @Override
    public void onCameraViewStopped() {
        mGrey.release();
        mRgba.release();

    }

    @Override
    public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
        mRgba=inputFrame.rgba();
        mGrey=inputFrame.gray();
        MatOfRect facedetection= new MatOfRect();
        facedetector.detectMultiScale(mRgba,facedetection);
        for(Rect rect: facedetection.toArray())
        {
            Imgproc.rectangle(mRgba,new Point(rect.x,rect.y),new Point(rect.x rect.width,rect.y rect.height),new Scalar(255,0,0));
        }
        return mRgba;
    }

    private final BaseLoaderCallback baseCallback=new BaseLoaderCallback(this) {
        @Override
        public void onManagerConnected(int status) throws IOException {
            switch (status)
            {
                case LoaderCallbackInterface.SUCCESS:
                {
                    InputStream is = getResources().openRawResource(R.raw.haarcascade_frontalface_alt2);
                    File cascadedir=getDir( "cascade" , Context.MODE_PRIVATE);
                    cascfile= new File(cascadedir, "haarcascade_frontalface_alt2.xml" );
                    FileOutputStream fos= new FileOutputStream(cascfile);

                    byte[] buffer=new byte[4096];
                    int bytesread;
                    while((bytesread = is.read(buffer))!=-1)
                    {
                        fos.write(buffer,0,bytesread);
                    }
                    is.close();
                    fos.close();
                    facedetector=new CascadeClassifier(cascfile.getAbsolutePath());
                    if(facedetector.empty())
                    {
                        facedetector=null;
                    }
                    else
                    {
                        cascadedir.delete();
                    }
                    javaCameraView.enableView();

                }
                break;

                default:
                    {
                    super.onManagerConnected(status);
                    }
                    break;

            }

        }
    };
}
  

это мои ошибки, кто-нибудь может помочь?

D / AndroidRuntime: завершение работы виртуальной машины E / AndroidRuntime: ФАТАЛЬНОЕ ИСКЛЮЧЕНИЕ: основной процесс: com.example.oc2, PID: 19468 java.lang.RuntimeException: Не удается запустить activity ComponentInfo{com.example.oc2/com.example.oc2.MainActivity}: java.lang.Исключение NullPointerException: попытка вызвать виртуальный метод ‘void org.opencv.android.JavaCameraView.enableView()’ для нулевой ссылки на объект в android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2984) в android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3119) в android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78) в android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java: 108) в android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java: 68) в android.app.ActivityThread $ H.handleMessage(ActivityThread.java: 1839) в android.os.Handler.DispatchMessage(Handler.java: 106) в android.os.Looper.loop(Looper.java: 201) в android.app.ActivityThread.main(ActivityThread.java:6864) в java.lang.reflect.Method.invoke(собственный метод) в com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547) в com.android.internal.os.ZygoteInit.main(ZygoteInit.java: 873), вызванное: java.lang.Исключение NullPointerException: попытка вызвать виртуальный метод ‘void org.opencv.android.JavaCameraView.enableView()’ для нулевой ссылки на объект в com.example.oc2.MainActivity$ 1.onManagerConnected(MainActivity.java:116) в com.example.oc2.MainActivity.onCreate(MainActivity.java:52) в android.app.Activity.performCreate(Activity.java :7232) в android.app.Activity.performCreate(Activity.java: 7221) в android.app.Instrumentation.callActivityOnCreate(Instrumentation.java: 1272) в android.app.ActivityThread.performLaunchActivity(ActivityThread.java: 2964) в android.app.ActivityThread.handleLaunchActivity(ActivityThread.java :3119) в android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78) в android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java: 108) в android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java: 68) на android.app.ActivityThread $ H.handleMessage(ActivityThread.java: 1839) на android.os.Handler.DispatchMessage(Handler.java: 106) на android.os.Looper.loop(Looper.java:201) на android.app.ActivityThread.main(ActivityThread.java: 6864) в java.lang.reflect.Method.invoke(собственный метод) в com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547) в com.android.internal.os.ZygoteInit.main(ZygoteInit.java:873) I / Process: отправка сигнала. PID: 19468 SIG: 9

если бы кто-нибудь мог дать шаги по устранению ошибок, это было бы очень полезно.

Ответ №1:

У меня два чувства к вашему коду:

1 — в вашей onCreate деятельности вам не хватает строки как:

 javaCameraView = (CameraBridgeViewBase) findViewById(R.id.java_camera_view);
  

2 — вы не проверяете, было ли предоставлено разрешение камеры, что может привести к другой ошибке позже [ "it seems that your device does not support camera or it is locked - application will be closed" ]

Итак, проведите тест с этим фрагментом, но учтите, что для того, чтобы он работал, вам нужно будет включить разрешение камеры для приложения перед запуском приложения [ Settings->Apps->YourApp->Permissions->Camera ]. Часть разрешений должна быть переписана правильно, это только для быстрого тестирования

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

    javaCameraView = (CameraBridgeViewBase) findViewById(R.id.java_camera_view);

    // added for black screen
    if (ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA)
            == PackageManager.PERMISSION_GRANTED) {
        Log.d(TAG, "Permissions granted");
        javaCameraView.setCameraPermissionGranted();    
        javaCameraView.setCameraIndex(CameraBridgeViewBase.CAMERA_ID_FRONT);    
        javaCameraView.setVisibility(CameraBridgeViewBase.VISIBLE);
        javaCameraView.setCvCameraViewListener(this);
    } else {
        Log.d(TAG, "Troubles");
    }   
}