openmedialibrary_platform/Darwin/lib/python3.5/site-packages/PIL/CurImagePlugin.py

87 lines
1.9 KiB
Python
Raw Normal View History

2013-10-11 17:28:32 +00:00
#
# The Python Imaging Library.
# $Id$
#
# Windows Cursor support for PIL
#
# notes:
# uses BmpImagePlugin.py to read the bitmap data.
#
# history:
# 96-05-27 fl Created
#
# Copyright (c) Secret Labs AB 1997.
# Copyright (c) Fredrik Lundh 1996.
#
# See the README file for information on usage and redistribution.
#
2014-09-30 16:15:32 +00:00
from PIL import Image, BmpImagePlugin, _binary
2013-10-11 17:28:32 +00:00
2015-11-25 01:25:01 +00:00
__version__ = "0.1"
2013-10-11 17:28:32 +00:00
#
# --------------------------------------------------------------------
2014-09-30 16:15:32 +00:00
i8 = _binary.i8
i16 = _binary.i16le
i32 = _binary.i32le
2013-10-11 17:28:32 +00:00
def _accept(prefix):
2014-09-30 16:15:32 +00:00
return prefix[:4] == b"\0\0\2\0"
2013-10-11 17:28:32 +00:00
2015-11-25 01:25:01 +00:00
2013-10-11 17:28:32 +00:00
##
# Image plugin for Windows Cursor files.
class CurImageFile(BmpImagePlugin.BmpImageFile):
format = "CUR"
format_description = "Windows Cursor"
def _open(self):
offset = self.fp.tell()
# check magic
s = self.fp.read(6)
if not _accept(s):
2015-11-25 01:25:01 +00:00
raise SyntaxError("not a CUR file")
2013-10-11 17:28:32 +00:00
# pick the largest cursor in the file
2014-09-30 16:15:32 +00:00
m = b""
2013-10-11 17:28:32 +00:00
for i in range(i16(s[4:])):
s = self.fp.read(16)
if not m:
m = s
2014-09-30 16:15:32 +00:00
elif i8(s[0]) > i8(m[0]) and i8(s[1]) > i8(m[1]):
2013-10-11 17:28:32 +00:00
m = s
2015-11-25 01:25:01 +00:00
# print "width", i8(s[0])
# print "height", i8(s[1])
# print "colors", i8(s[2])
# print "reserved", i8(s[3])
# print "hotspot x", i16(s[4:])
# print "hotspot y", i16(s[6:])
# print "bytes", i32(s[8:])
# print "offset", i32(s[12:])
2013-10-11 17:28:32 +00:00
# load as bitmap
self._bitmap(i32(m[12:]) + offset)
# patch up the bitmap height
2014-09-30 16:15:32 +00:00
self.size = self.size[0], self.size[1]//2
2013-10-11 17:28:32 +00:00
d, e, o, a = self.tile[0]
2015-11-25 01:25:01 +00:00
self.tile[0] = d, (0, 0)+self.size, o, a
2013-10-11 17:28:32 +00:00
return
#
# --------------------------------------------------------------------
2015-11-25 01:25:01 +00:00
Image.register_open(CurImageFile.format, CurImageFile, _accept)
2013-10-11 17:28:32 +00:00
2015-11-25 01:25:01 +00:00
Image.register_extension(CurImageFile.format, ".cur")