home *** CD-ROM | disk | FTP | other *** search
/ Enter 2004 April / enter-2004-04.iso / files / EVE_1424_100181.exe / XbmImagePlugin.py < prev    next >
Encoding:
Text File  |  2004-04-20  |  2.3 KB  |  92 lines

  1. #
  2. # The Python Imaging Library.
  3. # $Id: //modules/pil/PIL/XbmImagePlugin.py#3 $
  4. #
  5. # XBM File handling
  6. #
  7. # History:
  8. # 1995-09-08 fl   Created
  9. # 1996-11-01 fl   Added save support
  10. # 1997-07-07 fl   Made header parser more tolerant
  11. # 1997-07-22 fl   Fixed yet another parser bug
  12. # 2001-02-17 fl   Use 're' instead of 'regex' (Python 2.1) (0.4)
  13. # 2001-05-13 fl   Added hotspot handling (based on code from Bernhard Herzog)
  14. #
  15. # Copyright (c) 1997-2001 by Secret Labs AB
  16. # Copyright (c) 1996-1997 by Fredrik Lundh
  17. #
  18. # See the README file for information on usage and redistribution.
  19. #
  20.  
  21. __version__ = "0.4"
  22.  
  23. import re, string
  24. import Image, ImageFile
  25.  
  26. # XBM header
  27. xbm_head = re.compile(
  28.     "#define[ \t]+[^_]*_width[ \t]+(?P<width>[0-9]+)[\r\n]+"
  29.     "#define[ \t]+[^_]*_height[ \t]+(?P<height>[0-9]+)[\r\n]+"
  30.     "(?P<hotspot>"
  31.     "#define[ \t]+[^_]*_x_hot[ \t]+(?P<xhot>[0-9]+)[\r\n]+"
  32.     "#define[ \t]+[^_]*_y_hot[ \t]+(?P<yhot>[0-9]+)[\r\n]+"
  33.     ")?"
  34.     "[\\000-\\377]*_bits\\[\\]"
  35. )
  36.  
  37. def _accept(prefix):
  38.     return prefix[:7] == "#define"
  39.  
  40.  
  41. class XbmImageFile(ImageFile.ImageFile):
  42.  
  43.     format = "XBM"
  44.     format_description = "X11 Bitmap"
  45.  
  46.     def _open(self):
  47.  
  48.         m = xbm_head.match(self.fp.read(512))
  49.  
  50.         if m:
  51.  
  52.             xsize = int(m.group("width"))
  53.             ysize = int(m.group("height"))
  54.  
  55.             if m.group("hotspot"):
  56.                 self.info["hotspot"] = (
  57.                     int(m.group("xhot")), int(m.group("yhot"))
  58.                     )
  59.  
  60.             self.mode = "1"
  61.             self.size = xsize, ysize
  62.  
  63.             self.tile = [("xbm", (0, 0)+self.size, m.end(), None)]
  64.  
  65.  
  66. def _save(im, fp, filename):
  67.  
  68.     if im.mode != "1":
  69.         raise IOError, "cannot write mode %s as XBM" % im.mode
  70.  
  71.     fp.write("#define im_width %d\n" % im.size[0])
  72.     fp.write("#define im_height %d\n" % im.size[1])
  73.  
  74.     hotspot = im.encoderinfo.get("hotspot")
  75.     if hotspot:
  76.         fp.write("#define im_x_hot %d\n" % hotspot[0])
  77.         fp.write("#define im_y_hot %d\n" % hotspot[1])
  78.  
  79.     fp.write("static char im_bits[] = {\n")
  80.  
  81.     ImageFile._save(im, fp, [("xbm", (0,0)+im.size, 0, None)])
  82.  
  83.     fp.write("};\n")
  84.  
  85.  
  86. Image.register_open("XBM", XbmImageFile, _accept)
  87. Image.register_save("XBM", _save)
  88.  
  89. Image.register_extension("XBM", ".xbm")
  90.  
  91. Image.register_mime("XBM", "image/xbm")
  92.