日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Android仿微信通話背景的高斯模糊效果

瀏覽:220日期:2022-06-03 16:45:15

先看下效果圖:

Android仿微信通話背景的高斯模糊效果

仔細觀察上圖,我們可以發(fā)現,背景圖以用戶頭像為模板,對其進行了高斯模糊,并把它作為整個頁面的背景色。

關于Android如何快速實現高斯模糊(毛玻璃效果),網上一堆相關介紹, 下面直接給出網上模糊化工具類(已驗證可行):

import android.graphics.Bitmap;/** * 快速模糊化工具 */public class FastBlur { public static Bitmap doBlur(Bitmap sentBitmap, int radius, boolean canReuseInBitmap) {Bitmap bitmap;if (canReuseInBitmap) { bitmap = sentBitmap;} else { bitmap = sentBitmap.copy(sentBitmap.getConfig(), true);}if (radius < 1) { return (null);}int w = bitmap.getWidth();int h = bitmap.getHeight();int[] pix = new int[w * h];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 dv[] = new int[256 * divsum];for (i = 0; i < 256 * divsum; 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; }}bitmap.setPixels(pix, 0, w, 0, 0, w, h);return (bitmap); }}

那么,我們使用這個工具類,就可以高仿微信聊天頁面了么?答案是NO。

我們先看下直接使用該工具類能實現的效果:

Android仿微信通話背景的高斯模糊效果

我們可以看出來,通過該工具類,能實現圖片的毛玻璃效果,可是并不理想,因為微信的背景顏色偏暗,而我們模糊化得到的圖片顏色偏淡。效果有些不盡如人意。了解ios的人,或許知道,ios實現高斯模糊有直接的api:UIBlurEffectStyleExtraLight、UIBlurEffectStyleLight 、UIBlurEffectStyleDark,而UIBlurEffectStyleDark就可以直接實現比較暗的毛玻璃效果。那放在android這邊,該如何辦呢?

我這里采用的是“曲線求國”的策略,要想背景色偏暗,我們使用FrameLayout布局,在其中添加一個比較暗的一層View,就可以實現啦。

<?xml version='1.0' encoding='utf-8'?><FrameLayout xmlns:android='http://schemas.android.com/apk/res/android' android:layout_width='match_parent' android:layout_height='match_parent' android:fitsSystemWindows='true' android:orientation='vertical'> <ImageViewandroid: android:layout_width='match_parent'android:layout_height='match_parent'android:adjustViewBounds='true'android:maxHeight='1500dp'android:maxWidth='1000dp'android:scaleType='centerCrop' /> <ImageViewandroid:layout_width='match_parent'android:layout_height='match_parent'android:background='#90000000' /> <RelativeLayoutandroid: android:layout_width='match_parent'android:layout_height='match_parent'android:fitsSystemWindows='true'android:orientation='vertical'><ImageView android: android:layout_width='100dp' android:layout_height='100dp' android:layout_centerHorizontal='true' android:layout_marginTop='80dp' android:scaleType='fitXY' android:src='http://m.b3g6.com/bcjs/@mipmap/ic_launcher' /><TextView android: android:layout_width='wrap_content' android:layout_height='wrap_content' android:layout_below='@id/imgUserHead' android:layout_centerHorizontal='true' android:layout_marginTop='30dp' android:gravity='center_horizontal' android:text='靜音' android:textColor='#ffffff' android:textSize='24dp' /></RelativeLayout></FrameLayout>

上面代碼中,可以看到,我們添加了這么一個ImageView:

<ImageViewandroid:layout_width='match_parent'android:layout_height='match_parent'android:background='#90000000' />

如此這般,便是可以實現真正的高仿啦。

最重實現的效果圖如下:

Android仿微信通話背景的高斯模糊效果

源碼地址:

https://github.com/zuiwuyuan/FastBlur_VoiceChat

到這里就結束啦。

以上就是Android仿微信通話背景的高斯模糊效果的詳細內容,更多關于Android 高斯模糊效果的資料請關注好吧啦網其它相關文章!

