这篇将讲到图片特效处理的图片光晕效果。跟前面一样是对像素点进行处理,本篇实现的思路可参见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. vue --- 路由传参的几种方式

    方案一: getDescribe(id) { // 直接调用$router.push 实现携带参数的跳转 this.$router.push({ path: `/describe/${id}`, }) ...

  2. 转】关于cgi、FastCGI、php-fpm、php-cgi

    首先,CGI是干嘛的?CGI是为了保证web server传递过来的数据是标准格式的,方便CGI程序的编写者. web server(比如说nginx)只是内容的分发者.比如,如果请求/index.h ...

  3. 当fastJson邂逅大写字段时

    在项目中遇到了一件令人头疼的事.使用fastJson反序列化时下面的Json时,得到对象属性总为null(如下图),可能细心的朋友一看就知道问题出在哪里,没错!问题就出在返回的字段首字母给大写了.fa ...

  4. 洛谷P3332 [ZJOI2013]K大数查询 权值线段树套区间线段树_标记永久化

    Code: #include <cstdio> #include <algorithm> #include <string> #include <cstrin ...

  5. Linux LVM在线扩容

    环境: 虚拟化环境,SUSE Linux Enterprise Server 11sp3,直接把虚拟磁盘从100G改成150G. 现有的LVM是100G,/home 的LV需要再加50G. 步骤: f ...

  6. C#-修改图书借阅管理系统-错误与SQL server 2008错误、复制数据库

    VS2012错误: *)不存在从对象类型 System.Object[] 到已知的托管提供程序本机类型的映射 public DataTable loadData2UserSearch(params o ...

  7. HNU 12961 BitTorrent DP

    题意: 你在网上下载东西,一个文件存储在一段或者多段里面,问怎么选择能在规定的流量内下载最多的文件数量.每段的大小一样. 思路: 习惯了做答案保存在DP数组里的题,做这种答案保存在下标里的题,转不过弯 ...

  8. 自己定义View之Chart图标系列(1)——点阵图

    近期要做一些图表类的需求,一開始就去github上看了看,发现开源的图表框架还是蛮多的.可是非常少有全然符合我的需求的.另外就是使用起来比較麻烦.所以就决定自己来造轮子了~~~ 今天要介绍的就是And ...

  9. Linux异常关机后,Mysql启动出错ERROR 2002 (HY000)

    Linux异常关机后,Mysql启动或訪问时,出错: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/ ...

  10. 把握linux内核设计思想(三):下半部机制之软中断

    [版权声明:尊重原创.转载请保留出处:blog.csdn.net/shallnet,文章仅供学习交流,请勿用于商业用途]         中断处理程序以异步方式执行,其会打断其它重要代码,其执行时该中 ...