Android中二维码扫描的最常用库是zxing和zbar,zxing项目地址为https://github.com/zxing/zxing,目前还有多个人在维护。zbar主要用C来写的,对速度有要求的可使用zbar,但目前没有在维护,项目地址:https://github.com/ZBar/ZBar。

1.引入jar包

2.copy Zxing包到项目

 这里包名不一样肯定会报错,我们暂时不管,先把资源文件copy过来,后面来做处理。

3.导入相关资源文件

     copy res底下的相关资源文件,如下: 
       drawable、drawable-hdpi和layout 

 raw文件和values文件 

4.AndroidManifest.xml加入相关权限和扫描的Activity

               
  

6.capture.xml的ViewfinderView改成自己包名下的

7.调起扫描界面 获取扫描结果

   在需要打开扫描界面的地方直接跳转到CaptureActivity就OK(使用startActivityForResult)

/**     * 跳转到扫码界面扫码     */    private void goScan() {        Intent intent = new Intent(MainActivity.this, CaptureActivity.class);        startActivityForResult(intent, REQUEST_CODE_SCAN);    }

  在onActivityResult的回调中即可获取扫描内容

@Overrideprotected void onActivityResult(int requestCode, int resultCode, Intent data) {    super.onActivityResult(requestCode, resultCode, data);    // 扫描二维码/条码回传    if (requestCode == REQUEST_CODE_SCAN && resultCode == RESULT_OK) {        if (data != null) {            //返回的文本内容            String content = data.getStringExtra(DECODED_CONTENT_KEY);            //返回的BitMap图像            Bitmap bitmap = data.getParcelableExtra(DECODED_BITMAP_KEY);        }    }}

动态权限申请

  由于扫描需要调用相机,打开摄像头属于敏感权限,所以需要进行权限的动态申请,如下

//动态权限申请if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) {    ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.CAMERA}, 1);} else {    //扫码    goScan();}@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {    switch (requestCode) {        case 1:            if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {                //扫码                goScan();            } else {                Toast.makeText(this, "你拒绝了权限申请,无法打开相机扫码哟!", Toast.LENGTH_SHORT).show();            }            break;        default:    }}

上面的代码就是动态申请权限的流程,首先判断用户是不是已经给我们权限授权了,使用ContextCompat.checkSelfPermission()方法,第一个参数是Context,第二个参数是具体的权限名称,如果等于PackageManager.PERMISSION_GRANTED表明已授权,不等于就是没有授权。 
     如果已授权就直接做后面的操作,如果没有授权,需要调用ActivityCompat.requestPermissions()方法申请授权,第一个参数是当前Activity实例,第二个参数是权限数组,第三个是请求码。 
     用户的选择将会回调到onRequestPermissionsResult()方法中,授权结果封装在grantResults参数中,如果grantResults长度大于0且grantResults[0]等于PackageManager.PERMISSION_GRANTED,也就是上面权限数组中加入的第一个打开摄像头的权限被授权,则可跳转至扫描界面扫码,否则提示用户未打开权限无法使用。Demo下载地址

 

更多相关文章

  1. android的XML连续动画
  2. 【Android】 NDK开发基础
  3. android EditTextDialog与软键盘适配(QVGA)
  4. Android(安卓)热修复框架 AndFix (一)
  5. Android系统启动流程分析
  6. 关于如何检测Android的内存泄漏:
  7. Android使用代码进行界面布局和改变图标、标题、名称、主界面
  8. Android(安卓)ADB 找不到设备的解决方法
  9. Android(安卓)NDK编译Box2D_V2.2

随机推荐

  1. 【Android(安卓)性能优化】应用启动优化
  2. Android(安卓)事件全局监听(二)需要root权
  3. MDCC印象之三:Android热的背后
  4. Android(安卓)Studio如何提示函数用法
  5. Android工程 引用另外一个Android工程
  6. Android(安卓)Cocos2dx 之用eclipse开发
  7. android UI进阶之android中隐藏的layout
  8. Android和设计模式:备忘录模式
  9. Android(安卓)无障碍服务一 让应用具有辅
  10. Android无线连接打印第三方开发的实现