標簽: 微信
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产在线|日韩| 国产精品伦一区二区| 国产一区二区三区精品在线观看 | 精品中文字幕一区二区三区 | 亚州国产精品| 亚洲精品九九| 91精品啪在线观看国产爱臀| 日韩欧美2区| 日韩成人av影视| 91精品国产自产在线丝袜啪| 欧美日韩a区| 国产精品久久久久久久久久齐齐| 欧美黑人巨大videos精品| 麻豆视频久久| 日韩1区2区| 久久激情一区| 一区久久精品| 香蕉久久国产| 视频在线观看91| 久久亚洲风情| 日本视频中文字幕一区二区三区| 国产精品三级| a国产在线视频| 欧美性感美女一区二区| 蜜桃视频欧美| 亚洲精品乱码日韩| 久久一区亚洲| 欧洲av一区二区| 一本色道久久精品| 日韩va欧美va亚洲va久久| 亚洲三级av| 久久99影视| 日韩欧美精品综合| 亚洲欧洲一区| 欧美在线观看天堂一区二区三区| 久久亚洲国产精品尤物| 久久精品高清| 亚洲理论在线| 麻豆免费精品视频| 亚洲a一区二区三区| 免费看精品久久片| 国产精品男女| 欧美aa国产视频| 日韩高清电影免费| 国产福利91精品一区二区| 亚洲一级特黄| 欧美亚洲国产日韩| 国产资源在线观看入口av| 9色国产精品| 麻豆91精品视频| 亚洲国产一区二区三区在线播放| 天堂av一区| 午夜精品成人av| 日韩中文字幕无砖| 国产一二在线播放| 日本亚洲视频| se01亚洲视频 | 国产精品美女久久久浪潮软件| 日本午夜精品久久久久| 亚洲1234区| 欧美日韩一区自拍| 免费视频一区三区| 国产精品欧美在线观看| 日韩午夜在线| 精品精品久久| 亚洲一区二区三区久久久| 国产精品高颜值在线观看| 亚洲欧美日韩专区| 国产盗摄——sm在线视频| 久久国产99| 国产一区二区三区久久久久久久久| 免费观看日韩电影| 亚洲精品一区三区三区在线观看| 日韩欧美精品一区二区综合视频| 亚洲va中文在线播放免费| 国产日产高清欧美一区二区三区 | 人人爱人人干婷婷丁香亚洲| 亚洲v在线看| 久久精品午夜| 91福利精品在线观看| 不卡在线一区二区| 免费在线观看一区| 亚洲另类黄色| 九九综合在线| 欧美国产美女| 97精品国产99久久久久久免费| 欧美日韩中文字幕一区二区三区| 久久在线91| 国产情侣久久| 亚洲欧洲国产精品一区| 性欧美69xoxoxoxo| 蜜臀国产一区| 免费一级欧美在线观看视频| 亚洲另类黄色| 亚洲一区二区三区四区五区午夜| 色在线中文字幕| 国产精品久久久免费| 亚洲久久视频| 亚洲欧美不卡| 激情综合网站| 午夜精品成人av| av在线最新| 精品午夜av| 亚洲一级大片| 国产偷自视频区视频一区二区| 婷婷综合六月| 日韩福利一区| 综合日韩av| 精品久久影院| 精品美女在线视频| 蜜桃久久久久| 国产乱码精品| 少妇精品久久久一区二区| 天堂成人免费av电影一区| 日韩午夜av| 国产精品视区| 免费日韩视频| 日韩影院在线观看| 视频一区二区中文字幕| 国产亚洲在线| 视频在线观看国产精品| 另类亚洲自拍| 亚洲天堂日韩在线| 日韩网站中文字幕| 日韩视频中文| 91p九色成人| 在线国产精品一区| 夜夜嗨一区二区三区| 在线 亚洲欧美在线综合一区| 999久久久国产精品| 亚洲啊v在线| 欧美成a人国产精品高清乱码在线观看片在线观看久| 精品久久网站| 免费看av不卡| 欧美精选一区二区三区| 国产精品av一区二区| 亚洲黄页一区| 一二三区精品| 97精品国产99久久久久久免费| 91精品国产自产在线丝袜啪| 欧美一级二区| 欧美成人aaa| 国产不卡一区| 99精品在线| 久久av日韩| 亚洲www免费| 9国产精品视频| 日韩av资源网| 欧美激情视频一区二区三区免费| 精品中文字幕一区二区三区 | 国产欧美日韩一区二区三区在线| 国产精品成人3p一区二区三区| 久久久久九九精品影院| 中文字幕在线视频久| 欧美日韩国产亚洲一区| 国产偷自视频区视频一区二区| 日韩亚洲精品在线观看| 久久av日韩| 亚洲高清不卡| 亚洲视频电影在线| 美女久久久久久| 久久精品成人| 亚洲网址在线观看| 久久香蕉网站| 欧美日韩国产高清| 国产亚洲精品精品国产亚洲综合| 一区二区不卡| 国产一区国产二区国产三区| 国产99久久久国产精品成人免费| 国产亚洲永久域名| 国产欧美一区二区三区国产幕精品 | 日产精品一区二区| 亚洲一区欧美二区| 麻豆视频久久| 一区福利视频| 欧美交a欧美精品喷水| 久久激情网站| 欧美亚洲自偷自偷| 亚洲性图久久| 国产精品一区二区av日韩在线| 国产欧美一区二区三区精品酒店| 亚洲欧美不卡| 精品视频在线观看网站| 国产精品日本欧美一区二区三区| 国产日韩中文在线中文字幕 | 高清久久一区| 美女精品一区| 免费在线成人| 国产女优一区| 精品女同一区二区三区在线观看| 国产午夜精品一区二区三区欧美| 国产精品极品在线观看| 国产精品毛片视频| 狠狠爱www人成狠狠爱综合网| 国产伦精品一区二区三区在线播放| 久久精品在线| 国产精品免费大片| 香蕉精品999视频一区二区| 国产一区二区三区久久 | 欧美日韩国产欧|