Android开发经验谈

Android webview长按识别二维码及保存图片到本地

2019-03-19  本文已影响4人  AmoRobin

添加所需要的依赖框架:

implementation 'cn.yipianfengye.android:zxing-library:2.2'
implementation 'com.github.bumptech.glide:glide:4.1.1'

长按识别图片是否为二维码:

    /**
     * 长按webview图片
     */
    webView.setOnLongClickListener(new View.OnLongClickListener() {
            @Override
            public boolean onLongClick(View v) {
                final WebView.HitTestResult htr = ((WebView) v).getHitTestResult();//获取所点击的内容
                if (htr.getType() == WebView.HitTestResult.IMAGE_TYPE //判断被点击的类型为图片
                        || htr.getType() == WebView.HitTestResult.IMAGE_ANCHOR_TYPE
                        || htr.getType() == WebView.HitTestResult.SRC_IMAGE_ANCHOR_TYPE) {
                    imagePath = htr.getExtra();
                    analyzeBitmap(htr.getExtra(), new AnalyzeCallback() {
                        @Override
                        public void onAnalyzeSuccess(Bitmap mBitmap, final String result) {
                            List<String> list = new ArrayList<>();
                            list.add("保存图片到本地");
                            list.add("识别图中二维码");
                            showDialog(list, result);
                        }

                        @Override
                        public void onAnalyzeFailed() {
                            List<String> list = new ArrayList<>();
                            list.add("保存图片到本地");
                            showDialog(list, "");
                        }
                    });
                }
                return false;
            }
        });

    /**
     * 解析二维码图片工具类
     */
    public void analyzeBitmap(final String path, final AnalyzeCallback analyzeCallback) {
        Glide.with(getActivity()).load(path).into(new SimpleTarget<Drawable>() {
            @Override
            public void onResourceReady(Drawable resource, Transition<? super Drawable> transition) {
                BitmapDrawable bd = (BitmapDrawable) resource;
                mBitmap = bd.getBitmap();
                MultiFormatReader multiFormatReader = new MultiFormatReader();

                // 解码的参数
                Hashtable<DecodeHintType, Object> hints = new Hashtable<DecodeHintType, Object>(2);
                // 可以解析的编码类型
                Vector<BarcodeFormat> decodeFormats = new Vector<BarcodeFormat>();
                if (decodeFormats == null || decodeFormats.isEmpty()) {
                    decodeFormats = new Vector<BarcodeFormat>();

                    // 这里设置可扫描的类型,我这里选择了都支持
                    decodeFormats.addAll(DecodeFormatManager.ONE_D_FORMATS);
                    decodeFormats.addAll(DecodeFormatManager.QR_CODE_FORMATS);
                    decodeFormats.addAll(DecodeFormatManager.DATA_MATRIX_FORMATS);
                }
                hints.put(DecodeHintType.POSSIBLE_FORMATS, decodeFormats);
                // 设置继续的字符编码格式为UTF8
                // hints.put(DecodeHintType.CHARACTER_SET, "UTF8");
                // 设置解析配置参数
                multiFormatReader.setHints(hints);

                // 开始对图像资源解码
                Result rawResult = null;
                try {
                    rawResult = multiFormatReader.decodeWithState(new BinaryBitmap(new HybridBinarizer(new BitmapLuminanceSource(mBitmap))));
                } catch (Exception e) {
                    e.printStackTrace();
                }

                if (rawResult != null) {
                    if (analyzeCallback != null) {
                        analyzeCallback.onAnalyzeSuccess(mBitmap, rawResult.getText());
                    }
                } else {
                    if (analyzeCallback != null) {
                        analyzeCallback.onAnalyzeFailed();
                    }
                }
            }
        });
    }

    /**
     * 解析二维码结果
     */
    public interface AnalyzeCallback {

        void onAnalyzeSuccess(Bitmap mBitmap, String result);

        void onAnalyzeFailed();
    }
附:保存图片到本地的方法:
    private class SaveImage extends AsyncTask<String, Void, String> {
        @Override
        protected String doInBackground(String... params) {
            String result = "";
            try {
                String sdcard = null;
                String sdStatus = Environment.getExternalStorageState();
                if (sdStatus.equals(Environment.MEDIA_MOUNTED)) { // 检测sd卡是否可用
                    sdcard = Environment.getExternalStorageDirectory().getAbsolutePath();
                } else {
                    ToastUtil.show(getActivity(), "SD卡不可用");
                }
                File file = new File(sdcard + "/Download");
                if (!file.exists()) {
                    file.mkdirs();
                }
                file = new File(sdcard + "/Download/" + new Date().getTime() + ".jpg");
                InputStream inputStream = null;
                URL url = new URL(imagePath);
                HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                conn.setRequestMethod("GET");
                conn.setConnectTimeout(20000);
                if (conn.getResponseCode() == 200) {
                    inputStream = conn.getInputStream();
                }
                byte[] buffer = new byte[4096];
                int len = 0;
                FileOutputStream outStream = new FileOutputStream(file);
                while ((len = inputStream.read(buffer)) != -1) {
                    outStream.write(buffer, 0, len);
                }
                outStream.close();
                result = "图片已保存至:" + file.getAbsolutePath();
            } catch (Exception e) {
                result = "保存失败!" + e.getLocalizedMessage();
            }
            return result;
        }

        @Override
        protected void onPostExecute(String result) {
            ToastUtil.show(getActivity(), result);
        }
    }

使用方法:

SaveImage saveImage = new SaveImage();
saveImage.execute();

注:Android 6.0以上需动态申请权限:WRITE_EXTERNAL_STORAGE,READ_EXTERNAL_STORAGE,才能保存图片到本地。

上一篇 下一篇

猜你喜欢

热点阅读