php 图像边缘检测,C#_C#图像边缘检测(Roberts)的方法,本文实例讲述了C#图像边缘检 - phpStudy...

C#图像边缘检测(Roberts)的方法

本文实例讲述了C#图像边缘检测(Roberts)的方法。分享给大家供大家参考。具体如下:

//定义roberts算子函数

private static Bitmap robert(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, r5, r6, r7;

int g5, g6, g7, g0;

int b5, b6, b7, b0;

double vR, vG, vB;

//右

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;

r0 = p[2];

g0 = p[1];

b0 = p[0];

vR = (double)(Math .Abs (r0-r5)+Math .Abs ( r5-r7));

vG = (double)(Math.Abs(g0 - g5) + Math.Abs(g5 - g7));

vB = (double)(Math.Abs(b0 - b5) + Math.Abs(b5 - b7));

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#程序设计有所帮助。相关阅读:

SQLServer主键和唯一约束的区别

MySQL 5.5/5.6/5.7及以上版本安装包安装时如何选择安装路径

win10系统itunes不能连接手机和平板电脑的解决方法

JavaScript转换二进制编码为ASCII码的方法

ASP.NET MVC5 网站开发框架模型、数据存储、业务逻辑(三)

css3闪亮进度条效果实现思路及代码

JS显示日历和天气的方法

Ubuntu 16.04系统总的启动器栏该怎么设置?

Win7旗舰版电脑如何开启最高权限?Win7旗舰版开启最高权限的方法

js实现分享到随页面滚动而滑动效果的方法

AngularJS 基础ng-class-even指令用法

php 无法加载mcrypt.dll的解决办法

Android仿外卖购物车功能

javascript运算符语法全面概述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值