static void adjust() { if (gs.vp.width < jas_image_width(gs.image) / gs.sx) { float mnx; float mxx; mnx = jas_image_tlx(gs.image) + 0.5 * gs.vp.width * gs.sx; mxx = jas_image_brx(gs.image) - 0.5 * gs.vp.width * gs.sx; if (gs.vcx < mnx) { gs.vcx = mnx; } else if (gs.vcx > mxx) { gs.vcx = mxx; } } else { gs.vcx = (jas_image_tlx(gs.image) + jas_image_brx(gs.image)) / 2.0; } if (gs.vp.height < jas_image_height(gs.image) / gs.sy) { float mny; float mxy; mny = jas_image_tly(gs.image) + 0.5 * gs.vp.height * gs.sy; mxy = jas_image_bry(gs.image) - 0.5 * gs.vp.height * gs.sy; if (gs.vcy < mny) { gs.vcy = mny; } else if (gs.vcy > mxy) { gs.vcy = mxy; } } else { gs.vcy = (jas_image_tly(gs.image) + jas_image_bry(gs.image)) / 2.0; } }
static void reshape(int w, int h) { if (cmdopts.verbose) { jas_eprintf("reshape(%d, %d)\n", w, h); dumpstate(); } if (pixmap_resize(&gs.vp, w, h)) { cleanupandexit(EXIT_FAILURE); } pixmap_clear(&gs.vp); glViewport(0, 0, w, h); glMatrixMode(GL_PROJECTION); glLoadIdentity(); glOrtho( 0, w, 0, h, 0.f, 1.f ); glMatrixMode(GL_MODELVIEW); glLoadIdentity(); glTranslatef(0, 0, 0); glRasterPos2i(0, 0); if (gs.vp.width > jas_image_width(gs.image) / gs.sx) { gs.vcx = (jas_image_tlx(gs.image) + jas_image_brx(gs.image)) / 2.0; } if (gs.vp.height > jas_image_height(gs.image) / gs.sy) { gs.vcy = (jas_image_tly(gs.image) + jas_image_bry(gs.image)) / 2.0; } gs.dirty = 1; }
bool Jpeg2KDecoder::readComponent8u( uchar *data, void *_buffer, int step, int cmpt, int maxval, int offset, int ncmpts ) { jas_matrix_t* buffer = (jas_matrix_t*)_buffer; jas_image_t* image = (jas_image_t*)m_image; int xstart = jas_image_cmpttlx( image, cmpt ); int xend = jas_image_cmptbrx( image, cmpt ); int xstep = jas_image_cmpthstep( image, cmpt ); int xoffset = jas_image_tlx( image ); int ystart = jas_image_cmpttly( image, cmpt ); int yend = jas_image_cmptbry( image, cmpt ); int ystep = jas_image_cmptvstep( image, cmpt ); int yoffset = jas_image_tly( image ); int x, y, x1, y1, j; int rshift = cvRound(std::log(maxval/256.)/std::log(2.)); int lshift = MAX(0, -rshift); rshift = MAX(0, rshift); int delta = (rshift > 0 ? 1 << (rshift - 1) : 0) + offset; for( y = 0; y < yend - ystart; ) { jas_seqent_t* pix_row = &jas_matrix_get( buffer, y / ystep, 0 ); uchar* dst = data + (y - yoffset) * step - xoffset; if( xstep == 1 ) { if( maxval == 256 && offset == 0 ) for( x = 0; x < xend - xstart; x++ ) { int pix = pix_row[x]; dst[x*ncmpts] = CV_CAST_8U(pix); } else for( x = 0; x < xend - xstart; x++ ) { int pix = ((pix_row[x] + delta) >> rshift) << lshift; dst[x*ncmpts] = CV_CAST_8U(pix); } } else if( xstep == 2 && offset == 0 ) for( x = 0, j = 0; x < xend - xstart; x += 2, j++ ) { int pix = ((pix_row[j] + delta) >> rshift) << lshift; dst[x*ncmpts] = dst[(x+1)*ncmpts] = CV_CAST_8U(pix); } else for( x = 0, j = 0; x < xend - xstart; j++ )
static int loadimage() { int reshapeflag; jas_stream_t *in; int scrnwidth; int scrnheight; int vh; int vw; char *pathname; jas_cmprof_t *outprof; assert(!gs.image); assert(!gs.altimage); gs.image = 0; gs.altimage = 0; pathname = cmdopts.filenames[gs.filenum]; if (pathname && pathname[0] != '\0') { #if 1 jas_eprintf("opening %s\n", pathname); #endif /* The input image is to be read from a file. */ if (!(in = jas_stream_fopen(pathname, "rb"))) { jas_eprintf("error: cannot open file %s\n", pathname); goto error; } } else { /* The input image is to be read from standard input. */ in = streamin; } /* Get the input image data. */ if (!(gs.image = jas_image_decode(in, -1, 0))) { jas_eprintf("error: cannot load image data\n"); goto error; } /* Close the input stream. */ if (in != streamin) { jas_stream_close(in); } if (!(outprof = jas_cmprof_createfromclrspc(JAS_CLRSPC_SRGB))) goto error; if (!(gs.altimage = jas_image_chclrspc(gs.image, outprof, JAS_CMXFORM_INTENT_PER))) goto error; if ((scrnwidth = glutGet(GLUT_SCREEN_WIDTH)) < 0) { scrnwidth = 256; } if ((scrnheight = glutGet(GLUT_SCREEN_HEIGHT)) < 0) { scrnheight = 256; } vw = min(jas_image_width(gs.image), 0.95 * scrnwidth); vh = min(jas_image_height(gs.image), 0.95 * scrnheight); gs.vcx = (jas_image_tlx(gs.image) + jas_image_brx(gs.image)) / 2.0; gs.vcy = (jas_image_tly(gs.image) + jas_image_bry(gs.image)) / 2.0; gs.sx = 1.0; gs.sy = 1.0; if (gs.altimage) { gs.monomode = 0; } else { gs.monomode = 1; gs.cmptno = 0; } #if 1 jas_eprintf("num of components %d\n", jas_image_numcmpts(gs.image)); #endif if (vw < jas_image_width(gs.image)) { gs.sx = jas_image_width(gs.image) / ((float) vw); } if (vh < jas_image_height(gs.image)) { gs.sy = jas_image_height(gs.image) / ((float) vh); } if (gs.sx > gs.sy) { gs.sy = gs.sx; } else if (gs.sx < gs.sy) { gs.sx = gs.sy; } vw = jas_image_width(gs.image) / gs.sx; vh = jas_image_height(gs.image) / gs.sy; gs.dirty = 1; reshapeflag = 0; if (vw != glutGet(GLUT_WINDOW_WIDTH) || vh != glutGet(GLUT_WINDOW_HEIGHT)) { glutReshapeWindow(vw, vh); reshapeflag = 1; } if (cmdopts.title) { glutSetWindowTitle(cmdopts.title); } else { glutSetWindowTitle((pathname && pathname[0] != '\0') ? pathname : "stdin"); } /* If we reshaped the window, GLUT will automatically invoke both the reshape and display callback (in this order). Therefore, we only need to explicitly force the display callback to be invoked if the window was not reshaped. */ if (!reshapeflag) { glutPostRedisplay(); } if (cmdopts.tmout != 0) { glutTimerFunc(cmdopts.tmout, timer, gs.nexttmid); gs.activetmid = gs.nexttmid; ++gs.nexttmid; } return 0; error: unloadimage(); return -1; }
static void special(int key, int x, int y) { if (cmdopts.verbose) { jas_eprintf("special(%d, %d, %d)\n", key, x, y); } switch (key) { case GLUT_KEY_UP: { float oldvcy; float vh; float pan; if (gs.vp.height < jas_image_height(gs.image) / gs.sy) { pan = (glutGetModifiers() & GLUT_ACTIVE_SHIFT) ? BIGPAN : SMALLPAN; oldvcy = gs.vcy; vh = gs.sy * gs.vp.height; gs.vcy = max(gs.vcy - pan * vh, jas_image_tly(gs.image) + 0.5 * vh); if (gs.vcy != oldvcy) { gs.dirty = 1; glutPostRedisplay(); } } } break; case GLUT_KEY_DOWN: { float oldvcy; float vh; float pan; if (gs.vp.height < jas_image_height(gs.image) / gs.sy) { pan = (glutGetModifiers() & GLUT_ACTIVE_SHIFT) ? BIGPAN : SMALLPAN; oldvcy = gs.vcy; vh = gs.sy * gs.vp.height; gs.vcy = min(gs.vcy + pan * vh, jas_image_bry(gs.image) - 0.5 * vh); if (gs.vcy != oldvcy) { gs.dirty = 1; glutPostRedisplay(); } } } break; case GLUT_KEY_LEFT: { float oldvcx; float vw; float pan; if (gs.vp.width < jas_image_width(gs.image) / gs.sx) { pan = (glutGetModifiers() & GLUT_ACTIVE_SHIFT) ? BIGPAN : SMALLPAN; oldvcx = gs.vcx; vw = gs.sx * gs.vp.width; gs.vcx = max(gs.vcx - pan * vw, jas_image_tlx(gs.image) + 0.5 * vw); if (gs.vcx != oldvcx) { gs.dirty = 1; glutPostRedisplay(); } } } break; case GLUT_KEY_RIGHT: { float oldvcx; float vw; float pan; if (gs.vp.width < jas_image_width(gs.image) / gs.sx) { pan = (glutGetModifiers() & GLUT_ACTIVE_SHIFT) ? BIGPAN : SMALLPAN; oldvcx = gs.vcx; vw = gs.sx * gs.vp.width; gs.vcx = min(gs.vcx + pan * vw, jas_image_brx(gs.image) - 0.5 * vw); if (gs.vcx != oldvcx) { gs.dirty = 1; glutPostRedisplay(); } } } break; default: break; } }