博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Win8Metro(C#)数字图像处理--2.4图像颜色聚类
阅读量:6161 次
发布时间:2019-06-21

本文共 1229 字,大约阅读时间需要 4 分钟。

原文:



[函数名称]

图像颜色聚类函数ClusterProcess(WriteableBitmap src,int value)

[算法说明]

  图像颜色聚类的方法有很多,但是对于视频监控而言,现有方法很难满足实时性的要求,这里介绍一种位屏蔽压缩的方法实现颜色聚类,可以满足实时性的要求。

  位屏蔽法就是在3DRGB真彩空间中近似均匀采样的颜色压缩方法,即将屏蔽的颜色位置设置为0,具体可以采用移位运算来实现

  一个像素的RGBA分量各占一个字节(这里指32位格式),对于每一个字节,它的大小为[0,255],用二进制位表示如下:

                        0000 0000——1111 1111

  比如11111111移位3位为11111000,按这个方法,我们可以将其移位N(0<N<=7)位,在C#中表现为&操作,如11111111位移3位可表示为:255&248

  用上述这个移位屏蔽算法,我们可以对彩色图像中的每一个像素进行这样的移位操作,那么图像像素值就会得到相应的颜色空间的压缩,从而达到聚类的效果。

[函数代码]

       ///<summary>

       /// Cluster process (a fast method be introduced here).

       ///</summary>

       ///<param name="src">Source image.</param>

       ///<param name="value">Choose one of {254-128}</param>

       ///<returns></returns>

       publicstaticWriteableBitmap ClusterProcess(WriteableBitmap src,int value)4聚类处理

       {

           if(src!=null )

           {

           int w = src.PixelWidth;

           int h = src.PixelHeight;

           WriteableBitmap clusterImage =newWriteableBitmap(w,h);

           byte[] temp = src.PixelBuffer.ToArray();

           for (int i = 0; i < temp.Length; i += 4)

           {

               temp[i] = (byte)(temp[i] & value);

               temp[i + 1] = (byte)(temp[i + 1] & value);

               temp[i + 2] = (byte)(temp[i + 2] & value);

           }

           Stream sTemp = clusterImage.PixelBuffer.AsStream();

           sTemp.Seek(0,SeekOrigin.Begin);

           sTemp.Write(temp, 0, w * 4 * h);

           return clusterImage;

           }

           else

           {

               returnnull;

           }  

       }

你可能感兴趣的文章
Linux下安装配置PHP环境(上)---Apache2
查看>>
自定义ViewGroup (2)支持滑动,并处理多指触摸可能产生的跳动问题
查看>>
Mac 下安装Redis
查看>>
oracle客户端安装
查看>>
在网页在播放flv格式的视频
查看>>
kvm虚拟机vnc和spice配置
查看>>
css设计模式
查看>>
Java IO 之 介质流
查看>>
JS生成二维码
查看>>
Spring 源码分析(三) —— AOP(二)Spring AOP 整体架构
查看>>
【自用】Android 切割Bitmap为多个小的Bitmap
查看>>
深入理解JAVA中的NIO
查看>>
js-匹配边界
查看>>
sql--索引
查看>>
virtualbox导致Windows7重启
查看>>
判断链表是否存在环 Linked List Cycle
查看>>
持续集成实践二之Jenkins与Sonar Qube集成
查看>>
教你怎么样快速降低室内装饰设计污染
查看>>
【原创】rabbitmq-echopid用户手册(翻译)
查看>>
Spark Streaming 实时流处理总结
查看>>