andorid jar/庫源碼解析之zxing

来源:https://www.cnblogs.com/Supperlitt/archive/2020/05/05/12782875.html
-Advertisement-
Play Games

目錄:andorid jar/庫源碼解析 Zxing: 作用: 生成和識別,二維碼,條形碼。 慄子: 生成二維碼,賦值到ImageView上 QRCodeWriter qrCodeWriter = new QRCodeWriter(); Map<EncodeHintType, String> hin ...


目錄:andorid jar/庫源碼解析 

Zxing:

  作用:

    生成和識別,二維碼,條形碼。

  慄子:

   生成二維碼,賦值到ImageView上

     QRCodeWriter qrCodeWriter = new QRCodeWriter();
        Map<EncodeHintType, String> hints = new HashMap<>();
        hints.put(EncodeHintType.CHARACTER_SET, "utf-8"); //記得要自定義長寬
        BitMatrix encode = null;
        try {
            encode = qrCodeWriter.encode("hello,world!", BarcodeFormat.QR_CODE, width, height, hints);
        } catch (WriterException e) {
            e.printStackTrace();
        }
        int[] colors = new int[width * height];
        //利用for迴圈將要表示的信息寫出來
        for (int i = 0; i < width; i++) {
            for (int j = 0; j < height; j++) {
                if (encode.get(i, j)) {
                    colors[i * width + j] = Color.BLACK;
                } else {
                    colors[i * width + j] = Color.WHITE;
                }
            }
        }

        Bitmap bit = Bitmap.createBitmap(colors, width, height, Bitmap.Config.RGB_565);
        imageView.setImageBitmap(bit);

  生成條形碼,賦值到ImageView上

     final int WHITE = 0xFFFFFFFF;
        final int BLACK = 0xFF000000;
        MultiFormatWriter writer = new MultiFormatWriter();
        BitMatrix result = null;
        try {
            BarcodeFormat barcodeFormat = BarcodeFormat.CODE_128;
            result = writer.encode("1234567123456", barcodeFormat, 400,
                    100, null);
        } catch (WriterException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        int width = result.getWidth();
        int height = result.getHeight();
        int[] pixels = new int[width * height];
        for (int y = 0; y < height; y++) {
            int offset = y * width;
            for (int x = 0; x < width; x++) {
                pixels[offset + x] = result.get(x, y) ? BLACK : WHITE;
            }
        }

        Bitmap bitmap = Bitmap.createBitmap(width, height,
                Bitmap.Config.ARGB_8888);
        bitmap.setPixels(pixels, 0, width, 0, 0, width, height);

        imageView2.setImageBitmap(bitmap);

  識別二維碼

   private void Test3() {
        recogQRcode(imageView);
    }

    public void recogQRcode(ImageView imageView){
        Bitmap QRbmp = ((BitmapDrawable) (imageView).getDrawable()).getBitmap();   //將圖片bitmap化
        int width = QRbmp.getWidth();
        int height = QRbmp.getHeight();
        int[] data = new int[width * height];
        QRbmp.getPixels(data, 0, width, 0, 0, width, height);    //得到像素
        RGBLuminanceSource source = new RGBLuminanceSource(width, height, data);
        BinaryBitmap bitmap1 = new BinaryBitmap(new HybridBinarizer(source));
        QRCodeReader reader = new QRCodeReader();
        Result re = null;
        try {
            //得到結果
            re = reader.decode(bitmap1);
        } catch (NotFoundException e) {
            e.printStackTrace();
        } catch (ChecksumException e) {
            e.printStackTrace();
        } catch (FormatException e) {
            e.printStackTrace();
        }

        lblMsg1.setText(re.getText());
    }

  識別條形碼

     Bitmap QRbmp = ((BitmapDrawable) (imageView2).getDrawable()).getBitmap();   //將圖片bitmap化
        int width = QRbmp.getWidth();
        int height = QRbmp.getHeight();
        int[] data = new int[width * height];
        QRbmp.getPixels(data, 0, width, 0, 0, width, height);    //得到像素
        RGBLuminanceSource source = new RGBLuminanceSource(width, height, data);

        //二進位圖片轉換成bitmap對象(說明:創建HybridBinarizer對象,需要傳入LuminanceSource,所以傳入source(二進位的圖片),並且通過BinaryBitmap轉換成bitmap對象)
        BinaryBitmap bitmap1 = new BinaryBitmap(new HybridBinarizer(source));
        //CodaBarReader codaBarReader= new CodaBarReader();    //codaBarReader  二維碼
        try {
            //MultiFormatReader是讀取圖像的類(在core包)
            Result result = new MultiFormatReader().decode(bitmap1);      //識別條形碼,和二維碼(說明:獲取到我們需要的信息)
            lblMsg2.setText(result.getText());
        } catch (NotFoundException e) {
            e.printStackTrace();
            lblMsg2.setText("ex " + e.getMessage());
        }

  源碼解讀:

  A:生成二維碼

    1、創建一個 QRCodeWriter對象,調用 encode,傳入需要生成二維碼的數據,格式化參數,大小,和編碼信息

    2、調用Encoder的encode方法,a,確定當前使用的編碼。b,判斷生成二維碼數據的編碼模式(數字,byte,和 0x00-0x5f)。c,附加ECI部分(二維碼格式中的一部分)。d,填充 FNC1信息到頭部中。e,寫入模式標記到頭部中。

    3、把二維碼文本數據,按照不同的模式,寫入到不同的結果bit集合中。

    4、判斷版本和容量,是否在範圍內。

    5、合併頭部,數據長度,數據內容到一個bit集合。

    6、填充數據,使bit數據時8的整數倍。

    7、把位數據信息和糾錯碼,交織在一起,存入新的數據(演算法複雜,具體參考二維碼生成演算法)。

    8、調用 MatrixUtil.buildMatrix,構建二維碼矩陣,並返回二維碼信息。 QRCode中 使用 ByteMatrix 存儲矩陣,內部是一個二維的bytes數組。 private final byte[][] bytes;

    9、轉換矩陣顏色,從 輸入矩陣使用0==白色,1==黑色,而輸出矩陣使用 0==黑色,255==白色(即8位灰度點陣圖)。

    10、創建一個color數組,把顏色數據存入。調用   Bitmap.createBitmap ,把color集合信息,傳遞給他,然後返回一個Bitmap就是二維碼數據了。

  B:生成條形碼

    1、創建一個 MultiFormatWriter 對象,並調用他的 encode方法,傳入條形碼數據,和編碼信息,和條形碼結果大小。

    2、根據不同的編碼,選擇了不同的寫入器,這裡採用了 Code128Writer

    3、a,判斷條形碼內容,長度限制[1,80]。...略

    4、使用二進位,把二進位轉換成圖片。就是最後的結果了。。

  C:識別二維碼。(反向解析)

  D:識別條形碼。(反向解析)

  源碼:https://github.com/zxing/zxing

  引入:

api 'com.google.zxing:android-core:3.3.0'
api 'com.google.zxing:core:3.3.2'

  註意:(如果無法從google載入,就需要換一個來源,下麵代碼和圖)

maven{ url'http://maven.aliyun.com/nexus/content/groups/public/' }
maven{ url'http://maven.aliyun.com/nexus/content/repositories/jcenter'}
  
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 目錄:andorid jar/庫源碼解析 Bolts: 作用: 用於鏈式執行跨線程代碼,且傳遞數據 慄子: Task.call(new Callable<Boolean>() { @Override public Boolean call() throws Exception { return tr ...
  • 快速接入訊飛語音聽寫SDK(內附空指針解決和修改對話框文字方法) ...
  • 簡單又詳細,Android Library 發佈開源庫 JCenter & JitPack 攻略~ ...
  • 前言 最近項目有一個節點進度條的小需求,完成後,想分享出來希望可以幫到有需要的同學。 真機效果圖 自定義View完整代碼 開箱即用~,註釋已經炒雞詳細了 註意點 1. 控制項的節點總個數是與傳入的節點底部標題列表中元素個數控制(相同)的,簡而言之就是傳入的標題列表中有多少個標題,節點就會繪製多少個 2 ...
  • 一、ValueAnimator ValueAnimator是值的變動,可以控制控制項的一些值,從而達到變化動畫的效果。 監聽器三個 移除監聽器 當移除監聽器時,正在執行的動畫不會受到影響,但是之後再執行動畫,動畫的監聽效果將不會再呈現。 不常用函數 常用函數 效果: 二、自定義插值器 1.插值器的理解 ...
  • 前言 Excel 解析,一般來說是在服務端進行的,但是如果移動端要實現解析Excel的功能,那也是有實現的方法的。 不過由於Android 原生用Java/Kotlin實現,所以也可以參考服務端解析Excel的方法。 首先說, jxl ,過去比較流行的解析office文檔的框架,但目前官方的版本,在 ...
  • CameraX 又是一個 Google 推出的 JetPack 組件 ,是一個新鮮玩意兒,故給大家分享下我在項目中的使用過程心得。。 CameraX 是什麼? Google 開發者文檔 對 CameraX 的評價如下: CameraX是一個Jetpack支持庫,旨在幫助您簡化相機應用程式的開發工作。 ...
  • 如果你的Mac還沒安裝Homebrew, 先安裝Homebrew,Homebrew是Mac上非常優秀的軟體包管理工具。 擁有安裝、卸載、更新、查看、搜索等很多實用的功能。 推薦國內的一鍵安裝腳本,該腳本會自動設置國內源: /bin/zsh -c "$(curl -fsSL https://gitee ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...