= 0 and opacity "/> = 0 and opacity ">
Rumah > pembangunan bahagian belakang > Tutorial Python > python使用PIL制作水印

python使用PIL制作水印

巴扎黑
Lepaskan: 2016-12-08 10:50:25
asal
1610 orang telah melayarinya

import Image, ImageEnhance
 
def reduce_opacity(im, opacity):
    """Returns an image with reduced opacity."""
    assert opacity >= 0 and opacity <= 1
    if im.mode != &#39;RGBA&#39;:
        im = im.convert(&#39;RGBA&#39;)
    else:
        im = im.copy()
    alpha = im.split()[3]
    alpha = ImageEnhance.Brightness(alpha).enhance(opacity)
    im.putalpha(alpha)
    return im
 
def watermark(im, mark, position, opacity=1):
    """Adds a watermark to an image."""
    if opacity < 1:
        mark = reduce_opacity(mark, opacity)
    if im.mode != &#39;RGBA&#39;:
        im = im.convert(&#39;RGBA&#39;)
    # create a transparent layer the size of the image and draw the
    # watermark in that layer.
    layer = Image.new(&#39;RGBA&#39;, im.size, (0,0,0,0))
    if position == &#39;tile&#39;:
        for y in range(0, im.size[1], mark.size[1]):
            for x in range(0, im.size[0], mark.size[0]):
                layer.paste(mark, (x, y))
    elif position == &#39;scale&#39;:
        # scale, but preserve the aspect ratio
        ratio = min(
            float(im.size[0]) / mark.size[0], float(im.size[1]) / mark.size[1])
        w = int(mark.size[0] * ratio)
        h = int(mark.size[1] * ratio)
        mark = mark.resize((w, h))
        layer.paste(mark, ((im.size[0] - w) / 2, (im.size[1] - h) / 2))
    else:
        layer.paste(mark, position)
    # composite the watermark with the layer
    return Image.composite(layer, im, layer)
 
def test():
    im = Image.open(&#39;test.png&#39;)
    mark = Image.open(&#39;overlay.png&#39;)
    watermark(im, mark, &#39;tile&#39;, 0.5).show()
    watermark(im, mark, &#39;scale&#39;, 1.0).show()
    watermark(im, mark, (100, 100), 0.5).show()
 
if __name__ == &#39;__main__&#39;:
    test()
Salin selepas log masuk

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan