【问题标题】:Application stopped unexpectedly. Force close. what to do?应用程序意外停止。强制关闭。该怎么办?
【发布时间】:2024-01-04 19:08:01
【问题描述】:
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;

}

在执行此代码进行人脸检测时。我明白了,应用程序意外停止。我决定在没有任何选项的情况下进行人脸检测。所以任何人都可以建议我我的代码有什么问题。

提前致谢。

日志猫
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。实例化异常: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): at 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): at 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): Caused by: 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 更多

【问题讨论】:

  • 请给我们一个错误堆栈跟踪...
  • 控制台实际上并没有出现错误。所以我把 logcat 发给你了。
  • 我在问题本身中完成了 logcat 的附件。请看一下。

标签: java android opencv camera frame


【解决方案1】:
Caused by: java.lang.InstantiationException: com.example.faces.MainActivity

确保您的 MainActivity 类可以被实例化。造成这种情况的一些常见原因:

  • 班级是abstract

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

【讨论】:

  • 编辑了答案。还可以考虑在问题中提供其他详细信息。什么异常说通过反射相当于new com.example.faces.MainActivity() 失败。
【解决方案2】:

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

【讨论】:

  • 是的。我也完成了将活动附加到清单文件。
【解决方案3】:

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

【讨论】:

    最近更新 更多