init
This commit is contained in:
31
cmd/zplgfa/README.md
Normal file
31
cmd/zplgfa/README.md
Normal file
@@ -0,0 +1,31 @@
|
||||
# ZPLGFA CLI Tool
|
||||
|
||||
The ZPLGFA cli tool converts PNG, JPEG and GIF images to [ZPL](https://www.zebra.com/content/dam/zebra/manuals/printers/common/programming/zpl-zbi2-pm-en.pdf) strings.
|
||||
So if you need to print labels on a [ZPL](https://en.wikipedia.org/wiki/Zebra_(programming_language) compatible printer
|
||||
(like the amazing [ZEBRA ZM400](https://amzn.to/2OD5S4n)), but don't have ZPL-templates, you can use this free tool.
|
||||
|
||||
## install
|
||||
|
||||
1. [install Golang](https://golang.org/doc/install)
|
||||
1. `go install simonwaldherr.de/go/zplgfa/cmd/zplgfa`
|
||||
|
||||
## usage
|
||||
|
||||
So if your image file is `label.png` and the IP of your printer is `192.168.178.42` you can print via this command:
|
||||
|
||||
```sh
|
||||
./zplgfa -file label.png | nc 192.168.178.42 9100
|
||||
```
|
||||
|
||||
You can also use some effects, e.g. blur:
|
||||
|
||||
```sh
|
||||
./zplgfa -file label.png -edit blur | nc 192.168.178.42 9100
|
||||
```
|
||||
|
||||
The ZPLGFA is actually just a demo application for the ZPLGFA package,
|
||||
if you need something for productive work, look at the source and build something, depending on your needs
|
||||
|
||||
## test
|
||||
|
||||
You have your ZPLs, but no ZEBRA printer? You can test almost all ZPL functionality at [labelary.com](http://labelary.com/viewer.html).
|
||||
146
cmd/zplgfa/main.go
Normal file
146
cmd/zplgfa/main.go
Normal file
@@ -0,0 +1,146 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"simonwaldherr.de/go/zplgfa"
|
||||
"flag"
|
||||
"fmt"
|
||||
"github.com/anthonynsimon/bild/blur"
|
||||
"github.com/anthonynsimon/bild/effect"
|
||||
"github.com/anthonynsimon/bild/segment"
|
||||
"github.com/nfnt/resize"
|
||||
"image"
|
||||
"image/color"
|
||||
_ "image/gif"
|
||||
_ "image/jpeg"
|
||||
_ "image/png"
|
||||
"log"
|
||||
"math"
|
||||
"os"
|
||||
"strings"
|
||||
)
|
||||
|
||||
func main() {
|
||||
var filenameFlag string
|
||||
var graphicTypeFlag string
|
||||
var imageEditFlag string
|
||||
var imageResizeFlag float64
|
||||
var graphicType zplgfa.GraphicType
|
||||
|
||||
flag.StringVar(&filenameFlag, "file", "", "filename to convert to zpl")
|
||||
flag.StringVar(&graphicTypeFlag, "type", "CompressedASCII", "type of graphic field encoding")
|
||||
flag.StringVar(&imageEditFlag, "edit", "", "manipulate the image [invert,monochrome]")
|
||||
flag.Float64Var(&imageResizeFlag, "resize", 1.0, "zoom/resize the image")
|
||||
|
||||
// load flag input arguments
|
||||
flag.Parse()
|
||||
|
||||
// open file
|
||||
file, err := os.Open(filenameFlag)
|
||||
if err != nil {
|
||||
log.Printf("Warning: could not open the file \"%s\": %s\n", filenameFlag, err)
|
||||
return
|
||||
}
|
||||
|
||||
defer file.Close()
|
||||
|
||||
// load image head information
|
||||
config, format, err := image.DecodeConfig(file)
|
||||
if err != nil {
|
||||
log.Printf("Warning: image not compatible, format: %s, config: %v, error: %s\n", format, config, err)
|
||||
}
|
||||
|
||||
// reset file pointer to the beginning of the file
|
||||
file.Seek(0, 0)
|
||||
|
||||
// load and decode image
|
||||
img, _, err := image.Decode(file)
|
||||
if err != nil {
|
||||
log.Printf("Warning: could not decode the file, %s\n", err)
|
||||
return
|
||||
}
|
||||
|
||||
// select graphic field type
|
||||
switch graphicTypeFlag {
|
||||
case "ASCII":
|
||||
graphicType = zplgfa.ASCII
|
||||
case "Binary":
|
||||
graphicType = zplgfa.Binary
|
||||
case "CompressedASCII":
|
||||
graphicType = zplgfa.CompressedASCII
|
||||
default:
|
||||
graphicType = zplgfa.CompressedASCII
|
||||
}
|
||||
|
||||
// apply image manipulation functions
|
||||
if strings.Contains(imageEditFlag, "monochrome") {
|
||||
img = editImageMonochrome(img)
|
||||
}
|
||||
if strings.Contains(imageEditFlag, "blur") {
|
||||
img = blur.Gaussian(img, float64(config.Width)/300)
|
||||
}
|
||||
if strings.Contains(imageEditFlag, "edge") {
|
||||
img = effect.Sobel(img)
|
||||
}
|
||||
if strings.Contains(imageEditFlag, "segment") {
|
||||
img = segment.Threshold(img, 128)
|
||||
}
|
||||
if strings.Contains(imageEditFlag, "invert") {
|
||||
img = editImageInvert(img)
|
||||
}
|
||||
|
||||
// resize image
|
||||
if imageResizeFlag != 1.0 {
|
||||
img = resize.Resize(uint(float64(config.Width)*imageResizeFlag), uint(float64(config.Height)*imageResizeFlag), img, resize.MitchellNetravali)
|
||||
}
|
||||
|
||||
// flatten image
|
||||
flat := zplgfa.FlattenImage(img)
|
||||
|
||||
// convert image to zpl compatible type
|
||||
gfimg := zplgfa.ConvertToZPL(flat, graphicType)
|
||||
|
||||
// output zpl with graphic field date to stdout
|
||||
fmt.Println(gfimg)
|
||||
}
|
||||
|
||||
type ImageSet interface {
|
||||
Set(x, y int, c color.Color)
|
||||
}
|
||||
|
||||
func editImageInvert(img image.Image) image.Image {
|
||||
b := img.Bounds()
|
||||
|
||||
imgSet := img.(ImageSet)
|
||||
for y := b.Min.Y; y < b.Max.Y; y++ {
|
||||
for x := b.Min.X; x < b.Max.X; x++ {
|
||||
oldPixel := img.At(x, y)
|
||||
r, g, b, a := oldPixel.RGBA()
|
||||
r = 65535 - r
|
||||
g = 65535 - g
|
||||
b = 65535 - b
|
||||
pixel := color.RGBA{uint8(r), uint8(g), uint8(b), uint8(a)}
|
||||
imgSet.Set(x, y, pixel)
|
||||
}
|
||||
}
|
||||
return img
|
||||
}
|
||||
|
||||
func editImageMonochrome(img image.Image) image.Image {
|
||||
b := img.Bounds()
|
||||
|
||||
imgSet := img.(ImageSet)
|
||||
for y := b.Min.Y; y < b.Max.Y; y++ {
|
||||
for x := b.Min.X; x < b.Max.X; x++ {
|
||||
oldPixel := img.At(x, y)
|
||||
r, g, b, a := oldPixel.RGBA()
|
||||
if r > math.MaxUint16/2 || g > math.MaxUint16/2 || b > math.MaxUint16/2 {
|
||||
r, g, b = 65535, 65535, 65535
|
||||
} else {
|
||||
r, g, b = 0, 0, 0
|
||||
}
|
||||
pixel := color.RGBA{uint8(r), uint8(g), uint8(b), uint8(a)}
|
||||
imgSet.Set(x, y, pixel)
|
||||
}
|
||||
}
|
||||
return img
|
||||
}
|
||||
Reference in New Issue
Block a user