当前位置: 首页 > news >正文

wordpress实现下载功能成都seo培训班

wordpress实现下载功能,成都seo培训班,用java做网站可以,渭南免费做网站图像轮廓 1.获取图像轮廓 cv2.findContours() 函数是 OpenCV 库中用于检测图像中轮廓的函数。它可以检测到图像中所有连通区域的边界,并返回这些轮廓的列表。从 OpenCV 3.4 版本开始,这个函数的返回值和参数有所变化,以下是详细的参数说明&…

图像轮廓

1.获取图像轮廓

cv2.findContours() 函数是 OpenCV 库中用于检测图像中轮廓的函数。它可以检测到图像中所有连通区域的边界,并返回这些轮廓的列表。从 OpenCV 3.4 版本开始,这个函数的返回值和参数有所变化,以下是详细的参数说明:

方法:

contours, hierarchy = cv2.findContours( img, mode, method )

参数说明

  1. img:输入图像,必须是二值图像。图像中的轮廓将基于此图像进行检测。

  2. mode:轮廓检索模式,用于指定要检索哪些轮廓。可用的模式有:

    • cv2.RETR_EXTERNAL:只检索最外层的轮廓。
    • cv2.RETR_LIST:检索所有轮廓,但不建立任何父子关系。
    • cv2.RETR_CCOMP:检索所有轮廓,并将它们组织成两级层次结构。
    • cv2.RETR_TREE:检索所有轮廓,并重建完整的层次结构。
  3. method:轮廓近似方法,用于指定如何存储轮廓点。可用的方法有:

    • cv2.CHAIN_APPROX_NONE:存储所有轮廓点。
    • cv2.CHAIN_APPROX_SIMPLE:只存储轮廓的拐点,这可以减少轮廓点的数量。

返回值

  • contours:这是一个 Python 列表,其中包含了检测到的轮廓。每个轮廓都是一个形状为 (n, 1, 2) 的 numpy 数组,其中 n 是轮廓点的数量。
  • hierarchy:这是一个 numpy 数组,包含了轮廓的层次信息。层次信息可以用来了解轮廓之间的父子关系。

2.绘制图像轮廓

        在OpenCV中,cv2.drawContours()函数用于在图像上绘制轮廓。这个函数非常强大,因为它允许你指定轮廓的颜色、线条粗细以及其他参数。下面是这个函数的详细参数说明:

方法:

cv2.drawContours(img, contours, contourIdx, color, thickness, lineType=None, hierarchy=None)

参数说明

  1. img:目标图像,即你要在其上绘制轮廓的图像。这个图像应该是一个可以修改的图像数组。

  2. contours:这是一个轮廓列表。轮廓可以是OpenCV中找到的任何轮廓,通常是一个形状为(N, 1, 2)的numpy数组,其中N是轮廓中的点数。

  3. contourIdx:指定要绘制的轮廓的索引。如果传递的是-1,则绘制所有轮廓。

  4. color:轮廓线的颜色。这应该是一个具有三个元素的元组,表示BGR颜色(例如,红色为(0, 0, 255))。

  5. thickness:线条的粗细。如果设置为正数,则线条的粗细为指定的像素数;如果设置为cv2.FILLED-1,则轮廓将被填充。

  6. lineType(可选):线条的类型。默认是cv2.LINE_8,表示8连通性线。其他选项包括cv2.LINE_4(4连通性线)和cv2.LINE_AA(抗锯齿线)。

  7. hierarchy(可选):轮廓的层次结构。这是一个与contours数组相对应的数组,其中包含每个轮廓的层次信息。如果提供,可以用来绘制轮廓的父子关系。

实验代码

1.获取图像

import cv2# 读取图像
phone = cv2.imread('cat.png')  # 读取名为'cat.png'的图像# 将图像转换为灰度图像
phone_gray = cv2.cvtColor(phone, cv2.COLOR_BGR2GRAY)  # 将彩色图像转换为灰度图# 应用阈值操作以创建二值图像
ret, phone_binary = cv2.threshold(phone_gray, 120, 255, cv2.THRESH_BINARY)  # 使用阈值120将灰度图转换为二值图
# cv2.imshow('1',phone_binary)  # 显示二值图像

2.查找轮廓

# 查找轮廓
_, contours, hierarchy = cv2.findContours(phone_binary, cv2.RETR_TREE, cv2.CHAIN_APPROX_NONE)  # 在二值图中查找轮廓
# 打印轮廓数量和层次结构信息
print(hierarchy)  # 打印轮廓的层次结构信息
print(len(contours))  # 打印轮廓的数量

3.复制图像用于绘制轮廓

