亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android 二維碼掃描和生成二維碼功能

 更新時間:2017年12月18日 09:29:09   作者:FBY展菲  
二維碼,我們也稱作QRCode,QR表示quick response即快速響應,在很多App中我們都能見到二維碼的身影,最常見的莫過于微信了。下面通過本文給大家講解Android 二維碼掃描和生成二維碼功能,需要的朋友參考下吧

在APP開發(fā)中,常遇到二維碼掃描功能和生成二維碼的需求。Android大部分是集成了zxing這個開源項目的掃碼功能。 開源項目地址 下面給大家介紹一下具體的集成步驟

集成步驟

參考demo

1.demo展示如下:

1.1demo首頁

 

1.2掃描界面

 

可以根據需求修改,我實際項目中界面截圖如下:

 

1.3生成二維碼

 

2.引入文件

2.1 下載demo,拷貝demo中的com.google.zxing5個包和com.utils包引入到自己的項目中。

 

2.2 拷貝本項目demo中的布局activity_scanner.xml和toolbar_scanner.xml

 

2.3 拷貝資源目錄raw至本項目中,beep.ogg是掃描成功時的提示音。

 

2.4 拷貝或合并文件內容attrs.xml/colors.xml/ids.xml三個文件。

 

2.5 build.gradle文件中添加引用

compile 'com.google.zxing:core:3.3.0'

2.6 修改R文件引用路徑 修改以下4個文件中的R文件引用地址,引用本項目的R

//com.google替換成自己項目的包名即可
com.google.zxing.activity.CaptureActivity
com.google.zxing.decoding.CaptureActivityHandler
com.google.zxing.decoding.DecodeHandler
com.google.zxing.view.ViewfinderView

3. 權限配置

3.1 AndroidManifest.xml中添加權限申請代碼:

<uses-permission android:name="android.permission.INTERNET" /> <!-- 網絡權限 -->
 <uses-permission android:name="android.permission.VIBRATE" /> <!-- 震動權限 -->
 <uses-permission android:name="android.permission.CAMERA" /> <!-- 攝像頭權限 -->
 <uses-feature android:name="android.hardware.camera.autofocus" /> <!-- 自動聚焦權限 -->

4. 功能實現

完成上述集成之后,通過調用CaptureActivity就可以實現掃碼功能。 MainActivity源碼部分:

public class MainActivity extends AppCompatActivity {
 @BindView(R.id.openQrCodeScan)
 Button openQrCodeScan;
 @BindView(R.id.text)
 EditText text;
 @BindView(R.id.CreateQrCode)
 Button CreateQrCode;
 @BindView(R.id.QrCode)
 ImageView QrCode;
 @BindView(R.id.qrCodeText)
 TextView qrCodeText;
 //打開掃描界面請求碼
 private int REQUEST_CODE = 0x01;
 //掃描成功返回碼
 private int RESULT_OK = 0xA1;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 ButterKnife.bind(this);
 }
 @OnClick({R.id.openQrCodeScan, R.id.CreateQrCode})
 public void onClick(View view) {
 switch (view.getId()) {
  case R.id.openQrCodeScan:
  //打開二維碼掃描界面
  if(CommonUtil.isCameraCanUse()){
   Intent intent = new Intent(MainActivity.this, CaptureActivity.class);
   startActivityForResult(intent, REQUEST_CODE);
  }else{
   Toast.makeText(this,"請打開此應用的攝像頭權限!",Toast.LENGTH_SHORT).show();
  }
  break;
  case R.id.CreateQrCode:
  try {
   //獲取輸入的文本信息
   String str = text.getText().toString().trim();
   if(str != null && !"".equals(str.trim())){
   //根據輸入的文本生成對應的二維碼并且顯示出來
   Bitmap mBitmap = EncodingHandler.createQRCode(text.getText().toString(), 500);
   if(mBitmap != null){
    Toast.makeText(this,"二維碼生成成功!",Toast.LENGTH_SHORT).show();
    QrCode.setImageBitmap(mBitmap);
   }
   }else{
   Toast.makeText(this,"文本信息不能為空!",Toast.LENGTH_SHORT).show();
   }
  } catch (WriterException e) {
   e.printStackTrace();
  }
  break;
 }
 }
 @Override
 protected void onActivityResult(int requestCode, int resultCode, Intent data) {
 super.onActivityResult(requestCode, resultCode, data);
 //掃描結果回調
 if (resultCode == RESULT_OK) { //RESULT_OK = -1
  Bundle bundle = data.getExtras();
  String scanResult = bundle.getString("qr_scan_result");
  //將掃描出的信息顯示出來
  qrCodeText.setText(scanResult);
 }
 }
}

