#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");
}
}