C#图像处理之边缘检测(Sobel)的方法
作者:沧海一粟…… 时间:2022-05-12 02:05:50
本文实例讲述了C#图像处理之边缘检测(Sobel)的方法。分享给大家供大家参考。具体如下:
//定义sobel算子函数
private static Bitmap sobel(Bitmap a)
{
int w = a.Width;
int h = a.Height;
try
{
Bitmap dstBitmap = new Bitmap(w, h, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
System.Drawing.Imaging.BitmapData srcData = a.LockBits(new Rectangle
(0, 0, w, h), System.Drawing.Imaging.ImageLockMode.ReadOnly, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
System.Drawing.Imaging.BitmapData dstData = dstBitmap.LockBits(new Rectangle
(0, 0, w, h), System.Drawing.Imaging.ImageLockMode.WriteOnly, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
unsafe
{
byte* pIn = (byte*)srcData.Scan0.ToPointer();
byte* pOut = (byte*)dstData.Scan0.ToPointer();
byte* p;
int stride = srcData.Stride;
for (int y = 0; y < h; y++)
{
for (int x = 0; x < w; x++)
{
//边缘八个点像素不变
if (x == 0 || x == w - 1 || y == 0 || y == h - 1)
{
pOut[0] = pIn[0];
pOut[1] = pIn[1];
pOut[2] = pIn[2];
}
else
{
int r0, r1, r2, r3, r4, r5, r6, r7, r8;
int g1, g2, g3, g4, g5, g6, g7, g8, g0;
int b1, b2, b3, b4, b5, b6, b7, b8, b0;
double vR, vG, vB;
//左上
p = pIn - stride - 3;
r1 = p[2];
g1 = p[1];
b1 = p[0];
//正上
p = pIn - stride;
r2 = p[2];
g2 = p[1];
b2 = p[0];
//右上
p = pIn - stride + 3;
r3 = p[2];
g3 = p[1];
b3 = p[0];
//左
p = pIn - 3;
r4 = p[2];
g4 = p[1];
b4 = p[0];
//右
p = pIn + 3;
r5 = p[2];
g5 = p[1];
b5 = p[0];
//左下
p = pIn + stride - 3;
r6 = p[2];
g6 = p[1];
b6 = p[0];
//正下
p = pIn + stride;
r7 = p[2];
g7 = p[1];
b7 = p[0];
// 右下
p = pIn + stride + 3;
r8 = p[2];
g8 = p[1];
b8 = p[0];
//中心点
p = pIn;
r0 = p[2];
g0 = p[1];
b0 = p[0];
//使用模板
vR = (double)(Math .Abs (r1+2*r4+r6-r3-2*r5-r8)+Math .Abs (r1+2*r2+r3-r6-2*r7-r8));
vG = (double)(Math .Abs (g1+2*g4+g6-g3-2*g5-g8)+Math .Abs (g1+2*g2+g3-g6-2*g7-g8));
vB = (double)(Math .Abs (b1+2*b4+b6-b3-2*b5-b8)+Math .Abs (b1+2*b2+b3-b6-2*b7-b8));
if (vR > 0)
{
vR = Math.Min(255, vR);
}
else
{
vR = Math.Max(0, vR);
}
if (vG > 0)
{
vG = Math.Min(255, vG);
}
else
{
vG = Math.Max(0, vG);
}
if (vB > 0)
{
vB = Math.Min(255, vB);
}
else
{
vB = Math.Max(0, vB);
}
pOut[0] = (byte)vB;
pOut[1] = (byte)vG;
pOut[2] = (byte)vR;
}
pIn += 3;
pOut += 3;
}
pIn += srcData.Stride - w * 3;
pOut += srcData.Stride - w * 3;
}
}
a.UnlockBits(srcData);
dstBitmap.UnlockBits(dstData);
return dstBitmap;
}
catch
{
return null;
}
}
希望本文所述对大家的C#程序设计有所帮助。
标签:C#,图像,边缘
0
投稿
猜你喜欢
带你了解Java数据结构和算法之无权无向图
2023-12-24 10:54:05
SpringBoot统一功能处理的方式详解
2021-08-17 10:46:07
Android Studio3.2中导出jar包的过程详解
2021-10-14 07:06:05
android studio 安装完成ButterKnife插件却无法使用(解决方案)
2023-03-14 17:54:58
java并发之ArrayBlockingQueue详细介绍
2023-04-23 07:30:01
Java 将List中的实体类按照某个字段进行分组并存放至Map中操作
2022-09-13 20:25:35
C语言数据结构之单链表与双链表的增删改查操作实现
2023-01-24 07:27:35
HashSet和TreeSet使用方法的区别解析
2022-05-03 12:54:05
SpringBoot集成Redis的实现示例
2022-10-22 14:50:33
unity实现UI元素跟随3D物体
2021-11-15 02:00:48
zookeeper实现分布式锁
2023-08-03 13:44:18
SpringBoot实现分页功能
2021-11-07 12:33:16
Unity UI或3D场景实现跟随手机陀螺仪的晃动效果
2021-12-09 01:09:32
java开发_图片截取工具实现原理
2023-10-23 22:52:06
JAVA MyBatis入门学习过程记录
2022-04-23 13:49:24
IDEA配置JRebel实现热部署的方法
2022-08-28 20:53:00
Java8如何将Array转换为Stream的实现代码
2022-09-15 06:41:31
Struts2中validate数据校验的两种方法详解附Struts2常用校验器
2022-06-03 11:08:13
java sql ResultSet 之getRow()用法说明
2022-07-01 02:43:15
JDBC+GUI实现简单学生管理系统
2022-08-21 02:52:00