5. 源碼分析

5.1打開二維碼掃描界面

//打開二維碼掃描界面
  if(CommonUtil.isCameraCanUse()){
   Intent intent = new Intent(MainActivity.this, CaptureActivity.class);
   startActivityForResult(intent, REQUEST_CODE);
  }else{
   Toast.makeText(this,"請打開此應用的攝像頭權限!",Toast.LENGTH_SHORT).show();
  }

5.2 根據輸入的文本生成對應的二維碼并且顯示出來

try {
   //獲取輸入的文本信息
   String str = text.getText().toString().trim();
   if(str != null && !"".equals(str.trim())){
   //根據輸入的文本生成對應的二維碼并且顯示出來
   Bitmap mBitmap = EncodingHandler.createQRCode(text.getText().toString(), 500);
   if(mBitmap != null){
    Toast.makeText(this,"二維碼生成成功!",Toast.LENGTH_SHORT).show();
    QrCode.setImageBitmap(mBitmap);
   }
   }else{
   Toast.makeText(this,"文本信息不能為空!",Toast.LENGTH_SHORT).show();
   }
  } catch (WriterException e) {
   e.printStackTrace();
  }

5.3 掃描結果回調

@Override
 protected void onActivityResult(int requestCode, int resultCode, Intent data) {
 super.onActivityResult(requestCode, resultCode, data);
 //掃描結果回調
 if (resultCode == RESULT_OK) { //RESULT_OK = -1
  Bundle bundle = data.getExtras();
  String scanResult = bundle.getString("qr_scan_result");
  //將掃描出的信息顯示出來
  qrCodeText.setText(scanResult);
 }
 }

總結

以上所述是小編給大家介紹的Android 二維碼掃描和生成二維碼功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • Android手機聯系人帶字母索引的快速查找

    Android手機聯系人帶字母索引的快速查找

    這篇文章主要為大家詳細介紹了Android手機聯系人帶字母索引的快速查找實現方法,感興趣的小伙伴們可以參考一下
    2016-03-03
  • Android studio 解決logcat無過濾工具欄的操作

    Android studio 解決logcat無過濾工具欄的操作

    這篇文章主要介紹了Android studio 解決logcat無過濾工具欄的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • Android ListView常見的優(yōu)化方式詳解

    Android ListView常見的優(yōu)化方式詳解

    這篇文章主要介紹了Android ListView常見的優(yōu)化方式詳解的相關資料,需要的朋友可以參考下
    2017-02-02
  • Android實現狀態(tài)欄白底黑字效果示例代碼

    Android實現狀態(tài)欄白底黑字效果示例代碼

    這篇文章主要介紹了Android實現狀態(tài)欄白底黑字效果的相關資料,實現后的效果非常適合日常開發(fā)中使用,文中給出了詳細的示例代碼供大家參考學習,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-10-10
  • Android TabLayout實現京東詳情效果

    Android TabLayout實現京東詳情效果

    這篇文章主要為大家詳細介紹了android TabLayout實現京東詳情效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Android中常用的XML生成方法實例分析

    Android中常用的XML生成方法實例分析

    這篇文章主要介紹了Android中常用的XML生成方法,以實例形式較為詳細的分析了Android生成XML的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • Android中復制圖片的實例代碼

    Android中復制圖片的實例代碼

    本文通過實例代碼給大家介紹了android 復制圖片的實現方法,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-08-08
  • Android基于Flutter編寫文件下載管理器

    Android基于Flutter編寫文件下載管理器

    文件下載在很多類型的應用中會涉及,例如音樂、文檔、包括圖片(只是圖片可以使用一些組件完成無感知的下載)。本篇介紹使用Flutter中的Dio下載方法完成文件的下載,需要的可以參考一下
    2022-03-03
  • Android中WebView圖片實現自適應的方法

    Android中WebView圖片實現自適應的方法

    這篇文章主要介紹了Android中WebView圖片實現自適應的方法,涉及Android操作圖片顯示的相關技巧,需要的朋友可以參考下
    2015-05-05
  • Android 代碼JIT友好度檢測工具

    Android 代碼JIT友好度檢測工具

    本文主要介紹一個Android代碼JIT友好度檢測工具,這里對JIT工具的資料做了一下整理,有需要的小伙伴可以參考下
    2016-08-08

最新評論