Go語言生成二維碼是如此簡單
本文為原創文章,轉載註明出處,歡迎掃碼關注公眾號
flysnow_org
或者網站http://www.flysnow.org/,第一時間看後續精彩文章。覺得好的話,順手分享到朋友圈吧,感謝支持。
二維碼作為一種快速的輸入手段越來越流行,支付,添加好友,買東西,掃個二維碼就可以,非常方便。那麼二維碼是如何製作生成的呢?我們如何製作自己的二維碼呢?
什麼是二維碼?
二維條碼是指在一維條碼的基礎上擴展出另一維具有可讀性的條碼,使用黑白矩形圖案表示二進位數據,被設備掃描後可獲取其中所包含的信息。一維條碼的寬度記載著數據,而其長度沒有記載數據。二維條碼的長度、寬度均記載著數據。二維條碼有一維條碼沒有的「定位點」和「容錯機制」。容錯機制在即使沒有辨識到全部的條碼、或是說條碼有污損時,也可以正確地還原條碼上的信息。
以上節選自維基百科。
Go語言生成二維碼圖片
使用Go語言編程時,生成任意內容的二維碼是非常方便的,因為我們有go-qrcode
這個庫。該庫的源代碼託管在github上,大家可以下載使用 https://github.com/skip2/go-qrcode。
這個庫的使用很簡單,假如我要以我的博客網站地址http://www.flysnow.org生成一張256*256的圖片,可以使用如下代碼:
import "github.com/skip2/go-qrcode"nnfunc main() {n qrcode.WriteFile("http://www.flysnow.org/",qrcode.Medium,256,"./blog_qrcode.png")n}n
這樣我們運行代碼的時候,就在當前目錄下,生成一張256*256的二維碼,掃描後可以看到內容是http://www.flysnow.org/
。
func WriteFile(content string, level RecoveryLevel, size int, filename string) errorn
WriteFile
函數的原型定義如上,它有幾個參數,大概意思如下:
content
表示要生成二維碼的內容,可以是任意字元串。level
表示二維碼的容錯級別,取值有Low、Medium、High、Highest。size
表示生成圖片的width和height,像素單位。filename
表示生成的文件名路徑。
RecoveryLevel
類型其實是個int
,它的定義和常量如下。
type RecoveryLevel intnnconst (n // Level L: 7% error recovery.n Low RecoveryLevel = iotann // Level M: 15% error recovery. Good default choice.n Mediumnn // Level Q: 25% error recovery.n Highnn // Level H: 30% error recovery.n Highestn)n
RecoveryLevel
越高,二維碼的容錯能力越好。
生成二維碼圖片位元組
有時候我們不想直接生成一個PNG文件存儲,我們想對PNG圖片做一些處理,比如縮放了,旋轉了,或者網路傳輸了等,基於此,我們可以使用Encode
函數,生成一個PNG 圖片的位元組流,這樣我們就可以進行各種處理了。
func Encode(content string, level RecoveryLevel, size int) ([]byte, error)n
用法和WriteFile
函數差不多,只不過返回的是一個[]byte
位元組數組,這樣我們就可以對這個位元組數組進行處理了。
自定義二維碼
除了以上兩種快捷方式,該庫還為我們提供了對二維碼的自定義方式,比如我們可以自定義二維碼的前景色和背景色等。qrcode.New
函數可以返回一個*QRCode
,我們可以對*QRCode
設置,實現對二維碼的自定義。
比如我們設置背景色為綠色,前景色為白色的二維碼
func main() {n qr,err:=qrcode.New("http://www.flysnow.org/",qrcode.Medium)n if err != nil {n log.Fatal(err)n } else {n qr.BackgroundColor = color.RGBA{50,205,50,255}n qr.ForegroundColor = color.Whiten qr.WriteFile(256,"./blog_qrcode.png")n }n}n
指定*QRCode
的BackgroundColor
和ForegroundColor
即可。然後調用WriteFile
方法生成這個二維碼文件。
func New(content string, level RecoveryLevel) (*QRCode, error)nn// A QRCode represents a valid encoded QRCode.ntype QRCode struct {n // Original content encoded.n Content stringnn // QR Code type.n Level RecoveryLeveln VersionNumber intnn // User settable drawing options.n ForegroundColor color.Colorn BackgroundColor color.Colorn}n
以上QRCode
的這些欄位都是可以設置的,這樣我們就可以靈活自定義二維碼了。
小結
二維碼是一種流行的輸入技術手段,不光Go可以生成,其他語言也可以生成,並且生成的二維碼是標準的,都可以掃描和識別,比如Java可以通過這個https://github.com/kenglxn/QRGen庫來生成。
本文為原創文章,轉載註明出處,歡迎掃碼關注公眾號
flysnow_org
或者網站http://www.flysnow.org/,第一時間看後續精彩文章。覺得好的話,順手分享到朋友圈吧,感謝支持。
http://weixin.qq.com/r/NjhqctXEt4jIrZER920k (二維碼自動識別)
推薦閱讀:
※你覺得學習編程給你帶來了什麼樣的改變?
※使用Flask如何在Bootstrap模態框(Modal)里實現表單的渲染和驗證?
※Python中那些神一樣的代碼