當前位置: 首頁>>代碼示例>>Python>>正文


Python PngImagePlugin.PngInfo方法代碼示例

本文整理匯總了Python中PIL.PngImagePlugin.PngInfo方法的典型用法代碼示例。如果您正苦於以下問題:Python PngImagePlugin.PngInfo方法的具體用法?Python PngImagePlugin.PngInfo怎麽用?Python PngImagePlugin.PngInfo使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在PIL.PngImagePlugin的用法示例。


在下文中一共展示了PngImagePlugin.PngInfo方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_dos_total_memory

# 需要導入模塊: from PIL import PngImagePlugin [as 別名]
# 或者: from PIL.PngImagePlugin import PngInfo [as 別名]
def test_dos_total_memory(self):
        im = Image.new('L', (1, 1))
        compressed_data = zlib.compress(b'a'*1024*1023)

        info = PngImagePlugin.PngInfo()

        for x in range(64):
            info.add_text('t%s' % x, compressed_data, zip=True)
            info.add_itxt('i%s' % x, compressed_data, zip=True)

        b = BytesIO()
        im.save(b, 'PNG', pnginfo=info)
        b.seek(0)

        try:
            im2 = Image.open(b)
        except ValueError as msg:
            self.assertIn("Too much memory", msg)
            return

        total_len = 0
        for txt in im2.text.values():
            total_len += len(txt)
        self.assertLess(total_len, 64*1024*1024,
                        "Total text chunks greater than 64M") 
開發者ID:holzschu,項目名稱:python3_ios,代碼行數:27,代碼來源:check_png_dos.py

示例2: test_roundtrip_itxt

# 需要導入模塊: from PIL import PngImagePlugin [as 別名]
# 或者: from PIL.PngImagePlugin import PngInfo [as 別名]
def test_roundtrip_itxt(self):
        # Check iTXt roundtripping

        im = Image.new("RGB", (32, 32))
        info = PngImagePlugin.PngInfo()
        info.add_itxt("spam", "Eggs", "en", "Spam")
        info.add_text("eggs", PngImagePlugin.iTXt("Spam", "en", "Eggs"),
                      zip=True)

        im = roundtrip(im, pnginfo=info)
        self.assertEqual(im.info, {"spam": "Eggs", "eggs": "Spam"})
        self.assertEqual(im.text, {"spam": "Eggs", "eggs": "Spam"})
        self.assertEqual(im.text["spam"].lang, "en")
        self.assertEqual(im.text["spam"].tkey, "Spam")
        self.assertEqual(im.text["eggs"].lang, "en")
        self.assertEqual(im.text["eggs"].tkey, "Eggs") 
開發者ID:holzschu,項目名稱:python3_ios,代碼行數:18,代碼來源:test_file_png.py

示例3: test_unicode_text

# 需要導入模塊: from PIL import PngImagePlugin [as 別名]
# 或者: from PIL.PngImagePlugin import PngInfo [as 別名]
def test_unicode_text(self):
        # Check preservation of non-ASCII characters on Python 3
        # This cannot really be meaningfully tested on Python 2,
        # since it didn't preserve charsets to begin with.

        def rt_text(value):
            im = Image.new("RGB", (32, 32))
            info = PngImagePlugin.PngInfo()
            info.add_text("Text", value)
            im = roundtrip(im, pnginfo=info)
            self.assertEqual(im.info, {"Text": value})

        if py3:
            rt_text(" Aa" + chr(0xa0) + chr(0xc4) + chr(0xff))  # Latin1
            rt_text(chr(0x400) + chr(0x472) + chr(0x4ff))       # Cyrillic
            rt_text(chr(0x4e00) + chr(0x66f0) +                 # CJK
                    chr(0x9fba) + chr(0x3042) + chr(0xac00))
            rt_text("A" + chr(0xc4) + chr(0x472) + chr(0x3042))  # Combined 
開發者ID:holzschu,項目名稱:python3_ios,代碼行數:20,代碼來源:test_file_png.py

示例4: test_roundtrip_text

