我正在尝试使图像背景中的黑色像素透明。为此,我写了下面的函数。然后,我将图像(在黑色像素周围的中心的汽车)叠加在自身的副本上,然后缓慢移动第一个。我期待第一张图像显示下面的副本而不显示矩形边界,因为该部分应该是透明的。但是,我没有得到预期的效果。有谁知道我错过了什么?
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
答案 0 :(得分:1)
我无法弄清楚如何使透明度工作,所以我只是创建了自己的粘贴方法,直接更新了我粘贴的图像的字节,这让我得到了理想的效果。
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]