mirror of
https://github.com/zxing/zxing.git
synced 2025-01-12 19:57:27 -08:00
Continue in codeset A when character encoded single number or FNC1-4 in Code128Writer (#1108)
* Continue in code A when character encodes FNC1-4 in Code128Writer * FNC1 in codeset A * Single number also can continue in codeset A
This commit is contained in:
parent
e636498b5e
commit
79bdb2c84e
|
@ -233,18 +233,24 @@ public final class Code128Writer extends OneDimensionalCodeWriter {
|
||||||
private static int chooseCode(CharSequence value, int start, int oldCode) {
|
private static int chooseCode(CharSequence value, int start, int oldCode) {
|
||||||
CType lookahead = findCType(value, start);
|
CType lookahead = findCType(value, start);
|
||||||
if (lookahead == CType.ONE_DIGIT) {
|
if (lookahead == CType.ONE_DIGIT) {
|
||||||
|
if (oldCode == CODE_CODE_A) {
|
||||||
|
return CODE_CODE_A;
|
||||||
|
}
|
||||||
return CODE_CODE_B;
|
return CODE_CODE_B;
|
||||||
}
|
}
|
||||||
if (lookahead == CType.UNCODABLE) {
|
if (lookahead == CType.UNCODABLE) {
|
||||||
if (start < value.length()) {
|
if (start < value.length()) {
|
||||||
char c = value.charAt(start);
|
char c = value.charAt(start);
|
||||||
if (c < ' ' || (oldCode == CODE_CODE_A && c < '`')) {
|
if (c < ' ' || (oldCode == CODE_CODE_A && (c < '`' || (c >= ESCAPE_FNC_1 && c <= ESCAPE_FNC_4)))) {
|
||||||
// can continue in code A, encodes ASCII 0 to 95
|
// can continue in code A, encodes ASCII 0 to 95 or FNC1 to FNC4
|
||||||
return CODE_CODE_A;
|
return CODE_CODE_A;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return CODE_CODE_B; // no choice
|
return CODE_CODE_B; // no choice
|
||||||
}
|
}
|
||||||
|
if (oldCode == CODE_CODE_A && lookahead == CType.FNC_1) {
|
||||||
|
return CODE_CODE_A;
|
||||||
|
}
|
||||||
if (oldCode == CODE_CODE_C) { // can continue in code C
|
if (oldCode == CODE_CODE_C) { // can continue in code C
|
||||||
return CODE_CODE_C;
|
return CODE_CODE_C;
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,8 @@ public class Code128WriterTestCase extends Assert {
|
||||||
private static final String FNC1 = "11110101110";
|
private static final String FNC1 = "11110101110";
|
||||||
private static final String FNC2 = "11110101000";
|
private static final String FNC2 = "11110101000";
|
||||||
private static final String FNC3 = "10111100010";
|
private static final String FNC3 = "10111100010";
|
||||||
private static final String FNC4 = "10111101110";
|
private static final String FNC4A = "11101011110";
|
||||||
|
private static final String FNC4B = "10111101110";
|
||||||
private static final String START_CODE_A = "11010000100";
|
private static final String START_CODE_A = "11010000100";
|
||||||
private static final String START_CODE_B = "11010010000";
|
private static final String START_CODE_B = "11010010000";
|
||||||
private static final String START_CODE_C = "11010011100";
|
private static final String START_CODE_C = "11010011100";
|
||||||
|
@ -44,6 +45,7 @@ public class Code128WriterTestCase extends Assert {
|
||||||
private static final String SWITCH_CODE_B = "10111101110";
|
private static final String SWITCH_CODE_B = "10111101110";
|
||||||
private static final String QUIET_SPACE = "00000";
|
private static final String QUIET_SPACE = "00000";
|
||||||
private static final String STOP = "1100011101011";
|
private static final String STOP = "1100011101011";
|
||||||
|
private static final String LF = "10000110010";
|
||||||
|
|
||||||
private Writer writer;
|
private Writer writer;
|
||||||
private Code128Reader reader;
|
private Code128Reader reader;
|
||||||
|
@ -106,7 +108,7 @@ public class Code128WriterTestCase extends Assert {
|
||||||
public void testEncodeWithFunc4() throws WriterException {
|
public void testEncodeWithFunc4() throws WriterException {
|
||||||
String toEncode = "\u00f4" + "123";
|
String toEncode = "\u00f4" + "123";
|
||||||
// "1" "2" "3" check digit 59
|
// "1" "2" "3" check digit 59
|
||||||
String expected = QUIET_SPACE + START_CODE_B + FNC4 + "10011100110" + "11001110010" + "11001011100" + "11100011010" + STOP + QUIET_SPACE;
|
String expected = QUIET_SPACE + START_CODE_B + FNC4B + "10011100110" + "11001110010" + "11001011100" + "11100011010" + STOP + QUIET_SPACE;
|
||||||
|
|
||||||
BitMatrix result = writer.encode(toEncode, BarcodeFormat.CODE_128, 0, 0);
|
BitMatrix result = writer.encode(toEncode, BarcodeFormat.CODE_128, 0, 0);
|
||||||
|
|
||||||
|
@ -114,6 +116,19 @@ public class Code128WriterTestCase extends Assert {
|
||||||
assertEquals(expected, actual);
|
assertEquals(expected, actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testEncodeWithFncsAndNumberInCodesetA() throws Exception {
|
||||||
|
String toEncode = "\n" + "\u00f1" + "\u00f4" + "1" + "\n";
|
||||||
|
|
||||||
|
String expected = QUIET_SPACE + START_CODE_A + LF + FNC1 + FNC4A + "10011100110" + LF + "10101111000" + STOP + QUIET_SPACE;
|
||||||
|
|
||||||
|
BitMatrix result = writer.encode(toEncode, BarcodeFormat.CODE_128, 0, 0);
|
||||||
|
|
||||||
|
String actual = BitMatrixTestCase.matrixToString(result);
|
||||||
|
|
||||||
|
assertEquals(expected, actual);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testEncodeSwitchBetweenCodesetsAAndB() throws Exception {
|
public void testEncodeSwitchBetweenCodesetsAAndB() throws Exception {
|
||||||
// start with A switch to B and back to A
|
// start with A switch to B and back to A
|
||||||
|
|
Loading…
Reference in a new issue