web-dev-qa-db-ja.com

AndroidのMobileVisionAPIを使用したQRコードのスキャン

私はこれに従いました チュートリアル QRコードをスキャンできるAndroidアプリを構築する方法について。

これが完全なコードです。私はそのようなグレードを使用してGooglePlay開発者サービスを追加しましたcompile 'com.google.Android.gms:play-services:7.8.0'

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:Android="http://schemas.Android.com/apk/res/Android"
    package="bitinvent.io.qrscanner" >

    <meta-data Android:name="com.google.Android.gms.vision.DEPENDENCIES" Android:value="barcode"/>
    <uses-permission Android:name="Android.permission.INTERNET"/>
    <uses-permission Android:name="Android.permission.CAMERA"/>

    <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>

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:tools="http://schemas.Android.com/tools" Android:layout_width="match_parent"
    Android:layout_height="match_parent" Android:paddingLeft="@dimen/activity_horizontal_margin"
    Android:paddingRight="@dimen/activity_horizontal_margin"
    Android:paddingTop="@dimen/activity_vertical_margin"
    Android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">

    <SurfaceView
        Android:id="@+id/cameraView"
        Android:layout_width="640px"
        Android:layout_height="480px"
        Android:layout_centerVertical="true"
        Android:layout_alignParentLeft="true"/>

    <TextView
        Android:id="@+id/infoTextView"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_alignParentTop="true"
        Android:layout_toRightOf="@+id/cameraView"
        Android:layout_marginLeft="16dp"
        Android:text="Nothing to read"
        Android:textSize="20sp"/>

</RelativeLayout>

MainActivity.Java

package bitinvent.io.qrscanner;

import Android.app.Activity;
import Android.os.Bundle;
import Android.util.Log;
import Android.util.SparseArray;
import Android.view.SurfaceHolder;
import Android.view.SurfaceView;
import Android.widget.TextView;

import com.google.Android.gms.vision.CameraSource;
import com.google.Android.gms.vision.Detector;
import com.google.Android.gms.vision.barcode.Barcode;
import com.google.Android.gms.vision.barcode.BarcodeDetector;

import Java.io.IOException;

public class MainActivity extends Activity {

    private SurfaceView cameraView;
    private TextView barcodeInfo;
    private CameraSource cameraSource;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        cameraView = (SurfaceView) findViewById(R.id.cameraView);
        barcodeInfo = (TextView) findViewById(R.id.infoTextView);

        BarcodeDetector detector = new BarcodeDetector.Builder(this).setBarcodeFormats(Barcode.QR_CODE).build();
        cameraSource = new CameraSource.Builder(this, detector).setRequestedPreviewSize(640, 480).build();

        cameraView.getHolder().addCallback(new SurfaceHolder.Callback() {
            @Override
            public void surfaceCreated(SurfaceHolder holder) {
                try {
                    cameraSource.start(cameraView.getHolder());
                } catch (IOException e) {
                    Log.e("CAMERA SOURCE", e.getMessage());
                }
            }

            @Override
            public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {

            }

            @Override
            public void surfaceDestroyed(SurfaceHolder holder) {
                cameraSource.stop();
            }
        });

        detector.setProcessor(new Detector.Processor<Barcode>() {
            @Override
            public void release() {

            }

            @Override
            public void receiveDetections(Detector.Detections<Barcode> detections) {
                final SparseArray<Barcode> barcodes = detections.getDetectedItems();
                if (barcodes.size() != 0) {
                    barcodeInfo.post(new Runnable() {
                        @Override
                        public void run() {
                            barcodeInfo.setText(barcodes.valueAt(0).displayValue);
                        }
                    });
                }
            }
        });
    }
}

Android 4.4.2を実行しているHTCDesire 816でこれをテストしましたが、機能していないようです。カメラビューはアクティブですが、QRコードをポイントすると検出されません。しかし、エラーやクラッシュも発生しません。

私は何かが足りないのですか?

16
Isuru

ついに私はそれを私の側で機能させました。アプリケーションにQRコードスキャンを実装するために、現在持っているプロセスとコードを共有したいと思いました。私は実際にあなたの質問に答えていません。ただし、Google Vision APIを使用してQRコードスキャンを実装する方法に関して、StackOverflowから適切なヘルプソースが見つかりませんでした。私はあなたがあなたの質問で指摘したチュートリアルを調べました。しかし、チュートリアルは私にとってもあまり役に立ちませんでした。したがって、アプリケーションにQRコードスキャンを実装するためのクラスと手順を書き留めています。

まず、gradleの依存関係が必要になります。したがって、build.gradleファイルに、次の依存関係を追加します。

