# go-qrcode #
[data:image/s3,"s3://crabby-images/0da84/0da844953cda24f8ba15a5cf3925179ce219a567" alt="Go Report Card"](https://goreportcard.com/report/github.com/yeqown/go-qrcode)
[data:image/s3,"s3://crabby-images/0eaa1/0eaa102a2ad8fa5eb2710e91cee9d30aaefd9449" alt="go.dev reference"](https://pkg.go.dev/github.com/yeqown/go-qrcode/v2)
[data:image/s3,"s3://crabby-images/aa641/aa6410dc573c12f2bdecd1c7fcef6da0c1bc8678" alt="Go"](https://github.com/yeqown/go-qrcode/actions/workflows/go.yml) data:image/s3,"s3://crabby-images/3fd1a/3fd1a559884008885e29915bfc0aab5137b967ca" alt=""
data:image/s3,"s3://crabby-images/0451c/0451c5f1d288eac4c1ec06db9b96be44ae6b8e97" alt="GitHub release (latest SemVer)"
data:image/s3,"s3://crabby-images/97657/97657068a83546e8997b5d10e0778849996173f4" alt="GitHub go.mod Go version"
[data:image/s3,"s3://crabby-images/ea4c5/ea4c54b5c3dd3609b358f69163415b4411bd47f9" alt="License"](./LICENSE)
QR code (abbreviated from Quick Response Code) is the trademark for a type of matrix barcode (or two-dimensional barcode) first designed in 1994 for the automotive industry in Japan. A barcode is a machine-readable optical label that contains information about the item to which it is attached. A QR code uses four standardized encoding modes (numeric, alphanumeric, byte/binary, and kanji) to store data efficiently; extensions may also be used
### Features
- [x] Normally generate QR code across `version 1` to `version 40`.
- [x] Automatically analyze QR version by source text.
- [x] Specifying cell shape allowably with `WithCustomShape`, `WithCircleShape` (default is `rectangle`)
- [x] Specifying output file's format with `WithBuiltinImageEncoder`, `WithCustomImageEncoder` (default is `JPEG`)
- [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](./example/webassembly/README.md) and [README](cmd/wasm/README.md) for more detail.
- [x] support Halftone QR Codes, check out the [Example](./example/with-halftone).
### Install
```sh
go get -u github.com/yeqown/go-qrcode/v2
```
### Quick Start
link to [CODE](./example/main.go)
```go
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
```go
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: