对于模糊图片这个效果的实现,其实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. go标准库的学习-fmt

    参考https://studygolang.com/pkgdoc 导入方式: import "fmt" mt包实现了类似C语言printf和scanf的格式化I/O.格式化动作(' ...

  2. solidity-library

    library 1)直接使用使用库合约的合约,可以将库合约视为隐式的父合约(base contracts),当然它们不会显式的出现在继承关系中.意思就是不用写is来继承,直接可以在合约中使用: lib ...

  3. 素数判断-----埃氏筛法&欧拉筛法

    埃氏筛法 /* |埃式筛法| |快速筛选素数| |15-7-26| */ #include <iostream> #include <cstdio> using namespa ...

  4. ajax上传文件以及实现上传进度条(转载)

    做微信企业号的时候,在‘我的日志'功能模块里边需要添加一个上传文件的功能,并且要显示上传过程中的进度条和提交后的文件名列表,于是做了基于ajax的文件上传,UI用的是MUI框架,后台是TP框架 前端代 ...

  5. BZOJ3451 Normal 期望、点分治、NTT

    BZOJCH传送门 题目大意:给出一棵树,求对其进行随机点分治的复杂度期望 可以知道一个点的贡献就是其点分树上的深度,也就是这个点在点分树上的祖先数量+1. 根据期望的线性性,考虑一个点对\((x,y ...

  6. linux shell的here document用法

    转载自: http://my.oschina.net/u/1032146/blog/146941 什么是Here Document?Here Document 是在Linux Shell 中的一种特殊 ...

  7. WPF 滚动文字控件MarqueeControl

    原文:WPF 滚动文字控件MarqueeControl WPF使用的滚动文字控件,支持上下左右滚动方式,支持设置滚动速度 XAML部分: <UserControl x:Class="U ...

  8. Create-React-App 使用记录

    如果要修改 host 和 端口,需要在项目根目录添加 .env 文件,然后再文件中添加 HOST=dev.zhengtongauto.com PORT=3000 如果需要加上反向代理,需要处理接口跨域 ...

  9. SSL踩坑ERR_SSL_VERSION_OR_CIPHER_MISMATCH

    最近公司项目开发了一个微信小程序,并且部署测试OK,由于微信小程序调用的后端接口必须是HTTPS,所以给接口安装了SSL,第一天测试都正常.第二天早上再使用时页面无响应. 抓包发现是后端接口抛出: n ...

  10. 欧拉函数(小于或等于n的数中与n互质的数的数目)&& 欧拉函数线性筛法

    [欧拉函数] 在数论,对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目.此函数以其首名研究者欧拉命名,它又称为Euler’s totient function.φ函数.欧拉商数等. 例如φ( ...