OpenCV圖像處理基本操作詳解
本文實(shí)例為大家分享了OpenCV圖像處理基本操作的具體代碼,供大家參考,具體內(nèi)容如下
圖像的讀取
cv2.IMREAD_COLOR 彩色圖像
cv2.IMREAD_GRAYSCALE 灰色圖像
import cv2#opencv 的讀取格式是BGR
import matplotlib.pyplot as plt
import numpy as np
#圖像的顯示,也可以創(chuàng)建多個(gè)窗口
img=cv2.imread('tu.jpg')
cv2.imshow('name',img)
#等待時(shí)間毫秒級(jí),0表示任意鍵終止
cv2.waitKey(0)
cv2.destroyAllWindows()
#顏色通道提取
b,g,r=cv2.split(img)
print(b)
print(b.shape)
#顏色通道融合
img=cv2.merge((b,g,r))
print(img.shape)
#可以將其余兩通道全部置零,保留一個(gè)顏色通道
cur_img=img.copy()
cur_img[:,:,0]=0#BRG
cur_img[:,:,1]=0
cv2.imshow('cur_img',cur_img)
邊界填充
BORDER_REPLICATE:復(fù)制法,也就是復(fù)制最邊緣像素
BORDER_REFLECT:反射法,對(duì)感興趣的圖片中的像素的兩邊進(jìn)行復(fù)制:cba|abc|cba
BORDER_REFLECT_101:反射法,對(duì)稱,cb|abcd|cda
BORDER_WRAP:外包裝法abc|abc|abc
BORDER_CONSTANT:常量法常數(shù)填充
top_size,bottom_size,left_size,right_size=(50,50,50,50)
replicate=cv2.copyMakeBorder(img,top_size,bottom_size,left_size,right_size,borderType=cv2.BORDER_REPLICATE)
reflect=cv2.copyMakeBorder(img,top_size,bottom_size,left_size,right_size,borderType=cv2.BORDER_REFLECT)
reflect101=cv2.copyMakeBorder(img,top_size,bottom_size,left_size,right_size,borderType=cv2.BORDER_REFLECT_101)
wrap=cv2.copyMakeBorder(img,top_size,bottom_size,left_size,right_size,borderType=cv2.BORDER_WRAP)
constant=cv2.copyMakeBorder(img,top_size,bottom_size,left_size,right_size,borderType=cv2.BORDER_CONSTANT,value=0)
#將圖片畫(huà)出對(duì)比
plt.subplot(231),plt.imshow(img,'gray'),plt.title('GRIGNAAL')
plt.subplot(232),plt.imshow(replicate,'gray'),plt.title('replicate')
plt.subplot(233),plt.imshow(reflect,'gray'),plt.title('reflect')
plt.subplot(234),plt.imshow(wrap,'gray'),plt.title('wrap')
plt.subplot(235),plt.imshow(constant,'gray'),plt.title('constant')
plt.show()

視頻的讀取
#視頻的讀取 cv2.VideoCapture 可以捕獲攝像頭,用數(shù)字來(lái)捕獲不同設(shè)備,列如0,1 如果是視頻文件直接指定好路徑即可
vc=cv2.VideoCapture('IMG_1972.mp4')
#檢測(cè)是否打開(kāi)正確
if vc.isOpened():
open,frame=vc.read()
else:
open=False
while open:#一幀一幀的處理為灰色
ret,frame=vc.read()
if frame is None:
break
if ret==True:
gray=cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) #一幀一幀的處理為灰色
cv2.imshow('result',gray)
if cv2.waitKey(100) & 0xFF==27:
break
vc.release()
cv2.destroyAllWindows()


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- OpenCV半小時(shí)掌握基本操作之圖像裁剪融合
- OpenCV半小時(shí)掌握基本操作之圖像處理
- opencv-python基本圖像處理詳解
- Opencv圖像處理之詳解掩膜mask
- 基于python的opencv圖像處理實(shí)現(xiàn)對(duì)斑馬線的檢測(cè)示例
- Python+OpenCV圖像處理——圖像二值化的實(shí)現(xiàn)
- OpenCV半小時(shí)掌握基本操作之分水嶺算法
- OpenCV半小時(shí)掌握基本操作之傅里葉變換
- OpenCV半小時(shí)掌握基本操作之圖像輪廓
- OpenCV半小時(shí)掌握基本操作之直方圖
- OpenCV半小時(shí)掌握基本操作之模板匹配
- OpenCV半小時(shí)掌握基本操作之圓圈檢測(cè)
- OpenCV半小時(shí)掌握基本操作之對(duì)象測(cè)量
- OpenCV半小時(shí)掌握基本操作之圖像基礎(chǔ)操作
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)經(jīng)典掃雷小游戲的示例代碼
掃雷游戲是在一個(gè)指定的二維空間里,隨機(jī)布置雷,把不是雷的位置都找出來(lái),在你點(diǎn)一個(gè)位置的時(shí)候它會(huì)顯示它周圍全部雷的個(gè)數(shù),根據(jù)這個(gè)線索去找 ,會(huì)更容易贏。本文將用C語(yǔ)言實(shí)現(xiàn)這一經(jīng)典游戲,感興趣的可以嘗試一下2022-11-11
VC++ 字符串String MD5計(jì)算小工具 VS2008工程
基于字符串加密的MD5算法,VS2008 VC++,多字節(jié)編譯工程。主要代碼如下,實(shí)現(xiàn)了ANSI字符串加密與Unicode字符串加密,需要的朋友可以參考下2017-07-07
C語(yǔ)言實(shí)現(xiàn)三子棋游戲簡(jiǎn)易版
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)三子棋游戲簡(jiǎn)易版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
一篇文章帶你了解C語(yǔ)言文件操作中的幾個(gè)函數(shù)
這篇文章主要介紹了使用C語(yǔ)言操作文件的基本函數(shù)整理,包括創(chuàng)建和打開(kāi)以及關(guān)閉文件的操作方法,需要的朋友可以參考下,希望能夠給你帶來(lái)幫助2021-09-09
c++ 一個(gè)二進(jìn)制串轉(zhuǎn)化為整數(shù)的解決方法
以下是將一個(gè)二進(jìn)制串轉(zhuǎn)化為整數(shù)的實(shí)例。需要的朋友參考下2013-05-05
基于C語(yǔ)言實(shí)現(xiàn)個(gè)人通訊錄管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于C語(yǔ)言實(shí)現(xiàn)個(gè)人通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06

