不知道别人是怎么做的,闲着无聊就根据前几天看到的一些PIL里面的函数,写了这个小程序,经过测试,基本可以给所有像宽400以上的图片打上从左下到右上的看上去质量尚可的水印,更小的图片水印偏下。写完觉得很简单,还是写出来记录一下,唔,我现在仍然很无聊。
我的思路很简单:
1、第一部分,主要是程序要用到的库的调用,以及需要的基本信息初始化,如下:
2、第二部分,根据图片大小确定打水印的文字大小。对于不同大小的相片,如果添加水印过大,甚至不能全部显示,或者过小都不美观。但是像素值与字号之间的对应关系我不知道是否有直接的工具可以实现,问了许久也没有办法解决,于是选择了最拙劣的分区赋值。还好最后测试的效果还算可以,只是图片过小的时候会稍稍偏下,不过像宽400以上基本上没有问题
if imageW < 400: k = 32 elif imageW < 600: k = 48 elif imageW < 800: k = elif imageW < 1000: k = 80 elif imageW < 1200: k = 100 elif imageW < 1400: k =128 elif imageW < 1800: k= 156 elif imageW < 2200: k = 192 elif imageW < 2600: k = 256 elif imageW < 3100: k = 300 print "fontsize:",k
3、在空白图片上添加文字。为了实现更好的裁剪,我将文字写在空白图像的正中间
效果如下:Font = ImageFont.truetype("C:\Windows\Fonts\SHOWG.TTF",k) #创建Font对象,k之为字号 textW,textH = Font.getsize(text) #获取文字尺寸 d.ink = 0 + 0 * 256 + 0 * 256 * 256 #黑色 d.text([(textImageW-textW)/2,(textImageH-textH)/2],text,font = Font)#将文字写在空白图像正中间
4、旋转图像,实现文字倾斜
效果如下:#旋转文字 textRotate = blank.rotate(30) #textRotate.show()
5、截取文字区域。要从上图中截取出最大的不触及黑色背景的图片,可以根据旋转角度以及图像尺寸计算出,可截取的最大尺寸,方法如下:
效果如下:rLen = math.sqrt((textW/2)**2+(textH/2)**2) oriAngle = math.atan(textH/textW) cropW = rLen*math.cos(oriAngle + math.pi/6) *2 #被截取区域的宽高 cropH = rLen*math.sin(oriAngle + math.pi/6) *2 box = [int((textImageW-cropW)/2-1),int((textImageH-cropH)/2-1)-50,int((textImageW+cropW)/2+1),int((textImageH+cropH)/2+1)] textIm = textRotate.crop(box) #截取文字图片
6、截取后的图片贴在另一个跟相片尺寸相同的空白图像上。达到比较好的效果,要粘贴在空白图像的正
效果如下:pasteW,pasteH = textIm.size #旋转后的文字图片粘贴在一个新的blank图像上 textBlank = Image.new("RGB",(imageW,imageH),"white") pasteBox = (int((imageW-pasteW)/2-1),int((imageH-pasteH)/2-1)) textBlank.paste(textIm,pasteBox)
7、图像合并,水印完成。可改变alpha值,改变水印的深浅程度
效果如下:waterImage = Image.blend(im,textBlank,0.2)
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- hids.cn 版权所有 赣ICP备2024042780号-1
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务