光晕效果

这篇将讲到图片特效处理的图片光晕效果。跟前面一样是对像素点进行处理,本篇实现的思路可参见android图像处理系列之九--图片特效处理之二-模糊效果android图像处理系列之十三--图片特效处理之六-光照效果。实现的效果是圆圈之内图片像素点不变,圆圈之外的点做模糊处理。所以用到了模糊效果和光照效果里面的是否是在圆圈内的算法,可以说是上面提到的两篇的效果的组合。

下面看效果图:

原图:

效果图:

光晕效果看得不是很明显,模糊强度不够,但是还能明显看到图片中有一个圆圈,圈内区域要比圈外区域看得清楚一点(MM的左右脸就可以看到效果)。处理效果不是很理想,在此只能抛砖引玉。下面贴代码:

[java] view plaincopy

  1. /**
  2. * 光晕效果
  3. * @param bmp
  4. * @param x 光晕中心点在bmp中的x坐标
  5. * @param y 光晕中心点在bmp中的y坐标
  6. * @param r 光晕的半径
  7. * @return
  8. */
  9. public Bitmap halo(Bitmap bmp, int x, int y, float r)
  10. {
  11. long start = System.currentTimeMillis();
  12. // 高斯矩阵
  13. int[] gauss = new int[] { 1, 2, 1, 2, 4, 2, 1, 2, 1 };
  14. int width = bmp.getWidth();
  15. int height = bmp.getHeight();
  16. Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.RGB_565);
  17. int pixR = 0;
  18. int pixG = 0;
  19. int pixB = 0;
  20. int pixColor = 0;
  21. int newR = 0;
  22. int newG = 0;
  23. int newB = 0;
  24. int delta = 18; // 值越小图片会越亮,越大则越暗
  25. int idx = 0;
  26. int[] pixels = new int[width * height];
  27. bmp.getPixels(pixels, 0, width, 0, 0, width, height);
  28. for (int i = 1, length = height - 1; i < length; i++)
  29. {
  30. for (int k = 1, len = width - 1; k < len; k++)
  31. {
  32. idx = 0;
  33. int distance = (int) (Math.pow(k - x, 2) + Math.pow(i - y, 2));
  34. // 不是中心区域的点做模糊处理
  35. if (distance > r * r)
  36. {
  37. for (int m = -1; m <= 1; m++)
  38. {
  39. for (int n = -1; n <= 1; n++)
  40. {
  41. pixColor = pixels[(i + m) * width + k + n];
  42. pixR = Color.red(pixColor);
  43. pixG = Color.green(pixColor);
  44. pixB = Color.blue(pixColor);
  45. newR = newR + (int) (pixR * gauss[idx]);
  46. newG = newG + (int) (pixG * gauss[idx]);
  47. newB = newB + (int) (pixB * gauss[idx]);
  48. idx++;
  49. }
  50. }
  51. newR /= delta;
  52. newG /= delta;
  53. newB /= delta;
  54. newR = Math.min(255, Math.max(0, newR));
  55. newG = Math.min(255, Math.max(0, newG));
  56. newB = Math.min(255, Math.max(0, newB));
  57. pixels[i * width + k] = Color.argb(255, newR, newG, newB);
  58. newR = 0;
  59. newG = 0;
  60. newB = 0;
  61. }
  62. }
  63. }
  64. bitmap.setPixels(pixels, 0, width, 0, 0, width, height);
  65. long end = System.currentTimeMillis();
  66. Log.d("may", "used time="+(end - start));
  67. return bitmap;
  68. }

光晕效果,布布扣,bubuko.com

时间: 2024-10-05 23:56:51

光晕效果的相关文章

【转】七、android图片特效处理之光晕效果

这篇将讲到图片特效处理的图片光晕效果.跟前面一样是对像素点进行处理,本篇实现的思路可参见android图像处理系列之九--图片特效处理之二-模糊效果和android图像处理系列之十三--图片特效处理之六-光照效果.实现的效果是圆圈之内图片像素点不变,圆圈之外的点做模糊处理.所以用到了模糊效果和光照效果里面的是否是在圆圈内的算法,可以说是上面提到的两篇的效果的组合. 下面看效果图: 原图: 效果图: 光晕效果看得不是很明显,模糊强度不够,但是还能明显看到图片中有一个圆圈,圈内区域要比圈外区域看得清

