python+opencv学习之--提取角点

简介: python+opencv学习之--提取角点

实现提取轮廓的功能,并且绘制出轮廓的重心


import numpy as np

import cv2

from pylab import imshow

from pylab import array

from pylab import plot

from pylab import title

#读取图片

img = cv2.imread('timg.jpeg')

img = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)#转灰度值

#二值化,canny检测

binaryImg = cv2.Canny(img,50,200)

#寻找轮廓

contours,contourstype=cv2.findContours(binaryImg,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)

#查看轮廓数量

-- print (len(contours))

--print (type(contours))

-- print (type(contourstype))

--print ((contourstype))

temp = np.ones(binaryImg.shape,np.uint8)*255

for each in contours:

M = cv2.moments(each)#轮廓的矩
复制代码

(在OpenCV中,可以很方便的计算多边形区域的3阶特征矩,opencv中的矩主要包括以下几种:空间矩,中心矩和中心归一化矩。)

if (M['m00']!=0):
    cx = int(M['m10']/M['m00'])#计算重心
    cy = int(M['m01']/M['m00'])
    pos=(cx,cy)
    print(pos)
cv2.circle(temp,pos, 4, (0, 0, 0), 4)#绘制轮廓的中心点
(img为源图像指针;第一个参数是圆心坐标;第二个参数是为圆的半径;第三是为设定圆的颜色,规则根据B(蓝)G(绿)R(红)第四个s参数如果是正数,表示组成圆的线条的粗细程度。否则,表示圆是否被填充)
复制代码


#画出轮廓:temp是白色幕布,contours是轮廓,-1表示全画,然后是颜色,厚度

cv2.drawContours(temp,contours,-1,(0,255,0),3)

(在图像中绘制外部和内部的轮廓;其中当当thickness >= 0 时,绘制轮廓线;否则填充由轮廓包围的部分。。)

cv2.imshow("contours",temp)

cv2.waitKey(0)

cv2.destroyAllWindows()

关于drawContours参考blog.csdn.net/fulva/artic…关于画圆函数参考blog.csdn.net/yangfengman…



相关文章
|
1月前
|
PyTorch Linux 算法框架/工具
pytorch学习一:Anaconda下载、安装、配置环境变量。anaconda创建多版本python环境。安装 pytorch。
这篇文章是关于如何使用Anaconda进行Python环境管理,包括下载、安装、配置环境变量、创建多版本Python环境、安装PyTorch以及使用Jupyter Notebook的详细指南。
257 1
pytorch学习一:Anaconda下载、安装、配置环境变量。anaconda创建多版本python环境。安装 pytorch。
|
1月前
|
机器学习/深度学习 人工智能 架构师
Python学习圣经:从0到1,精通Python使用
尼恩架构团队的大模型《LLM大模型学习圣经》是一个系统化的学习系列,初步规划包括以下内容: 1. **《Python学习圣经:从0到1精通Python,打好AI基础》** 2. **《LLM大模型学习圣经:从0到1吃透Transformer技术底座》**
Python学习圣经:从0到1,精通Python使用
|
1月前
|
机器学习/深度学习 缓存 PyTorch
pytorch学习一(扩展篇):miniconda下载、安装、配置环境变量。miniconda创建多版本python环境。整理常用命令(亲测ok)
这篇文章是关于如何下载、安装和配置Miniconda,以及如何使用Miniconda创建和管理Python环境的详细指南。
362 0
pytorch学习一(扩展篇):miniconda下载、安装、配置环境变量。miniconda创建多版本python环境。整理常用命令(亲测ok)
|
1月前
|
计算机视觉 Python
python利用pyqt5和opencv打开电脑摄像头并进行拍照
本项目使用Python的PyQt5和OpenCV库实现了一个简单的摄像头应用。用户可以通过界面按钮打开或关闭摄像头,并实时预览视频流。点击“拍照”按钮可以捕捉当前画面并保存为图片文件。该应用适用于简单的图像采集和处理任务。
102 0
python利用pyqt5和opencv打开电脑摄像头并进行拍照
|
1月前
|
开发者 Python
Python学习九:file操作
这篇文章是关于Python文件操作的详细教程,包括文件的打开、读写、关闭,以及文件备份脚本的编写和文件定位操作。
21 2
|
1月前
|
Java C# Python
Python学习七:面向对象编程(中)
这篇文章是关于Python面向对象编程的中级教程,涵盖了析构函数、对象的三大特征(封装、继承、多态)、类属性与实例属性、以及类方法与静态方法的对比。
22 2
|
1月前
|
设计模式 安全 JavaScript
Python学习八:面向对象编程(下):异常、私有等
这篇文章详细介绍了Python面向对象编程中的私有属性、私有方法、异常处理及动态添加属性和方法等关键概念。
22 1
|
1月前
|
存储 Java 编译器
Python学习三:学习python的 变量命名规则,算数、比较、逻辑、赋值运算符,输入与输出。
这篇文章是关于Python编程语言中变量命名规则、基本数据类型、算数运算符、比较运算符、逻辑运算符、赋值运算符以及格式化输出与输入的详细教程。
19 0
Python学习三:学习python的 变量命名规则,算数、比较、逻辑、赋值运算符,输入与输出。
|
1月前
|
资源调度 前端开发 JavaScript
Python学习二:Python包管理器pip
这篇文章介绍了Python包管理器pip的基本概念、基本操作、如何更改下载源为国内镜像以加速下载,以及如何指定安装包的位置。
38 0
Python学习二:Python包管理器pip
|
1月前
|
设计模式 运维 安全
Python学习—装饰器的力量 (一)
Python学习—装饰器的力量 (一)