# 需要導入模塊: from PIL import PngImagePlugin [as 別名]
# 或者: from PIL.PngImagePlugin import PngInfo [as 別名]
def test_roundtrip_text(self):
        # Check text roundtripping

        im = Image.open(TEST_PNG_FILE)

        info = PngImagePlugin.PngInfo()
        info.add_text("TXT", "VALUE")
        info.add_text("ZIP", "VALUE", zip=True)

        im = roundtrip(im, pnginfo=info)
        self.assertEqual(im.info, {'TXT': 'VALUE', 'ZIP': 'VALUE'})
        self.assertEqual(im.text, {'TXT': 'VALUE', 'ZIP': 'VALUE'}) 
開發者ID:holzschu,項目名稱:python3_ios,代碼行數:14,代碼來源:test_file_png.py

示例5: test_nonunicode_text

# 需要導入模塊: from PIL import PngImagePlugin [as 別名]
# 或者: from PIL.PngImagePlugin import PngInfo [as 別名]
def test_nonunicode_text(self):
        # Check so that non-Unicode text is saved as a tEXt rather than iTXt

        im = Image.new("RGB", (32, 32))
        info = PngImagePlugin.PngInfo()
        info.add_text("Text", "Ascii")
        im = roundtrip(im, pnginfo=info)
        self.assertIsInstance(im.info["Text"], str) 
開發者ID:holzschu,項目名稱:python3_ios,代碼行數:10,代碼來源:test_file_png.py

示例6: pngsave

# 需要導入模塊: from PIL import PngImagePlugin [as 別名]
# 或者: from PIL.PngImagePlugin import PngInfo [as 別名]
def pngsave(A, file, info={}):
    """
        wrapper around PIL 1.1.7 Image.save to preserve PNG metadata
        based on public domain script by Nick Galbreath                                                                                                        

        http://blog.modp.com/2007/08/python-pil-and-png-metadata-take-2.html                                                                 
    """
    from PIL import Image, PngImagePlugin
    im = Image.fromarray(256.0*A).convert('RGB')
    reserved = ('interlace', 'gamma', 'dpi', 'transparency', 'aspect')
    meta = PngImagePlugin.PngInfo()
    for k,v in _iteritems(info):
        if k in reserved: continue
        meta.add_text(k, v, 0)
    im.save(file, "PNG", pnginfo=meta) 
開發者ID:jahuth,項目名稱:convis,代碼行數:17,代碼來源:png.py

示例7: png_client

# 需要導入模塊: from PIL import PngImagePlugin [as 別名]
# 或者: from PIL.PngImagePlugin import PngInfo [as 別名]
def png_client(images,info={},port=10000,host='localhost',compress_level=0,resize=(1.0,1.0)):
    if len(images.shape) == 2:
        images = [images]
    # Create a TCP/IP socket
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

    # Connect the socket to the port where the server is listening
    server_address = (host, port)
    sock.connect(server_address)
    try:
        for A in images:
            im = Image.fromarray(256.0*A).convert('RGB')
            if resize != (1.0,1.0) and resize is not None:
                if not type(resize) == tuple:
                    resize = (resize,resize)
                im = im.resize((int(resize[0]*im.size[0]), int(resize[1]*im.size[1])), PIL.Image.ANTIALIAS)
            output = StringIO.StringIO()
            meta = PngImagePlugin.PngInfo()
            reserved = ('interlace', 'gamma', 'dpi', 'transparency', 'aspect')
            for k,v in _iteritems(info):
                if k in reserved:
                    continue
                meta.add_text(str(k), str(v), 0)
            im.save(output, format="PNG", pnginfo=meta, compress_level=compress_level)
            message = output.getvalue()
            output.close()
            sock.sendall(message)
    finally:
        sock.close() 
開發者ID:jahuth,項目名稱:convis,代碼行數:31,代碼來源:png.py

示例8: save_png_with_metadata

# 需要導入模塊: from PIL import PngImagePlugin [as 別名]
# 或者: from PIL.PngImagePlugin import PngInfo [as 別名]
def save_png_with_metadata(fig, filename, fig_kwds, kwds):
    """ Save a matplotlib figure to a png with metadata
    """
    from PIL import Image, PngImagePlugin
    fig.savefig(filename, **fig_kwds)

    im = Image.open(filename)
    meta = PngImagePlugin.PngInfo()

    for key in kwds:
        meta.add_text(str(key), str(kwds[key]))

    im.save(filename, "png", pnginfo=meta) 
開發者ID:gwastro,項目名稱:pycbc,代碼行數:15,代碼來源:metadata.py


注:本文中的PIL.PngImagePlugin.PngInfo方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。