您好,登錄后才能下訂單哦!
Python如何實現(xiàn)疊加矩形框圖層?相信很多新手小白還沒學(xué)會這個技能,通過這篇文章的總結(jié),希望你能學(xué)會這個技能。以下資料是實現(xiàn)的步驟。
兩種方式以及效果:
方式一,使用PIL.Image.blend方式:
from PIL import Image, ImageDraw im = Image.open('d:/tmp/58.249.0.220_01_20200604141800866_TIMING.jpg', 'r') im2 = Image.open('d:/tmp/58.249.0.220_01_20200604141800866_TIMING.jpg', 'r') draw = ImageDraw.Draw(im2) draw.rectangle([(1000, 500), (1200, 800)], fill=(255, 0, 0), width=2) out = Image.blend(im, im2, 0.5) out.save('d:/tmp/demo1.jpg') im.close() im2.close() out.show() out.close()
方式二:直接進行像素疊加:
from PIL import Image, ImageDraw im = Image.open('d:/tmp/58.249.0.220_01_20200604141800866_TIMING.jpg', 'r') b = (255, 0, 0) opacity = 0.5 for x in range(1000, 1200): for y in range(500, 800): p = im.getpixel((x, y)) p = [int(p[i]*(1-opacity) + b[i]*opacity) for i in range(3)] im.putpixel((x, y), tuple(p)) im.save('d:/tmp/demo2.jpg') im.show() im.close()
兩種的效果圖都如下:
說明:第一種可以畫矩形橢圓等定義好的一些形狀,但是第二種,可以自主控制形狀的能力更好,只要將相應(yīng)的數(shù)據(jù)公式編輯到程序中,就可以繪制一些想要的輪廓出來;
第二種方式,是受第一種方式的定義(
out = image1 * (1.0 - alpha) + image2 * alpha)
然后聯(lián)想到色盲測試圖、另一種圖(不知道叫什么名字,就是一張圖里面不同的人,可能看出不同的東西出來)而想出來的。
看完上述內(nèi)容,你們掌握Python實現(xiàn)疊加矩形框圖層的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。