亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? dmtxencode.c

?? data matrix 生成、解析、攝像頭自動識別源碼
?? C
字號:
/*libdmtx - Data Matrix Encoding/Decoding LibraryCopyright (C) 2006 Mike LaughtonThis library is free software; you can redistribute it and/ormodify it under the terms of the GNU Lesser General PublicLicense as published by the Free Software Foundation; eitherversion 2.1 of the License, or (at your option) any later version.This library is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNULesser General Public License for more details.You should have received a copy of the GNU Lesser General PublicLicense along with this library; if not, write to the Free SoftwareFoundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USAContact: mike@dragonflylogic.com*//* $Id: dmtxencode.c,v 1.5 2006/10/12 20:49:40 mblaughton Exp $ *//** * * @param XXX * @return XXX */extern DmtxEncode *dmtxEncodeCreate(void){   DmtxEncode *encode;   encode = (DmtxEncode *)malloc(sizeof(DmtxEncode));   if(encode == NULL)      exit(3);   memset(encode, 0x00, sizeof(DmtxEncode));   encode->scheme = DMTX_ENCODING_AUTO;   encode->moduleSize = 5;   encode->marginSize = 10;   // This can be cleaned up later   encode->matrix.gradient.isDefined = DMTX_TRUE;   // Initialize background color to white   encode->matrix.gradient.ray.p.R = 255.0;   encode->matrix.gradient.ray.p.G = 255.0;   encode->matrix.gradient.ray.p.B = 255.0;   // Initialize foreground color to black   encode->matrix.gradient.tMin = 0.0;   encode->matrix.gradient.tMax = dmtxColor3Mag(&(encode->matrix.gradient.ray.p));   encode->matrix.gradient.tMid = (encode->matrix.gradient.tMin + encode->matrix.gradient.tMax)/2.0;   dmtxColor3Scale(&(encode->matrix.gradient.ray.c),         &(encode->matrix.gradient.ray.p), -1.0/encode->matrix.gradient.tMax);   dmtxMatrix3Identity(encode->xfrm);   return encode;}/** * * @param XXX * @return XXX */extern voiddmtxEncodeDestroy(DmtxEncode **encode){   if(*encode == NULL)      return;   dmtxImageDeInit(&((*encode)->image));   free(*encode);   *encode = NULL;}/** * * @param XXX * @return XXX */extern intdmtxEncodeData(DmtxEncode *encode, unsigned char *inputString){   // Analyze data stream for encoding type   // Insert additional codewords to switch between more efficient encoding schemes   EncodeText(&(encode->matrix), inputString);   // Add pad characters to fill out required number of codewords   // If matrix size is not specified then choose the smallest size that accomodates data   AddPadChars(&(encode->matrix));   // Generate error correction codewords   GenReedSolEcc(&(encode->matrix));   // Allocate storage for pattern   PatternInit(&(encode->matrix));   // Module placement in matrix   ModulePlacementEcc200(&(encode->matrix));   // Allocate memory for the image to be generated   encode->image.width = (2 * encode->marginSize) + (encode->matrix.dataCols + 2) * encode->moduleSize;   encode->image.height = (2 * encode->marginSize) + (encode->matrix.dataRows + 2) * encode->moduleSize;   encode->image.pxl = (DmtxPixel *)malloc(encode->image.width * encode->image.height * sizeof(DmtxPixel));   if(encode->image.pxl == NULL) {      perror("malloc error");      exit(2);   }   // Insert aligment pattern modules (if any)   // Insert finder pattern modules   PrintPattern(encode);   // Clean up   dmtxMatrixRegionDeInit(&(encode->matrix));   return DMTX_SUCCESS;}/** * * @param XXX * @return XXX */static voidEncodeText(DmtxMatrixRegion *matrixRegion, unsigned char *inputText){   unsigned char *rangeStart, *ptr;   unsigned char *codewordPtr;   unsigned char buf[1024];   int unpaddedDataSize;   /* initial implementation: latching to new encodation scheme becomes    * justified when latching overhead is offset by benefit as compared to    * staying with basic ASCII.  Question: If switching from one non-ASCII    * scheme to another non-ASCII scheme do I have to switch back to ASCII    * and then to the new one?  Or instead can I switch directly to the new    * scheme.    *    * In any event, depending on the answer to that question, it might make    * sense in the future to weigh latching benefit as compared to CURRENT    * encodation scheme.    */   // XXX first read into a big buffer   memset(buf, 0x00, 1024);   fprintf(stdout, "\ninput:   \"%s\"", inputText);   rangeStart = ptr = inputText;   codewordPtr = buf;   do {      if(isdigit(*ptr) && isdigit(*rangeStart)) {         ptr++;      }      else {         // If there are more than 2 characters of digits then write them (even number)         if(ptr - rangeStart > 1) {            rangeStart = ptr = WriteAscii2Digit(&codewordPtr, rangeStart, ptr - 1);         }         // And then write the remaining characters as straight ASCII         else {            rangeStart = ptr = WriteAsciiChar(&codewordPtr, rangeStart);         }      }   } while(*rangeStart != '\0');   unpaddedDataSize = codewordPtr - buf;   // Loop determines matrix size and data/error counts   for(matrixRegion->sizeIdx = 0; matrixRegion->sizeIdx < 24; matrixRegion->sizeIdx++) {      if(dataWordLength[matrixRegion->sizeIdx] >= unpaddedDataSize)         break;   }   matrixRegion->padSize = dataWordLength[matrixRegion->sizeIdx] - unpaddedDataSize;   matrixRegion->codeSize = dataWordLength[matrixRegion->sizeIdx] + errorWordLength[matrixRegion->sizeIdx];   matrixRegion->dataRows = matrixRegion->dataCols = dataRegionSize[matrixRegion->sizeIdx];// fprintf(stdout, "\n\nsize:    %dx%d w/ %d error codewords\n", rows, cols, errorWordLength(matrixRegion->sizeIdx));   matrixRegion->code = (unsigned char *)malloc(sizeof(unsigned char) * matrixRegion->codeSize);   if(matrixRegion->code == NULL) {      perror("dmtxEncodeData");      exit(7);   }   memset(matrixRegion->code, 0x00, sizeof(unsigned char) * matrixRegion->codeSize);   memcpy(matrixRegion->code, buf, unpaddedDataSize);}/** * * @param XXX * @return XXX */static unsigned char *WriteAscii2Digit(unsigned char **dest, unsigned char *src, unsigned char *srcEnd){   while(src < srcEnd) {      *((*dest)++) = 10 * (*src - '0') + (*(src + 1) - '0') + 130;      fprintf(stdout, "\ndigits:  \"%c%c\" ==> %d", *src, *(src + 1), *((*dest)-1)); fflush(stdout);      src += 2;   }   return src;}/** * * @param XXX * @return XXX */static unsigned char *WriteAsciiChar(unsigned char **dest, unsigned char *src){   fprintf(stdout, "\nascii:   \"%c\" ==> %d", *src, *src + 1); fflush(stdout);   *((*dest)++) = *(src++) + 1;   return src;}/** * * @param XXX * @return XXX */static voidAddPadChars(DmtxMatrixRegion *matrix){   int i;   int dataSize;   int padBegin;   // XXX we can do it cleaner than this // XXX this is probably broken too (compare to older version for fix)   dataSize = dataWordLength[matrix->sizeIdx];   padBegin = dataSize - matrix->padSize;   for(i = padBegin; i < dataSize; i++) {      matrix->code[i] = (i == padBegin) ? 129 : Randomize253State(129, i + 1);   }}/** * * @param XXX * @return XXX */static unsigned charRandomize253State(unsigned char codewordValue, int codewordPosition){   int pseudoRandom;   int tmp;   pseudoRandom = ((149 * codewordPosition) % 253) + 1;   tmp = codewordValue + pseudoRandom;   return (tmp <= 254) ? tmp : tmp - 254;}/** * * @param XXX * @return XXX *//* XXX uncomment this function later -- will need for encoding Base256static unsigned charRandomize255State(unsigned char codewordValue, int codewordPosition){   int pseudoRandom;   int tmp;   pseudoRandom = ((149 * codewordPosition) % 255) + 1;   tmp = codewordValue + pseudoRandom;   return (tmp <= 255) ? tmp : tmp - 256;}*//** * * @param XXX * @return XXX */static voidPatternInit(DmtxMatrixRegion *matrixRegion){   int patternSize;   if(matrixRegion == NULL)      exit(1); // XXX find better error handling here   patternSize = sizeof(unsigned char) * matrixRegion->dataRows * matrixRegion->dataCols;   matrixRegion->array = (unsigned char *)malloc(patternSize);   if(matrixRegion->array == NULL)      exit(2); // XXX find better error handling here   memset(matrixRegion->array, 0x00, patternSize);}/** * * @param XXX * @return XXX */static voidPrintPattern(DmtxEncode *encode){   int row, col, dataRow, dataCol;   float sxy, txy;   DmtxMatrix3 m1, m2, m3;   DmtxVector2 vIn, vOut;   DmtxPixel black, white;   // Print ASCII rendition of barcode pattern   for(row = 0; row < encode->matrix.dataRows + 2; row++) {      for(col = 0; col < encode->matrix.dataCols + 2; col++) {         if(col == 0 || row == encode->matrix.dataRows + 1) {            fprintf(stdout, "XX");         }         else if (row == 0) {            fprintf(stdout, "%s", (col & 0x01) ? "  " : "XX");         }         else if (col == encode->matrix.dataCols + 1) {            fprintf(stdout, "%s", (row & 0x01) ? "XX" : "  ");         }         else {            dataRow = row - 1;            dataCol = col - 1;            fprintf(stdout, "%s", (encode->matrix.array[dataRow *                  encode->matrix.dataCols + dataCol] & DMTX_MODULE_ON) ?                  "XX" : "  ");         }      }      fprintf(stdout, "\n");   }   fprintf(stdout, "\n");   txy = -1.0 * (encode->marginSize + encode->moduleSize);   sxy = 1.0/encode->moduleSize;   dmtxMatrix3Translate(m1, txy, txy);   dmtxMatrix3Scale(m2, sxy, -sxy);   dmtxMatrix3Translate(m3, -0.5, encode->matrix.dataRows - 0.5);   dmtxMatrix3Multiply(encode->xfrm, m1, m2);   dmtxMatrix3MultiplyBy(encode->xfrm, m3);// dmtxMatrix3Rotate(m4, 0.1);// dmtxMatrix3MultiplyBy(encode->xfrm, m4);   memset(&black, 0x00, sizeof(DmtxPixel));   memset(&white, 0xff, sizeof(DmtxPixel));   // Print raster version of barcode pattern   // IMPORTANT: DmtxImage is stored with its origin at bottom-right   // (unlike common image file formats) to preserve "right-handed" 2D space   for(row = 0; row < encode->image.height; row++) {      for(col = 0; col < encode->image.width; col++) {         vIn.X = col;         vIn.Y = row;         dmtxMatrix3VMultiply(&vOut, &vIn, encode->xfrm);         dataCol = (int)(vOut.X + ((vOut.X > 0) ? 0.5 : -0.5));         dataRow = (int)(vOut.Y + ((vOut.Y > 0) ? 0.5 : -0.5));         // Margin         if(dataCol < -1 || dataCol > encode->matrix.dataCols ||            dataRow < -1 || dataRow > encode->matrix.dataRows) {            encode->image.pxl[row * encode->image.width + col] = white;         }         // Finder bars         else if(dataCol == -1 || dataRow == encode->matrix.dataRows) {            encode->image.pxl[row * encode->image.width + col] = black;         }         // Top calibration bar         else if(dataRow == -1) {            encode->image.pxl[row * encode->image.width + col] = (dataCol & 0x01) ? black : white;         }         // Right calibration bar         else if(dataCol == encode->matrix.dataCols) {            encode->image.pxl[row * encode->image.width + col] = (dataRow & 0x01) ? white : black;         }         else if(encode->matrix.array[dataRow * encode->matrix.dataCols + dataCol] & DMTX_MODULE_ON) {            encode->image.pxl[row * encode->image.width + col] = black;         }         else {            encode->image.pxl[row * encode->image.width + col] = white;         }      }   }}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲第一综合色| 99视频精品全部免费在线| 国产精品传媒入口麻豆| 一个色妞综合视频在线观看| 九九九精品视频| 欧美一卡二卡三卡四卡| 欧美三级欧美一级| 欧美日韩国产一区| 在线不卡中文字幕播放| 日韩一级高清毛片| 精品福利一二区| 国产无人区一区二区三区| 国产欧美一区视频| 椎名由奈av一区二区三区| 一区二区激情视频| 视频在线观看国产精品| 九九九久久久精品| 99久久综合国产精品| 欧美三级一区二区| 日韩欧美色综合网站| 国产日韩欧美制服另类| 亚洲精品视频免费观看| 日韩成人免费在线| 国产成人自拍网| 色婷婷综合视频在线观看| 欧美人与禽zozo性伦| 亚洲精品一线二线三线无人区| 国产日韩欧美制服另类| 一区二区三区四区精品在线视频| 天堂va蜜桃一区二区三区| 久久国产三级精品| 91在线视频免费91| 日韩久久久久久| 中文字幕日本乱码精品影院| 视频精品一区二区| 风间由美中文字幕在线看视频国产欧美| 99久久精品国产精品久久| 91麻豆精品国产| 水蜜桃久久夜色精品一区的特点| 久久91精品久久久久久秒播| a4yy欧美一区二区三区| 日韩一级免费一区| 亚洲欧美偷拍三级| 国产在线日韩欧美| 精品视频1区2区3区| 久久久99久久| 蜜臀av性久久久久蜜臀aⅴ| 成人久久18免费网站麻豆| 欧美日本韩国一区二区三区视频| 国产精品久久久爽爽爽麻豆色哟哟 | 日韩欧美一区二区不卡| 国产精品久久久久四虎| 美国十次综合导航| 在线观看免费视频综合| 国产精品国产馆在线真实露脸| 日韩电影在线看| 欧亚洲嫩模精品一区三区| 欧美国产97人人爽人人喊| 日本美女视频一区二区| 91国偷自产一区二区三区成为亚洲经典| 久久综合九色综合久久久精品综合| 亚洲卡通动漫在线| av中文字幕亚洲| 欧美韩日一区二区三区| 黄色日韩网站视频| 日韩欧美高清在线| 日韩经典中文字幕一区| 欧美日韩国产123区| 一区二区久久久久久| 在线观看亚洲a| 一区二区三区欧美久久| 一本一道波多野结衣一区二区| 欧美国产乱子伦| 成人一区二区三区中文字幕| 久久精品综合网| 高清在线不卡av| 国产精品美女久久福利网站| 国产成人精品www牛牛影视| 久久精品欧美一区二区三区不卡| 国内精品国产成人| 国产视频一区在线播放| 国产精品综合一区二区| 日本一区二区三区电影| 国产成人精品午夜视频免费| 国产日韩成人精品| 91视视频在线观看入口直接观看www| 国产精品污网站| 一本大道综合伊人精品热热| 一区二区三区资源| 欧美日精品一区视频| 日本伊人色综合网| 久久久精品2019中文字幕之3| 久久成人免费电影| 久久久国产综合精品女国产盗摄| 国产99精品国产| 亚洲男人的天堂网| 91精品国产综合久久久久久久 | 欧美亚洲高清一区| 日本大胆欧美人术艺术动态| 欧美大胆人体bbbb| 成人深夜在线观看| 国产精品一区二区无线| 久久精品男人天堂av| 99国产精品久久久| 日本亚洲三级在线| 国产女人18毛片水真多成人如厕 | 国产亚洲一区二区三区在线观看| 成人高清在线视频| 五月天视频一区| www国产精品av| 99国产精品视频免费观看| 亚洲成av人影院在线观看网| 26uuu精品一区二区| 日本久久一区二区| 国产一区二区成人久久免费影院 | 日韩精品一级中文字幕精品视频免费观看 | 亚洲免费av高清| 欧美大片日本大片免费观看| 91美女在线观看| 精品在线亚洲视频| 洋洋成人永久网站入口| 久久综合五月天婷婷伊人| 欧美性欧美巨大黑白大战| 国产麻豆视频一区| 婷婷开心激情综合| 中文字幕视频一区| 久久亚洲精品国产精品紫薇| 欧美日韩综合色| 99re8在线精品视频免费播放| 美女视频第一区二区三区免费观看网站 | 欧美精品一区二区久久久| 在线观看三级视频欧美| 国产a级毛片一区| 久久99日本精品| 亚洲国产日韩a在线播放性色| 中文字幕欧美区| 久久久影视传媒| 日韩丝袜情趣美女图片| 欧美三级在线看| 在线观看日韩电影| 色综合av在线| 精品国产91久久久久久久妲己| 欧美精品18+| 欧美日本韩国一区二区三区视频 | 石原莉奈在线亚洲二区| 亚洲小少妇裸体bbw| 亚洲天堂免费看| 国产精品国产三级国产aⅴ原创| 欧美精品一区二区三区在线播放 | 在线观看欧美日本| 色噜噜狠狠一区二区三区果冻| 国产xxx精品视频大全| 国产精品自拍三区| 国产电影一区在线| 国产成人综合亚洲91猫咪| 国产经典欧美精品| 粉嫩aⅴ一区二区三区四区| 国产成人夜色高潮福利影视| 国产在线精品不卡| 粉嫩绯色av一区二区在线观看| 国产精品1024| 99久久亚洲一区二区三区青草 | 欧美日韩国产中文| 日韩欧美国产一区在线观看| 欧美日本一区二区| 日韩欧美黄色影院| 国产午夜精品久久久久久免费视| 日本一区二区免费在线| 国产精品福利影院| 一区二区三区日韩欧美精品| 亚洲国产人成综合网站| 97se亚洲国产综合自在线观| 99re成人精品视频| 欧美日韩中文一区| 精品国产精品网麻豆系列| 国产视频一区在线播放| 亚洲人妖av一区二区| 亚洲成人精品一区二区| 蜜臀精品久久久久久蜜臀| 国产乱色国产精品免费视频| av在线免费不卡| 欧美精品在线一区二区三区| 欧美成人一区二区| 成人欧美一区二区三区| 日韩主播视频在线| 国模大尺度一区二区三区| 91色在线porny| 日韩色视频在线观看| 国产精品系列在线| 日韩va亚洲va欧美va久久| 国产专区欧美精品| 欧美中文字幕一二三区视频| 日韩欧美一二三区| 亚洲图片另类小说| 久久福利资源站| 色综合视频一区二区三区高清| 91精品国产综合久久蜜臀| 成人欧美一区二区三区视频网页| 老鸭窝一区二区久久精品| 91色九色蝌蚪|