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

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

新規登録して質問してみよう
ただいま回答率
85.50%
OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Q&A

解決済

2回答

5702閲覧

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

tomoe

総合スコア12

OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

0グッド

0クリップ

投稿2016/10/23 16:37

編集2016/10/24 18:28

###前提・実現したいこと
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.

###該当のソースコード

AndroidManifest.xml

1<?xml version="1.0" encoding="utf-8"?> 2<manifest xmlns:android="http://schemas.android.com/apk/res/android" 3 package="com.example.tomoe.opencvcamera"> 4 <uses-permission android:name="android.permission.CAMERA"/> 5 <uses-feature android:name="android.hardware.camera2" android:required="false"/> 6 <uses-feature android:name="android.hardware.camera2.autofocus" android:required="false"/> 7 <application 8 android:allowBackup="true" 9 android:icon="@mipmap/ic_launcher" 10 android:label="@string/app_name" 11 android:supportsRtl="true" 12 android:theme="@style/AppTheme"> 13 <activity android:name=".MainActivity"> 14 <intent-filter> 15 <action android:name="android.intent.action.MAIN" /> 16 17 <category android:name="android.intent.category.LAUNCHER" /> 18 </intent-filter> 19 </activity> 20 </application> 21 22</manifest> 23

MainActivity.java

1import android.support.v7.app.AppCompatActivity; 2import android.os.Bundle; 3import android.util.Log; 4import android.view.SurfaceView; 5 6import org.opencv.android.BaseLoaderCallback; 7import org.opencv.android.CameraBridgeViewBase; 8import org.opencv.android.JavaCameraView; 9import org.opencv.android.LoaderCallbackInterface; 10import org.opencv.android.OpenCVLoader; 11import org.opencv.core.CvType; 12import org.opencv.core.Mat; 13 14public class MainActivity extends AppCompatActivity implements CameraBridgeViewBase.CvCameraViewListener2{ 15 16 private static String TAG = "MainActivity"; 17 JavaCameraView javacameraview; 18 Mat mRgba; 19 BaseLoaderCallback mLoaderCallBack = new BaseLoaderCallback(this){ 20 21 @Override 22 public void onManagerConnected(int status) { 23 switch (status){ 24 case BaseLoaderCallback.SUCCESS:{ 25 javacameraview.enableView(); 26 break; 27 } 28 default:{ 29 super.onManagerConnected(status); 30 break; 31 } 32 } 33 34 } 35 }; 36 37 static { 38 if (OpenCVLoader.initDebug()){ 39 Log.i(TAG, "Opencv loaded successfully"); 40 } 41 else { 42 Log.i(TAG, "OpenCV not loaded"); 43 } 44 } 45 @Override 46 protected void onCreate(Bundle savedInstanceState) { 47 super.onCreate(savedInstanceState); 48 setContentView(R.layout.activity_main); 49 50 javacameraview = (JavaCameraView)findViewById(R.id.java_camera_view); 51 javacameraview.setVisibility(SurfaceView.VISIBLE); 52 javacameraview.setCvCameraViewListener(this); 53 54 } 55 56 @Override 57 protected void onPause(){ 58 super.onPause(); 59 if(javacameraview!=null) 60 javacameraview.disableView(); 61 } 62 63 @Override 64 protected void onDestroy(){ 65 super.onDestroy(); 66 if(javacameraview!=null) 67 javacameraview.disableView(); 68 } 69 70 @Override 71 protected void onResume(){ 72 super.onResume(); 73 if (OpenCVLoader.initDebug()){ 74 Log.i(TAG, "Opencv loaded successfully"); 75 mLoaderCallBack.onManagerConnected(LoaderCallbackInterface.SUCCESS); 76 77 } 78 else { 79 Log.i(TAG, "OpenCV not loaded"); 80 OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_11, this, mLoaderCallBack); 81 } 82 } 83 84 @Override 85 public void onCameraViewStarted(int width, int height) { 86 mRgba = new Mat(height,width, CvType.CV_8UC4); 87 } 88 89 @Override 90 public void onCameraViewStopped() { 91 mRgba.release(); 92 } 93 94 @Override 95 public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) { 96 mRgba = inputFrame.rgba(); 97 return mRgba; 98 } 99} 100

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

###補足情報(言語/FW/ツール等のバージョンなど)
Androidstudio2.2
OpenCV for android 2.4.11
実機ASUS Nexus7 (android6.0.1,API23)

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

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

投稿2016/10/23 22:04

MasahikoHirata

総合スコア3747

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tomoe

2016/10/23 23:11

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

2016/10/24 00:15

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

2016/10/24 05: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.
tomoe

2016/10/24 18:30

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

0

自己解決

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

投稿2016/10/25 07:58

tomoe

総合スコア12

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tomoe

2016/10/25 08:27

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問