mirror of
				https://github.com/RaySollium99/libpicofe.git
				synced 2025-10-26 09:09:40 -04:00 
			
		
		
		
	readpng: put image on center if it's too large
This commit is contained in:
		
							parent
							
								
									6282e17ef5
								
							
						
					
					
						commit
						8ef1ad3218
					
				
					 1 changed files with 9 additions and 4 deletions
				
			
		
							
								
								
									
										13
									
								
								readpng.c
									
										
									
									
									
								
							
							
						
						
									
										13
									
								
								readpng.c
									
										
									
									
									
								
							|  | @ -68,23 +68,28 @@ int readpng(void *dest, const char *fname, readpng_what what, int req_w, int req | |||
| 	{ | ||||
| 		case READPNG_BG: | ||||
| 		{ | ||||
| 			int height, width, h; | ||||
| 			int height, width, h, x_ofs = 0, y_ofs = 0; | ||||
| 			unsigned short *dst = dest; | ||||
| 
 | ||||
| 			if (png_get_bit_depth(png_ptr, info_ptr) != 8) | ||||
| 			{ | ||||
| 				lprintf(__FILE__ ": bg image uses %ibpc, needed 8bpc\n", png_get_bit_depth(png_ptr, info_ptr)); | ||||
| 				break; | ||||
| 			} | ||||
| 			width = png_get_image_width(png_ptr, info_ptr); | ||||
| 			if (width > req_w) | ||||
| 			if (width > req_w) { | ||||
| 				x_ofs = (width - req_w) / 2; | ||||
| 				width = req_w; | ||||
| 			} | ||||
| 			height = png_get_image_height(png_ptr, info_ptr); | ||||
| 			if (height > req_h) | ||||
| 			if (height > req_h) { | ||||
| 				y_ofs = (height - req_h) / 2; | ||||
| 				height = req_h; | ||||
| 			} | ||||
| 
 | ||||
| 			for (h = 0; h < height; h++) | ||||
| 			{ | ||||
| 				unsigned char *src = row_ptr[h]; | ||||
| 				unsigned char *src = row_ptr[h + y_ofs] + x_ofs * 3; | ||||
| 				int len = width; | ||||
| 				while (len--) | ||||
| 				{ | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Grazvydas Ignotas
						Grazvydas Ignotas