fixed code128 and added some tests
This commit is contained in:
parent
b1ca18cc4c
commit
ea51d46359
|
@ -43,7 +43,11 @@ func getCodeIndexList(content []rune) *utils.BitList {
|
||||||
|
|
||||||
if shouldUseCTable(content[i:], curEncoding) {
|
if shouldUseCTable(content[i:], curEncoding) {
|
||||||
if curEncoding != startCSymbol {
|
if curEncoding != startCSymbol {
|
||||||
result.AddByte(startCSymbol)
|
if curEncoding == byte(0) {
|
||||||
|
result.AddByte(startCSymbol)
|
||||||
|
} else {
|
||||||
|
result.AddByte(codeCSymbol)
|
||||||
|
}
|
||||||
curEncoding = startCSymbol
|
curEncoding = startCSymbol
|
||||||
}
|
}
|
||||||
idx := (content[i] - '0') * 10
|
idx := (content[i] - '0') * 10
|
||||||
|
@ -53,24 +57,45 @@ func getCodeIndexList(content []rune) *utils.BitList {
|
||||||
result.AddByte(byte(idx))
|
result.AddByte(byte(idx))
|
||||||
} else {
|
} else {
|
||||||
if curEncoding != startBSymbol {
|
if curEncoding != startBSymbol {
|
||||||
result.AddByte(startBSymbol)
|
if curEncoding == byte(0) {
|
||||||
|
result.AddByte(startBSymbol)
|
||||||
|
} else {
|
||||||
|
result.AddByte(codeBSymbol)
|
||||||
|
}
|
||||||
curEncoding = startBSymbol
|
curEncoding = startBSymbol
|
||||||
}
|
}
|
||||||
idx := strings.IndexRune(bTable, content[i])
|
var idx int
|
||||||
|
switch content[i] {
|
||||||
|
case FNC1:
|
||||||
|
idx = 102
|
||||||
|
break
|
||||||
|
case FNC2:
|
||||||
|
idx = 97
|
||||||
|
break
|
||||||
|
case FNC3:
|
||||||
|
idx = 96
|
||||||
|
break
|
||||||
|
case FNC4:
|
||||||
|
idx = 100
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
idx = strings.IndexRune(bTable, content[i])
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
if idx < 0 {
|
if idx < 0 {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
result.AddByte(byte(idx))
|
result.AddByte(byte(idx))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fmt.Println(result.GetBytes())
|
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
||||||
// Encode creates a Code 128 barcode for the given content
|
// Encode creates a Code 128 barcode for the given content
|
||||||
func Encode(content string) (barcode.Barcode, error) {
|
func Encode(content string) (barcode.Barcode, error) {
|
||||||
contentRunes := strToRunes(content)
|
contentRunes := strToRunes(content)
|
||||||
if len(contentRunes) < 0 || len(contentRunes) > 80 {
|
if len(contentRunes) <= 0 || len(contentRunes) > 80 {
|
||||||
return nil, fmt.Errorf("content length should be between 1 and 80 runes but got %d", len(contentRunes))
|
return nil, fmt.Errorf("content length should be between 1 and 80 runes but got %d", len(contentRunes))
|
||||||
}
|
}
|
||||||
idxList := getCodeIndexList(contentRunes)
|
idxList := getCodeIndexList(contentRunes)
|
||||||
|
|
|
@ -0,0 +1,51 @@
|
||||||
|
package code128
|
||||||
|
|
||||||
|
import (
|
||||||
|
"image/color"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func testEncode(t *testing.T, txt, testResult string) {
|
||||||
|
code, err := Encode(txt)
|
||||||
|
if err != nil || code == nil {
|
||||||
|
t.Error(err)
|
||||||
|
} else {
|
||||||
|
if code.Bounds().Max.X != len(testResult) {
|
||||||
|
t.Errorf("%v: length missmatch", txt)
|
||||||
|
} else {
|
||||||
|
for i, r := range testResult {
|
||||||
|
if (code.At(i, 0) == color.Black) != (r == '1') {
|
||||||
|
t.Errorf("%v: code missmatch on position %d", txt, i)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func Test_EncodeFunctionChars(t *testing.T) {
|
||||||
|
encFNC1 := "11110101110"
|
||||||
|
encFNC2 := "11110101000"
|
||||||
|
encFNC3 := "10111100010"
|
||||||
|
encFNC4 := "10111101110"
|
||||||
|
encStartB := "11010010000"
|
||||||
|
encStop := "1100011101011"
|
||||||
|
|
||||||
|
testEncode(t, string(FNC1)+"123", encStartB+encFNC1+"10011100110"+"11001110010"+"11001011100"+"11001000010"+encStop)
|
||||||
|
testEncode(t, string(FNC2)+"123", encStartB+encFNC2+"10011100110"+"11001110010"+"11001011100"+"11100010110"+encStop)
|
||||||
|
testEncode(t, string(FNC3)+"123", encStartB+encFNC3+"10011100110"+"11001110010"+"11001011100"+"11101000110"+encStop)
|
||||||
|
testEncode(t, string(FNC4)+"123", encStartB+encFNC4+"10011100110"+"11001110010"+"11001011100"+"11100011010"+encStop)
|
||||||
|
}
|
||||||
|
|
||||||
|
func Test_Unencodable(t *testing.T) {
|
||||||
|
if _, err := Encode(""); err == nil {
|
||||||
|
t.Fail()
|
||||||
|
}
|
||||||
|
if _, err := Encode("ä"); err == nil {
|
||||||
|
t.Fail()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func Test_EncodeCTable(t *testing.T) {
|
||||||
|
testEncode(t, "HI345678H", "110100100001100010100011000100010101110111101000101100011100010110110000101001011110111011000101000111011000101100011101011")
|
||||||
|
testEncode(t, "334455", "11010011100101000110001000110111011101000110100100111101100011101011")
|
||||||
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
package code128
|
package code128
|
||||||
|
|
||||||
var encodingTable [107][]bool = [107][]bool{
|
var encodingTable = [107][]bool{
|
||||||
[]bool{true, true, false, true, true, false, false, true, true, false, false},
|
[]bool{true, true, false, true, true, false, false, true, true, false, false},
|
||||||
[]bool{true, true, false, false, true, true, false, true, true, false, false},
|
[]bool{true, true, false, false, true, true, false, true, true, false, false},
|
||||||
[]bool{true, true, false, false, true, true, false, false, true, true, false},
|
[]bool{true, true, false, false, true, true, false, false, true, true, false},
|
||||||
|
@ -110,9 +110,24 @@ var encodingTable [107][]bool = [107][]bool{
|
||||||
[]bool{true, true, false, false, false, true, true, true, false, true, false, true, true},
|
[]bool{true, true, false, false, false, true, true, true, false, true, false, true, true},
|
||||||
}
|
}
|
||||||
|
|
||||||
const startASymbol byte = 103
|
// const startASymbol byte = 103
|
||||||
const startBSymbol byte = 104
|
const startBSymbol byte = 104
|
||||||
const startCSymbol byte = 105
|
const startCSymbol byte = 105
|
||||||
|
|
||||||
|
const codeBSymbol byte = 100
|
||||||
|
const codeCSymbol byte = 99
|
||||||
|
|
||||||
const stopSymbol byte = 106
|
const stopSymbol byte = 106
|
||||||
|
|
||||||
|
const (
|
||||||
|
// FNC1 - Special Function 1
|
||||||
|
FNC1 = '\u00f1'
|
||||||
|
// FNC2 - Special Function 2
|
||||||
|
FNC2 = '\u00f2'
|
||||||
|
// FNC3 - Special Function 3
|
||||||
|
FNC3 = '\u00f3'
|
||||||
|
// FNC4 - Special Function 4
|
||||||
|
FNC4 = '\u00f4'
|
||||||
|
)
|
||||||
|
|
||||||
const bTable = " !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~"
|
const bTable = " !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~"
|
||||||
|
|
Loading…
Reference in New Issue