对于模糊图片这个效果的实现,其实css3中的filter属性也能够实现,但是这个属性的兼容性不是很好,所以我们通常不用这种方法实现,而使用canvas配合JS实现。

  1. <span style="white-space:pre">  </span>//高斯模糊  参数说明:width:canvas对象或者是数据体对象的宽,height:canvas或者是数据体对象的高,
  2. //radius:模糊取值半径(默认为3),sigma:方差取值(默认为1)
  3. /**
  4. * [Gaussian_blur description]
  5. * @param {[type]} data   [description]
  6. * @param {[type]} width  [description]
  7. * @param {[type]} height [description]
  8. * @param {[type]} radius [description]
  9. * @param {[type]} sigma  [description]
  10. */
  11. function Gaussian_blur(data, width, height, radius, sigma) {
  12. var gaussMatrix = [],
  13. gaussSum = 0,
  14. x, y,
  15. r, g, b, a,
  16. i, j, k, len;
  17. radius = Math.floor(radius) || 3;
  18. sigma = sigma || radius / 3;
  19. a = 1 / (Math.sqrt(2 * Math.PI) * sigma);
  20. b = -1 / (2 * sigma * sigma);
  21. //生成高斯矩阵
  22. for (i = 0, x = -radius; x <= radius; x++, i++) {
  23. g = a * Math.exp(b * x * x);
  24. gaussMatrix[i] = g;
  25. gaussSum += g;
  26. }
  27. //归一化, 保证高斯矩阵的值在[0,1]之间
  28. for (i = 0, len = gaussMatrix.length; i < len; i++) {
  29. gaussMatrix[i] /= gaussSum;
  30. }
  31. //x方向
  32. for (y = 0; y < height; y++) {
  33. for (x = 0; x < width; x++) {
  34. r = g = b = a = 0;
  35. gaussSum = 0;
  36. for (j = -radius; j <= radius; j++) {
  37. k = x + j;  a=j+row;
  38. if (k >= 0 && k < width) { //确保 k 没超出 x 的范围
  39. i = (y * width + k) * 4;
  40. r += data[i] * gaussMatrix[j + radius];
  41. g += data[i + 1] * gaussMatrix[j + radius];
  42. b += data[i + 2] * gaussMatrix[j + radius];
  43. gaussSum += gaussMatrix[j + radius];
  44. }
  45. }
  46. i = (y * width + x) * 4;
  47. data[i] = r / gaussSum;
  48. data[i + 1] = g / gaussSum;
  49. data[i + 2] = b / gaussSum;
  50. }
  51. }
  52. //y方向
  53. for (x = 0; x < width; x++) {
  54. for (y = 0; y < height; y++) {
  55. r = g = b = a = 0;
  56. gaussSum = 0;
  57. for (j = -radius; j <= radius; j++) {
  58. k = y + j;
  59. if (k >= 0 && k < height) { //确保 k 没超出 y 的范围
  60. i = (k * width + x) * 4;
  61. r += data[i] * gaussMatrix[j + radius];
  62. g += data[i + 1] * gaussMatrix[j + radius];
  63. b += data[i + 2] * gaussMatrix[j + radius];
  64. gaussSum += gaussMatrix[j + radius];
  65. }
  66. }
  67. i = (y * width + x) * 4;
  68. data[i] = r / gaussSum;
  69. data[i + 1] = g / gaussSum;
  70. data[i + 2] = b / gaussSum;
  71. }
  72. }
  73. return data;
  74. }

