Go語言生成二維碼是如此簡單

申金鑫? 17101223365

轉載自公眾號flysnow_org

【嵌牛導讀】: Go語言生成二維碼

【嵌牛鼻子】: Go語言? ? ? 二維碼

【嵌牛提問】: Go語言怎么生成二維碼

【嵌牛正文】:

二維碼作為一種快速的輸入手段越來越流行,支付,添加好友,買東西,掃個二維碼就可以,非常方便。那么二維碼是如何制作生成的呢?我們如何制作自己的二維碼呢?

什么是二維碼?

二維條碼是指在一維條碼的基礎上擴展出另一維具有可讀性的條碼,使用黑白矩形圖案表示二進制數據,被設備掃描后可獲取其中所包含的信息。一維條碼的寬度記載著數據,而其長度沒有記載數據。二維條碼的長度、寬度均記載著數據。二維條碼有一維條碼沒有的“定位點”和“容錯機制”。容錯機制在即使沒有辨識到全部的條碼、或是說條碼有污損時,也可以正確地還原條碼上的信息。

以上節(jié)選自維基百科。

Go語言生成二維碼圖片

使用Go語言編程時,生成任意內容的二維碼是非常方便的,因為我們有go-qrcode這個庫。該庫的源代碼托管在github上,大家可以下載使用 https://github.com/skip2/go-qrcode。

這個庫的使用很簡單,假如我要以我的博客網站地址http://www.flysnow.org生成一張256*256的圖片,可以使用如下代碼:

import "github.com/skip2/go-qrcode"

func main() {

? ? qrcode.WriteFile("http://www.flysnow.org/",qrcode.Medium,256,"./blog_qrcode.png")

}

這樣我們運行代碼的時候,就在當前目錄下,生成一張256*256的二維碼,掃描后可以看到內容是http://www.flysnow.org/。

func WriteFile(content string, level RecoveryLevel, size int, filename string) error

WriteFile函數的原型定義如上,它有幾個參數,大概意思如下:

content表示要生成二維碼的內容,可以是任意字符串。

level表示二維碼的容錯級別,取值有Low、Medium、High、Highest。

size表示生成圖片的width和height,像素單位。

filename表示生成的文件名路徑。

RecoveryLevel類型其實是個int,它的定義和常量如下。

type RecoveryLevel int

const (

? ? // Level L: 7% error recovery.

? ? Low RecoveryLevel = iota

? ? // Level M: 15% error recovery. Good default choice.

? ? Medium

? ? // Level Q: 25% error recovery.

? ? High

? ? // Level H: 30% error recovery.

? ? Highest

)

RecoveryLevel越高,二維碼的容錯能力越好。

生成二維碼圖片字節(jié)

有時候我們不想直接生成一個PNG文件存儲,我們想對PNG圖片做一些處理,比如縮放了,旋轉了,或者網絡傳輸了等,基于此,我們可以使用Encode函數,生成一個PNG 圖片的字節(jié)流,這樣我們就可以進行各種處理了。

func Encode(content string, level RecoveryLevel, size int) ([]byte, error)

用法和WriteFile函數差不多,只不過返回的是一個[]byte字節(jié)數組,這樣我們就可以對這個字節(jié)數組進行處理了。

自定義二維碼

除了以上兩種快捷方式,該庫還為我們提供了對二維碼的自定義方式,比如我們可以自定義二維碼的前景色和背景色等。qrcode.New函數可以返回一個*QRCode,我們可以對*QRCode設置,實現(xiàn)對二維碼的自定義。

比如我們設置背景色為綠色,前景色為白色的二維碼

func main() {

? ? qr,err:=qrcode.New("http://www.flysnow.org/",qrcode.Medium)

? ? if err != nil {

? ? ? ? log.Fatal(err)

? ? } else {

? ? ? ? qr.BackgroundColor = color.RGBA{50,205,50,255}

? ? ? ? qr.ForegroundColor = color.White

? ? ? ? qr.WriteFile(256,"./blog_qrcode.png")

? ? }

}

指定*QRCode的BackgroundColor和ForegroundColor即可。然后調用WriteFile方法生成這個二維碼文件。

func New(content string, level RecoveryLevel) (*QRCode, error)

// A QRCode represents a valid encoded QRCode.

type QRCode struct {

? ? // Original content encoded.

? ? Content string

? ? // QR Code type.

? ? Level? ? ? ? RecoveryLevel

? ? VersionNumber int

? ? // User settable drawing options.

? ? ForegroundColor color.Color

? ? BackgroundColor color.Color

}

以上QRCode的這些字段都是可以設置的,這樣我們就可以靈活自定義二維碼了。

小結

二維碼是一種流行的輸入技術手段,不光Go可以生成,其他語言也可以生成,并且生成的二維碼是標準的,都可以掃描和識別,比如Java可以通過這個https://github.com/kenglxn/QRGen庫來生成。

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容