android图片特效处理之光晕效果

这篇将讲到图片特效处理的图片光晕效果.跟前面一样是对像素点进行处理,本篇实现的思路可参见android图像处理系列之九--图片特效处理之二-模糊效果和android图像处理系列之十三--图片特效处理之六-光照效果.实现的效果是圆圈之内图片像素点不变,圆圈之外的点做模糊处理.所以用到了模糊效果和光照效果里面的是否是在圆圈内的算法,可以说是上面提到的两篇的效果的组合. 下面看效果图: 原图: 效果图: 光晕效果看得不是很明显,模糊强度不够,但是还能明显看到图片中有一个圆圈,圈内区域要比圈外区域看得清

Viewpager 去掉两侧的光晕效果

方案1: viewPager.setOverScrollMode(viewPager.OVER_SCROLL_NEVER); 方案2:通过反射的办法,直接操作具体控件具体的控件 private void initViewPager() { try { Field leftEdgeField = viewpager.getClass().getDeclaredField("mLeftEdge"); Field rightEdgeField = viewpager.getClass().g

NeHe OpenGL教程 第四十四课:3D光晕

转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线教程的编写,以及yarn的翻译整理表示感谢. NeHe OpenGL第四十四课:3D光晕 3D 光晕 当镜头对准太阳的时候就会出现这种效果,模拟它非常的简单,一点数学和纹理贴图就够了.好好看看吧. 大家好,欢迎来到新的一课,在这一课中我们将扩展glCamera类,来实现镜头光晕的效果.在日常生活中,

[UnityShader3]彩光效果

参考链接:http://blog.csdn.net/stalendp/article/details/40690185 效果图: 这里我把它分三部分实现:1.彩色 2.光圈 3.动画 1.先实现彩色效果.分析一下那张彩色图,它是以中心为原点的,然后颜色分为三部分,如下图.当角度为90度时,蓝色最多:当角度为-150度时,红色最多:当角度为-30度时,绿色最多.然后其他地方就是三色混合. Shader "Custom/Colors" { Properties { _AngleRange

android求助:关于播放器中的“播放/暂停”键: 用ImageButton来设置点击效果时的问题

============问题描述============ 大家好,我最近遇到个问题: 大家都知道,播放器中的播放/暂停键是这样的逻辑:当用户点击了这个键,如果当前显示的是"播放"图案,会变为"暂停"图案:反之,如果当前是"暂停"图案,会变为"播放"图案 , 如此反复... 现在我正在实现这个效果,我是这样做的: 在以上的基本效果的基础上,我还添加了点击过程中的效果,就是当点下还木有松开时,会有一个点击效果(比如给当前图片加个光

文字效果和颜色

css3.0新增颜色模式 (1)rgba颜色模式 r Red 红 0-255 g Green 绿 0-255 b Blue 蓝 0-255 a Alpha 透明度 0-1 实例: 背景透明,文字不透明 问题:注意边框颜色透明有问题 (2)Hsl颜色模式‘ (2)Hsl颜色模式‘ H Hue 色调 任意数值 S saturation 饱和度 0%-100% L Lightness 亮度 0%-100% 文字阴影:text-shadow 语法:text-shadow:x y blur color,

Unity3d 怪物死亡燃烧掉效果

效果 BurnToFadeOut.shader代码 Shader "BurnToFadeOut" { Properties { _StartColor ("Start Color", Color) = (1,1,1,1) _EndColor ("End Color", Color) = (1,1,1,1) _MainTex ("Base (RGB) Trans (A)", 2D) = "white" {}

[JS,NodeJs]个人网站效果代码集合

上次发的个人网站效果代码集合: 代码集合: 1.彩色文字墙[鼠标涟漪痕迹] 2.彩色旋转圆环 [模仿http://www.moma.org/interactives/exhibitions/2012/centuryofthechild/中间部分效果, 那个走路的孩子技术很简单,和以前的春分秋分Google的Doodles类似,就没有模仿,换成一个头像] 3.视屏拼图 4.百度地图api简单应用集合 5.财经数据 6.天气预报 [nodejs搭建,express框架,nodejs简单页面抓取,JS