android Studio 二維碼掃一掃 使用精簡過的zxing
今天學習做個掃一掃 於是就上百度找找前人的作品,終於找到了,於是就開始搞
我使用的是 最新的android Studio
Android Studio 3.1.2
Build #AI-173.4720617, built on April 14, 2018
JRE: 1.8.0_152-release-1024-b02 amd64
JVM: OpenJDK 64-Bit Server VM by JetBrains s.r.o
Windows 10 10.0
想做的APP樣子是: A界面中有個按鈕。點擊之後跳到掃一掃B界面,掃完了之後,回調到A界面,在A界面彈一個toast
首先 引用:
在build.gradle中的dependencies 添加一句話 implementation ‘cn.yipianfengye.android:zxing-library:2.2‘
如果其他版本的Android Studio 引入報錯 就使用 compile引用 。
dependencies { implementation fileTree(dir: ‘libs‘, include: [‘*.jar‘]) implementation ‘com.android.support:appcompat-v7:27.1.1‘ implementation ‘com.android.support.constraint:constraint-layout:1.1.0‘ testImplementation ‘junit:junit:4.12‘ androidTestImplementation ‘com.android.support.test:runner:1.0.2‘ androidTestImplementation ‘com.android.support.test.espresso:espresso-core:3.0.2‘ implementation ‘cn.yipianfengye.android:zxing-library:2.2‘ }
demo中 一共有 三個 layout 兩個 class 一張圖 我命名為 scan 定義了一個顏色資源
1、打開 colors.xml 添加資源
<item name="scan_color">#ffffff</item>
2、復制圖片 scan.png到drawable
3、動手搞A界面
名字activity_camera.xml 布局為:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".QR"> <Button android:id="@+id/bt_QR" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="1" android:text="掃描二維碼" /> </LinearLayout>
QR class代碼:
package com.example.administrator.qr; import android.content.Intent; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.Toast; import com.uuzuche.lib_zxing.activity.CodeUtils; import java.nio.charset.CoderResult; public class QR extends AppCompatActivity { @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if(requestCode ==1){ if(data!=null){ Bundle bundle = data.getExtras(); if(bundle==null){ return ; } if(bundle.getInt(CodeUtils.RESULT_TYPE)==CodeUtils.RESULT_SUCCESS){ String ret = bundle.getString(CodeUtils.RESULT_STRING); Toast.makeText(this, "掃碼成功,結果:"+ret, Toast.LENGTH_SHORT).show(); } } } super.onActivityResult(requestCode, resultCode, data); } @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_qr); Button button = findViewById(R.id.bt_QR); button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(QR.this,Camera.class); startActivityForResult(intent,1); } }); } }
4、開始搞B界面
名字 activity_camera.xml 布局代碼:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".Camera"> <FrameLayout android:id="@+id/myCamera" android:layout_width="match_parent" android:layout_height="match_parent"> </FrameLayout> <Button android:id="@+id/bt_back" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="返回" /> <Button android:id="@+id/bt_kaideng" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="false" android:layout_alignParentRight="true" android:layout_alignParentTop="true" android:text="打開閃光燈" /> <TextView android:id="@+id/textView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBottom="@+id/bt_back" android:layout_alignParentTop="true" android:layout_alignTop="@+id/bt_back" android:layout_centerHorizontal="true" android:gravity="fill_vertical" android:text="掃一掃" android:textColor="@color/encode_view" android:textSize="24sp" /> </RelativeLayout>
再弄一個布局 用於替換原始掃一掃的那正方形窗口,如圖所示:
名字 camera.xml 布局為:
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="fill_parent" android:layout_height="fill_parent"> <SurfaceView android:id="@+id/preview_view" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <com.uuzuche.lib_zxing.view.ViewfinderView android:id="@+id/viewfinder_view" android:layout_width="wrap_content" android:layout_height="wrap_content" app:inner_corner_color="@color/scan_corner_color" //這個是掃一掃四個角的顏色 app:inner_corner_length="30dp" app:inner_corner_width="2dp" //這個是掃一掃 四個角的粗細 app:inner_height="200dp" app:inner_margintop="150dp" app:inner_scan_bitmap="@drawable/scan" //這個是掃一掃那條線 app:inner_scan_iscircle="false" app:inner_scan_speed="50" //這個是那條線 從上往下的速度 app:inner_width="200dp" /> </FrameLayout>
//這個布局中的id不能更改 否則報空指針
// com.uuzuche.lib_zxing.view.ViewfinderView標簽可以根據需要修改
Camera class 代碼為:
package com.example.administrator.qr; import android.content.Intent; import android.graphics.Bitmap; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.util.Log; import android.view.WindowManager; import com.uuzuche.lib_zxing.activity.CaptureFragment; import com.uuzuche.lib_zxing.activity.CodeUtils; public class Camera extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); getSupportActionBar().hide(); getWindow().setFlags(WindowManager.LayoutParams.ALPHA_CHANGED, WindowManager.LayoutParams.ALPHA_CHANGED); setContentView(R.layout.activity_camera);// Log.d("bug", "onCreate: "+1); CaptureFragment captureFragment = new CaptureFragment(); Log.d("bug", "onCreate: "+2); CodeUtils.setFragmentArgs(captureFragment,R.layout.camera); //設置自定義掃碼界面 captureFragment.setAnalyzeCallback(analyzeCallback); Log.d("bug", "onCreate: "+3); //R.id.fl_zxing_container 對應 setContentView 布局中的 Fragment getSupportFragmentManager().beginTransaction().replace(R.id.myCamera, captureFragment).commit(); // 替換setContenView設置的布局中的 ID為myCamera } CodeUtils.AnalyzeCallback analyzeCallback = new CodeUtils.AnalyzeCallback() { @Override public void onAnalyzeSuccess(Bitmap mBitmap, String result) { Intent resultIntent = new Intent(); Bundle bundle = new Bundle(); bundle.putInt(CodeUtils.RESULT_TYPE, CodeUtils.RESULT_SUCCESS); bundle.putString(CodeUtils.RESULT_STRING, result); resultIntent.putExtras(bundle); Camera.this.setResult(RESULT_OK, resultIntent); Camera.this.finish(); } @Override public void onAnalyzeFailed() { Intent resultIntent = new Intent(); Bundle bundle = new Bundle(); bundle.putInt(CodeUtils.RESULT_TYPE, CodeUtils.RESULT_FAILED); bundle.putString(CodeUtils.RESULT_STRING, ""); resultIntent.putExtras(bundle); Camera.this.setResult(RESULT_OK, resultIntent); Camera.this.finish(); } }; }
最後添加權限
<uses-permission android:name="android.permission.CAMERA" /> <uses-permission android:name="android.permission.FLASHLIGHT" /> <uses-feature android:name="android.hardware.camera" /> <uses-feature android:name="android.hardware.camera.autofocus" /> <uses-permission android:name="android.permission.VIBRATE" /> <uses-permission android:name="android.permission.WAKE_LOCK" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.INTERNET" />
聲明界面
<activity android:name="com.example.administrator.qr.Camera">
android Studio 二維碼掃一掃 使用精簡過的zxing