mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 09:32:31 +00:00 
			
		
		
		
	 6a23dfbc92
			
		
	
	
		6a23dfbc92
		
	
	
	
	
		
			
			PBM, PGM, and PPM image loaders are mostly common. The only difference is how the data is read and the associated magic numbers. The magic numbers are already made common using the loading contexts. Now make the implementations common via a class template which accepts the context to disambiguate.
		
			
				
	
	
		
			72 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020, Hüseyin ASLITÜRK <asliturk@hotmail.com>
 | |
|  * Copyright (c) 2022, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include "PPMLoader.h"
 | |
| #include "PortableImageLoaderCommon.h"
 | |
| #include "Streamer.h"
 | |
| #include <AK/Endian.h>
 | |
| #include <AK/LexicalPath.h>
 | |
| #include <AK/ScopeGuard.h>
 | |
| #include <AK/StringBuilder.h>
 | |
| #include <string.h>
 | |
| 
 | |
| namespace Gfx {
 | |
| 
 | |
| bool read_image_data(PPMLoadingContext& context, Streamer& streamer)
 | |
| {
 | |
|     Vector<Gfx::Color> color_data;
 | |
|     color_data.ensure_capacity(context.width * context.height);
 | |
| 
 | |
|     if (context.type == PPMLoadingContext::Type::ASCII) {
 | |
|         u16 red;
 | |
|         u16 green;
 | |
|         u16 blue;
 | |
| 
 | |
|         while (true) {
 | |
|             if (!read_number(streamer, &red))
 | |
|                 break;
 | |
| 
 | |
|             if (!read_whitespace(context, streamer))
 | |
|                 break;
 | |
| 
 | |
|             if (!read_number(streamer, &green))
 | |
|                 break;
 | |
| 
 | |
|             if (!read_whitespace(context, streamer))
 | |
|                 break;
 | |
| 
 | |
|             if (!read_number(streamer, &blue))
 | |
|                 break;
 | |
| 
 | |
|             if (!read_whitespace(context, streamer))
 | |
|                 break;
 | |
| 
 | |
|             Color color { (u8)red, (u8)green, (u8)blue };
 | |
|             if (context.format_details.max_val < 255)
 | |
|                 color = adjust_color(context.format_details.max_val, color);
 | |
|             color_data.append(color);
 | |
|         }
 | |
|     } else if (context.type == PPMLoadingContext::Type::RAWBITS) {
 | |
|         u8 pixel[3];
 | |
|         while (streamer.read_bytes(pixel, 3)) {
 | |
|             color_data.append({ pixel[0], pixel[1], pixel[2] });
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if (context.width * context.height != color_data.size())
 | |
|         return false;
 | |
| 
 | |
|     if (!create_bitmap(context)) {
 | |
|         return false;
 | |
|     }
 | |
| 
 | |
|     set_pixels(context, color_data);
 | |
| 
 | |
|     context.state = PPMLoadingContext::State::Bitmap;
 | |
|     return true;
 | |
| }
 | |
| }
 |