void winwidget_render_image(winwidget winwid, int resize, int force_alias) { int sx, sy, sw, sh, dx, dy, dw, dh; int calc_w, calc_h; int antialias = 0; if (!winwid->full_screen && resize) { winwidget_resize(winwid, winwid->im_w, winwid->im_h, 0); winwidget_reset_image(winwid); } D(("winwidget_render_image resize %d force_alias %d im %dx%d\n", resize, force_alias, winwid->im_w, winwid->im_h)); /* winwidget_setup_pixmaps(winwid) resets the winwid->had_resize flag */ int had_resize = winwid->had_resize || resize; winwidget_setup_pixmaps(winwid); if (had_resize && !opt.keep_zoom_vp && (winwid->type != WIN_TYPE_THUMBNAIL)) { double required_zoom = 1.0; feh_calc_needed_zoom(&required_zoom, winwid->im_w, winwid->im_h, winwid->w, winwid->h); winwid->zoom = opt.default_zoom ? (0.01 * opt.default_zoom) : 1.0; if ((opt.scale_down || (winwid->full_screen && !opt.default_zoom)) && winwid->zoom > required_zoom) winwid->zoom = required_zoom; else if ((opt.zoom_mode && required_zoom > 1) && (!opt.default_zoom || required_zoom < winwid->zoom)) winwid->zoom = required_zoom; if (opt.offset_flags & XValue) { if (opt.offset_flags & XNegative) { winwid->im_x = winwid->w - (winwid->im_w * winwid->zoom) - opt.offset_x; } else { winwid->im_x = - opt.offset_x * winwid->zoom; } } else { winwid->im_x = (int) (winwid->w - (winwid->im_w * winwid->zoom)) >> 1; } if (opt.offset_flags & YValue) { if (opt.offset_flags & YNegative) { winwid->im_y = winwid->h - (winwid->im_h * winwid->zoom) - opt.offset_y; } else { winwid->im_y = - opt.offset_y * winwid->zoom; } } else { winwid->im_y = (int) (winwid->h - (winwid->im_h * winwid->zoom)) >> 1; } }
void winwidget_render_image(winwidget winwid, int resize, int force_alias) { int sx, sy, sw, sh, dx, dy, dw, dh; int calc_w, calc_h; int antialias = 0; int need_center = winwid->had_resize; if (!winwid->full_screen && resize) { winwidget_resize(winwid, winwid->im_w, winwid->im_h); winwidget_reset_image(winwid); } /* bounds checks for panning */ if (winwid->im_x > winwid->w) winwid->im_x = winwid->w; if (winwid->im_y > winwid->h) winwid->im_y = winwid->h; D(("winwidget_render_image resize %d force_alias %d im %dx%d\n", resize, force_alias, winwid->im_w, winwid->im_h)); winwidget_setup_pixmaps(winwid); if (!winwid->full_screen && opt.scale_down && ((winwid->w < winwid->im_w) || (winwid->h < winwid->im_h)) && (winwid->type != WIN_TYPE_THUMBNAIL) && (winwid->old_zoom == 1.0)) { D(("scaling down image %dx%d\n", winwid->w, winwid->h)); feh_calc_needed_zoom(&(winwid->zoom), winwid->im_w, winwid->im_h, winwid->w, winwid->h); if (resize) winwidget_resize(winwid, winwid->im_w * winwid->zoom, winwid->im_h * winwid->zoom); D(("after scaling down image %dx%d\n", winwid->w, winwid->h)); } if (!winwid->full_screen && ((gib_imlib_image_has_alpha(winwid->im)) || (opt.geom_flags & (WidthValue | HeightValue)) || (winwid->im_x || winwid->im_y) || (winwid->zoom != 1.0) || (winwid->w > winwid->im_w || winwid->h > winwid->im_h) || (winwid->has_rotated))) feh_draw_checks(winwid); if (!winwid->full_screen && opt.zoom_mode && (winwid->zoom == 1.0) && ! (opt.geom_flags & (WidthValue | HeightValue)) && (winwid->w > winwid->im_w) && (winwid->h > winwid->im_h)) feh_calc_needed_zoom(&(winwid->zoom), winwid->im_w, winwid->im_h, winwid->w, winwid->h); if (resize && (winwid->full_screen || (opt.geom_flags & (WidthValue | HeightValue)))) { int smaller; /* Is the image smaller than screen? */ int max_w = 0, max_h = 0; if (winwid->full_screen) { max_w = scr->width; max_h = scr->height; #ifdef HAVE_LIBXINERAMA if (opt.xinerama && xinerama_screens) { max_w = xinerama_screens[xinerama_screen].width; max_h = xinerama_screens[xinerama_screen].height; } #endif /* HAVE_LIBXINERAMA */ } else { if (opt.geom_flags & WidthValue) { max_w = opt.geom_w; } if (opt.geom_flags & HeightValue) { max_h = opt.geom_h; } } D(("Calculating for fullscreen/fixed geom render\n")); smaller = ((winwid->im_w < max_w) && (winwid->im_h < max_h)); if (!smaller || opt.zoom_mode) { double ratio = 0.0; /* Image is larger than the screen (so wants shrinking), or it's smaller but wants expanding to fill it */ ratio = feh_calc_needed_zoom(&(winwid->zoom), winwid->im_w, winwid->im_h, max_w, max_h); /* contributed by Jens Laas <*****@*****.**> * What it does: * zooms images by a fixed amount but never larger than the screen. * * Why: * This is nice if you got a collection of images where some * are small and can stand a small zoom. Large images are unaffected. * * When does it work, and how? * You have to be in fullscreen mode _and_ have auto-zoom turned on. * "feh -FZ --zoom 130 imagefile" will do the trick. * -zoom percent - the new switch. * 100 = orignal size, * 130 is 30% larger. */ if (opt.default_zoom) { double old_zoom = winwid->zoom; winwid->zoom = 0.01 * opt.default_zoom; if (winwid->zoom != 1.0) { if ((winwid->im_h * winwid->zoom) > max_h) winwid->zoom = old_zoom; else if ((winwid->im_w * winwid->zoom) > max_w) winwid->zoom = old_zoom; } winwid->im_x = ((int) (max_w - (winwid->im_w * winwid->zoom))) >> 1; winwid->im_y = ((int) (max_h - (winwid->im_h * winwid->zoom))) >> 1; } else {