}
void find_structure(CanonImage *im, int *max_relevant_y_r,
- Point *commod_focus_point_r) {
+ Point *commod_focus_point_r,
+ Point *commod_page_point_r,
+ Point *commod_focuslast_point_r) {
cim= im;
Rect whole = { {0,0}, {cim->w-1,cim->h-1} };
Point csb_p; \
Rect csb_r; \
csb_p= mainr.tl; \
+ csb_p.x++; csb_p.y++; \
csb_p.xy= mainr.tlbr.xy; \
if (get_p(csb_p)=='+') { \
csb_r= mainr; \
}
MUST( colno >= MIN_COLUMNS, MI(colno);MR(mainr);MR(across); );
+ const int pagerh= 6;
+ Rect pager= {{ mainr.br.x, mainr.br.y - (pagerh-1) },
+ { mainr.br.x + 1, mainr.br.y }};
+
+ debug_rect("pager",__LINE__,pager);
+ ADJUST_BOX(pager, "o",>=,pagerh-2, whole.br.x,MUST, br,x,+1);
+ debug_rect("pager",__LINE__,pager);
+
+ pager.tl.x= pager.br.x;
+ pager.br.x= pager.br.x + 1;
+ debug_rect("pager",__LINE__,pager);
+ ADJUST_BOX(pager, "o",>=,pagerh-2, whole.br.x,MUST, br,x,+1);
+ debug_rect("pager",__LINE__,pager);
+
+ ADJUST_BOX(pager, "o",>=,RECT_W(pager)-2, mainr.tl.y,LIMIT_QUITEQ, tl,y,-1);
+ debug_rect("pager",__LINE__,pager);
+
#define SET_ONCE(var,val) do{ \
int v= (val); \
if ((var)==-1) (var)= v; \
commod_focus_point_r->x += 10;
commod_focus_point_r->y += comminty/3;
}
+ if (commod_focuslast_point_r) {
+ *commod_focuslast_point_r= mainr.br;
+ commod_focuslast_point_r->x -= 10;
+ commod_focuslast_point_r->y -= comminty/3;
+ }
+ if (commod_page_point_r) {
+ commod_page_point_r->x= (pager.tl.x + pager.br.x) / 2;
+ commod_page_point_r->y= pager.tl.y - 1;
+ }
MUST( text_h <= OCR_MAX_H, MI(text_h) );
}
int page, tryrect, colno;
for (page=0; page<npages; page++) {
- find_structure(page_images[page], 0, 0);
+ find_structure(page_images[page], 0,0,0,0);
if (!page)
check_correct_commodities();
}
void find_islandname(void) {
- find_structure(page_images[0], 0, 0);
+ find_structure(page_images[0], 0,0,0,0);
RgbImage *ri= alloc_rgb_image(page_images[0]->rgb->w,
page_images[0]->rgb->h);