圖片高斯模糊效果簡單優化
模糊背景現在已經很流行了,固定圖片的模糊可以讓設計師處理,那麼動態模糊,或者每個使用者個人主頁用自己頭像的圖片模糊做背景,這就需要我們程式設計師通過程式碼來實現了,實現的方案在github上已經有比較完善和得到大家公認的開源專案:
Blurry
。前者主要通過判斷系統版本號,大於API17的時候調系統的API renderscript處理,否則採用Java實現的方式對一個bitmap物件進行高斯模糊,把該模組封裝成一個工具類。後者則進一步封裝一個功能強大,使用簡單的庫,有點類似UIL , Volley ,Picasso這些圖片載入庫,在內部已經封裝了執行緒池,通過現場對圖片進行高斯模糊,並且通過傳入具體view物件,來直接在回撥結果裡把高斯模糊後的bitmap載入到你需要的view控制元件上,主要用法如下:
Blurry.with(context).radius(25).sampling(2).onto((ViewGroup) rootView);
Blurry.with(context).capture(view).into(imageView);
對於第二種在github過千star的專案,不用過多介紹,直接拿下來用,基本上也沒多大問題了,現在主要對第一種方式,結合最近做的一個小專案來分享一點經驗,也算是自己的學習筆記。專案的需求是獲取一張相簿的圖片,載入到介面上,並且在介面上有一個拖動的滑條,動態來改變模糊半徑值,結果顯示出來。
首先是renderscript使用有API版本的限制,必須API 17(4.2)或者以上才能用,以前專案通過第一種方式(
這裡穿插一下高斯模糊的原理,簡單介紹一下(別的地方copy一個簡單介紹過來);
"模糊"的演算法有很多種,其中有一種叫做"高斯模糊"(Gaussian Blur)。它將正態分佈(又名"高斯分佈")用於影象處理。"高斯模糊"的演算法,本質上它是一種資料平滑技術(data smoothing),適用於多個場合,影象處理恰好提供了一個直觀的應用例項。
所謂"模糊",可以理解成每一個畫素都取周邊畫素的平均值。"中間點"取"周圍點"的平均值,就會變成1。在數值上,這是一種"平滑化"。在圖形上,就相當於產生"模糊"效果,"中間點"失去細節。模糊半徑越大,影象就越模糊。從數值角度看,就是數值越平滑。簡單來說,高斯的基本原理或者說核心思想就是每個點,取周邊的點的均值,達到平滑效果,實際上實現和演算法,涉及到權重等問題,這裡就不展開了,這就是為什麼同樣的圖片,不同實現方法效能差異很大。
瞭解了高斯模糊的基本原理,至少有兩點是可以肯定的是,一是圖片越大(指的是長和寬或者說畫素點數量)越耗時;二是,模糊半徑越大越耗時,因為模糊半徑越大,意味著取周邊的點更多,計算的時間也是越多,而且這個增加不是線性的,據說是指數上升,簡單理解就是,如上圖,模糊半徑1PX的時候,計算每個點取周邊8個點,但模糊半徑2PX的時候,需求取周邊24個點(大概理解如此,沒有實際驗證具體數值)。實際測試列印的執行時間也是符合這兩點。
回到我們的需求,要載入大圖,而且還是動態改變模糊半徑顯示到UI上,那麼就要求我們對圖片的模糊處理耗時控制到一定範圍,比如200毫秒以內,每200毫秒重新整理UI,載入新的模糊後的圖片,時間越短越流暢平滑,當然對高斯處理的耗時也越嚴格了。首先是方法的選擇,對比發現同樣的圖片和同樣模糊半徑下,renderscript的效能要遠遠高於Java實現的那個方法,renderscript的原始碼沒有去細看,沒法相容到4.2系統以下那肯定不是簡單的純Java實現的方式,必然是有依賴到底層的API的。在這裡有兩種方式處理相容問題:一是判斷系統版本,高版本調renderscript,低版本還是調Java的方法;二是直接加入support v8的包。
手上的機器都是5.0+的,效能也不差,包括MX5和谷歌親兒子,當即使用效能不錯的renderscript去處理大圖或者模糊半徑比較大的時候,仍然非常耗時(耗時超過500毫秒就別想滑動來在UI上實現"實時"顯示模糊效果了,延遲非常明顯,加入每次處理都耗時500毫秒,使用者第一次滑動到半徑5的位置,半秒後滑動到半徑10的位置,這時候才顯示出模糊半徑5的圖片,滯後非常明顯的,200毫秒以內還能接受,真正實時的話,估計難以實現了。。。只能壓縮模糊處理的時間,把延遲滯後時間不斷縮短來達到效果);另外一個問題就是renderscript只支援0-25PX畫素的模糊,不支援25畫素以上的模糊處理。
解決方案其實也非常簡單,那就是縮小圖片。 平時我們對圖片縮小,必然會帶來很明顯的清晰度的損失,當高斯模糊本身的目的就是要實現模糊的效果,因此實際上的效果差別不大,幾乎可以忽略。
例如需求:圖片原圖大小500*1000,進行10個畫素的高斯模糊,顯示到500*1000的view上。
方法1:不縮放,直接原圖進行10畫素模糊處理,加載出來。
方法2:圖片長寬縮小到原來一半,5個畫素模糊,放大處理後的250*500的圖到view上。
實測的效果就是,顯示效果差別非常小,但耗時差別非常大。 方法2不但需要模糊的畫素點縮小到原來的25%(長寬減半),而且模糊半徑也10縮小到5了,長寬縮小一半,模糊半徑也應該縮小一半,這個還是很好理解的。半徑10變成5,每個點計算均值的參與的周邊的畫素點,又10*10下降到5*5(粗略演算法姑且這樣認為),整個時間就大大縮小了。
對於另外一個問題renderscript不支援25畫素以上的模糊,解決方案同樣是縮小圖片,如果需求50畫素的模糊,圖片長寬縮小一半,再直接進行25畫素模糊,放大回去效果跟原圖直接50畫素模糊幾乎一樣的,時間就天差地別了。
簡單總結來說,無非就是大概知道高斯模糊的原理是對畫素點取周邊畫素計算均值達到平滑效果,畫素點越多(長寬越大)越耗時,模糊半徑越大也越耗時,那麼解決方案就是縮小圖片的長寬或者模糊半徑。而恰好,縮小模糊半徑也是需要對應縮小對應的圖片。因此實際上對耗時非常嚴格的時候,可以通過迴圈判斷模糊半徑R>X的時候,不斷縮小圖片來實現,至於X取值25還是更小,根據專案實際場景來決定,實測效果就是X取10真的比25要快得多。。。
應用到實際專案需要注意的地方:
1.針對我上面的需求,滑條可以滑動到模糊半徑R=0,1,2,3等半徑小的值的情況,也就是需要顯示完全清晰或者非常清晰(模糊半徑1,2,3)的情況,因為需要控制好圖片不能縮小得太小,或者乾脆判斷R<3的時候,不縮小圖片,因為R很小的時候,速度還是很快的。如果業務需求R是固定值,比如10或者更大,那圖片可以縮小好幾倍都幾乎沒有效果上的影響。
2.imageview載入了模糊半徑=10的bitmap1後,間隔200毫秒再載入模糊半徑=20的bitmap2的過渡問題。可以用TransitionDrawable來實現平滑過渡,順便學了一個新的API哈,高手忽略吧,當學習筆記。。。但需要注意的是TransitionDrawable的記憶體溢位問題,這裡不多說了,貼兩個連結,大家看看就明白了。
上一個效果圖,壓縮的厲害失真了。。。
相關推薦
圖片高斯模糊效果簡單優化
模糊背景現在已經很流行了,固定圖片的模糊可以讓設計師處理,那麼動態模糊,或者每個使用者個人主頁用自己頭像的圖片模糊做背景,這就需要我們程式設計師通過程式碼來實現了,實現的方案在github上已經有比較完善和得到大家公認的開源專案: Blurry 。前者主要通過
iOS開發-圖片高斯模糊效果
iOS開發的時候有的時候需要將圖片設定模糊,或者通過點選下拉方法,去除模糊,一切都是為了應用更受使用者歡迎,iOS7之後半透明模糊效果得到大範圍使用的比較大,現在也可以看到很多應用區域性用到了圖片模糊效果,關於圖片實現高斯模糊效果有三種方式,CoreImage,GPUImag
Android本地圖片或者網路圖片高斯模糊效果(毛玻璃效果)圖片模糊效果一行程式碼搞定
一,實現本地圖片或者網路圖片的毛玻璃效果特別方便,只需要把下面的FastBlurUtil類複製到你的專案中就行 package com.testdemo.blur_image_lib10; import android.graphics.Bitmap; import andr
Android使用RenderScript實現圖片的高斯模糊效果
Android使用RenderScript實現圖片的高斯模糊效果 首先來看一下什麼是高斯模糊效果呢? 高斯模糊(英語:Gaussian Blur),也叫高斯平滑,是在Adobe Photoshop、GIMP以及Paint.NET等影象處理軟體中廣泛使用的處理效果,通常用它
Android 高斯模糊效果從319ms到3ms的優化實現
之前做過高斯模糊的的效果,不過依賴一個三方庫,今天看到了一篇文章,一個類檔案就能解決,感覺竊喜,分享給大家。 使用: Glide.with(getActivity()).load(mUser.avatarUrl).asBitmap().into(ne
圖片處理的幾種演算法(毛玻璃效果,高斯模糊效果,舊時光效果,lomo效果,暖意效果)
毛玻璃效果:高斯模糊效果: //高斯模糊,毛玻璃 //低於Android4.2可以用Java原生程式碼實現。但是效率會低不少:這完全是一種妥協的方式,不推薦 public Bitmap fastblur(Context context, Bitmap sentBitma
Android中為網路圖片設定高斯模糊效果
寫一個方法,用來對Bitmap進行高斯模糊: public static Bitmap blurBitmap(Bitmap bitmap ,Context context){ //Let
CSS: filter: blur(); 實現高斯模糊效果,不可不知的細節優化
前言 在專案中,要實現如下的效果: 頁面頂部的設計稿,前面一個卡片式的輪播,後邊的背景(是橢圓的一部分)取前面的圖片,進行一個高斯模糊的處理。 開始 前面的輪播部分,使用了第三方的輪播外掛,非常好用,推薦給大家(地址)。輪播,不作為今天的主要內容,暫時簡單描述下,
Android——圖片設定為高斯模糊效果(ImageView)
效果圖://模糊 Resources res = ShowActivity.this.getResources(); //拿到初始圖 Bitmap bmp= BitmapFactory.decodeRe
Android 自定義設定圖片模糊度、高斯模糊效果
最近專案中有需要到“毛玻璃”效果,網上找一下,千篇一律。高談闊論扯淡的多,真正有用的沒幾個! 藉助此文,做修改之後,實現效果!我只是個搬運工,在此表示感謝! 淡不多扯,直接上程式碼: MainActivity: public class MainActiv
Android 圖片高斯模糊解決方案
Android 圖片高斯模糊解決方案 近年來,圖片高斯模糊備受設計師的青睞,在各大知名APP中,如微信、手機QQ、網易雲音樂等等都有對背景高斯圖模糊的設計,在Adnroid 中,現在常用的圖片高斯模糊技術有三種:RenderScript 、fastBlur、對RenderScript和
CSS3 filter濾鏡屬性小專案——圖片高斯模糊、高亮、對比度、灰度、色調、色彩旋轉、透明、飽和、褐色調整
學到了CSS3的filter屬性,心血來潮做了個filter濾鏡組工具,可以多重給自己的圖片新增濾鏡。 拿走不謝,別忘了更改對應的路徑名。 程式碼如下 html部分 <!DOCTYPE html> <html> <head>
使用canvas實現區域性高斯模糊效果
這個功能目的是為了模糊一些人的臉部,一些文字資訊。主要用於使用者手動操作進行模糊。 實現的功能:本人實現了再pc端上面進行拖拽模糊。 實現思路: 首先載入圖片,然後再載入完成的回撥中,建立一個高斯模糊過的圖片畫布。 接著,繫結滑鼠的互動事件,在裡面獲取到在畫布
高斯模糊效果
高斯模糊可以實現模糊效果,可用於眩暈,場景動畫等效果 高斯模糊利用了卷積計算,把每個畫素和周圍的畫素混合 見程式碼實現 c#程式碼 ImageEffectBase using UnityEngine; namespace GameBase.Effe
基於正態分佈的圖片高斯模糊演算法
前言: 先來看看下面這張圖,我把一張圖進行了二等份了,左邊是經過高斯模糊過的,右邊是原圖。 圖-1 高斯模糊效果對比圖 概述: 高斯模糊也叫做高斯平滑,是一種影象平滑處理的技術。高斯模糊演算法的原理是選取一箇中心點,以及一個半徑周圍的所有點,再計算這些畫素點
iOS自帶實現高斯模糊效果
引 什麼叫高斯模糊效果,通俗地說,就是毛玻璃效果,從iOS 7以來,就頻繁地被設計使用,如果用得好,效果會顯得非常的好。我們來看一個例子: 圖中下面一小部分就是高斯模糊效果。要實現也很簡單,iOS自身就支援這種效果。 iOS 7 UIToolbar
【iOS】iOS下高斯模糊效果的實現
其實有很多種實現方式,但是沒必要了解那麼多,簡單實用就行,選取一種效能相對來說比較好的方式 效果圖如下(高斯0.1): 程式碼: 需要匯入 #import <Accelerate/Accelerate.h> UIImage *ima
圖片高斯模糊[python]
簡介 畢業設計圖片處理部分需要模擬日常生活中的一些圖片模糊情況,於是在百度百科”高斯模糊”後自己簡單實現了下,高斯模糊原理很簡單,就是用高斯分佈對影象畫素值進行卷積。本篇部落格建議看完百度百科後再看。 高斯函式(正太分佈) 一維高斯分佈 公式 σ 為
高斯模糊效果實現方案及效能對比
高斯模糊實現方案探究 現在越來越多的app在背景圖中使用高斯模糊效果,如yahoo天氣,效果做得很炫。 這裡就用一個demo來談談它的不同實現方式及各自的優缺點。 1. RenderScript 談到高斯模糊,第一個想到的就是RenderScript。RenderScrip
Android也能流暢實現毛玻璃效果(高斯模糊)效果
前言 上圖就是我們在IOS裝置上經常能夠見到的毛玻璃(高斯模糊)效果。不得不說,這種效果在適合的場景下使用,能夠獲得絕佳的美感。但是鑑於Android裝置效能和相容性問題,我們通常很難在Android裝置上見到這種效果。 但這並不是IOS的專利效果,Android