实现C#马赛克算法

开发 后端 算法
本文介绍C#马赛克算法很简单,说白了就是把一张图片分割成若干个val * val像素的小区块,每个小区块的颜色都是相同的。

应听众点播要求,今天讲讲C#马赛克算法的实现。老规矩,不求甚解,只许看不许问为什么

很多图片处理的算法从原理上讲其实非常简单,难点往往在如何去写算法实现它,更加难的就是如何去优化实现的算法。虽说我一向认为程序员的效率比程序的效率更重要,但为了等处理一张自己拍摄的数码照片,溜出去买杯奶茶顺便再买张彩票回来发现还没算好,无论如何都是不能忍受的。

C#马赛克算法很简单,说白了就是把一张图片分割成若干个val * val像素的小区块(可能在边缘有零星的小块,但不影响整体算法),每个小区块的颜色都是相同的。为了方便起见,我们不妨让这个颜色就用该区域最左上角的那个点的颜色。当然还可以有其他方法,比如取区块中间点的颜色,或区块中随机点的颜色作代表等等。

下面的示意图就是取val=2的结果。

原图像素
ABCDEFG
HIJKLMN  
OPQRSTU  
VWXYZ01  
2345678  

马赛克处理后
AACCEEG
AACCEEG
OOQQSSU
OOQQSSU
2244668

原理就是那么简单。具体实现就看各人的思维习惯了。我的想法是:

当y(当前高度)是val的整数倍时:
 扫描当前行中的每一点x,如果x也是val的整数倍,记录下当前x,y的颜色值;如果x不是val的整数倍,则沿用最近一次被记录的颜色值。
当y不是val的整数倍:
 很简单,直接复制上一行。

简单的说就是以线带面,最终实现让大家都看不清楚

下面就是源代码。写算法不是我的强项,不过偶尔勉为其难的写个可以跑跑的不求甚解版还是可以做到的,不指望可以帮到你,只希望没有误导你。

  1. publicstaticBitmapKiMosaic(Bitmapb,intval)  
  2. {  
  3. if(b.Equals(null))  
  4. {  
  5. returnnull;  
  6. }  
  7. intw=b.Width;  
  8. inth=b.Height;  
  9. intstdR,stdG,stdB;  
  10. stdR=0;  
  11. stdG=0;  
  12. stdB=0;  
  13. BitmapDatasrcData=b.LockBits(newRectangle(0,0,w,h),
    ImageLockMode.ReadWrite,PixelFormat.Format24bppRgb);  
  14. unsafe  
  15. {  
  16. byte*p=(byte*)srcData.Scan0.ToPointer();  
  17. for(inty=0;y<h;y++)  
  18. {  
  19. for(intx=0;x<w;x++)  
  20. {  
  21. if(y%val==0)  
  22. {  
  23. if(x%val==0)  
  24. {  
  25. stdR=p[2];stdG=p[1];stdB=p[0];  
  26. }  
  27. else  
  28. {  
  29. p[0]=(byte)stdB;  
  30. p[1]=(byte)stdG;  
  31. p[2]=(byte)stdR;  
  32. }  
  33. }  
  34. else  
  35. {  
  36. //复制上一行  
  37. byte*ppTemp=p-srcData.Stride;  
  38. p[0]=(byte)pTemp[0];  
  39. p[1]=(byte)pTemp[1];  
  40. p[2]=(byte)pTemp[2];  
  41. }  
  42. p+=3;  
  43. }//endofx  
  44. p+=srcData.Stride-w*3;  
  45. }//endofy  
  46. b.UnlockBits(srcData);  
  47. }  
  48. returnb;  

以上介绍C#马赛克算法

【编辑推荐】

  1. 浅析C# ArrayList
  2. C#对象初始化学习总结
  3. 使用C#正则表达式匹配相关字符串
  4. C#改写方法学习笔记
  5. 概述C#加框和消框
责任编辑:佚名 来源: 博客园
相关推荐

2022-09-07 08:37:34

DCGAN图片AI

2020-12-09 14:18:46

AI 技术马赛克

2018-07-03 08:50:12

人工智能深度学习CNN

2021-02-24 10:19:43

人工智能马赛克

2015-04-30 10:29:32

WOC视频会议优化方案深信服

2020-12-02 15:07:23

算法开源AI

2021-05-31 10:30:46

密码马赛克工具

2018-09-12 16:30:45

Python编程语言马赛克画

2020-06-18 11:10:16

AI人工智能神经网络

2021-02-24 11:25:44

人工智能AI算法马赛克

2011-08-18 15:56:03

深信服广域网优化

2012-05-25 14:41:19

JavaScript

2023-11-22 11:20:38

2012-03-16 16:33:35

视频会议马赛克深信服

2021-03-01 11:37:31

人工智能PULSE

2021-01-04 05:36:23

AI人工智能深度学习

2015-10-15 17:31:14

微软

2024-07-29 08:43:57

2020-05-07 11:03:32

AI 马赛克工具

2017-02-09 07:50:32

复原马赛克科技新闻早报
点赞
收藏

51CTO技术栈公众号