博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python opencv使用方法基础
阅读量:3900 次
发布时间:2019-05-23

本文共 3245 字,大约阅读时间需要 10 分钟。

安装:

pip install numpy opencv-python

读取图片

imread(filename,flag) 读取图片,返回图片对象    img_path: 图片的路径,即使路径错误也不会报错,但打印返回的图片对象为None    flag:cv2.IMREAD_COLOR,读取彩色图片,图片透明性会被忽略,为默认参数,也可以传入1          cv2.IMREAD_GRAYSCALE,按灰度模式读取图像,也可以传入0          cv2.IMREAD_UNCHANGED,读取图像,包括其alpha通道,也可以传入-1

eg:

desert_img = cv2.imread(r'Desert.jpg',cv2.IMREAD_GRAYSCALE)

显示照片

imshow(window_name,img):显示图片,窗口自适应图片大小    window_name: 指定窗口的名字    img:显示的图片对象    可以指定多个窗口名称,显示多个图片    waitKey(millseconds)  键盘绑定事件,阻塞监听键盘按键,返回一个数字(不同按键对应的数字不同)    millseconds: 传入时间毫秒数,在该时间内等待键盘事件;传入0时,会一直等待键盘事件    destroyAllWindows(window_name)     window_name: 需要关闭的窗口名字,不传入时关闭所有窗口

eg:

def waitkey(im):    cv2.imshow('image', desert_img)    cv2.waitKey(0)desert_img = cv2.imread(r'Desert.jpg',cv2.IMREAD_GRAYSCALE)p =threading.Thread(target = waitkey, args=[desert_img,])p.start()p.join(2)cv2.destroyAllWindows()

获取图片像素或者是编辑像素

在这里插入代码片
new_img = desert_imgcv2.imshow('d',desert_img)new_img[100:200,100] = numpy.zeros((100,3))cv2.imshow('c', new_img)cv2.waitKey(0)

在这里插入图片描述

获取图片性质’
1、shape 获取图片像素,(宽x,长y,3通道(BGR))
2、size获取图片像素量(xy3)
eg:

print(desert_img.shape,desert_img.size,)

(768, 1024, 3) 2359296

截取图片

roi = desert_img[600:700,300:400]desert_img[50:150,200:300] = roicv2.imshow('a',desert_img)cv2.waitKey(0)

在这里插入图片描述

添加边框:

cv2.copyMakeBorder()    参数:        img:图像对象        top,bottom,left,right: 上下左右边界宽度,单位为像素值        borderType:            cv2.BORDER_CONSTANT, 带颜色的边界,需要传入另外一个颜色值            cv2.BORDER_REFLECT, 边缘元素的镜像反射做为边界            cv2.BORDER_REFLECT_101/cv2.BORDER_DEFAULT            cv2.BORDER_REPLICATE, 边缘元素的复制做为边界            CV2.BORDER_WRAP        value: borderType为cv2.BORDER_CONSTANT时,传入的边界颜色值,如[0,255,0]
img = cv2.cvtColor(desert_img,cv2.COLOR_BGR2RGB)constant = cv2.copyMakeBorder(img,20,20,20,20,cv2.BORDER_CONSTANT,value=[255,0,0]) #红色reflect = cv2.copyMakeBorder(img,20,20,20,20,cv2.BORDER_REFLECT)reflect01 = cv2.copyMakeBorder(img,20,20,20,20,cv2.BORDER_REFLECT_101)replicate = cv2.copyMakeBorder(img,20,20,20,20,cv2.BORDER_REPLICATE)wrap = cv2.copyMakeBorder(img,20,20,20,20,cv2.BORDER_WRAP)titles = ["constant","reflect","reflect01","replicate","wrap"]images = [constant,reflect,reflect01,replicate,wrap]for i in range(5):    plt.subplot(2,3,i+1),plt.imshow(images[i]),plt.title(titles[i])    plt.xticks([]),plt.yticks([])plt.show()

在这里插入图片描述

图片相加合成

cv2.add()    参数:        img1:图片对象1        img2:图片对象2        mask:None (掩膜,一般用灰度图做掩膜,img1和img2相加后,和掩膜与运算,从而达到掩盖部分区域的目的)        dtype:-1

两张图片的像素必须是一样大小!

eg:

desert_img = cv2.imread(r'Desert.jpg',1)lighthouse =  cv2.imread(r'Lighthouse.jpg',1)roi_img  = numpy.zeros(desert_img.shape[0:2],dtype=numpy.uint8)roi_img[100:280,100:250]=255img_add = cv2.add(desert_img,lighthouse)img_add_mask = cv2.add(desert_img,lighthouse,mask=roi_img)cv2.imshow("img_add",img_add)cv2.imshow("img_add_mask",img_add_mask)cv2.waitKey(0)cv2.destroyAllWindows()

在这里插入图片描述

在这里插入图片描述
打入权重合成;

cv2.addWeighted() 两张图片相加,分别给予不同权重,实现图片融合和透明背景等效果    参数:        img1:图片对象1        alpha:img1的权重        img2:图片对象2        beta:img1的权重        gamma:常量值,图像相加后再加上常量值        dtype:返回图像的数据类型,默认为-1,和img1一样

eg:

lighthouse =  cv2.imread(r'Lighthouse.jpg',1)penguins = cv2.imread(r'Penguins.jpg',1)blend = cv2.addWeighted(lighthouse,0.9,penguins,0.2,0)cv2.imshow('blend', blend)cv2.waitKey(0)cv2.destroyAllWindows()

在这里插入图片描述

转载地址:http://mqben.baihongyu.com/

你可能感兴趣的文章
【C++基础】virtual析构函数
查看>>
【Java基础】面向对象
查看>>
【Java.Web】web.xml详解
查看>>
J2EE的技术体系
查看>>
【Java.Web】Java Web应用程序的规范目录结构,*WEB组件的URL/入口*
查看>>
【基础篇】计算机网络
查看>>
OSI 7层详解
查看>>
【C++基础】重载overload、重写(覆盖)override、隐藏hide的区别
查看>>
【算法详解】洗牌算法
查看>>
【设计模式基础】行为模式 - 1 - 观察者(Observer)
查看>>
从关系型数据库到非关系型数据库
查看>>
【数据库基础】数据库事务 - Transaction
查看>>
【设计模式基础】行为模式 - 3 - 职责链(Chain of responsibility)
查看>>
【Java基础】反射 - Reflection
查看>>
【C++基础】const成员函数
查看>>
【设计模式基础】行为模式 - 5 - 策略(Strategy)
查看>>
【Maven】Archetype
查看>>
【Java.Web】Cookie —— 基础
查看>>
【Tools.Eclipse】代码自动提示
查看>>
【Java.Web】MVC —— Model1 V.S. Model2
查看>>