`
fengzl
  • 浏览: 216747 次
  • 性别: Icon_minigender_1
  • 来自: 宁波
社区版块
存档分类
最新评论

利用PIL生成水印图片或文字

阅读更多
[img][/img]

import Image, ImageEnhance

POSITION = ('LEFTTOP','RIGHTTOP','CENTER','LEFTBOTTOM','RIGHTBOTTOM')
PADDING = 10
MARKIMAGE = 'pylogs.png'

def reduce_opacity(im, opacity):
    """Returns an image with reduced opacity."""
    assert opacity >= 0 and opacity <= 1
    if im.mode != 'RGBA':
        im = im.convert('RGBA')
    else:
        im = im.copy()
    alpha = im.split()[3]
    alpha = ImageEnhance.Brightness(alpha).enhance(opacity)
    im.putalpha(alpha)
    return im

def watermark(imagefile, markfile, position=POSITION[4], opacity=1):
    """Adds a watermark to an image."""    
    im = Image.open(imagefile)
    mark = Image.open(markfile)    
    if opacity < 1:
        mark = reduce_opacity(mark, opacity)
    if im.mode != 'RGBA':
        im = im.convert('RGBA')
    # create a transparent layer the size of the image and draw the
    # watermark in that layer.
    layer = Image.new('RGBA', im.size, (0,0,0,0))
    if position == 'title':
        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 == 'scale':
        # 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))
    elif position == POSITION[0]:
        #lefttop
        position = (PADDING,PADDING)
        layer.paste(mark, position)
    elif position == POSITION[1]:
        #righttop
        position = (im.size[0] - mark.size[0]-PADDING, PADDING)
        layer.paste(mark, position)
    elif position == POSITION[2]:
        #center
        position = ((im.size[0] - mark.size[0])/2,(im.size[1] - mark.size[1])/2)
        layer.paste(mark, position)
    elif position == POSITION[3]:
        #left bottom
        position = (PADDING,im.size[1] - mark.size[1]-PADDING,)
        layer.paste(mark, position)
    else:
        #right bottom (default)
        position = (im.size[0] - mark.size[0]-PADDING, im.size[1] - mark.size[1]-PADDING,)
        layer.paste(mark, position)
        
    # composite the watermark with the layer
    return Image.composite(layer, im, layer)

def test():
    watermark('4527800.jpg',MARKIMAGE,POSITION[0],opacity=0.7).save("watermarked_lt.jpg",quality=90)
    watermark('4527800.jpg',MARKIMAGE,POSITION[1],opacity=0.7).save("watermarked_rt.jpg",quality=90)
    watermark('4527800.jpg',MARKIMAGE,POSITION[2],opacity=0.7).save("watermarked_center.jpg",quality=90)
    watermark('4527800.jpg',MARKIMAGE,POSITION[3],opacity=0.7).save("watermarked_lb.jpg",quality=90)
    watermark('4527800.jpg',MARKIMAGE,POSITION[4],opacity=0.7).save("watermarked_rb.jpg",quality=90)
    watermark('4527800.jpg',MARKIMAGE,'title',opacity=0.7).save("watermarked_title.jpg",quality=90)
    watermark('4527800.jpg',MARKIMAGE,'scale',opacity=0.7).save("watermarked_scale.jpg",quality=90)
if __name__ == '__main__':
    test()


  • 大小: 24.8 KB
分享到:
评论

相关推荐

    上传图片加水印(图片水印和文字水印)

    这可能包括水印位置(中心、角落、自由定位等)、透明度、大小、角度以及是否使用图片或文字水印等。这些设置应保存在数据库中,以便在处理上传图片时调用。 5. **水印处理逻辑**:当图片上传后,服务器会读取存储...

    图片上生成水印图片并保存合并图片升级版.zip

    接下来,"图片上生成水印图片并保存合并图片"可能是一个脚本或应用程序,它能够接收一个或多个源图像,然后在每个图像上添加水印,并将它们合并成一个新的单一图像。这个过程涉及到读取图片文件,创建水印,定位水印...

    [其他类别]上传图片生成缩略图、图片水印、文字水印_7he7upload.zip

    这个压缩包文件"【其他类别】上传图片生成缩略图、图片水印、文字水印_7he7upload.zip"显然是一个关于图片处理的源码参考,它包含了解决三个关键问题的代码:生成缩略图、添加图片水印以及添加文字水印。接下来,...

    Python37_Python生成水印_python_

    在描述中提到的“切割图像”可能是指moviepy的视频剪辑功能,而“生成水印”则可能指的是使用moviepy的VideoFileClip类添加文本或图像水印到视频中的功能。 生成水印是保护知识产权和防止未经授权的使用的一种常见...

    上传图片生成水印缩略图

    "上传图片生成水印缩略图"是一个典型的需求,它涉及到文件上传、图像处理和优化等多个技术环节。接下来,我们将深入探讨这个话题。 1. **文件上传**:在Web应用中,`fileUpload`通常指的是用户通过网页上传文件的...

    生成二维码、图片水印、图片压缩

    为避免这个问题,我们需要优化算法,例如分块处理图片或使用流式处理。在Java中,可以使用Apache Batik或ImageMagick库来添加水印;在Python中,PIL(Python Imaging Library)或OpenCV库是常用的选择。 最后,**...

    图片批量加水印以及缩略图

    水印可以是文字、图形或透明度调整过的原图的一部分,位置、大小、透明度和角度都可以自定义。在选择软件时,用户需要考虑是否支持这些参数调整,以及是否支持多种图像格式。 2. **缩略图生成**:缩略图是原始图片...

    Python图片水印.zip

    综上所述,"Python图片水印.zip"包含了一个实用的Python脚本,用于在图片上添加文字和图片水印,支持中文,并且允许用户自定义水印的位置和颜色。这个工具对于需要批量处理图片的开发者和运维人员来说,无疑是一个...

    图片加水印软件源码

    首先,图片加水印是通过在原始图片上添加文字、图形或logo等元素,形成一种视觉标识,用于表明版权归属、防止盗用或者增添个性化标识。水印可以是透明的,不影响原图的主要内容,也可以是半透明或带有颜色的,以达到...

    图形图像和多媒体-如何批量为图片添加文字水印-Python实例源码.zip

    另一个相关的库是`reportlab`,用于生成PDF和创建矢量图形,这在创建高质量的文字水印时非常有用。 批量处理图片通常涉及到读取文件夹中的所有图片,对每一张图片执行相同的操作,然后保存修改后的结果。以下是一个...

    图片水印及缩略图

    例如,我们可以利用PIL库中的resize()函数实现等比例缩放,或使用thumbnail()方法,它会自动调整图像大小并保持比例。如果需要固定尺寸的缩略图,可以使用crop()方法配合resize()来完成。 在实际应用中,水印和缩略...

    图片加水印

    水印是一种半透明或淡化的文字、图案或logo,它被叠加在图片上,既不影响原图的主要内容展示,又能起到标识和保护的作用。在数字时代,水印通常通过软件或编程语言来生成,以防止图片被盗用或篡改。 接下来,我们...

    图片合并、缩放、裁剪、水印、防伪码、指纹

    水印可以是文字、图像或透明图案,用于标识版权或增加视觉效果。在代码中,可以使用图像处理库将水印作为另一个层叠加到原图上,调整透明度、位置和大小以达到预期效果。 5. **防伪码**: 防伪码通常是通过算法...

    Python不可见水印,隐形水印

    可见水印是在图像或视频中添加明显可见的标记,如文字、图案或LOGO,容易被肉眼识别。而不可见水印,即隐形水印,是在数字媒体中嵌入微小的、难以察觉的变化,只有通过特定的算法才能检测出来。隐形水印主要用于版权...

    PIL-1.1.7.win32-py2.5

    在Windows环境下,通过合适的安装包,如“PIL-1.1.7.win32-py2.5.exe”,可以轻松地在Python 2.5版本的环境中集成并利用PIL的强大功能。在实际项目中,结合PIL的各类方法和函数,开发者可以实现丰富的图像处理效果,...

    upload(批量上传加水印功能)

    2. CSS3:对于网页中的图片,可以通过CSS3的filter属性应用模糊、灰度等效果作为水印,或者使用伪元素定位文字或背景图像作为水印。 3. 前后端结合:在前端预处理,用户上传图片后立即加水印,然后发送加了水印的...

    pil-handbook.rar_overview_pil_python handbook

    6. **文字添加**:通过`ImageDraw`模块,可以在图像上添加文本,这对于创建动态图片或水印非常有用。 7. **分块操作**:对于大图像,可以按块进行处理,提高效率。 8. **支持透明度**:PIL能够处理透明度信息,...

    多张图片合成一张+打水印+登录窗口.rar

    水印可以是文字、图案或是半透明的图像,它被叠加在原始图片上,既不影响视觉效果,又能表明所有权或版权信息。实现这一功能,开发者通常会利用图像处理库提供的透明度控制和定位方法。水印可以动态生成,比如包含...

    上传 缩略图 水印

    水印的添加则是为了在图片上放置一个半透明的文字、图案或logo,以此标识所有权或者增加视觉效果。水印的位置、透明度、大小、字体、颜色等都可以自定义,常见的位置有角落、中心、底部等。在编程实现时,可以利用...

    上传生成缩略图并添加水印文字

    在IT行业中,生成缩略图并添加水印文字是一项常见的图像处理任务,广泛应用于网站、社交媒体、移动应用等场景。这个任务涉及到多个技术点,包括图片上传、图像处理、水印制作以及用户交互。以下是对这些知识点的详细...

Global site tag (gtag.js) - Google Analytics