dependencies {
    compile 'com.Android.support:design:25.3.1'
    compile 'com.google.Android.gms:play-services-vision:10.2.1'
}

次に、プロジェクトに次の5つのクラスが必要です。ここにクラスを追加しています。必要に応じて、不足しているクラスをインポートしてください。

  1. CameraSource.Java
  2. CameraSourcePreview.Java
  3. BarcodeCaptureActivity.Java
  4. BarcodeGraphicTracker.Java
  5. BarcodeTrackerFactory.Java

これで、BarcodeCaptureActivityには、layoutフォルダーにも配置する必要のあるレイアウトがあります。

必要なbarcode_capture.xmlレイアウトは次のとおりです。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:id="@+id/topLayout"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent"
    Android:keepScreenOn="true"
    Android:orientation="vertical">

    <!-- Do not forget to replace with your package name where the class is located -->
    <com.example.yourpackage.camera.CameraSourcePreview
        Android:id="@+id/preview"
        Android:layout_width="match_parent"
        Android:layout_height="match_parent" />

</LinearLayout>

BarcodeCaptureActivityのマニフェストにいくつかの文字列とアクティビティエントリが必要になります。 strings.xmlに入力する必要のある文字列は次のとおりです。

<!-- QR Code related strings -->
<string name="permission_camera_rationale">Access to the camera is needed for detection</string>
<string name="no_camera_permission">This application cannot run because it does not have the camera permission.  The application will now exit.</string>
<string name="low_storage_error">Face detector dependencies cannot be downloaded due to low device storage</string>
<string name="ok">OK</string>

また、AndroidManifest.xmlには、次のようにBarcodeCaptureActivityの新しいエントリが必要です。

<activity
    Android:name=".util.scanner.BarcodeCaptureActivity"
    Android:theme="@style/Theme.AppCompat" />

これでセットアップが完了し、バーコードまたはQRコードをスキャンするためにカメラを開く準備が整いました。必要に応じて、次のinitiateScan関数を呼び出すだけです。

public static final int RC_BARCODE_CAPTURE = 9001;

public void initiateScan() {
    Intent intent = new Intent(YourActivity.this, BarcodeCaptureActivity.class);
    startActivityForResult(intent, RC_BARCODE_CAPTURE);
}

initiateScan関数を呼び出す前に、ユーザーにカメラの許可を求める必要があることに注意してください。カメラの許可を与えると、initiateScan関数を呼び出します。

initiateScan関数はスキャナーを開き、スキャンが成功すると、呼び出し元のActivityまたはFragmentに戻ります。したがって、onActivityResultまたはActivityの呼び出しにはFragment関数が必要です。

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    if (resultCode == CommonStatusCodes.SUCCESS && requestCode == RC_BARCODE_CAPTURE) {
        if (data == null) return;
        Barcode barcode = data.getParcelableExtra(BarcodeCaptureActivity.BarcodeObject);
        final String scanResult = barcode.displayValue;
        if (scanResult == null) return;

        doSomethingWithTheScanResult(scanResult);
    }
}

AndroidManifest.xmlファイルにもCAMERA権限を追加することを忘れないでください。

<uses-permission Android:name="Android.permission.CAMERA" />

Google VisionAPIを使用したQRコードスキャナーの統合が容易になることを願っています。サンプルのQRコードスキャナーアプリケーション用に github project を追加しました。ご覧ください。

2
Reaz Murshed

Android開発は初めてですが、Play開発者サービス8.1を使用してチュートリアルに従いました。動作しました。

コードはあなたのものと非常に似ています。唯一の違いは、アプリケーションレベルでメタタグがあり、QRタイプコードに限定されているため、.setBarcodeFormats(Barcode.QR_CODE)を削除したことです。

また、ポートレートが機能していなかったため、横向きでアプリを使用しました。 QRコードの横向きでも、認識できるようになるまで、QRコードをカメラからゆっくりと離さなければならないことがありました。

0
user5601837

次の行を移動してみてください

<meta-data Android:name="com.google.Android.gms.vision.DEPENDENCIES" Android:value="barcode" />

<intent-filter/>の直後のyoutマニフェストのアクティビティタグに

こんな感じになります

<meta-data Android:name="com.google.Android.gms.vision.DEPENDENCIES" Android:value="barcode" /> </activity>

Lemmeはそれが役立つかどうか知っています

0
Bisma Frühling

デバイスでインターネット接続を有効にしましたか? GooglePlay開発者サービスを介してデータをダウンロードするため。デバイスを介したインターネット接続が必要ですが、許可を与える必要はありません。

0
AnkitRox