上回说到开发环境搭建,这回说说WP7上简单的图像处理(我这跨度会不会太大了。。。)因为我现在主要的工作在图像处理和视频传输上,所以搭好开发环境后就直接搞图像了。
图像处理中最简单的莫过于灰度图处理,所以就以灰度处理为例说一下在WP7上我们要怎么做。
基本的思路是:加载彩色图像->获取每个像素点的R、G、B值->根据公式做灰度变换->新建灰度图并打点。
一、首先是加载彩色图像:
在WP7中我们可以使用<Image>控件,只要指定Source属性即可。
<Image>控件支持本地图像,比如使用项目资源文件,Source="/ImageProcessTest;component/Images/hua.jpg";
也支持网络上的图像,只要将Source指定到某个URL即可,比如"http://www.chenxupro.com/hua.jpg"。
当然我们也可以通过Image类去动态加载。
二、获取每个像素点的RGB值:
在WP7中有个重要的类WriteableBitmap,它可以帮助我们去访问图像的每个像素点。
它的构造函数是:public WriteableBitmap(UIElement element, Transform transform);
// 参数:
// element:
// 要在位图中呈现的所需元素。
// transform:
// 用户要在绘制到位图中之前的最后一步中应用到元素的变换。如果您希望位图将它的变换考虑在内,则这对于您特别有意义。此值可以为 null。
我们可以通过WriteableBitmap类的Pixels成员变量去获取表示位图2D纹理的数组,这个数组是按行优先排列的。
WriteableBitmap wb = new WriteableBitmap(image_IP, null);
int[] ImageData = wb.Pixels;
依次通过该数组,获取作为整数值的单个像素值,这些整数值计算为自左乘的 ARGB32:
每个像素的RGB值可以这样获得:
byte RedValue = (byte)(curColor >> 16 & 0xFF); //0xFF实际上没有意义!!!
byte GreenValue = (byte)(curColor >> 8 & 0xFF);
byte BlueValue = (byte)(curColor & 0xFF);
三、根据公式做灰度变换:
byte GrayValue = (byte)(RedValue * 0.299 + GreenValue * 0.587 + BlueValue * 0.114);
四、新建灰度图并打点:
新建灰度图处理空间:
通过比特变换获得灰度值的整数表示:
将灰度值赋值给灰度图像:
这样灰度变换就完成啦~
下面是效果图:
完整的工程代码可以到这里下载:

本文详细介绍了在WP7平台上进行简单图像处理的方法,包括加载彩色图像、获取像素点RGB值、灰度变换及创建灰度图像的过程。通过实际代码示例,展示了如何使用WriteableBitmap类来实现图像的读取与处理。

1

被折叠的 条评论
为什么被折叠?



