mirror of
				https://github.com/python-pillow/Pillow.git
				synced 2025-10-26 05:31:02 +03:00 
			
		
		
		
	Update BmpImagePlugin.py
Fails on Python 3, tried some fixes before going the virtualenv3 route
This commit is contained in:
		
							parent
							
								
									514c55aa16
								
							
						
					
					
						commit
						310684521a
					
				|  | @ -23,8 +23,10 @@ | ||||||
| # See the README file for information on usage and redistribution. | # See the README file for information on usage and redistribution. | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| __version__ = "0.7" | __version__ = "0.7" | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| from PIL import Image, ImageFile, ImagePalette, _binary | from PIL import Image, ImageFile, ImagePalette, _binary | ||||||
| import math | import math | ||||||
| 
 | 
 | ||||||
|  | @ -47,7 +49,7 @@ BIT2MODE = { | ||||||
|     8: ("P", "P"), |     8: ("P", "P"), | ||||||
|     16: ("RGB", "BGR;15"), |     16: ("RGB", "BGR;15"), | ||||||
|     24: ("RGB", "BGR"), |     24: ("RGB", "BGR"), | ||||||
|     32: ("RGB", "BGRX") |     32: ("RGB", "BGRX"), | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -68,18 +70,6 @@ class BmpImageFile(ImageFile.ImageFile): | ||||||
|     COMPRESSIONS = {'RAW': 0, 'RLE8': 1, 'RLE4': 2, 'BITFIELDS': 3, 'JPEG': 4, 'PNG': 5} |     COMPRESSIONS = {'RAW': 0, 'RLE8': 1, 'RLE4': 2, 'BITFIELDS': 3, 'JPEG': 4, 'PNG': 5} | ||||||
|     RAW, RLE8, RLE4, BITFIELDS, JPEG, PNG = 0, 1, 2, 3, 4, 5 |     RAW, RLE8, RLE4, BITFIELDS, JPEG, PNG = 0, 1, 2, 3, 4, 5 | ||||||
| 
 | 
 | ||||||
|     def _open(self): |  | ||||||
|         """ Open file, check magic number and read header """ |  | ||||||
|         # read 14 bytes: magic number, filesize, reserved, header final offset |  | ||||||
|         head_data = self.fp.read(14) |  | ||||||
|         # choke if the file does not have the required magic bytes |  | ||||||
|         if head_data[0:2] != b"BM": |  | ||||||
|             raise SyntaxError("Expected a BMP file.") |  | ||||||
|         # read the start position of the BMP image data (u32)  |  | ||||||
|         offset = i32(head_data[10:14]) |  | ||||||
|         # load bitmap information (offset=raster info) |  | ||||||
|         self._bitmap(offset=offset) |  | ||||||
| 
 |  | ||||||
|     def _bitmap(self, header=0, offset=0): |     def _bitmap(self, header=0, offset=0): | ||||||
|         """ Read relevant info about the BMP """ |         """ Read relevant info about the BMP """ | ||||||
|         read, seek = self.fp.read, self.fp.seek |         read, seek = self.fp.read, self.fp.seek | ||||||
|  | @ -185,6 +175,19 @@ class BmpImageFile(ImageFile.ImageFile): | ||||||
|                       (raw_mode, ((file_info['width'] * file_info['bits'] + 31) >> 3) & (~3), file_info['direction'])   |                       (raw_mode, ((file_info['width'] * file_info['bits'] + 31) >> 3) & (~3), file_info['direction'])   | ||||||
|                       )] |                       )] | ||||||
| 
 | 
 | ||||||
|  |     def _open(self): | ||||||
|  |         """ Open file, check magic number and read header """ | ||||||
|  |         # read 14 bytes: magic number, filesize, reserved, header final offset | ||||||
|  |         head_data = self.fp.read(14) | ||||||
|  |         # choke if the file does not have the required magic bytes | ||||||
|  |         if head_data[0:2] != b"BM": | ||||||
|  |             raise SyntaxError("Not a BMP file") | ||||||
|  |         # read the start position of the BMP image data (u32)  | ||||||
|  |         offset = i32(head_data[10:14]) | ||||||
|  |         # load bitmap information (offset=raster info) | ||||||
|  |         self._bitmap(offset=offset) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| #=============================================================================== | #=============================================================================== | ||||||
| # Image plugin for the DIB format (BMP alias) | # Image plugin for the DIB format (BMP alias) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user