应用程序意外停止。强制关闭。该怎么办?

时间:2014-01-23 13:43:58

标签: java android opencv camera frame

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更多

3 个答案:

答案 0 :(得分:1)

Caused by: java.lang.InstantiationException: com.example.faces.MainActivity

确保您的MainActivity课程可以实例化。一些常见原因:

  • 该课程为abstract

  • 有一个显式的构造函数,它需要参数。活动不应该真正需要一个显式的构造函数。如果提供了一个,则不应该参数。

答案 1 :(得分:0)

您在此处附加的代码没有任何问题,因为我有相同示例代码的工作版本。您是否已将活动添加到AndroidManifest.xml文件中?

答案 2 :(得分:0)

我一直有同样的问题,所有类型的应用程序称为意外停止/请强制关闭。我做的是我完全恢复了我的手机,它帮助我再次避免这个问题。 在恢复之前,请确保所有需要的文档和文件都是安全的,转移到其他设备,或者您可以从谷歌市场下载一个程序,这有助于将文件从文件转移到其中的另一个新文件。 最后恢复必须去设置 - 应用程序 - 恢复SD卡和手机,手机将被关闭,需要重新开始上传您的Gmail帐户并连接到互联网或WiFi。