2014-01-23 3 views
0
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: Вт/dalvikvm (335): ThreadId = 1: поток, выходящий с неперехваченным исключением (группа = 0x40015560)

01-24 09: 50: 04,625 : E/AndroidRuntime (335): FATAL EXCEPTION: основная

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): at android.app.ActivityThread.performLaunchActivity (ActivityThread.java:1569)

01-24 09: 50: 04.625: E/AndroidRuntime (335) : at 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: Е/AndroidRuntime (335): в android.app.ActivityThread $ H.handleMessage (ActivityThread.java:931)

01-24 09: 50: 04.625: Е/AndroidRuntime (335): at android.os.Handler.dispatchMessage (Handler.java:99)

01-24 09: 50: 04.625: E/AndroidRuntime (335): at android.os.Looper.loop (Looper .java: 123)

01-24 09: 50: 04,625: Е/AndroidRuntime (335): в android.app.ActivityThread.main (ActivityThread.java:3683)

01-24 09:50 : 04.625: E/AndroidRuntime (335): at java.lang.refl ect.Method.invokeNative (Родной метод)

01-24 09: 50: 04,625: Е/AndroidRuntime (335): в 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 (родной метод)

01-24 09: 50: 04,625: Е/AndroidRuntime (335): Вызванный: java.lang.InstantiationException: com.example.faces.MainActivity

01-24 09: 50: 04.625: Е/AndroidRuntime (335): на java.lang.Class.newInstanceImpl (Родной метод)

01-24 09: 50: 04,625: Е/AndroidRuntime (335): в java.lang.Class.newInstance (Class.java:1409)

01-24 09:50 : 04.625: E/AndroidRuntime (335): at android.app.Instrumentation.newActivity (Instrumentation.java:1021)

01-24 09: 50: 04.625: E/AndroidRuntime (335): at android.app. ActivityThread.performLaunchActivity (ActivityThread.java:1561)

01-24 09: 50: 04,625: E/AndroidRuntime (335): ... 11 более

+2

, пожалуйста, сообщите нам об ошибке stacktrace ... –

+0

На самом деле в консоли не было ошибок. Поэтому я посылаю вам logcat. – Somashekar

+0

Я сделал с привязкой logcat в самом вопросе. пожалуйста, просмотрите это. – Somashekar

ответ

0

Нет ничего плохого в коде, который вы здесь добавили, поскольку у меня есть рабочая версия того же кода. Добавили ли вы эту активность в файл AndroidManifest.xml?

+0

Ya .. Я сделал с привязкой к активности для файла манифеста. – Somashekar

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

Убедитесь, что ваш класс MainActivity может быть создан. Некоторые распространенные причины этого:

  • Класс abstract.

  • Существует явный конструктор и он принимает аргументы. Действиям действительно не нужен явный конструктор. Если он предоставлен, он не должен принимать никаких аргументов.

+0

В моем коде нет абстрактного ключевого слова. – Somashekar

+0

Отредактирован ответ. Также рассмотрите вопрос о предоставлении дополнительной информации в вопросе. В чем исключение говорит о том, что эквивалент 'new com.example.faces.MainActivity()' через отражение не удался. – laalto

0

У меня была одна и та же проблема с этим заявлением всех типов, которое неожиданно остановилось/попробовало закрыть. что я сделал, я полностью восстановил свой телефон, и это помогло мне снова избежать этой проблемы. Перед восстановлением убедитесь, что все необходимые документы и файлы безопасны, перенесены на другое устройство или вы можете загрузить одну программу с рынка google, которая помогает переносить файлы из файла в другой новый файл. И, наконец, для восстановления нужно перейти к настройкам-приложениям - восстановить SD-карту и телефон, телефон будет отключен, и вам нужно будет снова начать загрузку вашей учетной записи gmail и подключиться к Интернету или WiFi.

Смежные вопросы