1

この問題は、私を何日も夢中にさせています。最新のパッケージであるopencv androidを使用しようとしています。すべてが挿入され、Android でプロジェクトを実行してクラッシュするまで、エラーは発生しません。Mat m = new Mat(); のような単純なコードを呼び出すと、アプリがクラッシュします。他の人が同じ問題を抱えているのを見ましたが、どうにかして修正できました。ここに私のコードがあります。私が本当に必要としているのは Matrix ライブラリだけです。Jama と jblas を試してみましたが、ある程度は機能しますが、クラッシュしてしまい、非常に遅くなります。

 package com.ece.facerecog;
 import java.io.File;
 import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;'
 import java.util.Arrays;

 import org.opencv.android.BaseLoaderCallback;
 import org.opencv.android.LoaderCallbackInterface;
 import org.opencv.android.OpenCVLoader;
     import org.opencv.core.Mat;

import com.ece.facerecog.utils.UIHelper;


//import org.jblas.DoubleMatrix;


  //import Jama.Matrix;
     import android.app.Activity;
 import android.content.Context;
    import android.graphics.Bitmap;
  import android.graphics.BitmapFactory;
 import android.graphics.Color;
 //import android.graphics.Matrix;

  import android.os.Bundle;
 import android.os.Environment;
 import android.util.Log;
 import android.widget.GridView;
 import android.widget.ImageView;
  import android.widget.TextView;

  public class Face extends Activity {
private Bitmap bitmap;
private int f = Crop.k;
private ImageView tv;

   private static final String    TAG                 = "OCVSample::Activity";

private BaseLoaderCallback mLoaderCallback = new BaseLoaderCallback(this) {
    @Override
    public void onManagerConnected(int status) {
        switch (status) {
            case LoaderCallbackInterface.SUCCESS:
            {
                Log.i(TAG, "OpenCV loaded successfully");

            } break;
            default:
            {
                super.onManagerConnected(status);
            } break;
        }
    }
};
  //    @Override
   //   public void onResume()
    //  {
  //        super.onResume();
  //        OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_5, this,                           k                  mLoaderCallback);
    //    }

private Bitmap ReadImage1(String fBitmap) {
    String root = Environment.getExternalStorageDirectory().toString();
    File myDir = new File(root + "/preprocessed");
    File file = new File(myDir , fBitmap); //or any other format supported
    UIHelper.displayText(this, R.id.textView1, file.toString());

    try {
        BitmapFactory.Options options = new BitmapFactory.Options();
        options.inPreferredConfig = Bitmap.Config.ARGB_8888;        
        Bitmap bitmap =            `BitmapFactory.decodeFile(file.getAbsolutePath(),options); //This gets the image `       
        return bitmap;

        } catch (Exception e) {
               e.printStackTrace();
               UIHelper.displayText(this, R.id.textView1, "Doesn't exist");
        }

        return bitmap;
    }



   @Override
   public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.face);

Log.i(TAG, "Trying to load OpenCV library");
if (!OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_5, this, mLoaderCallback))
{
  Log.e(TAG, "Cannot connect to OpenCV Manager");
}


ImageView tv = (ImageView) findViewById(R.id.imageView1);
Bitmap bmp = ReadImage1("/Image-" + f+ ".jpg");
tv.setImageBitmap(bmp);
Mat m = new Mat();

} }

`

これがログエラーです。

04-13 23:14:17.412: E/AndroidRuntime(12111): FATAL EXCEPTION: main
04-13 23:14:17.412: E/AndroidRuntime(12111): java.lang.UnsatisfiedLinkError: Native method not found: org.opencv.core.Mat.n_Mat:()J
04-13 23:14:17.412: E/AndroidRuntime(12111):    at org.opencv.core.Mat.n_Mat(Native Method)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at org.opencv.core.Mat.<init>(Mat.java:441)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at com.ece.facerecog.Face.onCreate(Face.java:147)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.app.Activity.performCreate(Activity.java:5104)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.app.ActivityThread.access$600(ActivityThread.java:141)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.os.Handler.dispatchMessage(Handler.java:99)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.os.Looper.loop(Looper.java:137)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at android.app.ActivityThread.main(ActivityThread.java:5039)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at java.lang.reflect.Method.invokeNative(Native Method)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at java.lang.reflect.Method.invoke(Method.java:511)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
04-13 23:14:17.412: E/AndroidRuntime(12111):    at dalvik.system.NativeStart.main(Native Method)

助けてくれてありがとう!

4

2 に答える 2

4

同じ問題に直面したばかりで、別の解決策を見つけました。
別のアクティビティを使用して、アクティビティを開始するボタンのある紹介画面のように、アクティビティ (「顔」) を呼び出すことができます。この導入アクティビティで OpenCV を初期化すると (自分のアクティビティで行ったのと同じ方法で)、次のアクティビティで OpenCV 関数を問題なく使用できます...

このように、OpenCV 変数をグローバル変数として宣言し、OpenCV の AsyncInitialization ブロックで初期化する必要はありません。

于 2013-05-16T19:34:02.050 に答える
4

のような OpenCV 関数は、またはMatのいずれかで呼び出す必要があると思います。ヘルプなしで AGES の同じ問題に直面しました。threadAsyncTask

クラッシュを避けるためにMat m、グローバル変数として宣言し、AsyncInitializationOpenCV のブロックで初期化することができます。

このようなもの :

 public class Face extends Activity {
 private Bitmap bitmap;
 private int f = Crop.k;
 private ImageView tv;
 Mat m;
 private static final String    TAG                 = "OCVSample::Activity";

  private BaseLoaderCallback mLoaderCallback = new BaseLoaderCallback(this) {
@Override
public void onManagerConnected(int status) {
    switch (status) {
        case LoaderCallbackInterface.SUCCESS:
        {
            Log.i(TAG, "OpenCV loaded successfully");
            m=new Mat();
        } break;
        default:
        {
            super.onManagerConnected(status);
        } break;
    }
}
};

それでもクラッシュする場合は、私のプロジェクトAsyncTaskのように、試している機能を実行することをお勧めします。ただし、関数は、OpenCV 関数で例外のリスクなしで宣言できます。ただし、UI で呼び出される関数ではこれが発生します。少なくともこれは私が見たものです。MatUnsatisfiedLinkError

于 2013-04-14T07:07:13.850 に答える