Merged img_display() into img_render()
This commit is contained in:
		
							parent
							
								
									44921e07aa
								
							
						
					
					
						commit
						629d37376d
					
				
							
								
								
									
										57
									
								
								image.c
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								image.c
									
									
									
									
									
								
							| @ -62,40 +62,13 @@ int img_load(img_t *img, const char *filename) { | |||||||
| 
 | 
 | ||||||
| 	imlib_context_set_image(im); | 	imlib_context_set_image(im); | ||||||
| 
 | 
 | ||||||
|  | 	img->re = 0; | ||||||
| 	img->w = imlib_image_get_width(); | 	img->w = imlib_image_get_width(); | ||||||
| 	img->h = imlib_image_get_height(); | 	img->h = imlib_image_get_height(); | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void img_display(img_t *img, win_t *win) { |  | ||||||
| 	float zw, zh; |  | ||||||
| 
 |  | ||||||
| 	if (!img || !win || !imlib_context_get_image()) |  | ||||||
| 		return; |  | ||||||
| 
 |  | ||||||
| 	/* set zoom level to fit image into window */ |  | ||||||
| 	if (img->scalemode != SCALE_ZOOM) { |  | ||||||
| 		zw = (float) win->w / (float) img->w; |  | ||||||
| 		zh = (float) win->h / (float) img->h; |  | ||||||
| 		img->zoom = MIN(zw, zh); |  | ||||||
| 
 |  | ||||||
| 		if (img->zoom < zoom_min) |  | ||||||
| 			img->zoom = zoom_min; |  | ||||||
| 		else if (img->zoom > zoom_max) |  | ||||||
| 			img->zoom = zoom_max; |  | ||||||
| 
 |  | ||||||
| 		if (img->scalemode == SCALE_DOWN && img->zoom > 1.0) |  | ||||||
| 			img->zoom = 1.0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	/* center image in window */ |  | ||||||
| 	img->x = (win->w - img->w * img->zoom) / 2; |  | ||||||
| 	img->y = (win->h - img->h * img->zoom) / 2; |  | ||||||
| 
 |  | ||||||
| 	img_render(img, win); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void img_check_pan(img_t *img, win_t *win) { | void img_check_pan(img_t *img, win_t *win) { | ||||||
| 	if (!img) | 	if (!img) | ||||||
| 		return; | 		return; | ||||||
| @ -121,11 +94,37 @@ void img_check_pan(img_t *img, win_t *win) { | |||||||
| void img_render(img_t *img, win_t *win) { | void img_render(img_t *img, win_t *win) { | ||||||
| 	int sx, sy, sw, sh; | 	int sx, sy, sw, sh; | ||||||
| 	int dx, dy, dw, dh; | 	int dx, dy, dw, dh; | ||||||
|  | 	float zw, zh; | ||||||
| 
 | 
 | ||||||
| 	if (!img || !win || !imlib_context_get_image()) | 	if (!img || !win || !imlib_context_get_image()) | ||||||
| 		return; | 		return; | ||||||
| 
 | 
 | ||||||
| 	img_check_pan(img, win); | 	if (!img->re) { | ||||||
|  | 		/* rendered for the first time */ | ||||||
|  | 		img->re = 1; | ||||||
|  | 
 | ||||||
|  | 		/* set zoom level to fit image into window */ | ||||||
|  | 		if (img->scalemode != SCALE_ZOOM) { | ||||||
|  | 			zw = (float) win->w / (float) img->w; | ||||||
|  | 			zh = (float) win->h / (float) img->h; | ||||||
|  | 			img->zoom = MIN(zw, zh); | ||||||
|  | 
 | ||||||
|  | 			if (img->zoom < zoom_min) | ||||||
|  | 				img->zoom = zoom_min; | ||||||
|  | 			else if (img->zoom > zoom_max) | ||||||
|  | 				img->zoom = zoom_max; | ||||||
|  | 
 | ||||||
|  | 			if (img->scalemode == SCALE_DOWN && img->zoom > 1.0) | ||||||
|  | 				img->zoom = 1.0; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		/* center image in window */ | ||||||
|  | 		img->x = (win->w - img->w * img->zoom) / 2; | ||||||
|  | 		img->y = (win->h - img->h * img->zoom) / 2; | ||||||
|  | 	} else { | ||||||
|  | 		/* typically after zooming and panning */ | ||||||
|  | 		img_check_pan(img, win); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if (img->x < 0) { | 	if (img->x < 0) { | ||||||
| 		sx = -img->x / img->zoom; | 		sx = -img->x / img->zoom; | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								image.h
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								image.h
									
									
									
									
									
								
							| @ -30,6 +30,7 @@ typedef enum scalemode_e { | |||||||
| typedef struct img_s { | typedef struct img_s { | ||||||
| 	float zoom; | 	float zoom; | ||||||
| 	scalemode_t scalemode; | 	scalemode_t scalemode; | ||||||
|  | 	unsigned char re; | ||||||
| 	int x; | 	int x; | ||||||
| 	int y; | 	int y; | ||||||
| 	int w; | 	int w; | ||||||
| @ -40,7 +41,6 @@ void imlib_init(win_t*); | |||||||
| void imlib_destroy(); | void imlib_destroy(); | ||||||
| 
 | 
 | ||||||
| int img_load(img_t*, const char*); | int img_load(img_t*, const char*); | ||||||
| void img_display(img_t*, win_t*); |  | ||||||
| void img_render(img_t*, win_t*); | void img_render(img_t*, win_t*); | ||||||
| 
 | 
 | ||||||
| int img_zoom_in(img_t*); | int img_zoom_in(img_t*); | ||||||
|  | |||||||
							
								
								
									
										6
									
								
								main.c
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								main.c
									
									
									
									
									
								
							| @ -93,7 +93,7 @@ int main(int argc, char **argv) { | |||||||
| 	imlib_init(&win); | 	imlib_init(&win); | ||||||
| 
 | 
 | ||||||
| 	img_load(&img, filenames[fileidx]); | 	img_load(&img, filenames[fileidx]); | ||||||
| 	img_display(&img, &win); | 	img_render(&img, &win); | ||||||
| 	update_title(); | 	update_title(); | ||||||
| 
 | 
 | ||||||
| 	run(); | 	run(); | ||||||
| @ -146,14 +146,14 @@ void on_keypress(XEvent *ev) { | |||||||
| 		case 'n': | 		case 'n': | ||||||
| 			if (fileidx + 1 < filecnt) { | 			if (fileidx + 1 < filecnt) { | ||||||
| 				img_load(&img, filenames[++fileidx]); | 				img_load(&img, filenames[++fileidx]); | ||||||
| 				img_display(&img, &win); | 				img_render(&img, &win); | ||||||
| 				update_title(); | 				update_title(); | ||||||
| 			} | 			} | ||||||
| 			break; | 			break; | ||||||
| 		case 'p': | 		case 'p': | ||||||
| 			if (fileidx > 0) { | 			if (fileidx > 0) { | ||||||
| 				img_load(&img, filenames[--fileidx]); | 				img_load(&img, filenames[--fileidx]); | ||||||
| 				img_display(&img, &win); | 				img_render(&img, &win); | ||||||
| 				update_title(); | 				update_title(); | ||||||
| 			} | 			} | ||||||
| 			break; | 			break; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Bert
						Bert