public void onManagerConnected(int status) {
switch (status) {
case LoaderCallbackInterface.SUCCESS:
{
Log.i(TAG, "OpenCV loaded successfully");
System.loadLibrary("detection_based_tracker");
try {
InputStream is = getResources().openRawResource(R.raw.lbpcascade_frontalface);
File cascadeDir = getDir("cascade", Context.MODE_PRIVATE);
mCascadeFile = new File(cascadeDir, "lbpcascade_frontalface.xml");
FileOutputStream os = new FileOutputStream(mCascadeFile);
byte[] buffer = new byte[4096];
int bytesRead;
while ((bytesRead = is.read(buffer)) != -1) {
os.write(buffer, 0, bytesRead);
}
is.close();
os.close();
mJavaDetector = new CascadeClassifier(mCascadeFile.getAbsolutePath());
if (mJavaDetector.empty()) {
Log.e(TAG, "Failed to load cascade classifier");
mJavaDetector = null;
} else
Log.i(TAG, "Loaded cascade classifier from " + mCascadeFile.getAbsolutePath());
cascadeDir.delete();
} catch (IOException e) {
e.printStackTrace();
Log.e(TAG, "Failed to load cascade. Exception thrown: " + e);
}
mOpenCvCameraView.enableView();
} break;
default:
{
super.onManagerConnected(status);
} break;
}
}
};
public Mat onCameraFrame(CvCameraViewFrame inputFrame)
{
mRgba = inputFrame.rgba();
mGray = inputFrame.gray();
if (mAbsoluteFaceSize == 0) {
int height = mGray.rows();
if (Math.round(height * mRelativeFaceSize) > 0) {
mAbsoluteFaceSize = Math.round(height * mRelativeFaceSize);
}
}
MatOfRect faces = new MatOfRect();
if (mDetectorType == JAVA_DETECTOR){
if (mJavaDetector != null)
mJavaDetector.detectMultiScale(mGray, faces, 1.1, 2, 2,
new Size(mAbsoluteFaceSize, mAbsoluteFaceSize), new Size());
}
else {
Log.e(TAG, "Detection method is not selected!");
}
Rect[] facesArray = faces.toArray();
for (int i = 0; i < facesArray.length; i++)
{
Core.rectangle(mRgba, facesArray[i].tl(), facesArray[i].br(), FACE_RECT_COLOR, 5);
}
return mRgba;
}
执行此代码进行面部检测时。我得到了这个,应用程序意外停止。我决定在没有任何选项的情况下进行面部检测。所以有人可以告诉我我的代码有什么问题。
提前致谢。
logcat的
01-24 09:50:04.605:D / dalvikvm(335):newInstance失败:p0 i0 [0 a1
01-24 09:50:04.605:D / AndroidRuntime(335):关闭虚拟机
01-24 09:50:04.605:W / dalvikvm(335):threadid = 1:线程退出未捕获异常(组= 0x40015560)
01-24 09:50:04.625:E / AndroidRuntime(335):致命异常:主
01-24 09:50:04.625:E / AndroidRuntime(335):java.lang.RuntimeException:无法实例化活动ComponentInfo {com.example.faces / com.example.faces.MainActivity}:java.lang。 InstantiationException:com.example.faces.MainActivity
01-24 09:50:04.625:E / AndroidRuntime(335):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1569)
01-24 09:50:04.625:E / AndroidRuntime(335):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
01-24 09:50:04.625:E / AndroidRuntime(335):在android.app.ActivityThread.access $ 1500(ActivityThread.java:117)
01-24 09:50:04.625:E / AndroidRuntime(335):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:931)
01-24 09:50:04.625:E / AndroidRuntime(335):在android.os.Handler.dispatchMessage(Handler.java:99)
01-24 09:50:04.625:E / AndroidRuntime(335):在android.os.Looper.loop(Looper.java:123)
01-24 09:50:04.625:E / AndroidRuntime(335):在android.app.ActivityThread.main(ActivityThread.java:3683)
01-24 09:50:04.625:E / AndroidRuntime(335):at java.lang.reflect.Method.invokeNative(Native Method)
01-24 09:50:04.625:E / AndroidRuntime(335):at java.lang.reflect.Method.invoke(Method.java:507)
01-24 09:50:04.625:E / AndroidRuntime(335):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:839)
01-24 09:50:04.625:E / AndroidRuntime(335):at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
01-24 09:50:04.625:E / AndroidRuntime(335):at dalvik.system.NativeStart.main(Native Method)
01-24 09:50:04.625:E / AndroidRuntime(335):引起:java.lang.InstantiationException:com.example.faces.MainActivity
01-24 09:50:04.625:E / AndroidRuntime(335):at java.lang.Class.newInstanceImpl(Native Method)
01-24 09:50:04.625:E / AndroidRuntime(335):at java.lang.Class.newInstance(Class.java:1409)
01-24 09:50:04.625:E / AndroidRuntime(335):在android.app.Instrumentation.newActivity(Instrumentation.java:1021)
01-24 09:50:04.625:E / AndroidRuntime(335):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1561)
01-24 09:50:04.625:E / AndroidRuntime(335):... 11更多
答案 0 :(得分:1)
Caused by: java.lang.InstantiationException: com.example.faces.MainActivity
确保您的MainActivity
课程可以实例化。一些常见原因:
该课程为abstract
。
有一个显式的构造函数,它需要参数。活动不应该真正需要一个显式的构造函数。如果提供了一个,则不应该参数。
答案 1 :(得分:0)
您在此处附加的代码没有任何问题,因为我有相同示例代码的工作版本。您是否已将活动添加到AndroidManifest.xml文件中?
答案 2 :(得分:0)
我一直有同样的问题,所有类型的应用程序称为意外停止/请强制关闭。我做的是我完全恢复了我的手机,它帮助我再次避免这个问题。 在恢复之前,请确保所有需要的文档和文件都是安全的,转移到其他设备,或者您可以从谷歌市场下载一个程序,这有助于将文件从文件转移到其中的另一个新文件。 最后恢复必须去设置 - 应用程序 - 恢复SD卡和手机,手机将被关闭,需要重新开始上传您的Gmail帐户并连接到互联网或WiFi。