63 #include "allheaders.h" 66 l_int32 skipdist, l_int32 delta,
67 l_int32 maxbg, l_int32 sideflag,
101 PROCNAME(
"pixMaskConnComp");
103 if (pboxa) *pboxa = NULL;
104 if (!pixs || pixGetDepth(pixs) != 1)
105 return (
PIX *)ERROR_PTR(
"pixs undefined or not 1 bpp", procName, NULL);
106 if (connectivity != 4 && connectivity != 8)
107 return (
PIX *)ERROR_PTR(
"connectivity not 4 or 8", procName, NULL);
153 l_int32 i, n, x, y, w, h;
156 PROCNAME(
"pixMaskBoxa");
159 return (
PIX *)ERROR_PTR(
"pixs not defined", procName, NULL);
160 if (pixGetColormap(pixs))
161 return (
PIX *)ERROR_PTR(
"pixs is cmapped", procName, NULL);
162 if (pixd && (pixd != pixs))
163 return (
PIX *)ERROR_PTR(
"if pixd, must be in-place", procName, NULL);
165 return (
PIX *)ERROR_PTR(
"boxa not defined", procName, NULL);
167 return (
PIX *)ERROR_PTR(
"invalid op", procName, NULL);
171 L_WARNING(
"no boxes to mask\n", procName);
175 for (i = 0; i < n; i++) {
221 l_int32 i, n, d, rval, gval, bval, newindex;
227 PROCNAME(
"pixPaintBoxa");
230 return (
PIX *)ERROR_PTR(
"pixs not defined", procName, NULL);
232 return (
PIX *)ERROR_PTR(
"boxa not defined", procName, NULL);
235 L_WARNING(
"no boxes to paint; returning a copy\n", procName);
240 if ((cmap = pixGetColormap(pixs)) != NULL) {
244 if (pixGetDepth(pixs) == 1 || mapvacancy)
249 return (
PIX *)ERROR_PTR(
"pixd not made", procName, NULL);
251 d = pixGetDepth(pixd);
253 cmap = pixGetColormap(pixd);
257 return (
PIX *)ERROR_PTR(
"cmap full; can't add", procName, NULL);
261 for (i = 0; i < n; i++) {
287 l_int32 i, n, d, index;
293 PROCNAME(
"pixSetBlackOrWhiteBoxa");
296 return (
PIX *)ERROR_PTR(
"pixs not defined", procName, NULL);
303 d = pixGetDepth(pixd);
305 for (i = 0; i < n; i++) {
316 cmap = pixGetColormap(pixs);
322 }
else if (d == 32) {
328 }
else if (d == 16) {
332 return (
PIX *)ERROR_PTR(
"invalid depth", procName, NULL);
335 for (i = 0; i < n; i++) {
367 l_int32 i, n, d, rval, gval, bval, index;
373 PROCNAME(
"pixPaintBoxaRandom");
376 return (
PIX *)ERROR_PTR(
"pixs not defined", procName, NULL);
378 return (
PIX *)ERROR_PTR(
"boxa not defined", procName, NULL);
381 L_WARNING(
"no boxes to paint; returning a copy\n", procName);
385 if (pixGetDepth(pixs) == 1)
390 return (
PIX *)ERROR_PTR(
"pixd not made", procName, NULL);
393 d = pixGetDepth(pixd);
397 for (i = 0; i < n; i++) {
399 index = 1 + (i % 254);
439 l_int32 i, n, rval, gval, bval, index;
445 PROCNAME(
"pixBlendBoxaRandom");
448 return (
PIX *)ERROR_PTR(
"pixs not defined", procName, NULL);
450 return (
PIX *)ERROR_PTR(
"boxa not defined", procName, NULL);
451 if (fract < 0.0 || fract > 1.0) {
452 L_WARNING(
"fract must be in [0.0, 1.0]; setting to 0.5\n", procName);
457 L_WARNING(
"no boxes to paint; returning a copy\n", procName);
462 return (
PIX *)ERROR_PTR(
"pixd not defined", procName, NULL);
465 for (i = 0; i < n; i++) {
467 index = 1 + (i % 254);
501 l_int32 rval, gval, bval, newindex;
506 PROCNAME(
"pixDrawBoxa");
509 return (
PIX *)ERROR_PTR(
"pixs not defined", procName, NULL);
511 return (
PIX *)ERROR_PTR(
"boxa not defined", procName, NULL);
513 return (
PIX *)ERROR_PTR(
"width must be >= 1", procName, NULL);
516 L_WARNING(
"no boxes to draw; returning a copy\n", procName);
521 if ((cmap = pixGetColormap(pixs)) != NULL) {
525 if (pixGetDepth(pixs) == 1 || mapvacancy)
530 return (
PIX *)ERROR_PTR(
"pixd not made", procName, NULL);
533 if (pixGetDepth(pixd) == 8) {
534 cmap = pixGetColormap(pixd);
564 l_int32 i, n, rval, gval, bval, index;
570 PROCNAME(
"pixDrawBoxaRandom");
573 return (
PIX *)ERROR_PTR(
"pixs not defined", procName, NULL);
575 return (
PIX *)ERROR_PTR(
"boxa not defined", procName, NULL);
577 return (
PIX *)ERROR_PTR(
"width must be >= 1", procName, NULL);
580 L_WARNING(
"no boxes to draw; returning a copy\n", procName);
585 if (pixGetDepth(pixs) == 1) {
595 for (i = 0; i < n; i++) {
597 index = 1 + (i % 254);
643 l_int32 i, j, n, m, rbox, gbox, bbox, rboxa, gboxa, bboxa;
649 PROCNAME(
"boxaaDisplay");
652 return (
PIX *)ERROR_PTR(
"baa not defined", procName, NULL);
654 if (w <= 0 || h <= 0) {
663 cmap = pixGetColormap(pixd);
676 for (i = 0; i < n; i++) {
682 for (j = 0; j < m; j++) {
721 l_int32 i, j, nba, n, nbox, rval, gval, bval;
723 l_uint32 colors[255];
729 PROCNAME(
"pixaDisplayBoxaa");
732 return (
PIXA *)ERROR_PTR(
"pixas not defined", procName, NULL);
734 return (
PIXA *)ERROR_PTR(
"baa not defined", procName, NULL);
736 return (
PIXA *)ERROR_PTR(
"width must be >= 1", procName, NULL);
738 return (
PIXA *)ERROR_PTR(
"no boxa in baa", procName, NULL);
740 return (
PIXA *)ERROR_PTR(
"no pix in pixas", procName, NULL);
742 return (
PIXA *)ERROR_PTR(
"num pix != num boxa", procName, NULL);
754 return (
PIXA *)ERROR_PTR(
"invalid colorflag", procName, NULL);
758 for (i = 0; i < 255; i++)
761 for (i = 0; i < 255; i++) {
763 colors[i] = 0xff000000;
765 colors[i] = 0x00ff0000;
767 colors[i] = 0x0000ff00;
770 for (i = 0; i < 255; i++) {
771 rval = (l_uint32)rand() & 0xff;
772 gval = (l_uint32)rand() & 0xff;
773 bval = (l_uint32)rand() & 0xff;
779 for (i = 0; i < n; i++) {
783 for (j = 0; j < nbox; j++) {
845 BOXA *boxa, *boxas, *boxad;
849 PROCNAME(
"pixSplitIntoBoxa");
851 if (!pixs || pixGetDepth(pixs) != 1)
852 return (
BOXA *)ERROR_PTR(
"pixs undefined or not 1 bpp", procName, NULL);
857 for (i = 0; i < n; i++) {
861 delta, maxbg, maxcomps, remainder);
953 l_int32 i, w, h, boxx, boxy, bx, by, bw, bh, maxdir, maxscore;
956 BOX *boxt1, *boxt2, *boxt3;
962 PROCNAME(
"pixSplitComponentIntoBoxa");
964 if (!pix || pixGetDepth(pix) != 1)
965 return (
BOXA *)ERROR_PTR(
"pix undefined or not 1 bpp", procName, NULL);
977 while (boxs != NULL) {
981 for (i = 0; i < 4; i++) {
989 fprintf(stderr,
"Iteration: %d\n", iter);
992 fprintf(stderr,
"\nmaxdir = %d, maxscore = %d\n\n", maxdir, maxscore);
1005 if (bw < 2 || bh < 2)
1009 if (remainder == 1) {
1020 if ((iter == maxcomps) && boxs) {
1021 if (remainder == 1) {
1069 l_int32 bx, by, bw, bh, width, height, setref, atref;
1070 l_int32 minincol, maxincol, mininrow, maxinrow, minval, maxval, bgref;
1071 l_int32 x, y, x0, y0, xref, yref, colsum, rowsum, score, countref, diff;
1075 PROCNAME(
"pixSearchForRectangle");
1077 if (!pixs || pixGetDepth(pixs) != 1)
1078 return ERROR_INT(
"pixs undefined or not 1 bpp", procName, 1);
1080 return ERROR_INT(
"boxs not defined", procName, 1);
1082 return ERROR_INT(
"boxat not defined", procName, 1);
1084 return ERROR_INT(
"nascore not defined", procName, 1);
1094 xref = yref = 100000;
1096 for (x = bx; x < bx + bw; x++) {
1100 for (y = by; y < by + bh; y++) {
1103 if (y > maxincol) maxincol = y;
1104 if (y < minincol) minincol = y;
1110 if (!setref && colsum >= minsum) {
1113 if (xref >= bx + bw)
1119 if (setref && x == xref) {
1122 bgref = maxincol - minincol + 1 - countref;
1130 diff = L_ABS(colsum - countref);
1131 if (diff >= delta || x == bx + bw - 1) {
1132 height = maxval - minval + 1;
1134 if (x == bx + bw - 1) width = x - bx + 1;
1135 boxr =
boxCreate(bx, minval, width, height);
1136 score = 2 * score - width * height;
1140 maxval = L_MAX(maxval, maxincol);
1141 minval = L_MIN(minval, minincol);
1145 for (x = bx + bw - 1; x >= bx; x--) {
1149 for (y = by; y < by + bh; y++) {
1152 if (y > maxincol) maxincol = y;
1153 if (y < minincol) minincol = y;
1157 if (!setref && colsum >= minsum) {
1163 if (setref && x == xref) {
1166 bgref = maxincol - minincol + 1 - countref;
1171 diff = L_ABS(colsum - countref);
1172 if (diff >= delta || x == bx) {
1173 height = maxval - minval + 1;
1175 if (x == bx) x0 = x;
1176 width = bx + bw - x0;
1177 boxr =
boxCreate(x0, minval, width, height);
1178 score = 2 * score - width * height;
1182 maxval = L_MAX(maxval, maxincol);
1183 minval = L_MIN(minval, minincol);
1187 for (y = by; y < by + bh; y++) {
1191 for (x = bx; x < bx + bw; x++) {
1194 if (x > maxinrow) maxinrow = x;
1195 if (x < mininrow) mininrow = x;
1199 if (!setref && rowsum >= minsum) {
1202 if (yref >= by + bh)
1205 if (setref && y == yref) {
1208 bgref = maxinrow - mininrow + 1 - countref;
1213 diff = L_ABS(rowsum - countref);
1214 if (diff >= delta || y == by + bh - 1) {
1215 width = maxval - minval + 1;
1217 if (y == by + bh - 1) height = y - by + 1;
1218 boxr =
boxCreate(minval, by, width, height);
1219 score = 2 * score - width * height;
1223 maxval = L_MAX(maxval, maxinrow);
1224 minval = L_MIN(minval, mininrow);
1228 for (y = by + bh - 1; y >= by; y--) {
1232 for (x = bx; x < bx + bw; x++) {
1235 if (x > maxinrow) maxinrow = x;
1236 if (x < mininrow) mininrow = x;
1240 if (!setref && rowsum >= minsum) {
1246 if (setref && y == yref) {
1249 bgref = maxinrow - mininrow + 1 - countref;
1254 diff = L_ABS(rowsum - countref);
1255 if (diff >= delta || y == by) {
1256 width = maxval - minval + 1;
1258 if (y == by) y0 = y;
1259 height = by + bh - y0;
1260 boxr =
boxCreate(minval, y0, width, height);
1261 score = 2 * score - width * height;
1265 maxval = L_MAX(maxval, maxinrow);
1266 minval = L_MIN(minval, mininrow);
1313 l_int32 i, nstrips, extra;
1317 PROCNAME(
"makeMosaicStrips");
1320 return (
BOXA *)ERROR_PTR(
"invalid w or h", procName, NULL);
1322 return (
BOXA *)ERROR_PTR(
"invalid direction", procName, NULL);
1324 return (
BOXA *)ERROR_PTR(
"size < 1", procName, NULL);
1329 for (i = 0; i < nstrips; i++) {
1333 if ((extra = w % size) > 0) {
1334 box =
boxCreate(nstrips * size, 0, extra, h);
1339 for (i = 0; i < nstrips; i++) {
1343 if ((extra = h % size) > 0) {
1344 box =
boxCreate(0, nstrips * size, w, extra);
1391 l_float32 *pdiffarea,
1392 l_float32 *pdiffxor,
1395 l_int32 w, h, x3, y3, w3, h3, x4, y4, w4, h4, n3, n4, area1, area2;
1396 l_int32 count3, count4, countxor;
1399 BOXA *boxa3, *boxa4, *boxa3t, *boxa4t;
1400 PIX *pix1, *pix2, *pix3, *pix4, *pix5;
1403 PROCNAME(
"boxaCompareRegions");
1405 if (pdiffxor) *pdiffxor = 1.0;
1406 if (ppixdb) *ppixdb = NULL;
1407 if (pnsame) *pnsame = FALSE;
1408 if (pdiffarea) *pdiffarea = 1.0;
1409 if (!boxa1 || !boxa2)
1410 return ERROR_INT(
"boxa1 and boxa2 not both defined", procName, 1);
1412 return ERROR_INT(
"&nsame not defined", procName, 1);
1414 return ERROR_INT(
"&diffarea not defined", procName, 1);
1424 if (n3 == 0 || n4 == 0) {
1427 if (n3 == 0 && n4 == 0) {
1431 if (pdiffxor) *pdiffxor = 0.0;
1439 *pdiffarea = (l_float32)L_ABS(area1 - area2) / (l_float32)(area1 + area2);
1456 w = L_MAX(x3 + w3, x4 + w4);
1457 h = L_MAX(y3 + h3, y4 + h4);
1465 pix5 =
pixXor(NULL, pix3, pix4);
1468 *pdiffxor = (l_float32)countxor / (l_float32)(count3 + count4);
1482 pixAnd(pix3, pix3, pix4);
1534 l_int32 connectivity)
1539 PROCNAME(
"pixSelectLargeULComp");
1542 return (
BOX *)ERROR_PTR(
"pixs not defined", procName, NULL);
1543 if (areaslop < 0.0 || areaslop > 1.0)
1544 return (
BOX *)ERROR_PTR(
"invalid value for areaslop", procName, NULL);
1545 yslop = L_MAX(0, yslop);
1576 l_int32 w, h, i, n, x1, y1, x2, y2, select;
1577 l_float32 area, max_area;
1579 BOXA *boxa1, *boxa2, *boxa3;
1581 PROCNAME(
"boxaSelectLargeULBox");
1584 return (
BOX *)ERROR_PTR(
"boxas not defined", procName, NULL);
1586 return (
BOX *)ERROR_PTR(
"no boxes in boxas", procName, NULL);
1587 if (areaslop < 0.0 || areaslop > 1.0)
1588 return (
BOX *)ERROR_PTR(
"invalid value for areaslop", procName, NULL);
1589 yslop = L_MAX(0, yslop);
1595 max_area = (l_float32)(w * h);
1599 for (i = 0; i < n; i++) {
1601 area = (l_float32)(w * h);
1602 if (area / max_area >= areaslop) {
1613 for (i = 1; i < n; i++) {
1615 if (y2 - y1 < yslop && x2 < x1) {
BOXA * pixSplitComponentIntoBoxa(PIX *pix, BOX *box, l_int32 minsum, l_int32 skipdist, l_int32 delta, l_int32 maxbg, l_int32 maxcomps, l_int32 remainder)
pixSplitComponentIntoBoxa()
BOX * boxaSelectLargeULBox(BOXA *boxas, l_float32 areaslop, l_int32 yslop)
boxaSelectLargeULBox()
PIX * boxaaDisplay(PIX *pixs, BOXAA *baa, l_int32 linewba, l_int32 linewb, l_uint32 colorba, l_uint32 colorb, l_int32 w, l_int32 h)
boxaaDisplay()
BOXA * makeMosaicStrips(l_int32 w, l_int32 h, l_int32 direction, l_int32 size)
makeMosaicStrips()
l_ok boxaJoin(BOXA *boxad, BOXA *boxas, l_int32 istart, l_int32 iend)
boxaJoin()
NUMA * numaGetSortIndex(NUMA *na, l_int32 sortorder)
numaGetSortIndex()
BOXA * boxaSort(BOXA *boxas, l_int32 sorttype, l_int32 sortorder, NUMA **pnaindex)
boxaSort()
PTAA * generatePtaaBoxa(BOXA *boxa)
generatePtaaBoxa()
PIX * pixConvertTo32(PIX *pixs)
pixConvertTo32()
l_ok numaAddNumber(NUMA *na, l_float32 val)
numaAddNumber()
l_ok pixSetInRectArbitrary(PIX *pix, BOX *box, l_uint32 val)
pixSetInRectArbitrary()
l_ok boxaaGetExtent(BOXAA *baa, l_int32 *pw, l_int32 *ph, BOX **pbox, BOXA **pboxa)
boxaaGetExtent()
PIXA * pixaCreate(l_int32 n)
pixaCreate()
l_int32 boxaaGetCount(BOXAA *baa)
boxaaGetCount()
l_ok pixRasterop(PIX *pixd, l_int32 dx, l_int32 dy, l_int32 dw, l_int32 dh, l_int32 op, PIX *pixs, l_int32 sx, l_int32 sy)
pixRasterop()
l_ok boxaWriteStream(FILE *fp, BOXA *boxa)
boxaWriteStream()
PIX * pixConvertTo8(PIX *pixs, l_int32 cmapflag)
pixConvertTo8()
void ** pixGetLinePtrs(PIX *pix, l_int32 *psize)
pixGetLinePtrs()
PIX * pixCreate(l_int32 width, l_int32 height, l_int32 depth)
pixCreate()
l_ok pixSetAll(PIX *pix)
pixSetAll()
void pixcmapDestroy(PIXCMAP **pcmap)
pixcmapDestroy()
NUMA * numaCreate(l_int32 n)
numaCreate()
void boxaDestroy(BOXA **pboxa)
boxaDestroy()
BOX * boxTransform(BOX *box, l_int32 shiftx, l_int32 shifty, l_float32 scalex, l_float32 scaley)
boxTransform()
static l_int32 pixSearchForRectangle(PIX *pixs, BOX *boxs, l_int32 minsum, l_int32 skipdist, l_int32 delta, l_int32 maxbg, l_int32 sideflag, BOXA *boxat, NUMA *nascore)
pixSearchForRectangle()
#define GET_DATA_BIT(pdata, n)
PIX * pixCreateTemplate(PIX *pixs)
pixCreateTemplate()
PIX * pixDrawBoxaRandom(PIX *pixs, BOXA *boxa, l_int32 width)
pixDrawBoxaRandom()
l_ok pixClearInRect(PIX *pix, BOX *box)
pixClearInRect()
l_ok pixSetColormap(PIX *pix, PIXCMAP *colormap)
pixSetColormap()
PIX * pixPaintBoxaRandom(PIX *pixs, BOXA *boxa)
pixPaintBoxaRandom()
l_ok pixPaintThroughMask(PIX *pixd, PIX *pixm, l_int32 x, l_int32 y, l_uint32 val)
pixPaintThroughMask()
PIXCMAP * pixcmapCreate(l_int32 depth)
pixcmapCreate()
PIXA * pixaDisplayBoxaa(PIXA *pixas, BOXAA *baa, l_int32 colorflag, l_int32 width)
pixaDisplayBoxaa()
BOXA * pixConnComp(PIX *pixs, PIXA **ppixa, l_int32 connectivity)
pixConnComp()
BOX * pixSelectLargeULComp(PIX *pixs, l_float32 areaslop, l_int32 yslop, l_int32 connectivity)
pixSelectLargeULComp()
l_ok numaGetIValue(NUMA *na, l_int32 index, l_int32 *pival)
numaGetIValue()
l_ok pixaAddPix(PIXA *pixa, PIX *pix, l_int32 copyflag)
pixaAddPix()
PIX * pixXor(PIX *pixd, PIX *pixs1, PIX *pixs2)
pixXor()
BOXA * boxaTransform(BOXA *boxas, l_int32 shiftx, l_int32 shifty, l_float32 scalex, l_float32 scaley)
boxaTransform()
PIX * pixBlendBoxaRandom(PIX *pixs, BOXA *boxa, l_float32 fract)
pixBlendBoxaRandom()
BOXA * pixConnCompBB(PIX *pixs, l_int32 connectivity)
pixConnCompBB()
l_ok boxaGetBoxGeometry(BOXA *boxa, l_int32 index, l_int32 *px, l_int32 *py, l_int32 *pw, l_int32 *ph)
boxaGetBoxGeometry()
PIX * pixAnd(PIX *pixd, PIX *pixs1, PIX *pixs2)
pixAnd()
l_ok boxaGetArea(BOXA *boxa, l_int32 *parea)
boxaGetArea()
PIX * pixaDisplayTiledInRows(PIXA *pixa, l_int32 outdepth, l_int32 maxwidth, l_float32 scalefactor, l_int32 background, l_int32 spacing, l_int32 border)
pixaDisplayTiledInRows()
l_ok pixcmapGetColor(PIXCMAP *cmap, l_int32 index, l_int32 *prval, l_int32 *pgval, l_int32 *pbval)
pixcmapGetColor()
void ptaaDestroy(PTAA **pptaa)
ptaaDestroy()
l_ok pixCountPixels(PIX *pixs, l_int32 *pcount, l_int32 *tab8)
pixCountPixels()
l_ok boxaAddBox(BOXA *boxa, BOX *box, l_int32 copyflag)
boxaAddBox()
l_int32 * makePixelSumTab8(void)
makePixelSumTab8()
l_ok pixcmapAddNewColor(PIXCMAP *cmap, l_int32 rval, l_int32 gval, l_int32 bval, l_int32 *pindex)
pixcmapAddNewColor()
l_ok pixClipBoxToForeground(PIX *pixs, BOX *boxs, PIX **ppixd, BOX **pboxd)
pixClipBoxToForeground()
BOXA * boxaSelectByArea(BOXA *boxas, l_int32 area, l_int32 relation, l_int32 *pchanged)
boxaSelectByArea()
void pixDestroy(PIX **ppix)
pixDestroy()
PIX * pixMaskBoxa(PIX *pixd, PIX *pixs, BOXA *boxa, l_int32 op)
pixMaskBoxa()
BOX * boxaGetBox(BOXA *boxa, l_int32 index, l_int32 accessflag)
boxaGetBox()
PIX * pixRenderRandomCmapPtaa(PIX *pix, PTAA *ptaa, l_int32 polyflag, l_int32 width, l_int32 closeflag)
pixRenderRandomCmapPtaa()
l_ok boxaGetExtent(BOXA *boxa, l_int32 *pw, l_int32 *ph, BOX **pbox)
boxaGetExtent()
PIX * pixDrawBoxa(PIX *pixs, BOXA *boxa, l_int32 width, l_uint32 val)
pixDrawBoxa()
void numaDestroy(NUMA **pna)
numaDestroy()
l_ok pixGetDimensions(const PIX *pix, l_int32 *pw, l_int32 *ph, l_int32 *pd)
pixGetDimensions()
BOXA * pixSplitIntoBoxa(PIX *pixs, l_int32 minsum, l_int32 skipdist, l_int32 delta, l_int32 maxbg, l_int32 maxcomps, l_int32 remainder)
pixSplitIntoBoxa()
l_ok pixcmapAddBlackOrWhite(PIXCMAP *cmap, l_int32 color, l_int32 *pindex)
pixcmapAddBlackOrWhite()
PIX * pixPaintBoxa(PIX *pixs, BOXA *boxa, l_uint32 val)
pixPaintBoxa()
l_ok pixRenderBoxaArb(PIX *pix, BOXA *boxa, l_int32 width, l_uint8 rval, l_uint8 gval, l_uint8 bval)
pixRenderBoxaArb()
PIX * pixMaskConnComp(PIX *pixs, l_int32 connectivity, BOXA **pboxa)
pixMaskConnComp()
PIX * pixaGetPix(PIXA *pixa, l_int32 index, l_int32 accesstype)
pixaGetPix()
l_ok pixRenderBoxArb(PIX *pix, BOX *box, l_int32 width, l_uint8 rval, l_uint8 gval, l_uint8 bval)
pixRenderBoxArb()
l_ok pixRenderHashBoxaBlend(PIX *pix, BOXA *boxa, l_int32 spacing, l_int32 width, l_int32 orient, l_int32 outline, l_int32 rval, l_int32 gval, l_int32 bval, l_float32 fract)
pixRenderHashBoxaBlend()
l_int32 pixcmapGetCount(PIXCMAP *cmap)
pixcmapGetCount()
BOXA * boxaCreate(l_int32 n)
boxaCreate()
PIX * pixCopy(PIX *pixd, PIX *pixs)
pixCopy()
void boxDestroy(BOX **pbox)
boxDestroy()
l_ok boxaCompareRegions(BOXA *boxa1, BOXA *boxa2, l_int32 areathresh, l_int32 *pnsame, l_float32 *pdiffarea, l_float32 *pdiffxor, PIX **ppixdb)
boxaCompareRegions()
PIX * pixConvert1To8(PIX *pixd, PIX *pixs, l_uint8 val0, l_uint8 val1)
pixConvert1To8()
l_int32 boxaGetCount(BOXA *boxa)
boxaGetCount()
l_ok boxPrintStreamInfo(FILE *fp, BOX *box)
boxPrintStreamInfo()
l_ok composeRGBPixel(l_int32 rval, l_int32 gval, l_int32 bval, l_uint32 *ppixel)
composeRGBPixel()
l_ok pixcmapAddColor(PIXCMAP *cmap, l_int32 rval, l_int32 gval, l_int32 bval)
pixcmapAddColor()
l_ok boxGetGeometry(BOX *box, l_int32 *px, l_int32 *py, l_int32 *pw, l_int32 *ph)
boxGetGeometry()
void pixaDestroy(PIXA **ppixa)
pixaDestroy()
l_ok pixSetInRect(PIX *pix, BOX *box)
pixSetInRect()
void extractRGBValues(l_uint32 pixel, l_int32 *prval, l_int32 *pgval, l_int32 *pbval)
extractRGBValues()
BOX * boxCreate(l_int32 x, l_int32 y, l_int32 w, l_int32 h)
boxCreate()
l_int32 pixaGetCount(PIXA *pixa)
pixaGetCount()
l_ok pixBlendInRect(PIX *pixs, BOX *box, l_uint32 val, l_float32 fract)
pixBlendInRect()
PIX * pixSetBlackOrWhiteBoxa(PIX *pixs, BOXA *boxa, l_int32 op)
pixSetBlackOrWhiteBoxa()
BOXA * boxaaGetBoxa(BOXAA *baa, l_int32 index, l_int32 accessflag)
boxaaGetBoxa()
PIXCMAP * pixcmapCreateRandom(l_int32 depth, l_int32 hasblack, l_int32 haswhite)
pixcmapCreateRandom()