拍爱

watermark_utils.py 2.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. # -*- coding: utf-8 -*-
  2. try:
  3. import Image
  4. import ImageEnhance
  5. except ImportError:
  6. from PIL import Image, ImageEnhance
  7. def reduce_opacity(im, opacity):
  8. """Returns an image with reduced opacity."""
  9. assert 0 <= opacity <= 1
  10. im = im.convert('RGBA') if im.mode != 'RGBA' else im.copy()
  11. alpha = im.split()[3]
  12. alpha = ImageEnhance.Brightness(alpha).enhance(opacity)
  13. im.putalpha(alpha)
  14. return im
  15. def watermark(im, mark, position, opacity=1):
  16. """Adds a watermark to an image."""
  17. if opacity < 1:
  18. mark = reduce_opacity(mark, opacity)
  19. if im.mode != 'RGBA':
  20. im = im.convert('RGBA')
  21. # create a transparent layer the size of the image and draw the
  22. # watermark in that layer.
  23. layer = Image.new('RGBA', im.size, (0, 0, 0, 0))
  24. if position == 'tile':
  25. for y in range(0, im.size[1], mark.size[1]):
  26. for x in range(0, im.size[0], mark.size[0]):
  27. layer.paste(mark, (x, y))
  28. elif position == 'scale':
  29. # scale, but preserve the aspect ratio
  30. ratio = min(
  31. float(im.size[0]) / mark.size[0], float(im.size[1]) / mark.size[1])
  32. w = int(mark.size[0] * ratio)
  33. h = int(mark.size[1] * ratio)
  34. mark = mark.resize((w, h))
  35. layer.paste(mark, ((im.size[0] - w) / 2, (im.size[1] - h) / 2))
  36. else:
  37. layer.paste(mark, position)
  38. # composite the watermark with the layer
  39. return Image.composite(layer, im, layer)
  40. def watermark_wrap(im_path, mark_path, save_path=''):
  41. im, mark = Image.open(im_path), Image.open(mark_path)
  42. new_im = watermark(im, mark, (50, 50), 0.5)
  43. new_im.save(save_path or im_path)
  44. def watermark_test():
  45. im, mark = Image.open('original_CGzC_10a50000c8811190.jpg'), Image.open('paiai_96_96.png')
  46. watermark(im, mark, 'tile', 0.5).show()
  47. watermark(im, mark, 'scale', 1.0).show()
  48. watermark(im, mark, (50, 50), 0.5).show()
  49. if __name__ == '__main__':
  50. # watermark_test()
  51. watermark_wrap('original_CGzC_10a50000c8811190.jpg', 'paiai_96_96.png')