void _ZINT(int n, unsigned char *s, C_LONGINT &Param2, C_LONGINT &Param3, C_TEXT &Param4, ARRAY_LONGINT &Param5, C_TEXT &returnValue) { zint_symbol *sym = ZBarcode_Create(); if(sym){ sym->input_mode = UNICODE_MODE; sym->symbology = Param2.getIntValue(); if(Param5.getSize() > 1) sym->option_1 = Param5.getIntValueAtIndex(1); if(Param5.getSize() > 2) sym->option_2 = Param5.getIntValueAtIndex(2); if(Param5.getSize() > 3) sym->option_3 = Param5.getIntValueAtIndex(3); sym->show_hrt = 0; //no text #ifdef DEBUG sym->output_options = BARCODE_STDOUT; strncpy(sym->outfile, "dummy.txt", 10); #endif int err = ZBarcode_Encode(sym, s, n); if(!err){ #ifdef DEBUG err = ZBarcode_Print(sym, 0); #endif err = ZBarcode_Buffer(sym, 0); if(!err){ switch (Param3.getIntValue()) { case 1: _convertToSVG(sym, returnValue); break; default: _convertToText(sym, returnValue); break; } } }else{ CUTF8String err = (const uint8_t *)sym->errtxt; Param4.setUTF8String(&err); } ZBarcode_Delete(sym); } }
bool QZint::save_to_file(QString filename) { if (m_zintSymbol) ZBarcode_Delete(m_zintSymbol); QString fg_colour_hash = m_fgColor.name(); QString bg_colour_hash = m_bgColor.name(); m_lastError.clear(); m_zintSymbol = ZBarcode_Create(); m_zintSymbol->output_options=m_border; m_zintSymbol->symbology=m_symbol; m_zintSymbol->height=m_height; m_zintSymbol->whitespace_width=m_whitespace; m_zintSymbol->border_width=m_borderWidth; m_zintSymbol->option_1=m_securityLevel; m_zintSymbol->input_mode = m_input_mode; m_zintSymbol->option_2=m_width; if(m_hidetext) { m_zintSymbol->show_hrt = 0; } else { m_zintSymbol->show_hrt = 1; } if(m_symbol == BARCODE_PDF417) { m_zintSymbol->option_3=m_pdf417CodeWords; } else { m_zintSymbol->option_3 = m_option_3; } m_zintSymbol->scale=m_scale; QByteArray bstr=m_text.toUtf8(); QByteArray pstr=m_primaryMessage.left(99).toLatin1(); QByteArray fstr=filename.left(255).toLatin1(); strcpy(m_zintSymbol->primary,pstr.data()); strcpy(m_zintSymbol->outfile,fstr.data()); QByteArray fgcol=fg_colour_hash.right(6).toLatin1(); QByteArray bgcol=bg_colour_hash.right(6).toLatin1(); strcpy(m_zintSymbol->fgcolour,fgcol.data()); strcpy(m_zintSymbol->bgcolour,bgcol.data()); int error = ZBarcode_Encode(m_zintSymbol, (unsigned char*)bstr.data(), bstr.length()); if (error > WARN_INVALID_OPTION) m_lastError=m_zintSymbol->errtxt; error = ZBarcode_Print(m_zintSymbol, 0); if (error > WARN_INVALID_OPTION) m_lastError=m_zintSymbol->errtxt; if(error == 0) { return true; } else { return false; } }
void QZint::encode() { if (m_zintSymbol) ZBarcode_Delete(m_zintSymbol); m_lastError.clear(); m_zintSymbol = ZBarcode_Create(); m_zintSymbol->output_options=m_border; m_zintSymbol->symbology=m_symbol; m_zintSymbol->height=m_height; m_zintSymbol->whitespace_width=m_whitespace; m_zintSymbol->border_width=m_borderWidth; m_zintSymbol->option_1=m_securityLevel; m_zintSymbol->input_mode = m_input_mode; m_zintSymbol->option_2=m_width; if(m_hidetext) { m_zintSymbol->show_hrt = 0; } else { m_zintSymbol->show_hrt = 1; } if(m_symbol == BARCODE_PDF417) { m_zintSymbol->option_3=m_pdf417CodeWords; } else { m_zintSymbol->option_3 = m_option_3; } QByteArray bstr=m_text.toUtf8(); QByteArray pstr=m_primaryMessage.left(99).toLatin1(); strcpy(m_zintSymbol->primary,pstr.data()); int error = ZBarcode_Encode(m_zintSymbol, (unsigned char*)bstr.data(), bstr.length()); if (error > WARN_INVALID_OPTION) m_lastError=m_zintSymbol->errtxt; if (m_zintSymbol->symbology == BARCODE_MAXICODE) m_zintSymbol->height = 33; switch(m_zintSymbol->output_options) { case 0: m_border = NO_BORDER; break; case 2: m_border = BIND; break; case 4: m_border = BOX; break; } m_borderWidth = (BorderType)m_zintSymbol->border_width; m_whitespace = m_zintSymbol->whitespace_width; }
static gchar * create_serial_barcode (const gchar *serial) { gchar *savefile; const gchar *cache_dir; struct zint_symbol *barcode; cache_dir = g_get_user_cache_dir (); /* Create the directory if it's missing */ g_mkdir_with_parents (cache_dir, 0755); savefile = g_build_filename (cache_dir, "product_serial.png", NULL); barcode = ZBarcode_Create(); strncpy ((char *) barcode->outfile, savefile, 4096); if (ZBarcode_Encode_and_Print (barcode, (guchar *) serial, 0, 0)) { g_warning ("Error while generating barcode: %s", barcode->errtxt); } ZBarcode_Delete (barcode); return savefile; }
QZint::~QZint() { if (m_zintSymbol) ZBarcode_Delete(m_zintSymbol); }
lglBarcode * gl_barcode_zint_new (const gchar *id, gboolean text_flag, gboolean checksum_flag, gdouble w, gdouble h, const gchar *digits) { lglBarcode *gbc; struct zint_symbol *symbol; gint result; symbol = ZBarcode_Create(); /* Auto set to default size */ if ( (w == 0) && (h == 0) ) { w = DEFAULT_W; h = DEFAULT_H; } /* Assign type flag. Pre-filter by length for subtypes. */ if (g_ascii_strcasecmp (id, "AUSP") == 0) { symbol->symbology = BARCODE_AUSPOST; } if (g_ascii_strcasecmp (id, "AUSRP") == 0) { symbol->symbology = BARCODE_AUSREPLY; } if (g_ascii_strcasecmp (id, "AUSRT") == 0) { symbol->symbology = BARCODE_AUSROUTE; } if (g_ascii_strcasecmp (id, "AUSRD") == 0) { symbol->symbology = BARCODE_AUSREDIRECT; } if (g_ascii_strcasecmp (id, "AZTEC") == 0) { symbol->symbology = BARCODE_AZTEC; } if (g_ascii_strcasecmp (id, "AZRUN") == 0) { symbol->symbology = BARCODE_AZRUNE; } if (g_ascii_strcasecmp (id, "CBR") == 0) { symbol->symbology = BARCODE_CODABAR; } if (g_ascii_strcasecmp (id, "Code1") == 0) { symbol->symbology = BARCODE_CODEONE; } if (g_ascii_strcasecmp (id, "Code11") == 0) { symbol->symbology = BARCODE_CODE11; } if (g_ascii_strcasecmp (id, "C16K") == 0) { symbol->symbology = BARCODE_CODE16K; } if (g_ascii_strcasecmp (id, "C25M") == 0) { symbol->symbology = BARCODE_C25MATRIX; } if (g_ascii_strcasecmp (id, "C25I") == 0) { symbol->symbology = BARCODE_C25IATA; } if (g_ascii_strcasecmp (id, "C25DL") == 0) { symbol->symbology = BARCODE_C25LOGIC; } if (g_ascii_strcasecmp (id, "Code32") == 0) { symbol->symbology = BARCODE_CODE32; } if (g_ascii_strcasecmp (id, "Code39") == 0) { symbol->symbology = BARCODE_CODE39; } if (g_ascii_strcasecmp (id, "Code39E") == 0) { symbol->symbology = BARCODE_EXCODE39; } if (g_ascii_strcasecmp (id, "Code49") == 0) { symbol->symbology = BARCODE_CODE49; } if (g_ascii_strcasecmp (id, "Code93") == 0) { symbol->symbology = BARCODE_CODE93; } if (g_ascii_strcasecmp (id, "Code128") == 0) { symbol->symbology = BARCODE_CODE128; } if (g_ascii_strcasecmp (id, "Code128B") == 0) { symbol->symbology = BARCODE_CODE128B; } if (g_ascii_strcasecmp (id, "DAFT") == 0) { symbol->symbology = BARCODE_DAFT; } if (g_ascii_strcasecmp (id, "DMTX") == 0) { symbol->symbology = BARCODE_DATAMATRIX; } if (g_ascii_strcasecmp (id, "DPL") == 0) { symbol->symbology = BARCODE_DPLEIT; } if (g_ascii_strcasecmp (id, "DPI") == 0) { symbol->symbology = BARCODE_DPIDENT; } if (g_ascii_strcasecmp (id, "KIX") == 0) { symbol->symbology = BARCODE_KIX; } if (g_ascii_strcasecmp (id, "EAN") == 0) { symbol->symbology = BARCODE_EANX; } if (g_ascii_strcasecmp (id, "HIBC128") == 0) { symbol->symbology = BARCODE_HIBC_128; } if (g_ascii_strcasecmp (id, "HIBC39") == 0) { symbol->symbology = BARCODE_HIBC_39; } if (g_ascii_strcasecmp (id, "HIBCDM") == 0) { symbol->symbology = BARCODE_HIBC_DM; } if (g_ascii_strcasecmp (id, "HIBCQR") == 0) { symbol->symbology = BARCODE_HIBC_QR; } if (g_ascii_strcasecmp (id, "HIBCPDF") == 0) { symbol->symbology = BARCODE_HIBC_MICPDF; } if (g_ascii_strcasecmp (id, "HIBCMPDF") == 0) { symbol->symbology = BARCODE_HIBC_AZTEC; } if (g_ascii_strcasecmp (id, "HIBCAZ") == 0) { symbol->symbology = BARCODE_C25INTER; } if (g_ascii_strcasecmp (id, "I25") == 0) { symbol->symbology = BARCODE_C25INTER; } if (g_ascii_strcasecmp (id, "ISBN") == 0) { symbol->symbology = BARCODE_ISBNX; } if (g_ascii_strcasecmp (id, "ITF14") == 0) { symbol->symbology = BARCODE_ITF14; } if (g_ascii_strcasecmp (id, "GMTX") == 0) { symbol->symbology = BARCODE_GRIDMATRIX; } if (g_ascii_strcasecmp (id, "GS1-128") == 0) { symbol->symbology = BARCODE_EAN128; } if (g_ascii_strcasecmp (id, "LOGM") == 0) { symbol->symbology = BARCODE_LOGMARS; } if (g_ascii_strcasecmp (id, "RSS14") == 0) { symbol->symbology = BARCODE_RSS14; } if (g_ascii_strcasecmp (id, "RSSLTD") == 0) { symbol->symbology = BARCODE_RSS_LTD; } if (g_ascii_strcasecmp (id, "RSSEXP") == 0) { symbol->symbology = BARCODE_RSS_EXP; } if (g_ascii_strcasecmp (id, "RSSS") == 0) { symbol->symbology = BARCODE_RSS14STACK; } if (g_ascii_strcasecmp (id, "RSSSO") == 0) { symbol->symbology = BARCODE_RSS14STACK_OMNI; } if (g_ascii_strcasecmp (id, "RSSSE") == 0) { symbol->symbology = BARCODE_RSS_EXPSTACK; } if (g_ascii_strcasecmp (id, "PHARMA") == 0) { symbol->symbology = BARCODE_PHARMA; } if (g_ascii_strcasecmp (id, "PHARMA2") == 0) { symbol->symbology = BARCODE_PHARMA_TWO; } if (g_ascii_strcasecmp (id, "PZN") == 0) { symbol->symbology = BARCODE_PZN; } if (g_ascii_strcasecmp (id, "TELE") == 0) { symbol->symbology = BARCODE_TELEPEN; } if (g_ascii_strcasecmp (id, "TELEX") == 0) { symbol->symbology = BARCODE_TELEPEN_NUM; } if (g_ascii_strcasecmp (id, "JAPAN") == 0) { symbol->symbology = BARCODE_JAPANPOST; } if (g_ascii_strcasecmp (id, "KOREA") == 0) { symbol->symbology = BARCODE_KOREAPOST; } if (g_ascii_strcasecmp (id, "MAXI") == 0) { symbol->symbology = BARCODE_MAXICODE; } if (g_ascii_strcasecmp (id, "MPDF") == 0) { symbol->symbology = BARCODE_MICROPDF417; } if (g_ascii_strcasecmp (id, "MSI") == 0) { symbol->symbology = BARCODE_MSI_PLESSEY; } if (g_ascii_strcasecmp (id, "MQR") == 0) { symbol->symbology = BARCODE_MICROQR; } if (g_ascii_strcasecmp (id, "NVE") == 0) { symbol->symbology = BARCODE_NVE18; } if (g_ascii_strcasecmp (id, "PLAN") == 0) { symbol->symbology = BARCODE_PLANET; } if (g_ascii_strcasecmp (id, "POSTNET") == 0) { symbol->symbology = BARCODE_POSTNET; } if (g_ascii_strcasecmp (id, "PDF") == 0) { symbol->symbology = BARCODE_PDF417; } if (g_ascii_strcasecmp (id, "PDFT") == 0) { symbol->symbology = BARCODE_PDF417TRUNC; } if (g_ascii_strcasecmp (id, "QR") == 0) { symbol->symbology = BARCODE_QRCODE; } if (g_ascii_strcasecmp (id, "RM4") == 0) { symbol->symbology = BARCODE_RM4SCC; } if (g_ascii_strcasecmp (id, "UPC-A") == 0) { symbol->symbology = BARCODE_UPCA; } if (g_ascii_strcasecmp (id, "UPC-E") == 0) { symbol->symbology = BARCODE_UPCE; } if (g_ascii_strcasecmp (id, "USPS") == 0) { symbol->symbology = BARCODE_ONECODE; } if (g_ascii_strcasecmp (id, "PLS") == 0) { symbol->symbology = BARCODE_PLESSEY; } result = ZBarcode_Encode(symbol, (unsigned char *)digits, 0); if (result) { gl_debug (DEBUG_BARCODE, "Zint Error: %s", symbol->errtxt); ZBarcode_Delete (symbol); return NULL; } if(!text_flag) { symbol->show_hrt = 0; } if (!ZBarcode_Render(symbol, (float) w, (float) h)) { g_message("Zint Rendering Error: %s", symbol->errtxt); ZBarcode_Delete(symbol); return NULL; } /* Convert Sums provided by zint encode */ gbc = render_zint(symbol, text_flag); ZBarcode_Delete(symbol); return gbc; }
int main(int argc, char **argv) { struct zint_symbol *my_symbol; int c; int error_number; int rotate_angle; int generated; int batch_mode; error_number = 0; rotate_angle = 0; generated = 0; my_symbol = ZBarcode_Create(); my_symbol->input_mode = UNICODE_MODE; batch_mode = 0; if(argc == 1) die(help_usage); while(1) { int option_index = 0; static struct option long_options[] = { {"help", 0, 0, 'h'}, {"types", 0, 0, 't'}, {"bind", 0, 0, 0}, {"box", 0, 0, 0}, {"directeps", 0, 0, 0}, {"directpdf", 0, 0, 0}, {"directpng", 0, 0, 0}, {"directsvg", 0, 0, 0}, {"dump", 0, 0, 0}, {"barcode", 1, 0, 'b'}, {"height", 1, 0, 0}, {"whitesp", 1, 0, 'w'}, {"border", 1, 0, 0}, {"data", 1, 0, 'd'}, {"output", 1, 0, 'o'}, {"input", 1, 0, 'i'}, {"fg", 1, 0, 0}, {"bg", 1, 0, 0}, {"cols", 1, 0, 0}, {"vers", 1, 0, 0}, {"rotate", 1, 0, 0}, {"secure", 1, 0, 0}, {"reverse", 1, 0, 'r'}, {"mode", 1, 0, 0}, {"primary", 1, 0, 0}, {"scale", 1, 0, 0}, {"gs1", 0, 0, 0}, {"kanji", 0, 0, 0}, {"sjis", 0, 0, 0}, {"binary", 0, 0, 0}, {"notext", 0, 0, 0}, {"square", 0, 0, 0}, {"init", 0, 0, 0}, {"smalltext", 0, 0, 0}, {"batch", 0, 0, 0}, {0, 0, 0, 0} }; c = getopt_long(argc, argv, "htb:w:d:o:i:rcmp", long_options, &option_index); if(c == -1) break; switch(c) { case 0: if(!strcmp(long_options[option_index].name, "bind")) { my_symbol->output_options += BARCODE_BIND; } if(!strcmp(long_options[option_index].name, "box")) { my_symbol->output_options += BARCODE_BOX; } if(!strcmp(long_options[option_index].name, "init")) { my_symbol->output_options += READER_INIT; } if(!strcmp(long_options[option_index].name, "smalltext")) { my_symbol->output_options += SMALL_TEXT; } if(!strcmp(long_options[option_index].name, "directeps")) { my_symbol->output_options += BARCODE_STDOUT; strncpy(my_symbol->outfile, "dummy.eps", 10); } if(!strcmp(long_options[option_index].name, "directpdf")) { my_symbol->output_options += BARCODE_STDOUT; strncpy(my_symbol->outfile, "dummy.pdf", 10); } if(!strcmp(long_options[option_index].name, "directpng")) { my_symbol->output_options += BARCODE_STDOUT; strncpy(my_symbol->outfile, "dummy.png", 10); } if(!strcmp(long_options[option_index].name, "directsvg")) { my_symbol->output_options += BARCODE_STDOUT; strncpy(my_symbol->outfile, "dummy.svg", 10); } if(!strcmp(long_options[option_index].name, "dump")) { my_symbol->output_options += BARCODE_STDOUT; strncpy(my_symbol->outfile, "dummy.txt", 10); } if(!strcmp(long_options[option_index].name, "gs1")) { my_symbol->input_mode = GS1_MODE; } if(!strcmp(long_options[option_index].name, "kanji")) { my_symbol->input_mode = KANJI_MODE; } if(!strcmp(long_options[option_index].name, "sjis")) { my_symbol->input_mode = SJIS_MODE; } if(!strcmp(long_options[option_index].name, "binary")) { my_symbol->input_mode = DATA_MODE; } if(!strcmp(long_options[option_index].name, "fg")) { strncpy(my_symbol->fgcolour, optarg, 7); } if(!strcmp(long_options[option_index].name, "bg")) { strncpy(my_symbol->bgcolour, optarg, 7); } if(!strcmp(long_options[option_index].name, "notext")) { my_symbol->show_hrt = 0; } if(!strcmp(long_options[option_index].name, "square")) { my_symbol->option_3 = DM_SQUARE; } if(!strcmp(long_options[option_index].name, "scale")) { my_symbol->scale = (float)(atof(optarg)); if(my_symbol->scale < 0.01) { /* Zero and negative values are not permitted */ fprintf(stderr, "Invalid scale value\n"); my_symbol->scale = 1.0; } } if(!strcmp(long_options[option_index].name, "border")) { error_number = validator(NESET, optarg); if(error_number == ZERROR_INVALID_DATA) die("Invalid border width\n"); if((atoi(optarg) >= 0) && (atoi(optarg) <= 1000)) { my_symbol->border_width = atoi(optarg); } else { fprintf(stderr, "Border width out of range\n"); } } if(!strcmp(long_options[option_index].name, "height")) { error_number = validator(NESET, optarg); if(error_number == ZERROR_INVALID_DATA) die("Invalid symbol height\n"); if((atoi(optarg) >= 1) && (atoi(optarg) <= 1000)) { my_symbol->height = atoi(optarg); } else { fprintf(stderr, "Symbol height out of range\n"); } } if(!strcmp(long_options[option_index].name, "cols")) { if((atoi(optarg) >= 1) && (atoi(optarg) <= 30)) { my_symbol->option_2 = atoi(optarg); } else { fprintf(stderr, "Number of columns out of range\n"); } } if(!strcmp(long_options[option_index].name, "vers")) { if((atoi(optarg) >= 1) && (atoi(optarg) <= 40)) { my_symbol->option_2 = atoi(optarg); } else { fprintf(stderr, "Invalid QR Code version\n"); } } if(!strcmp(long_options[option_index].name, "secure")) { if((atoi(optarg) >= 1) && (atoi(optarg) <= 8)) { my_symbol->option_1 = atoi(optarg); } else { fprintf(stderr, "ECC level out of range\n"); } } if(!strcmp(long_options[option_index].name, "primary")) { if(strlen(optarg) <= 90) { strcpy(my_symbol->primary, optarg); } else { fprintf(stderr, "Primary data string too long"); } } if(!strcmp(long_options[option_index].name, "mode")) { if((optarg[0] >= '0') && (optarg[0] <= '6')) { my_symbol->option_1 = optarg[0] - '0'; } else { fprintf(stderr, "Invalid mode\n"); } } if(!strcmp(long_options[option_index].name, "rotate")) { /* Only certain inputs allowed */ error_number = validator(NESET, optarg); if(error_number == ZERROR_INVALID_DATA) die("Invalid rotation parameter\n"); switch(atoi(optarg)) { case 90: rotate_angle = 90; break; case 180: rotate_angle = 180; break; case 270: rotate_angle = 270; break; default: rotate_angle = 0; break; } } if(!strcmp(long_options[option_index].name, "batch")) { /* Switch to batch processing mode */ batch_mode = 1; } break; case 'h': die(help_usage); case 't': die(help_types); case 'b': error_number = validator(NESET, optarg); if (error_number == ZERROR_INVALID_DATA) die("Invalid barcode type\n"); my_symbol->symbology = atoi(optarg); break; case 'w': error_number = validator(NESET, optarg); if (error_number == ZERROR_INVALID_DATA) die("Invalid whitespace value\n"); if((atoi(optarg) >= 0) && (atoi(optarg) <= 1000)) { my_symbol->whitespace_width = atoi(optarg); } else { fprintf(stderr, "Whitespace value out of range"); } break; case 'd': /* we have some data! */ if(batch_mode == 0) { error_number = escape_char_process(my_symbol, (unsigned char*)optarg, strlen(optarg)); if(error_number == 0) { error_number = ZBarcode_Print(my_symbol, rotate_angle); } generated = 1; if(error_number != 0) { fprintf(stderr, "%s\n", my_symbol->errtxt); ZBarcode_Delete(my_symbol); return 1; } } else { fprintf(stderr, "Cannot define data in batch mode"); } break; case 'i': /* Take data from file */ if(batch_mode == 0) { error_number = ZBarcode_Encode_File(my_symbol, optarg); if(error_number == 0) { error_number = ZBarcode_Print(my_symbol, rotate_angle); } generated = 1; if(error_number != 0) { fprintf(stderr, "%s\n", my_symbol->errtxt); ZBarcode_Delete(my_symbol); return 1; } } else { /* Take each line of text as a separate data set */ error_number = batch_process(my_symbol, optarg); generated = 1; if(error_number != 0) { fprintf(stderr, "%s\n", my_symbol->errtxt); ZBarcode_Delete(my_symbol); return 1; } } break; case 'o': strncpy(my_symbol->outfile, optarg, 250); break; case 'r': strcpy(my_symbol->fgcolour, "ffffff"); strcpy(my_symbol->bgcolour, "000000"); break; case '?': break; default: fprintf(stderr, "?? getopt error 0%o\n", c); } } if (optind < argc) { fprintf(stderr, "Invalid option "); while (optind < argc) fprintf(stderr, "%s", argv[optind++]); fprintf(stderr, "\n"); } if(generated == 0) { fprintf(stderr, "error: No data received, no symbol generated\n"); } ZBarcode_Delete(my_symbol); return error_number; }