这篇将讲到图片特效处理的图片光晕效果。跟前面一样是对像素点进行处理,本篇实现的思路可参见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. 4.STL六大组件

    代码示例 #include <vector> #include <list> #include <iostream> #include <algorithm& ...

  2. 线程1—Runnable

    随便选择两个城市作为预选旅游目标.实现两个独立的线程分别显示10次城市名,每次显示后休眠一段随机时间(1000ms以内),哪个先显示完毕,就决定去哪个城市.分别用Runnable接口和Thread类实 ...

  3. Java基础学习(一) -- Java环境搭建、数据类型、分支循环等控制结构、简单一维数组详解

    一:java概述: 1982年,SUN公司诞生于美国斯坦福大学校园,并于1986年上市,在NASDAQ(纳斯达克:是全美证券商协会自动报价系统)的标识为SUNW,2007年改为JAVA. 2009年4 ...

  4. PostgreSQL Replication之第六章 监控您的设置(2)

    6.2 检查pg_stat_replication 检查归档以及 archive_command主要用于即时恢复( PITR,Point-In-Time- Recovery).如果您想监控一个基于流的 ...

  5. df 显示 100%的问题

    问题:         使用 df 命令查看,某个分区使用率已经达到100%,但是用du 命令统计该分区,发现该分区空间剩余10G可用.         实例:                分析: ...

  6. 紫书 例题 10-9 UVa 1636 (概率计算)

    小学数学问题 记得分数比较的时候可以交叉相乘(同号) #include<cstdio> #include<cstring> #define REP(i, a, b) for(i ...

  7. 题解 CF383C 【Propagating tree】

    这道题明明没有省选难度啊,为什么就成紫题了QAQ 另:在CF上A了但是洛谷Remote Judge玄学爆零. 思路是DFS序+线段树. 首先这道题直观上可以对于每一次修改用DFS暴力O(n),然后对于 ...

  8. Java基础学习总结(23)——GUI编程

    一.AWT介绍 所有的可以显示出来的图形元素都称为Component,Component代表了所有的可见的图形元素,Component里面有一种比较特殊的图形元素叫Container,Containe ...

  9. ArcGIS api for javascript——加入两个动态地图

    描述 这个示例表现如何加两个动态地图到一个地图.动态服务按用户缩放或平移服务器每次绘制的地图,ArcGISDynamicMapServiceLayer表示ArcGIS JavaScript API动态 ...

  10. 【HeadFirst设计模式——开篇】

    近期在看HeadFirst,接下来的一段时间会陆续更新有关HeadFirst设计模式相关的文章.记得非常久之前在学习大话设计模式的时候,仅仅是走马观花的大致走过一遍.至于里面非常多东西都掌握的不是非常 ...