opencv基础55-获取轮廓的特征值及示例

轮廓自身的一些属性特征及轮廓所包围对象的特征对于描述图像具有重要意义。本节介绍几个轮廓自身的属性特征及轮廓所包围对象的特征。

宽高比

可以使用宽高比(AspectRation)来描述轮廓,例如矩形轮廓的宽高比为:

宽高比 = 宽度(Width)/高度(Height)

示例:编写程序计算矩形轮廓的宽高比。

import cv2
o = cv2.imread('cc.bmp')
cv2.imshow("original",o)
gray = cv2.cvtColor(o,cv2.COLOR_BGR2GRAY)
ret, binary = cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
contours, hierarchy = cv2.findContours(binary,
 cv2.RETR_LIST,
cv2.CHAIN_APPROX_SIMPLE)
x,y,w,h = cv2.boundingRect(contours[0])
cv2.rectangle(o,(x,y),(x+w,y+h),(255,255,255),3)
aspectRatio = float(w)/h

print(aspectRatio)
cv2.imshow("result",o)
cv2.waitKey()
cv2.destroyAllWindows()

运行结果:
同时,程序还会显示如下的运行结果:

2.1506849315068495

可以看出,轮廓的宽高比约为 2。
在这里插入图片描述

Extent(用轮廓面积与矩形边界(矩形包围框、矩形轮廓)面积之比 )

可以使用轮廓面积与矩形边界(矩形包围框、矩形轮廓)面积之比 Extend 来描述图像及
其轮廓特征。计算方法为:
在这里插入图片描述

示例:计算图像的轮廓面积与其矩形边界面积之比。

import cv2
o = cv2.imread('cc.bmp')
cv2.imshow("original",o)
gray = cv2.cvtColor(o,cv2.COLOR_BGR2GRAY)
ret, binary = cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
contours, hierarchy = cv2.findContours(binary,
 cv2.RETR_LIST,
cv2.CHAIN_APPROX_SIMPLE)
x,y,w,h = cv2.boundingRect(contours[0])
cv2.drawContours(o,contours[0],-1,(0,0,255),3)
cv2.rectangle(o,(x,y),(x+w,y+h),(255,0,0),3)
#----------------计算轮廓的面积与边界矩形的面积-------------------------
rectArea=w*h
cntArea=cv2.contourArea(contours[0])

extend=float(cntArea)/rectArea
print(extend)
cv2.imshow("result",o)
cv2.waitKey()
cv2.destroyAllWindows()

同时,程序还会显示如下的运行结果:

0.6717127650292296

可以看出,本例中图像的轮廓面积与矩形边界面积的比值大约为 0.7。
在这里插入图片描述

Solidity(轮廓面积与凸包面积之比)

可以使用轮廓面积与凸包面积之比 Solidity 来衡量图像、轮廓及凸包的特征。其计算方法为:

在这里插入图片描述

示例:编写程序计算图像轮廓面积与凸包面积之比。

import cv2
o = cv2.imread('hand.bmp')
cv2.imshow("original",o)
gray = cv2.cvtColor(o,cv2.COLOR_BGR2GRAY)
ret, binary = cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
contours, hierarchy =cv2.findContours(binary,cv2.RETR_LIST,cv2.CHAIN_APPROX_SIMPLE)
cv2.drawContours(o,contours[0],-1,(0,0,255),3)
cntArea=cv2.contourArea(contours[0])
hull = cv2.convexHull(contours[0])
hullArea = cv2.contourArea(hull)
cv2.polylines(o, [hull], True, (0, 255, 0), 2)
solidity=float(cntArea)/hullArea
print(solidity)
cv2.imshow("result",o)
cv2.waitKey()
cv2.destroyAllWindows()

同时,程序还会显示如下的运行结果:

0.6752344564084751

可以看出,本例中图像的轮廓面积与凸包面积的比值约为 0.7。

就是绿色的跟红色的面积之比
在这里插入图片描述

等效直径(Equivalent Diameter)

可以用等效直径来衡量轮廓的特征值,该值是与轮廓面积相等的圆形的直径。其计算公式为:

在这里插入图片描述

示例:计算与轮廓面积相等的圆形的直径,并绘制与该轮廓等面积的圆。

import cv2
import numpy as np
o = cv2.imread('cc.bmp')
cv2.imshow("original",o)
gray = cv2.cvtColor(o,cv2.COLOR_BGR2GRAY)
ret, binary = cv2.threshold(gray,127,255,cv2.THRESH_BINARY)
contours, hierarchy = cv2.findContours(binary,
 cv2.RETR_LIST,
 cv2.CHAIN_APPROX_SIMPLE)

cv2.drawContours(o,contours[0],-1,(0,0,255),3)
cntArea=cv2.contourArea(contours[0])
equiDiameter = np.sqrt(4*cntArea/np.pi)
print(equiDiameter)
cv2.circle(o,(100,100),int(equiDiameter/2),(0,0,255),3) #展示等直径大小的圆
cv2.imshow("result",o)
cv2.waitKey()
cv2.destroyAllWindows()

同时,程序还会显示如下的运行结果:

99.00522529212108

可以看出,与本例中与轮廓面积相等的圆形的直径约为 99。

在这里插入图片描述

方向

在 OpenCV

可以通过以下步骤使用 C#SQL Server 数据库数据导出为 Excel 文件: 1. 使用 SQL Server Management Studio (SSMS) 创建一个 SQL 查询,该查询从特定中选择要导出的数据。 2. 在 Visual Studio 中创建一个新的 C# 控制台应用程序项目。 3. 在该项目中添加对 Microsoft.Office.Interop.Excel 引用的引用。 4. 在代码中,创建一个 SqlConnection 对象并打开连接。 5. 创建一个 SqlCommand 对象,并将查询字符串和 SqlConnection 对象传递给它。 6. 使用 SqlCommand 对象的 ExecuteReader 方法执行查询,并将结果存储在 SqlDataReader 对象中。 7. 创建一个 Excel.Application 对象,并使用它创建一个新的工作簿。 8. 在工作簿中创建一个新的工作,并将 SqlDataReader 对象中的数据写入该工作中。 9. 保存 Excel 文件。 以下是 C# 代码示例: ``` using System; using System.Data.SqlClient; using Microsoft.Office.Interop.Excel; namespace SQLtoExcel { class Program { static void Main(string[] args) { string connectionString = "Data Source=myServerAddress;Initial Catalog=myDataBase;Integrated Security=SSPI;"; string queryString = "SELECT * FROM myTable"; SqlConnection connection = new SqlConnection(connectionString); connection.Open(); SqlCommand command = new SqlCommand(queryString, connection); SqlDataReader reader = command.ExecuteReader(); Application excel = new Application(); Workbook workbook = excel.Workbooks.Add(); Worksheet worksheet = (Worksheet)workbook.Worksheets[1]; int row = 1; int column = 1; for (int i = 0; i < reader.FieldCount; i++) { worksheet.Cells[row, column++] = reader.GetName(i); } row++; while (reader.Read()) { column = 1; for (int i = 0; i < reader.FieldCount; i++) { worksheet.Cells[row, column++] = reader[i].ToString(); } row++; } workbook.SaveAs("output.xlsx"); workbook.Close(); excel.Quit(); Console.WriteLine("Data exported to Excel file."); Console.ReadLine(); } } } ``` 请注意,这只是一个简单的示例,您可能需要根据您的需要进行更改和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小海聊智造

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值