Zxing图片识别 从相册选二维码图片解析总结

本文详细解释了一段Android代码,包括如何通过Intent获取用户选择的二维码图片,获取图片路径,以及使用线程解析图片并处理可能出现的中文字符编码问题。
摘要由CSDN通过智能技术生成

Intent innerIntent = new Intent(); // “android.intent.action.GET_CONTENT”

if (Build.VERSION.SDK_INT < 19) {

innerIntent.setAction(Intent.ACTION_GET_CONTENT);

} else {

innerIntent.setAction(Intent.ACTION_OPEN_DOCUMENT);

}

innerIntent.setType(“image/*”);

Intent wrapperIntent = Intent.createChooser(innerIntent, “选择二维码图片”);

CaptureActivity.this

.startActivityForResult(wrapperIntent, REQUEST_CODE);

选中了照片后返回的数据在onActivityResult方法中获取

@Override

protected void onActivityResult(int requestCode, int resultCode, Intent data) {

super.onActivityResult(requestCode, resultCode, data);

if (resultCode == RESULT_OK) {

switch (requestCode) {

case REQUEST_CODE:

String[] proj = { MediaStore.Images.Media.DATA };

// 获取选中图片的路径

Cursor cursor = getContentResolver().query(data.getData(),

proj, null, null, null);

if (cursor.moveToFirst()) {

int column_index = cursor

.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);

photo_path = cursor.getString(column_index);

if (photo_path == null) {

photo_path = Utils.getPath(getApplicationContext(),

data.getData());

Log.i(“123path Utils”, photo_path);

}

Log.i(“123path”, photo_path);

}

cursor.close();

new Thread(new Runnable() {

@Override

public void run() {

Result result = scanningImage(photo_path);

// String result = decode(photo_path);

if (result == null) {

Looper.prepare();

Toast.makeText(getApplicationContext(), “图片格式有误”, 0)

.show();

Looper.loop();

} else {

Log.i(“123result”, result.toString());

// Log.i(“123result”, result.getText());

// 数据返回

String recode = recode(result.toString());

Intent data = new Intent();

data.putExtra(“result”, recode);

setResult(300, data);

finish();

}

}

}).start();

break;

}

}

}

上面这段代码

<1> 根据返回的照片信息  获取图片的路径photo_path

<2> 开启一个解析线程调用解析方法Result result = scanningImage(photo_path);      将photo_path传进去

<3> 对返回的解析的Result对象进行判断,获取字符串

<4> 调用recode对result数据进行中文乱码处理          (  具体在步骤3中说明   )

String recode = recode(result.toString());

<5>这里我将result 通过setResult(); 返回给了 父Activity

<6> Utils.getPath(getApplicationContext(),  data.getData());    //将图片Uri 转换成绝对路径

public class Utils {

public static final boolean isChineseCharacter(String chineseStr) {

char[] charArray = chineseStr.toCharArray();

for (int i = 0; i < charArray.length; i++) {

// 是否是Unicode编码,除了"�"这个字符.这个字符要另外处理

if ((charArray[i] >= ‘\u0000’ && charArray[i] < ‘\uFFFD’)

|| ((charArray[i] > ‘\uFFFD’ && charArray[i] < ‘\uFFFF’))) {

continue;

} else {

return false;

}

}

return true;

}

/**

  • Get a file path from a Uri. This will get the the path for Storage Access

  • Framework Documents, as well as the _data field for the MediaStore and

  • other file-based ContentProviders.

  • @param context

  •        The context.
    
  • @param uri

  •        The Uri to query.
    
  • @author paulburke

*/

public static String getPath(final Context context, final Uri uri) {

final boolean isKitKat = Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT;

// DocumentProvider

if (isKitKat && DocumentsContract.isDocumentUri(context, uri)) {

// ExternalStorageProvider

if (isExternalStorageDocument(uri)) {

final String docId = DocumentsContract.getDocumentId(uri);

final String[] split = docId.split(“:”);

final String type = split[0];

if (“primary”.equalsIgnoreCase(type)) {

return Environment.getExternalStorageDirectory() + “/”

  • split[1];

}

// TODO handle non-primary volumes

}

// DownloadsProvider

else if (isDownloadsDocument(uri)) {

final String id = DocumentsContract.getDocumentId(uri);

final Uri contentUri = ContentUris.withAppendedId(

Uri.parse(“content://downloads/public_downloads”),

Long.valueOf(id));

return getDataColumn(context, contentUri, null, null);

}

// MediaProvider

else if (isMediaDocument(uri)) {

final String docId = DocumentsContract.getDocumentId(uri);

final String[] split = docId.split(“:”);

final String type = split[0];

Uri contentUri = null;

if (“image”.equals(type)) {

contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;

} else if (“video”.equals(type)) {

contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI;

} else if (“audio”.equals(type)) {

contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;

}

final String selection = “_id=?”;

final String[] selectionArgs = new String[] { split[1] };

return getDataColumn(context, contentUri, selection,

selectionArgs);

}

}

// MediaStore (and general)

else if (“content”.equalsIgnoreCase(uri.getScheme())) {

return getDataColumn(context, uri, null, null);

}

// File

else if (“file”.equalsIgnoreCase(uri.getScheme())) {

return uri.getPath();

}

return null;

}

/**

  • Get the value of the data column for this Uri. This is useful for

  • MediaStore Uris, and other file-based ContentProviders.

  • @param context

  •        The context.
    
  • @param uri

  •        The Uri to query.
    
  • @param selection

  •        (Optional) Filter used in the query.
    
  • @param selectionArgs

  •        (Optional) Selection arguments used in the query.
    
  • @return The value of the _data column, which is typically a file path.

*/

public static String getDataColumn(Context context, Uri uri,

String selection, String[] selectionArgs) {

Cursor cursor = null;

final String column = “_data”;

final String[] projection = { column };

try {

cursor = context.getContentResolver().query(uri, projection,

selection, selectionArgs, null);

if (cursor != null && cursor.moveToFirst()) {

final int column_index = cursor.getColumnIndexOrThrow(column);

return cursor.getString(column_index);

}

} finally {

if (cursor != null)

cursor.close();

}

return null;

}

/**

  • @param uri

  •        The Uri to check.
    
  • @return Whether the Uri authority is ExternalStorageProvider.

*/

public static boolean isExternalStorageDocument(Uri uri) {

return “com.android.externalstorage.documents”.equals(uri

.getAuthority());

}

/**

  • @param uri

  •        The Uri to check.
    

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

在此为大家准备了四节优质的Android高级进阶视频:

架构师项目实战——全球首批Android开发者对Android架构的见解

附相关架构及资料

image.png

往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

在此为大家准备了四节优质的Android高级进阶视频:

架构师项目实战——全球首批Android开发者对Android架构的见解

附相关架构及资料

[外链图片转存中…(img-FpXJ6ElT-1711906839261)]

往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值