go-qrcode
go-qrcode copied to clipboard
To help gophers generate QR Codes with customized styles, such as color, block size, block shape, and icon.
go-qrcode
data:image/s3,"s3://crabby-images/90051/90051c0ed87c39c5cd2eb65e8513482174cb6507" alt=""
Features
- [x] Normally generate QR code across
version 1
toversion 40
. - [x] Automatically analyze QR version by source text.
- [x] Specifying cell shape allowably with
WithCustomShape
,WithCircleShape
(default isrectangle
) - [x] Specifying output file's format with
WithBuiltinImageEncoder
,WithCustomImageEncoder
(default isJPEG
) - [x] Not only shape of cell, but also color of QR Code background and foreground color.
- [x]
WithLogoImage
,WithLogoImageFilePNG
,WithLogoImageFileJPEG
help you add an icon at the central of QR Code. - [x]
WithBorderWidth
allows to specify any width of 4 sides around the qrcode. - [x]
WebAssembly
support, check out the Example and README for more detail. - [x] support Halftone QR Codes, check out the Example.
Install
go get -u github.com/yeqown/go-qrcode/v2
Quick Start
link to CODE
package main
import (
"github.com/yeqown/go-qrcode/v2"
"github.com/yeqown/go-qrcode/writer/standard"
)
func main() {
qrc, err := qrcode.New("https://github.com/yeqown/go-qrcode")
if err != nil {
fmt.Printf("could not generate QRCode: %v", err)
return
}
w, err := standard.New("../assets/repo-qrcode.jpeg")
if err != nil {
fmt.Printf("standard.New failed: %v", err)
return
}
// save file
if err = qrc.Save(w); err != nil {
fmt.Printf("could not save image: %v", err)
}
}
Options
const (
// EncModeNone mode ...
EncModeNone encMode = 1 << iota
// EncModeNumeric mode ...
EncModeNumeric
// EncModeAlphanumeric mode ...
EncModeAlphanumeric
// EncModeByte mode ...
EncModeByte
// EncModeJP mode ...
EncModeJP
)
// WithEncodingMode sets the encoding mode.
func WithEncodingMode(mode encMode) EncodeOption {}
const (
// ErrorCorrectionLow :Level L: 7% error recovery.
ErrorCorrectionLow ecLevel = iota + 1
// ErrorCorrectionMedium :Level M: 15% error recovery. Good default choice.
ErrorCorrectionMedium
// ErrorCorrectionQuart :Level Q: 25% error recovery.
ErrorCorrectionQuart
// ErrorCorrectionHighest :Level H: 30% error recovery.
ErrorCorrectionHighest
)
// WithErrorCorrectionLevel sets the error correction level.
func WithErrorCorrectionLevel(ecLevel ecLevel) EncodeOption {}
following are some shots:
data:image/s3,"s3://crabby-images/d1942/d19427b384368af3d3f8a88e6d1347f2abf619c9" alt="with bg-fg color"
data:image/s3,"s3://crabby-images/db0b5/db0b5ba849b0d415c84652298b883c949e5b5070" alt="with logo image"
data:image/s3,"s3://crabby-images/3bd8a/3bd8aacaa591a14fa4c0e72d5e1e6b3c01db07ac" alt="customize block shape"
data:image/s3,"s3://crabby-images/d418e/d418e7e35fd5a2d06824f19a5f82427b54c9dd71" alt="with transparent bg"
data:image/s3,"s3://crabby-images/774bf/774bfb94d3e3a23b341a0852041e31d4dd745807" alt="halftone0"
data:image/s3,"s3://crabby-images/f1a06/f1a06272f630c5f2f20eb5449860b59e5234f6d2" alt="halftone1"
data:image/s3,"s3://crabby-images/59284/5928443320698fedb29b40ba22f67cf1b31cfb8b" alt="halftone2"
data:image/s3,"s3://crabby-images/dbc72/dbc721203a659b5b040ae4891915d22faf0004dd" alt="halftone3"
Built-in Writers
- Standard Writer, prints QRCode into file and stream
- Terminal Writer, prints QRCode into terminal
Of course, you can also code your own writer, just implement Writer interface.
Migrating from v1
go-qrcode.v2
is a major upgrade from v1, and it is not backward compatible. v2
redesigned
the API, and it is more flexible and powerful. Features are split into different modules (according to functionality).
- github.com/yeqown/go-qrcode/v2 core
- github.com/yeqown/go-qrcode/writer/standard writer/imageFile
- github.com/yeqown/go-qrcode/writer/terminal writer/terminal
Check example/migrating-from-v1 for more details.