欢迎来到代码驿站!

Android代码

当前位置:首页 > 移动开发 > Android代码

Android实现图片毛玻璃背景效果

时间:2020-12-29 16:10:31|栏目:Android代码|点击:

本文实例为大家分享了Android实现毛玻璃背景效果的具体代码,供大家参考,具体内容如下

import android.content.Context; 
import android.graphics.Bitmap; 
 
/** 
 * Created by abel.zhang on 2016/8/9. 
 * 图片的毛玻璃效果 
 */ 
public class GsdFastBlur { 
 
 /** 
  * 
  * @param context 
  * @param sentBitmap 
  * @param radius 12 模糊程度 
  * @return 
  */ 
 public static Bitmap fastblur(Context context, Bitmap sentBitmap, int radius) { 
 
  if (sentBitmap==null){ 
   return null; 
  } 
  Bitmap bitmap =null; 
  try { 
   bitmap = sentBitmap.copy(sentBitmap.getConfig(), true); 
  }catch (Exception e){ 
   e.printStackTrace(); 
   return null; 
  } 
 
 
  if (radius < 1) { 
   return (null); 
  } 
 
  int w = bitmap.getWidth(); 
  int h = bitmap.getHeight(); 
 
  int[] pix = new int[w * h]; 
//  Log.e("pix", w + " " + h + " " + pix.length); 
  bitmap.getPixels(pix, 0, w, 0, 0, w, h); 
 
  int wm = w - 1; 
  int hm = h - 1; 
  int wh = w * h; 
  int div = radius + radius + 1; 
 
  int r[] = new int[wh]; 
  int g[] = new int[wh]; 
  int b[] = new int[wh]; 
  int rsum, gsum, bsum, x, y, i, p, yp, yi, yw; 
  int vmin[] = new int[Math.max(w, h)]; 
 
  int divsum = (div + 1) >> 1; 
  divsum *= divsum; 
  int temp = 256 * divsum; 
  int dv[] = new int[temp]; 
  for (i = 0; i < temp; i++) { 
   dv[i] = (i / divsum); 
  } 
 
  yw = yi = 0; 
 
  int[][] stack = new int[div][3]; 
  int stackpointer; 
  int stackstart; 
  int[] sir; 
  int rbs; 
  int r1 = radius + 1; 
  int routsum, goutsum, boutsum; 
  int rinsum, ginsum, binsum; 
 
  for (y = 0; y < h; y++) { 
   rinsum = ginsum = binsum = routsum = goutsum = boutsum = rsum = gsum = bsum = 0; 
   for (i = -radius; i <= radius; i++) { 
    p = pix[yi + Math.min(wm, Math.max(i, 0))]; 
    sir = stack[i + radius]; 
    sir[0] = (p & 0xff0000) >> 16; 
    sir[1] = (p & 0x00ff00) >> 8; 
    sir[2] = (p & 0x0000ff); 
    rbs = r1 - Math.abs(i); 
    rsum += sir[0] * rbs; 
    gsum += sir[1] * rbs; 
    bsum += sir[2] * rbs; 
    if (i > 0) { 
     rinsum += sir[0]; 
     ginsum += sir[1]; 
     binsum += sir[2]; 
    } else { 
     routsum += sir[0]; 
     goutsum += sir[1]; 
     boutsum += sir[2]; 
    } 
   } 
   stackpointer = radius; 
 
   for (x = 0; x < w; x++) { 
 
    r[yi] = dv[rsum]; 
    g[yi] = dv[gsum]; 
    b[yi] = dv[bsum]; 
 
    rsum -= routsum; 
    gsum -= goutsum; 
    bsum -= boutsum; 
 
    stackstart = stackpointer - radius + div; 
    sir = stack[stackstart % div]; 
 
    routsum -= sir[0]; 
    goutsum -= sir[1]; 
    boutsum -= sir[2]; 
 
    if (y == 0) { 
     vmin[x] = Math.min(x + radius + 1, wm); 
    } 
    p = pix[yw + vmin[x]]; 
 
    sir[0] = (p & 0xff0000) >> 16; 
    sir[1] = (p & 0x00ff00) >> 8; 
    sir[2] = (p & 0x0000ff); 
 
    rinsum += sir[0]; 
    ginsum += sir[1]; 
    binsum += sir[2]; 
 
    rsum += rinsum; 
    gsum += ginsum; 
    bsum += binsum; 
 
    stackpointer = (stackpointer + 1) % div; 
    sir = stack[(stackpointer) % div]; 
 
    routsum += sir[0]; 
    goutsum += sir[1]; 
    boutsum += sir[2]; 
 
    rinsum -= sir[0]; 
    ginsum -= sir[1]; 
    binsum -= sir[2]; 
 
    yi++; 
   } 
   yw += w; 
  } 
  for (x = 0; x < w; x++) { 
   rinsum = ginsum = binsum = routsum = goutsum = boutsum = rsum = gsum = bsum = 0; 
   yp = -radius * w; 
   for (i = -radius; i <= radius; i++) { 
    yi = Math.max(0, yp) + x; 
 
    sir = stack[i + radius]; 
 
    sir[0] = r[yi]; 
    sir[1] = g[yi]; 
    sir[2] = b[yi]; 
 
    rbs = r1 - Math.abs(i); 
 
    rsum += r[yi] * rbs; 
    gsum += g[yi] * rbs; 
    bsum += b[yi] * rbs; 
 
    if (i > 0) { 
     rinsum += sir[0]; 
     ginsum += sir[1]; 
     binsum += sir[2]; 
    } else { 
     routsum += sir[0]; 
     goutsum += sir[1]; 
     boutsum += sir[2]; 
    } 
 
    if (i < hm) { 
     yp += w; 
    } 
   } 
   yi = x; 
   stackpointer = radius; 
   for (y = 0; y < h; y++) { 
    // Preserve alpha channel: ( 0xff000000 & pix[yi] ) 
    pix[yi] = (0xff000000 & pix[yi]) | (dv[rsum] << 16) | (dv[gsum] << 8) | dv[bsum]; 
 
    rsum -= routsum; 
    gsum -= goutsum; 
    bsum -= boutsum; 
 
    stackstart = stackpointer - radius + div; 
    sir = stack[stackstart % div]; 
 
    routsum -= sir[0]; 
    goutsum -= sir[1]; 
    boutsum -= sir[2]; 
 
    if (x == 0) { 
     vmin[y] = Math.min(y + r1, hm) * w; 
    } 
    p = x + vmin[y]; 
 
    sir[0] = r[p]; 
    sir[1] = g[p]; 
    sir[2] = b[p]; 
 
    rinsum += sir[0]; 
    ginsum += sir[1]; 
    binsum += sir[2]; 
 
    rsum += rinsum; 
    gsum += ginsum; 
    bsum += binsum; 
 
    stackpointer = (stackpointer + 1) % div; 
    sir = stack[stackpointer]; 
 
    routsum += sir[0]; 
    goutsum += sir[1]; 
    boutsum += sir[2]; 
 
    rinsum -= sir[0]; 
    ginsum -= sir[1]; 
    binsum -= sir[2]; 
 
    yi += w; 
   } 
  } 
 
//  Log.e("pix", w + " " + h + " " + pix.length); 
  bitmap.setPixels(pix, 0, w, 0, 0, w, h); 
  return (bitmap); 
 } 
 
} 

效果图:

上一篇:android PopupWindow 和 Activity弹出窗口实现方式

栏    目:Android代码

下一篇:Android EditText监听回车键并处理两次回调问题

本文标题:Android实现图片毛玻璃背景效果

本文地址:http://www.codeinn.net/misctech/37893.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有