# 复制图像用于绘制轮廓
image_copy = phone.copy()
image_copy = cv2.drawContours(image=image_copy, contours=contours, contourIdx=-1, color=(0, 255, 0), thickness=3)  # 在图像上绘制所有轮廓
# cv2.imshow('contours',image_copy)  # 显示绘制了轮廓的图像
cv2.waitKey(0)  # 等待按键

4.计算轮廓面积和周长

# 计算第一个和第二个轮廓的面积
area_0 = cv2.contourArea(contours[0])
area_1 = cv2.contourArea(contours[1])
print(area_0, area_1)  # 打印面积# 计算第一个轮廓的周长
length = cv2.arcLength(contours[0], closed=True)
print(length)  # 打印周长

5.查找轮廓

# 筛选面积大于10000的轮廓
a_list = []
for i in range(len(contours)):if cv2.contourArea(contours[i]) > 10000:a_list.append(contours[i])# 找到第七个轮廓的最小包围圆
cnt = contours[6]
(x, y), r = cv2.minEnclosingCircle(cnt)
phone_circle = cv2.circle(phone, (int(x), int(y)), int(r), (0, 255, 0), 2)  # 在图像上绘制最小包围圆
cv2.imshow('phone_circle', phone_circle)  # 显示绘制了最小包围圆的图像# 找到第七个轮廓的最小包围矩形
x, y, w, h = cv2.boundingRect((cnt))
phone_rectangle = cv2.rectangle(phone, (x, y), (x + w, y + h), (0, 255, 0), 2)  # 在图像上绘制最小包围矩形
cv2.imshow('phone_rectangle', phone_rectangle)  # 显示绘制了最小包围矩形的图像

6.轮廓近似

# 重新查找轮廓
image, contours, hierarchy = cv2.findContours(phone_binary, cv2.RETR_TREE, cv2.CHAIN_APPROX_NONE)# 对最后一个轮廓进行轮廓近似
epsilon = 0.001 * cv2.arcLength(contours[-1], True)
approx = cv2.approxPolyDP(contours[-1], epsilon, True)
phone_new = phone.copy()
image_contours = cv2.drawContours(phone_new, [approx], contourIdx=-1, color=(0, 255, 0), thickness=3)  # 在图像上绘制近似轮廓
cv2.imshow('image_contours', image_contours)  # 显示绘制了近似轮廓的图像cv2.waitKey(0)

实验分析

  • 通过阈值操作,图像中的轮廓被清晰地分离出来,这为后续的轮廓处理提供了便利。
  • 轮廓的面积和周长的计算对于理解图像中对象的大小和形状特征非常重要。
  • 最小包围圆和最小包围矩形的绘制有助于识别和定位图像中的主要对象。
  • 轮廓近似可以简化轮廓的形状,减少计算复杂度,同时保留轮廓的主要特征。

结论

        本实验通过使用OpenCV库成功地完成了图像处理的各个步骤,包括图像的读取、转换、阈值操作、轮廓查找、面积和周长计算、最小包围圆和矩形的绘制以及轮廓近似。这些技术在图像识别、对象检测和图像分析等领域有着广泛的应用。

http://www.shuangfujiaoyu.com/news/7645.html

相关文章:

  • 用vs2010做网站导航优化快速排名教程
  • 深圳涂料网站建设付费推广方式有哪些
  • 建设网站最简单的软件是全国疫情高峰感染进度
  • 推广网站的方法有搜索引擎营销中国外贸订单网
  • 徐州哪里做网站好百度指数的搜索指数代表什么
  • 做网站记者好吗上海seo公司哪家好
  • 服务器机房托管价格关键词排名优化方法
  • 做怎么样的网站好今日小说排行榜百度搜索风云榜
  • 女孩做网站工作辛苦吗seo实战培训
  • html手机网站怎么做win优化大师有免费版吗
  • 私人做的网站怎么挣钱北京学校线上教学
  • 一级a做爰片了网站宽带业务如何推广
  • 做的好的政府网站网站推广文章
  • 清流县建设局网站品牌营销策略论文
  • 如何使用记事本做网站seo快速排名系统
  • binbinli.wordpressseo工具是什么意思
  • 技术培训网站公众号开发网站公司
  • 如何让网站快照新百度的seo排名怎么刷
  • 企业网站系统自动提取关键词的软件
  • 网站制作 电子商城百度热门搜索排行榜
  • 医药企业网站建设要哪些备案哈尔滨网站优化
  • 便民的网站app怎么做小说排行榜2020前十名
  • 哪些作弊网站如何获取热搜关键词
  • 长阳网站建设优化大师win7官方免费下载
  • 免费建站网站建设威海seo
  • 公众号做图网站360收录入口
  • 个人可以做新闻网站软文范例100字
  • 中国人做暧暧视频网站互联网营销培训班
  • 做的网站如何被百度搜到seo优化排名技术百度教程
  • 特价网站源码适合发表个人文章的平台