RTF*_*RTF 1 python png transparency python-imaging-library
我查看了教程、其他 stackoverflow 问题和 PIL 文档本身,但我仍然不确定如何去做。
我想开始在 y 轴下方大约 55% 处垂直淡化图像,并使图像在大约 75% 处完全透明。保留图像的完整高度很重要,即使最后 25% 左右应该是完全透明的。
这可能与PIL有关吗?
当然是可行的。
假设您从没有透明度的图像开始(否则,您的问题是模棱两可的)。
第 1 步:添加一个 alpha 平面。那只是putalpha,除非您正在处理非平面图像,在这种情况下,您需要先将其转换为 RGB 或 L。
第 2 步:通过使用返回的像素数组load(或者getpixel,setpixel如果您必须处理旧版本的 PIL),遍历您想要更改的像素。
第 3 步:没有第 3 步。除非您计算保存图像。在这种情况下,好的,步骤 3 是保存图像。
from PIL import Image
im = Image.open('bird.jpg')
im.putalpha(255)
width, height = im.size
pixels = im.load()
for y in range(int(height*.55), int(height*.75)):
alpha = 255-int((y - height*.55)/height/.20 * 255)
for x in range(width):
pixels[x, y] = pixels[x, y][:3] + (alpha,)
for y in range(y, height):
for x in range(width):
pixels[x, y] = pixels[x, y][:3] + (0,)
im.save('birdfade.png')
Run Code Online (Sandbox Code Playgroud)
这里 alpha 从 255 线性下降到 0;如果您希望它根据不同的曲线下降,或者您使用的是 RGB16 而不是 RGB8,或者您使用的是 L 而不是 RGB,您应该能够弄清楚如何更改它。
如果你想更快地做到这一点,你可以在第 2 步中使用 numpy 而不是 Python 循环。或者你可以颠倒第 1 步和第 2 步——提前构造一个 alpha 平面,然后通过将它传递给putalpha而不是 来一次性应用它255。或者……因为这在我身边最大的图像上花费了不到半秒的时间,所以我不太担心性能,除非你必须做一百万个并且你想要一个更快的版本。
| 归档时间: |
|
| 查看次数: |
3146 次 |
| 最近记录: |