常用的Opencv函数汇总(持续更新...)

0. 安装
  1. c++安装
  1. python安装
pip install opencv-contrib-python==3.4.3.18
1. cv.read()、cv.imwrite()
#读取图片
img_path = "img.jpg"
img = cv.imread(img_path)	#BGR
#写入图片
cv.imwrite("img.png", img) 

注,在读取操作时,PIL的Image.open函数读取的通道为RGB,速度比cv.read快。

2. cv2.findContours、cv2.drawContours函数
  • 作用:图像的轮廓检测、图像的轮廓绘制
  • 参考
  • 使用:
import cv2  
  
img = cv2.imread('test.jpg')  
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)  	#转灰度图
ret, binary = cv2.threshold(gray,127,255,cv2.THRESH_BINARY)  
  
contours, hierarchy = cv2.findContours(binary,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)  #找出轮廓点
cv2.drawContours(img,contours,-1,(0,0,255),3)  #绘制轮廓
  
cv2.imshow("img", img)  
cv2.waitKey(0)  

注,opencv2和opencv3的版本不同,findContours的输出会有不同,稍微注意一下

3. cv2.copyMakeBorder函数
4.cv2.createThinPlateSplineShapeTransformer()
5.cv2.copyTo()
6.cv2.circle/cv2.putText()
  • 作用:在指定位置做圆
  • 使用:
#cv2.circle
#2个参数为圆心位置, 3个参数为半径,4个参数为颜色
cv2.circle(img, (int(coords[0]),int(coords[1])), 3, (0,0,255), -1)

#cv2.putText()
#2个参数为要写的文字, 3个参数为位置,4个参数为字体,
for i in range(len(edge_points)):
	cv2.putText(img, str(i), (int(edge_points[i][0]),int(edge_points[i][1])), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0,255,0), 2)
7.cv2.Laplacian()
8.cv2.resize()
9.cv2.add/addWeighted()
10.cv2.seamlessClone()
11.cv2.GaussianBlur()、cv2.filter2D()
12.cv2.getRotationMatrix2D()、cv2.warpAffine()
  • 作用:用于旋转图片固定角度
  • 参考:图片旋转
    注:cv2的旋转是不保边的,保边旋转可以使用imutils.rotate_bound(参考)
13.放射变换、透视变换、tps插值

参考:Thin Plate Spline (薄板样条函数)(TPS)
参考:刚性变换、仿射变换、透视变换和非线形变换
参考:图像处理的仿射变换与透视变换

放射变换(线性变换)是2维空间,给定3个点,可以映射;只能是刚性变换,比如平移,翻转,裁剪;
透视变换(线性变换)是3维空间,给定4个点,可以映射;
tps插值的话是非刚性形变,相对自然,可以输入多个点,去插值;比如给定原始形状的有限点集A,变形后的对应目标点集B,设C=B-A,对(Ax,Ay, Cx)拟合出一个TPS,就可以得到x方向的内插函数;对(Ax,Ay, Cy)拟合出来的TPS则可以得到y方向的内插函数。这样一以来对于不在点集中的点,我们就可以插值得到目标点。从而完成整个面的变形。

14.cv2.minAreaRect、cv2.boxPoints
  • 作用:获取点集的最小外接矩形、获取最小外接矩定点坐标
  • 参考:minAreaRect boxPoints
15.meanStdDev
  • 作用:获取图片部分区域的均值和均方差
  • 参考:meanStdDev使用
    注:可以计算不规则区域的均值与方差,mean, var = cv2.meanStdDev(img, mask = mask)
16.contourArea、arcLength、approxPolyDP
  • 作用:计算轮廓面积、周长、获得轮廓近似
  • 参考:approxPolyDP
17.cv2.inpaint()
18.cv2.VideoCapture()
  • 5
    点赞
  • 79
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值