255[[255]" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

OpenCV-Python學習筆記(四):圖像上的算術運算:圖像加法、圖像混合

系統 1970 0

1.圖像加法

可以使用函數 cv2.add() 將兩幅圖像進行加法運算,兩幅圖像的大小,類型必須一致。
(注意: OpenCV 中的加法與 Numpy 的加法是有所不同的。OpenCV 的加法是一種飽和操作,而 Numpy 的加法是一種模操作。r如下所示。 推薦使用 OpenCV 中的函數

            
              import cv2
import numpy as np

x = np.uint8([250])
y = np.uint8([10])

print(cv2.add(x,y)) # 250+10 = 260 => 255
[[255]]

print(x+y) # 250+10 = 260 % 256 = 4
[4]
            
          

?

2.圖像混合

圖像混合其實也是加法,但是不同的是兩幅圖像的權重不同,這就會給人一種混合或者透明的感覺。圖像混合的計算公式如下:
g(x) = (1-\alpha )f_{0}(x) + \alpha f_{1}(x) + \gamma ?,α取值在0~1之間。

函數 cv2.addWeighted() 可以按上面的公式對圖片進行混合操作:

            
              import cv2
import numpy as np

img1 = cv2.imread('ml.png')
img2 = cv2.imread('opencv_logo.jpg')
dst = cv2.addWeighted(img1, 0.7, img2, 0.3, 0)
cv2.imshow('dst',dst)
cv2.waitKey(0)
cv2.destroyAllWindow()
            
          

上面代碼示例中α取0.3, γ取0,效果如下:

OpenCV-Python學習筆記(四):圖像上的算術運算:圖像加法、圖像混合、按位運算_第1張圖片

?

3.按位運算

這里包括的按位操作有: AND, OR, NOT, XOR 等。對應函數分別為:

cv2.bitwise_and() cv2.bitwise_or() cv2.bitwise_not()? 和? cv2.bitwise_xor()

當我們提取圖像的一部分,選擇非矩形 ROI 時這些操作會很有用。下面的例子就是教給我們如何改變一幅圖的特定區域:把 OpenCV 的標志放到另一幅圖像上。如果使用加法,顏色會改變,如果使用混合,會得到透明效果,但是我不想要透明。如果他是矩形我可以像上一章那樣使用 ROI。但是他不是矩形。但是我們可以通過下面的按位運算實現:

            
              import cv2
import numpy as np

# 加載圖像
img1 = cv2.imread('roi.jpg')
img2 = cv2.imread('opencv_logo.png')

# I want to put logo on top-left corner, So I create a ROI
rows,cols,channels = img2.shape
roi = img1[0:rows, 0:cols ]

# Now create a mask of logo and create its inverse mask also
img2gray = cv2.cvtColor(img2,cv2.COLOR_BGR2GRAY)
ret, mask = cv2.threshold(img2gray, 175, 255, cv2.THRESH_BINARY)
mask_inv = cv2.bitwise_not(mask)

# Now black-out the area of logo in ROI
# 取 roi 中與 mask 中不為零的值對應的像素的值,其他值為 0
# 注意這里必須有 mask=mask 或者 mask=mask_inv, 其中的 mask= 不能忽略
img1_bg = cv2.bitwise_and(roi,roi,mask = mask)

# 取 roi 中與 mask_inv 中不為零的值對應的像素的值,其他值為 0。
# Take only region of logo from logo image.
img2_fg = cv2.bitwise_and(img2,img2,mask = mask_inv)

# Put logo in ROI and modify the main image
dst = cv2.add(img1_bg,img2_fg)
img1[0:rows, 0:cols ] = dst

cv2.imshow('res',img1)
cv2.waitKey(0)
cv2.destroyAllWindows()
            
          

結果如下。左面的圖像是我們創建的掩碼。右邊的是最終結果。為了幫助理解,上面程序的中間結果也顯示了出來,特別是 img1_bg 和 img2_fg。

OpenCV-Python學習筆記(四):圖像上的算術運算:圖像加法、圖像混合、按位運算_第2張圖片


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产女主播在线 | 亚洲啊v| 国产福利在线观看永久免费 | 国产成人精品午夜在线播放 | 久久精品国产精品亚洲艾 | 久久精品道一区二区三区 | 免费欧洲毛片a级视频老妇女 | 国产舐足视频在线观看 | 日韩欧美在线中文字幕 | 在线播放真实国产乱子伦 | 99久久在线 | 天天躁日日躁狠狠躁黑人躁 | 羞羞视频免费网站在线 | 97国产在线观看 | 成人国产免费 | 国产91在线 | 中文 | 奇米第四色网站 | 日本一区二区三区四区 | 91长腿女神清纯大又嫩在线 | 草草免费视频 | 骚视频在线观看 | 国产成人啪午夜精品网站男同 | 精品国产高清自在线一区二区三区 | 午夜在线网站 | 加勒比黑人在线 | 国产精品视频永久免费播放 | 人成午夜免费大片在线观看 | 中文一级黄色片 | 久久久久毛片免费观看 | 四虎影院大全 | 国产福利视频 | 日韩欧美精品中文字幕 | 欧美深夜影院 | 中文国产成人精品久久水 | 日本中文字幕在线视频 | 亚洲精品中文字幕久久久久久 | 青青爽国产手机在线观看免费 | 久草在线这里只有精品 | 国产日韩欧美在线 | 国产一区二区三区视频在线观看 | 四虎aⅴ |