canvas高斯模糊算法的更多相关文章

  1. .net版高斯模糊算法

    最近挺多人找高斯算法,本人贴上一个高斯模糊算法类,希望可以帮助到大家.算法的效率还是可以接受的. #region 高斯模糊算法 /// <summary> /// 高斯模糊算法 /// & ...

  2. 简单的java高斯模糊算法

    import java.awt.Color; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOEx ...

  3. SSE图像算法优化系列二:高斯模糊算法的全面优化过程分享(一)。

    这里的高斯模糊采用的是论文<Recursive implementation of the Gaussian filter>里描述的递归算法. 仔细观察和理解上述公式,在forward过程 ...

  4. 高斯模糊算法的 C++ 实现

    2008 年在一个 PS 讨论群里,有网友不解 Photoshop 的高斯模糊中的半径是什么含义,因此当时我写了这篇文章: 对Photoshop高斯模糊滤镜的算法总结: 在那篇文章中,主要讲解了高斯模 ...

  5. 传统高斯模糊与优化算法(附完整C++代码)

    高斯模糊(英语:Gaussian Blur),也叫高斯平滑,是在Adobe Photoshop.GIMP以及Paint.NET等图像处理软件中广泛使用的处理效果,通常用它来减少图像噪声以及降低细节层次 ...

  6. webgl智慧楼宇发光效果算法系列之高斯模糊

    webgl智慧楼宇发光效果算法系列之高斯模糊 如果使用过PS之类的图像处理软件,相信对于模糊滤镜不会陌生,图像处理软件提供了众多的模糊算法.高斯模糊是其中的一种. 在我们的智慧楼宇的项目中,要求对楼宇 ...

  7. HTML5 实现图像模糊算法

    做个广告,WEB/PHP/JQ/HTML5/MYSQL/QQ群6848027 项目中需要用到HTML5模糊图像,以前用GDI,GDI+中都有现成的组件来实现,HTML5中如何实现? createIma ...

  8. Android高斯模糊

    传送门 github地址:http://developer.android.com/guide/topics/renderscript/compute.html: https://github.com ...

  9. Android开发学习之路-动态高斯模糊怎么做

    什么是高斯模糊? 高斯模糊(英语:Gaussian Blur),也叫高斯平滑,是在Adobe Photoshop.GIMP以及Paint.NET等图像处理软件中广泛使用的处理效果,通常用它来减少图像噪 ...

随机推荐

  1. 【Codeforces 1110D】Jongmah FST分析

    Codeforces 1110 D FST分析 dotorya.FizzyDavid.MofK.gamegame.matthew99.chokudai.eddy1021.DBradac.Happy_N ...

  2. Android学习之基础知识五—创建自定义控件

    下面是控件和布局的继承关系: 从上面我们看到: 1.所有控件都是直接或间接继承View,所有的布局都是直接或间接继承ViewGroup 2.View是Android中最基本的UI组件,各种组件其实就是 ...

  3. Luogu P2661 信息传递

    传送门 一眼就能看出来是个并查集 但是并不会写... 看了一下题解说是并查集求最小环qwq 所以,每次加入第i个小同学,判断如果他要告诉的小同学k最后会告诉他(也就是转回来了), 就说明出现了一个环, ...

  4. 浅谈UI自动化测试

    最近一直在学习python,正好部门技术结构调整,就开始了点工向UI自动化测试的转变,我要说瞌睡来了就掉枕头么? 不过还好,可以将python的学习成果在自动化测试中实践... 1.about自动化测 ...

  5. CMD命令查看当前电脑安装所有版本.NET Core SDK(转载)

    dotnet --version 查看当前使用版本 dotnet --info 安装的所有版本 包括版本地址 也可用命令帮助 dotnet help 原文链接

  6. Struts学习总结-02 上传文件

    Struts 2框架提供了内置支持处理文件上传使用基于HTML表单的文件上传.上传一个文件时,它通常会被存储在一个临时目录中,他们应该由Action类进行处理或移动到一个永久的目录,以确保数据不丢失. ...

  7. 实现Cookie集合

    以前Insus.NET有在博客上有写过一篇<在程序中使用Cookie集合>http://www.cnblogs.com/insus/archive/2011/05/25/2055531.h ...

  8. odoo 11导入外部数据过程记录

    在开发过程中,遇见需要将SQL Server中的数据转移到Pg数据库的情况,那么如何做才能解决这一问题呢? 1.自己写代码,将数据从SQL Server到PG. 2.利用odoo自带的导入功能导入. ...

  9. vue2.0中使用pug(jade)

    第一部分:pug(jade)模板引擎 pug,原名jade,是流行的HTML模板引擎,它是HAML在JavaScript上的实现,最大的特色是使用缩进排列替代成对标签. 它简化了HTML的成对标签的写 ...

  10. [JDBC]ORA-01000: 超出打开游标的最大数(ORA-01000: maximum open cursors exceeded)

    问题产生的原因: Java代码在执行conn.createStatement()和conn.prepareStatement()的时候,相当于在数据库中打开了一个cursor.由于oracle对打开的 ...