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條評論
主站蜘蛛池模板: 色拍拍欧美视频在线看 | 国产美女精品在线 | 国产精品亚洲二区在线 | 国产图片综合区 | 性欧美videos高清喷水 | 成人永久福利在线观看不卡 | 久久免费视频播放 | 四虎永久免费地址 | 天天综合天天做 | 国产亚洲精品资源一区 | 日本中文字幕不卡 | 国产一区二区精品久久91 | 四虎影视国产884a精品亚洲 | 成人精品福利 | 国产日韩欧美亚洲综合首页 | 成年女人永久免费观看片 | 91国内在线国内在线播放 | 久久国产网站 | 四虎影视最新网站在线播放 | 欧美日韩国产在线成人网 | 国产一区精品在线 | 日韩亚洲欧美综合一区二区三区 | 国产中文字幕第一页 | 暗香影院午夜国产精品 | 亚洲一区二区在线成人 | 国产精选自拍 | 国产福利不卡视频在免费 | a毛片在线免费观看 | 国产精品国色综合久久 | 99热这里只有精品一区二 | 欧美一区二区三区不卡片 | aaa一级毛片 | 最近中文字幕在线视频1 | 97视频在线看 | 在线观看国产一区二区三区99 | 深夜福利院 | 免费一区二区三区免费视频 | 色婷婷六月桃花综合影院 | 深夜免费网站 | 欧美高清一区二区三区欧美 | 国产毛片视频网站 |