質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.23%

OpenCVのカメラの実装時のエラー

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 3,772

tomoe

score 12

前提・実現したいこと

AndroidstudioにてOpenCVをつかったJavaCameraViewを動かしたいのですがエラーに悩まされています。

発生している問題・エラーメッセージ

Runログ
I/OpenCV/StaticHelper: -----------------------------------------------------------------
I/MainActivity: Opencv loaded successfully
D/JavaCameraView: Connecting to camera
D/JavaCameraView: Initialize java camera
D/JavaCameraView: Trying to open camera with old open()
W/CameraBase: An error occurred while connecting to camera: 0
E/JavaCameraView: Camera is not available (in use or does not exist): Fail to connect to camera service
D/JavaCameraView: Trying to open camera with new open(0)
W/CameraBase: An error occurred while connecting to camera: 0
E/JavaCameraView: Camera #0failed to open: Fail to connect to camera service
D/JavaCameraView: Trying to open camera with new open(1)
W/CameraBase: An error occurred while connecting to camera: 1
E/JavaCameraView: Camera #1failed to open: Fail to connect to camera service
D/JavaCameraView: Disconnecting from camera
D/JavaCameraView: Notify thread
D/JavaCameraView: Wating for thread


実機側
it seems that you device does not support camera (or it is locked).Application will be colosed.

該当のソースコード

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.tomoe.opencvcamera">
    <uses-permission android:name="android.permission.CAMERA"/>
    <uses-feature android:name="android.hardware.camera2" android:required="false"/>
    <uses-feature android:name="android.hardware.camera2.autofocus" android:required="false"/>
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.SurfaceView;

import org.opencv.android.BaseLoaderCallback;
import org.opencv.android.CameraBridgeViewBase;
import org.opencv.android.JavaCameraView;
import org.opencv.android.LoaderCallbackInterface;
import org.opencv.android.OpenCVLoader;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

public class MainActivity extends AppCompatActivity implements CameraBridgeViewBase.CvCameraViewListener2{

    private static String TAG = "MainActivity";
    JavaCameraView javacameraview;
    Mat mRgba;
    BaseLoaderCallback mLoaderCallBack = new BaseLoaderCallback(this){

        @Override
        public void onManagerConnected(int status) {
            switch (status){
                case BaseLoaderCallback.SUCCESS:{
                    javacameraview.enableView();
                    break;
                }
                default:{
                    super.onManagerConnected(status);
                    break;
                }
            }

        }
    };

    static {
        if (OpenCVLoader.initDebug()){
            Log.i(TAG, "Opencv loaded successfully");
        }
        else {
            Log.i(TAG, "OpenCV not loaded");
        }
    }
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        javacameraview = (JavaCameraView)findViewById(R.id.java_camera_view);
        javacameraview.setVisibility(SurfaceView.VISIBLE);
        javacameraview.setCvCameraViewListener(this);

    }

    @Override
    protected void onPause(){
        super.onPause();
        if(javacameraview!=null)
            javacameraview.disableView();
    }

    @Override
    protected void onDestroy(){
        super.onDestroy();
        if(javacameraview!=null)
            javacameraview.disableView();
    }

    @Override
    protected  void  onResume(){
        super.onResume();
        if (OpenCVLoader.initDebug()){
            Log.i(TAG, "Opencv loaded successfully");
            mLoaderCallBack.onManagerConnected(LoaderCallbackInterface.SUCCESS);

        }
        else {
            Log.i(TAG, "OpenCV not loaded");
            OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_11, this, mLoaderCallBack);
        }
    }

    @Override
    public void onCameraViewStarted(int width, int height) {
        mRgba = new Mat(height,width, CvType.CV_8UC4);
    }

    @Override
    public void onCameraViewStopped() {
        mRgba.release();
    }

    @Override
    public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
        mRgba = inputFrame.rgba();
        return mRgba;
    }
}

試したこと

API21からandroid.hardware.cameraが使えないということでcamera2に変更しましたがダメでした・・・

補足情報(言語/FW/ツール等のバージョンなど)

Androidstudio2.2
OpenCV for android 2.4.11
実機ASUS Nexus7 (android6.0.1,API23)

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

+1

カメラの認識がされていないようですが、システム設定は確認されました?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/10/24 08:11

    無知で申し訳ありません。OpenCVのサンプルではカメラ機能を使えています。
    システム設定というのはタブレット側のことでしょうか?

    キャンセル

  • 2016/10/24 09:15

    "OpenCVのサンプルではカメラ機能"という事は実機でopencvのカメラは動作したのですね?

    キャンセル

  • 2016/10/24 14:39

    googleアプリにあったOpenCVSampleと言うものは動作できました。

    自分で作ったカメラをrunすると下記のようにgradleで1個警告が出ています
    コレが原因なのかなと思いつつ場所が分かりません・・・

    Gradle build finished with 1 warnings(s) in 15s 42ms
    Instant Run performed a clean build and install since
    the installation on the device does not match the local build on disk.

    キャンセル

  • 2016/10/25 03:30

    AndroidManifestを記載したつもりがActivity_mainを上げていました・・・
    一応AndroidManifestではカメラの使用許可は出せていると思いますがいかがでしょうか

    キャンセル

check解決した方法

0

実機側のアプリ権限でカメラの使用許可を出してなかったのが原因でした

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/10/25 17:26

    良かったです。

    キャンセル

  • 2016/10/25 17:27

    ありがとうございましたm(__)m

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.23%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る