这篇将讲到图片特效处理的图片光晕效果。跟前面一样是对像素点进行处理,本篇实现的思路可参见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. Adobe 2015 CC update (Windows/Mac OS) 独立升级包下载 Adobe Photoshop CC (Windows 32bit)

    Adobe CC 2015 Product Updates/Downloads for Windows ** = To access these updates, please first follo ...

  2. SQL流程控制语句

    1 GoTo语句 IF 12>9GOTO print1ELSE GOTO print2 print1:PRINT '执行了流程1'--GOTO theEndprint2:PRINT '执行了流程 ...

  3. JS动态创建表单post提交

    <script> //@创建表单方法 function post(URL, PARAMS) { var temp = document.createElement("form&q ...

  4. [POI2009]KON-Ticket Inspector(二维前缀和+DP)

    题意 有n个车站,现在有一辆火车从1到n驶过,给出aij代表从i站上车j站下车的人的个数.列车行驶过程中你有K次检票机会,所有当前在车上的人会被检票,问最多能检多少个不同的人的票 (n<=600 ...

  5. NOIP 2012 疫情控制(二分+贪心+倍增)

    题解 二分时间 然后一个显然的事是一个军队向上爬的越高它控制的点越多 所以首先军队尽量往上爬. 当一个军队可以爬到根节点我们记录下它的剩余时间T和它到达根结点时经过的根节点的子节点son. 当一个军队 ...

  6. dd---复制文件并对原文件的内容进行转换和格式化处理

    dd命令用于复制文件并对原文件的内容进行转换和格式化处理.dd命令功能很强大的,对于一些比较底层的问题,使用dd命令往往可以得到出人意料的效果.用的比较多的还是用dd来备份裸设备.但是不推荐,如果需要 ...

  7. C# Expression 树转化为SQL与语句(二)--解决参数问题

    在用Expression解析的的时候碰到一些参数(不是具体的值),会出现这种情况. 在这里我们希望得到的是id=10,而不是id=m_id;那如何来解析这些参数? ================== ...

  8. STM32的Flash

    STM32中存储区分为:随机存取存储器RAM和只读存储器ROM. 其中: RAM为常说的内存,比如手机的2G内存4G内存等,就是程序跑起来的时候所占用的存储空间,特点是掉电数据丢失. ROM为常说的硬 ...

  9. C++模板中重要的术语

  10. [BZOJ4026]dC Loves Number Theory 欧拉函数+线段树

    链接 题意:给定长度为 \(n\) 的序列 A,每次求区间 \([l,r]\) 的乘积的欧拉函数 题解 考虑离线怎么搞,将询问按右端点排序,然后按顺序扫这个序列 对于每个 \(A_i\) ,枚举它的质 ...