我试图使图像背景中的黑色像素透明。为此,我在下面编写了函数。然后,我将图像(中间的一辆汽车被黑色像素包围(叠加在自己的副本上,并缓慢移动第一个图像。我期待第一张图像在不显示矩形边界的情况下显示下面的副本,因为该部分应该是透明的。但是,我没有得到预期的效果。有谁知道我错过了什么?
def makeImageTransparent(img):
img = img.convert("RGBA")
datas = img.getdata()
newData = []
ii = 0
for item in datas:
if item[0] == 0 and item[1] == 0 and item[2] == 0:
newData.append((0, 0, 0, 0))
ii = ii + 1
else:
newData.append(item)
print str(ii)
img.putdata(newData)
return img
我不知道如何使透明度工作,所以我只是创建了自己的粘贴方法,直接更新了我粘贴的图像的字节,这让我得到了想要的效果。
def pasteImage(img, bigim, posn):
pixdata = img.load()
width, height = img.size
mainpixdata = bigim.load()
for y in xrange(height):
for x in xrange(width):
if pixdata[x, y] != (0, 0, 0, 0):
mainpixdata[x+posn[0], y+posn[1]] = pixdata[x,y]