资源简介
基于Visual C#的运用霍夫变换对图像中的直线进行检测的算法,
代码片段和文件信息
///
/// 检测直线
///
/// hough变换后的曲线交点个数,取值越大,找出的直线越少
public Bitmap hough_line(Bitmap bmpobj int cross_num)
{
int x = bmpobj.Width;
int y = bmpobj.Height;
int rho_max = (int)Math.Floor(Math.Sqrt(x*x+y*y))+1; //由原图数组坐标算出ρ最大值,并取整数部分加1
//此值作为ρ,θ坐标系ρ最大值
int[] accarray = new int[rho_max180]; //定义ρ,θ坐标系的数组,初值为0。
//θ的最大值,180度
double[] Theta = new double[180];
//定义θ数组,确定θ取值范围
double i = 0;
for (int index = 0; index < 180; index++)
{
Theta[index] = i;
i += Math.PI/180;
}
double rho;
int rho_int;
for (int n = 0; n < x; n++)
{
for (int m = 0; m < y; m++)
{
Color pixel = bmpobj.GetPixel(n m);
if (pixel.R == 0)
{
for (int k = 0; k < 180; k++)
{
//将θ值代入hough变换方程,求ρ值
rho = (m * Math.Cos(Theta[k])) + (n * Math.Sin(Theta[k]));
//将ρ值与ρ最大值的和的一半作为ρ的坐标值(数组坐标),这样做是为了防止ρ值出现负数
rho_int = (int)Math.Round(rho / 2 + rho_max / 2);
//在ρθ坐标(数组)中标识点,即计数累加
accarray[rho_int k] = accarray[rho_int k] + 1;
}
}
}
}
//=======利用hough变换提取直线======
//寻找100个像素以上的直线在hough变换后形成的点
const int max_line = 100;
int[] case_accarray_n = new int[max_line];
int[] case_accarray_m = new int[max_li
相关资源
- C# TIP文件生成和拆解
- C#解析HL7消息的库135797
- C# OCR数字识别实例,采用TessnetOcr,对
- 考试管理系统 - C#源码
- asp.net C#购物车源代码
- C#实时网络流量监听源码
- C#百度地图源码
- Visual C#.2010从入门到精通配套源程序
- C# 软件版本更新
- C#屏幕软键盘源码,可以自己定制界面
- 智慧城市 智能家居 C# 源代码
- c#获取mobile手机的IMEI和IMSI
- C#实现简单QQ聊天程序
- 操作系统 模拟的 欢迎下载 C#版
- C#写的计算机性能监控程序
- 用C#实现邮件发送,有点类似于outlo
- MVC model层代码生成器 C#
- c#小型图书销售系统
- C# Socket Server Client 通讯应用 完整的服
- c# winform 自动登录 百度账户 源代码
- C#编写的16进制计算器
- C#TCP通信协议
- C# 数据表(Dataset)操作 合并 查询一
- C#语音识别系统speechsdk51,SpeechSDK51L
- 数据库备份还原工具1.0 C# 源码
-
[免费]xm
lDocument 节点遍历C# - EQ2008LEDc#开发实例
- DirectX.Capturec# winform 操作摄像头录像附
- c# 实现的最大最小距离方法对鸢尾花
- C#版保龄球记分代码
评论
共有 条评论