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

下面看效果图:

原图:

效果图:

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

    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. }

android 图片特效处理之 光晕效果的更多相关文章

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

    这篇将讲到图片特效处理的图片光晕效果.跟前面一样是对像素点进行处理,本篇实现的思路可参见android图像处理系列之九--图片特效处理之二-模糊效果和android图像处理系列之十三--图片特效处理之 ...

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

    这篇将讲到图片特效处理的图片光晕效果.跟前面一样是对像素点进行处理,本篇实现的思路可参见android图像处理系列之九--图片特效处理之二-模糊效果和android图像处理系列之十三--图片特效处理之 ...

  3. android 图片特效处理之怀旧效果

    图片特效处理系列将介绍图片的像素点的特效处理,这些物资注重的是原理.也就是说只要你知道这些算法不管是C++,VB,C#,Java都可以做出相同的特效.下面将介绍图片怀旧效果的算法.算法如下: 上面公式 ...

  4. android图片特效处理之怀旧效果

    图片特效处理系列将介绍图片的像素点的特效处理,这些物资注重的是原理.也就是说只要你知道这些算法不管是C++,VB,C#,Java都可以做出相同的特效.下面将介绍图片怀旧效果的算法.算法如下: 上面公式 ...

  5. android图片特效处理之模糊效果

    这篇将讲到图片特效处理的模糊效果.跟前面一样是对像素点进行处理,算法是通用的,但耗时会更长,至于为什么,看了下面的代码你就会明白. 算法: 一.简单算法:将像素点周围八个点包括自身一共九个点的RGB值 ...

  6. android 图片特效处理之 图片叠加

    这篇将讲到图片特效处理的图片叠加效果.跟前面一样是对像素点进行处理,可参照前面的android图像处理系列之七--图片涂鸦,水印-图片叠加和android图像处理系列之六--给图片添加边框(下)-图片 ...

  7. android 图片特效处理之图片叠加

    这篇将讲到图片特效处理的图片叠加效果.跟前面一样是对像素点进行处理,可参照前面的android图像处理系列之七--图片涂鸦,水印-图片叠加和android图像处理系列之六--给图片添加边框(下)-图片 ...

  8. android 图片特效处理之光照效果

    这篇将讲到图片特效处理的光照效果.跟前面一样是对像素点进行处理,算法是通用的. 算法原理:图片上面的像素点按照给定圆心,按照圆半径的变化,像素点的RGB值分别加上相应的值作为当前点的RGB值. 例: ...

  9. android 图片特效处理之锐化效果

    这篇将讲到图片特效处理的锐化效果.跟前面一样是对像素点进行处理,算法是通用的. 算法原理: 一.简单算法:分别获取当前像素点和八个周围像素点的RGB值,先求出当前像素点的RGB值与八个像素点RGB值的 ...

随机推荐

  1. HibernateProperties 配置属性

    Hibernate properties Hibernate配置属性 属性名 用途hibernate.dialect ;一个Hibernate Dialect类名允许Hibernate针对特定的关系数 ...

  2. IT男送什么礼物给女朋友呢?

    每到各种节日,加班到吐血的IT男们,总是没什么时间准备礼物给女朋友,偶尔想起又不知道送什么的好,女朋友虽然心里不说,多少有些难过.现在推荐朋友的羊毛毡手工店,每一件都是亲手制作,特别是可以个性定制,女 ...

  3. ListView 适配器实现getviewtypcount() 数组越界IndexOutOfBoundException

    ListView中Item的多布局显示,需要用到了getViewTypecount和getItemViewType这两个重写方法,但是做完后出现了如下提示错误:java.lang.ArrayIndex ...

  4. 不同框架实现的todomvc

    http://todomvc.com/ http://hao.jobbole.com/

  5. Functor& Monad解读

    整体上代表封装的概念,重点是函数的封装,及函数运行的上下文环境.trait Functor[F[_]] Functor:代表整体封装: F[_]:代表封装后的目标域. A.B:代表普通的对象:f:代表 ...

  6. 【Git 五】TortoiseGit中SSH密钥的配置方法

    注意:我用的 TortoiseGit 版本是 2.6 的. 一.找到安装目录下的 bin 目录 二.点击 puttygen.exe 三.点击 Generate 生成完毕之后,将 public key ...

  7. 洛谷1034 NOIP2002 矩形覆盖

    问题描述 在平面上有 n 个点(n <= 50),每个点用一对整数坐标表示.例如:当 n=4 时,4个点的坐标分另为:p1(1,1),p2(2,2),p3(3,6),P4(0,7). 这些点可以 ...

  8. bzoj1025 [SCOI2009]游戏 动态规划

    题目描述 对于一些长度为n的排列,将其作为一个置换,那么可能有一个自置换的次数使其回到1,2,3,...,n的情况.求对于所有能够回到1,2,3..,n的排列,不同的次数共有多少种. 题解来自黄学长 ...

  9. PKU 2528 Mayor's posters

    题意: 一个公告板上面贴海报,宽度都是一样的,长度可能不一样.后面的海报可能把前面的覆盖掉.问最后能看见多少张不同的海报. 思路: 这题原来做过,是用线段树的区间染色写的.记录每个区间是纯色还是杂色. ...

  10. js中数组增删查改unshift、push、pop、shift、slice、indexOf、concat、join

    js中数组增删查改unshift.push.pop.shift.slice.indexOf.concat.join