精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

使用RenderScript實現高斯模糊(毛玻璃/磨砂)效果

移動開發 Android
逛instagram的時候,偶然發現,instagram的對話框設計的很有意思,它的dialog的背景竟然是毛玻璃效果的,在我看來真漂亮,恩,對話框和迪麗熱巴都漂亮。看到這么好的效果,當然就要開始搞事情了,自己動手實現差不多的效果。

前言

逛instagram的時候,偶然發現,instagram的對話框設計的很有意思,如下圖:   

instagram的對話框 

它的dialog的背景竟然是毛玻璃效果的,在我看來真漂亮,恩,對話框和迪麗熱巴都漂亮😂。看到這么好的效果,當然就要開始搞事情了,自己動手實現差不多的效果。最終的實現效果如下圖: 

 

 

  

 

 

 

分別實現了對話框背景的虛化和手動調節虛化程度。

實現方法對比

最開始想要實現毛玻璃效果時,我是一臉懵逼的,不知道如何下手。幸虧,有***的Google。搜索之后發現常見的實現方法有4種,分別是:

  • RenderScript
  • Java算法
  • NDK算法
  • openGL

處理一整張圖片這么大計算量的工作,openGL的性能***,而用java實現肯定是最差的了。而RenderScript和NDK的性能相當,但是你懂得,NDK和openGL我無可奈何,綜合考慮,RenderScript應該是最適合的。

但并不是說RenderScript就是完全沒有問題的:

  1. 模糊半徑(radius)越大,性能要求越高,模糊半徑不能超過25,所以并不能得到模糊度非常高的圖片。
  2. ScriptIntrinsicBlur在API 17時才被引入,如果需要在Android 4.2以下的設備上實現,就需要引入RenderScript Support Library,當然,安裝包體積會相應的增大。

RenderScript實現

首先在app目錄下build.gradle文件中添加如下代碼:

  1. defaultConfig { 
  2.         applicationId "io.github.marktony.gaussianblur" 
  3.         minSdkVersion 19 
  4.         targetSdkVersion 25 
  5.         versionCode 1 
  6.         versionName "1.0" 
  7.         renderscriptTargetApi 19 
  8.         renderscriptSupportModeEnabled true 
  9.     }  

RenderScriptIntrinsics提供了一些可以幫助我們快速實現各種圖片處理的操作類,例如,ScriptIntrinsicBlur,可以簡單高效實現 高斯模糊效果。

  1. package io.github.marktony.gaussianblur; 
  2.  
  3. import android.content.Context; 
  4. import android.graphics.Bitmap; 
  5. import android.support.annotation.IntRange; 
  6. import android.support.annotation.NonNull; 
  7. import android.support.v8.renderscript.Allocation; 
  8. import android.support.v8.renderscript.Element; 
  9. import android.support.v8.renderscript.RenderScript; 
  10. import android.support.v8.renderscript.ScriptIntrinsicBlur; 
  11.  
  12. public class RenderScriptGaussianBlur { 
  13.  
  14.     private RenderScript renderScript; 
  15.  
  16.     public RenderScriptGaussianBlur(@NonNull Context context) { 
  17.         this.renderScript = RenderScript.create(context); 
  18.     } 
  19.  
  20.     public Bitmap gaussianBlur(@IntRange(from = 1, to = 25) int radius, Bitmap original) { 
  21.         Allocation input = Allocation.createFromBitmap(renderScript, original); 
  22.         Allocation output = Allocation.createTyped(renderScript, input.getType()); 
  23.         ScriptIntrinsicBlur scriptIntrinsicBlur = ScriptIntrinsicBlur.create(renderScript, Element.U8_4(renderScript)); 
  24.         scriptIntrinsicBlur.setRadius(radius); 
  25.         scriptIntrinsicBlur.setInput(input); 
  26.         scriptIntrinsicBlur.forEach(output); 
  27.         output.copyTo(original); 
  28.         return original; 
  29.     } 
  30.  
  31.  

然后就可以直接使用RenderScriptGaussianBlur,愉快地根據SeekBar的值,實現不同程度的模糊了。

  1. package io.github.marktony.gaussianblur; 
  2.  
  3. import android.content.DialogInterface; 
  4. import android.graphics.Bitmap; 
  5. import android.graphics.BitmapFactory; 
  6. import android.support.v7.app.AlertDialog; 
  7. import android.support.v7.app.AppCompatActivity; 
  8. import android.os.Bundle; 
  9. import android.util.Log; 
  10. import android.view.View
  11. import android.view.Window; 
  12. import android.view.WindowManager; 
  13. import android.widget.FrameLayout; 
  14. import android.widget.ImageView; 
  15. import android.widget.LinearLayout; 
  16. import android.widget.SeekBar; 
  17. import android.widget.TextView; 
  18.  
  19. public class MainActivity extends AppCompatActivity { 
  20.  
  21.     private ImageView imageView; 
  22.     private ImageView container; 
  23.     private LinearLayout layout; 
  24.     private TextView textViewProgress; 
  25.     private RenderScriptGaussianBlur blur; 
  26.  
  27.     @Override 
  28.     protected void onCreate(Bundle savedInstanceState) { 
  29.         super.onCreate(savedInstanceState); 
  30.         setContentView(R.layout.activity_main); 
  31.  
  32.         imageView = (ImageView) findViewById(R.id.imageView); 
  33.         container = (ImageView) findViewById(R.id.container); 
  34.  
  35.         container.setVisibility(View.GONE); 
  36.  
  37.         layout = (LinearLayout) findViewById(R.id.layout); 
  38.  
  39.         layout.setVisibility(View.VISIBLE); 
  40.  
  41.         SeekBar seekBar = (SeekBar) findViewById(R.id.seekBar); 
  42.         textViewProgress = (TextView) findViewById(R.id.textViewProgress); 
  43.         TextView textViewDialog = (TextView) findViewById(R.id.textViewDialog); 
  44.         blur = new RenderScriptGaussianBlur(MainActivity.this); 
  45.  
  46.         seekBar.setMax(25); 
  47.         seekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { 
  48.             @Override 
  49.             public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) { 
  50.                 textViewProgress.setText(String.valueOf(progress)); 
  51.             } 
  52.  
  53.             @Override 
  54.             public void onStartTrackingTouch(SeekBar seekBar) { 
  55.  
  56.             } 
  57.  
  58.             @Override 
  59.             public void onStopTrackingTouch(SeekBar seekBar) { 
  60.                 int radius = seekBar.getProgress(); 
  61.                 if (radius < 1) { 
  62.                     radius = 1; 
  63.                 } 
  64.                 Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.image); 
  65.                 imageView.setImageBitmap(blur.gaussianBlur(radius, bitmap)); 
  66.             } 
  67.         }); 
  68.  
  69.         textViewDialog.setOnClickListener(new View.OnClickListener() { 
  70.             @Override 
  71.             public void onClick(View v) { 
  72.  
  73.                 container.setVisibility(View.VISIBLE); 
  74.  
  75.                 layout.setDrawingCacheEnabled(true); 
  76.                 layout.setDrawingCacheQuality(View.DRAWING_CACHE_QUALITY_LOW); 
  77.  
  78.                 Bitmap bitmap = layout.getDrawingCache(); 
  79.  
  80.                 container.setImageBitmap(blur.gaussianBlur(25, bitmap)); 
  81.  
  82.                 layout.setVisibility(View.INVISIBLE); 
  83.  
  84.                 AlertDialog dialog = new AlertDialog.Builder(MainActivity.this).create(); 
  85.                 dialog.setTitle("Title"); 
  86.                 dialog.setMessage("Message"); 
  87.                 dialog.setButton(DialogInterface.BUTTON_POSITIVE, "OK", new DialogInterface.OnClickListener() { 
  88.                     @Override 
  89.                     public void onClick(DialogInterface dialog, int which) { 
  90.                         dialog.dismiss(); 
  91.                     } 
  92.                 }); 
  93.                 dialog.setButton(DialogInterface.BUTTON_NEGATIVE, "Cancel", new DialogInterface.OnClickListener() { 
  94.                     @Override 
  95.                     public void onClick(DialogInterface dialog, int which) { 
  96.  
  97.                     } 
  98.                 }); 
  99.                 dialog.setOnCancelListener(new DialogInterface.OnCancelListener() { 
  100.                     @Override 
  101.                     public void onCancel(DialogInterface dialog) { 
  102.  
  103.                     } 
  104.                 }); 
  105.  
  106.                 dialog.setOnCancelListener(new DialogInterface.OnCancelListener() { 
  107.                     @Override 
  108.                     public void onCancel(DialogInterface dialog) { 
  109.                         container.setVisibility(View.GONE); 
  110.                         layout.setVisibility(View.VISIBLE); 
  111.                     } 
  112.                 }); 
  113.  
  114.                 dialog.show(); 
  115.             } 
  116.         }); 
  117.  
  118.     } 
  119.  

在代碼里做了一些view的可見性的操作,比較簡單,相信你能看懂的。和instagram中dialog的實現有一點不同的是,我沒有截取整個頁面的bitmap,只是截取了actionbar下的內容,如果一定要實現一樣的效果,調整一下頁面的布局就可以了。這里不多說了。

是不是很簡單呢?

輪子

除了RenderScript外,還有一些優秀的輪子:

BlurTestAndroid對不同類庫的實現方式、采取的算法和所耗費的時間做了統計和比較,你也可以下載它的demo app,自行測試。 

 

 

 

示例代碼在這里:GaussianBlur 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2017-02-14 17:29:42

Android毛玻璃虛化效果

2010-01-21 15:48:38

C++語言

2021-07-06 06:07:14

CSS 技巧背景

2022-01-07 07:35:28

CSS 技巧磨砂玻璃

2016-08-30 21:36:56

JavascriptCSSWeb

2024-10-10 16:02:34

2022-03-01 17:24:33

iOS兼容性方案

2014-04-02 10:29:12

iOS 7模糊效果

2013-10-28 16:37:38

Windows 8.1技巧

2017-04-13 10:03:29

Java高斯模糊圖像

2017-01-09 09:47:40

Windows10AeroUI

2025-08-15 00:00:00

2023-05-26 07:08:05

CSS模糊實現文字

2012-11-15 09:43:08

開發算法高斯模糊

2025-01-10 08:38:16

2019-06-24 09:10:31

Windows操作系統Windows 10

2018-05-08 23:46:15

微軟語言Windows

2021-08-30 06:20:39

CSS 技巧3D 效果

2022-01-09 17:05:54

Windows 11操作系統微軟

2013-10-24 10:10:21

Android支持庫
點贊
收藏

51CTO技術棧公眾號

午夜视频久久久久久| 久久国产福利国产秒拍| 精品国产亚洲在线| 久久免费视频3| 福利视频在线导航| 国产精品影视在线| 69av在线播放| 女教师淫辱の教室蜜臀av软件| 欧洲大片精品免费永久看nba| 五月开心婷婷久久| 一个色的综合| 五月婷婷久久久| 美国三级日本三级久久99| 欧美多人爱爱视频网站| 日韩人妻无码精品综合区| 日本成人手机在线| 91久久一区二区| 黄色一级片在线看| 91亚洲欧美| bt7086福利一区国产| 成人精品视频99在线观看免费| 精品少妇theporn| 不卡视频在线| 亚洲精品国产品国语在线| 中文字幕1234区| 成人软件在线观看| 亚洲成人一区二区| 亚洲一区二区三区精品在线观看| 日本高清视频在线| 激情综合色综合久久| 国产精品99蜜臀久久不卡二区| 黄色一级片在线| 日韩中文首页| 亚洲人成伊人成综合网久久久| 欧美日韩一区二区区别是什么| 成人黄色图片网站| 日韩欧美一区视频| 欧美三级在线观看视频| 欧美xxx黑人xxx水蜜桃| 中文字幕一区二区日韩精品绯色| 日本午夜精品电影| 欧美在线一卡| av网站免费线看精品| 春色成人在线视频| 国产99对白在线播放| 久久精品国产亚洲高清剧情介绍| 欧美在线亚洲在线| www.国产色| 免费亚洲一区| 4444欧美成人kkkk| 国产做受高潮漫动| 在线看片一区| 久久露脸国产精品| 日韩精品成人在线| 精品99视频| 久久久免费av| 亚洲激情视频一区| 国产精品久久久久久模特| 51ⅴ精品国产91久久久久久| 色网站在线播放| 国产精品毛片| 日本久久久久久久久| 午夜久久久久久久久久影院| 首页国产欧美久久| 国产成人精品优优av| 激情五月婷婷网| 青青草97国产精品免费观看无弹窗版| 国产精品大陆在线观看| 日本丰满少妇做爰爽爽| 蜜桃久久久久久| 91久久久久久久一区二区| a在线观看免费| 成人一二三区视频| 精品中文字幕一区| av资源网站在线观看| 国产精品女主播av| 国产制服91一区二区三区制服| 四季久久免费一区二区三区四区| 亚洲va欧美va国产va天堂影院| 美脚丝袜脚交一区二区| av资源在线| 91极品视觉盛宴| 香蕉视频色在线观看| 成人三级毛片| 亚洲人a成www在线影院| 国产精品精品软件男同| 欧美日韩亚洲三区| 欧美一级电影在线| 亚洲无码久久久久| 国产成人高清在线| 日本成人看片网址| 18视频在线观看网站| 精品久久久久久国产91| 日韩大片一区二区| 国产成人av毛片| 色yeye香蕉凹凸一区二区av| 免费毛片在线播放免费| 日韩精品国产精品| 国产二区一区| www.av在线播放| 亚洲国产精品综合小说图片区| 国产免费视频传媒| 中文字幕亚洲在线观看| 亚洲图片制服诱惑| 久久久久免费看| 免费人成网站在线观看欧美高清| 操一操视频一区| se在线电影| 天天综合天天综合色| 黄色小视频免费网站| 欧美调教在线| 美女999久久久精品视频| 精品久久久久久久久久久国产字幕| 国产主播一区二区| 日本视频精品一区| av最新在线| 日韩一区二区不卡| 国产成人免费观看网站| 亚洲乱亚洲高清| 91网在线免费观看| 99re热久久这里只有精品34| 黄色一区二区在线观看| www.日本久久| 清纯唯美亚洲综合一区| 欧美资源在线观看| 欧美少妇bbw| 亚洲免费观看高清| 在线免费观看av的网站| 国产精品亚洲人成在99www| 欧美极品少妇全裸体| 国产精品天天操| 国产欧美精品在线观看| 激情综合在线观看| 国产精品美女在线观看直播| 欧美成在线视频| 国产露脸91国语对白| 国产精品网站在线播放| 成人免费无码av| 羞羞答答一区二区| 97在线视频一区| 蜜臀av午夜精品| 亚洲已满18点击进入久久| 91欧美一区二区三区| 999成人精品视频线3| 国产精品免费一区| 二区三区在线| 91福利在线免费观看| 中国毛片在线观看| 日日噜噜夜夜狠狠视频欧美人| 久久国产精品久久精品国产| a级片在线免费观看| 亚洲国产成人爱av在线播放| 日韩精品视频免费看| 成人激情文学综合网| 亚洲 欧美 日韩 国产综合 在线| 精品精品国产毛片在线看| 亚洲91av视频| 激情综合闲人网| 欧美色图12p| 少妇视频一区二区| 国产一区二区免费视频| 黑人巨大国产9丨视频| 日韩成人在线看| 欧美激情xxxxx| 天堂av在线免费观看| 日韩欧美国产免费播放| 亚洲图片另类小说| 男人操女人的视频在线观看欧美 | 精品久久视频| 国产一区二区丝袜| 色图在线观看| 日韩精品久久久久| 亚洲怡红院av| 依依成人精品视频| 最近日本中文字幕| 日韩成人伦理电影在线观看| 最新黄色av网站| 国产一区二区在线视频你懂的| 亲爱的老师9免费观看全集电视剧| 国产福利小视频在线观看| 欧美久久久一区| 国产真人真事毛片| 国产调教视频一区| 911av视频| 免费日韩av片| 国产日产欧美一区二区| 亚洲aa在线| 亚洲精品女av网站| 亚洲插插视频| 蜜臀久久99精品久久久无需会员 | 欧美精品18videosex性欧美| 日韩精品视频无播放器在线看 | 少妇精品一区二区三区| 久久se精品一区精品二区| 国产 欧美 日韩 一区| 久久91麻豆精品一区| 91视频免费在线| 成人激情综合| 久久久久久久久久久免费| 搞黄视频免费在线观看| 日韩女优制服丝袜电影| 91丨九色丨海角社区| 亚洲一级在线观看| 免费黄色在线网址| 99视频精品免费视频| 久久久精品高清| 国产精品毛片在线| 夜夜揉揉日日人人青青一国产精品| 亚洲成人av一区二区三区| 欧美mv日韩mv| 青青精品视频播放| 国产免费久久久| 黑人巨大精品欧美一区免费视频 | 欧美日韩成人一区二区三区| 国产成人精品一区二区三区免费| 国产做受69高潮| 日p在线观看| 亚洲性日韩精品一区二区| 三级在线观看网站| 欧美一级艳片视频免费观看| 91麻豆精品在线| 精品久久久中文| 激情五月少妇a| 亚洲视频一区二区在线| 成人无码av片在线观看| 91日韩精品一区| 亚洲啪av永久无码精品放毛片| 国产精品一区专区| 天天做天天干天天操| 免费看精品久久片| 中文字幕无码不卡免费视频| 性欧美videos另类喷潮| 国产毛片视频网站| 欧美精品18| 国产激情片在线观看| 91精品电影| 先锋影音男人资源| 97精品在线| 中文字幕一区二区三区四区五区| 精品av一区二区| 欧美一区二区三区电影在线观看| 亚洲丝袜美腿一区| 久久精品国产综合精品| 婷婷成人影院| 区一区二区三区中文字幕| 伊人春色之综合网| 久久久亚洲综合网站| 伊人久久大香线蕉综合网蜜芽| 精品久久精品久久| 亚洲妇女av| 日本一区二区三区四区在线观看| 国产一区二区三区网| 日韩精品大片| 久久美女视频| 国产对白在线播放| 午夜天堂精品久久久久| 人人妻人人澡人人爽欧美一区| 正在播放日韩欧美一页| 国产精品久久久影院| 激情久久一区| 久久久久久久久久久视频| 日日摸夜夜添夜夜添国产精品| 91插插插插插插插插| 捆绑调教美女网站视频一区| 亚洲精品成人在线播放| 国产一区二区三区久久久| 白丝校花扒腿让我c| www.欧美色图| 在线观看日本中文字幕| 中文字幕亚洲精品在线观看| 真实国产乱子伦对白在线| 亚洲第一成人在线| 亚洲天堂一区在线| 欧美日韩一卡二卡三卡| 国产成人三级在线播放| 日韩av最新在线观看| 国产日韩精品在线看| 久久精品视频va| h片精品在线观看| 国产精品黄视频| 日本在线成人| 麻豆久久久9性大片| 欧美黄色大片在线观看| 国产免费黄色一级片| 日韩福利电影在线| 中文字幕一区二区在线观看视频| 成人性生交大合| 久久丫精品忘忧草西安产品| 亚洲精品国产品国语在线app| 国产黄色片免费看| 一区二区免费看| 国产成人精品视频在线观看| 中文字幕欧美视频| aiai在线| 美女爽到高潮91| 亚洲xxxx视频| 日本中文字幕在线播放| 久久久久久久一| 91九色综合| 国内精品久久国产| 日韩久久视频| 亚洲熟妇国产熟妇肥婆| 国产精品综合二区| 91九色国产视频| 日本高清久久| 视频一区二区在线观看| 伊人成人网在线看| 激情五月俺来也| 91色综合久久久久婷婷| 久久久久久av无码免费网站| 欧美日韩综合不卡| 天堂av在线7| 欧美精品成人在线| 伊人亚洲精品| 欧美日韩综合久久| 精品电影一区| 国产精品嫩草影视| 国产精品久久久久天堂| www.国产com| 精品国产91乱码一区二区三区| 免费黄色网页在线观看| 国产精品成熟老女人| 自拍亚洲一区| 99视频在线免费播放| 成人免费视频网站在线观看| 秋霞欧美一区二区三区视频免费| 91福利精品第一导航| 三级在线电影| 69久久夜色精品国产69乱青草| 试看120秒一区二区三区| 一区高清视频| 青青草国产成人av片免费| 久久成人激情视频| 色哟哟国产精品免费观看| 亚洲精品911| 日本视频免费一区| 欧美激情在线有限公司| 国产精品无码久久久久久| 鲁鲁在线中文| 97不卡在线视频| 人妻va精品va欧美va| 亚洲电影在线观看| 91小视频xxxx网站在线| 91免费国产网站| 欧美gvvideo网站| 色悠悠久久综合网| 国产精品美女久久久久久2018| 成人黄色三级视频| 亚洲免费三区一区二区| 国产激情在线免费观看| 精品女厕一区二区三区| 色香蕉在线视频| 午夜欧美不卡精品aaaaa| 韩国女主播一区二区三区| 可以看毛片的网址| 99视频精品全部免费在线| 国产视频91在线| 亚洲片av在线| 久久青草免费| 懂色av粉嫩av蜜臀av| 国产黑丝在线一区二区三区| 国产无精乱码一区二区三区| 精品国产1区二区| 亚洲国产福利| 午夜精品福利一区二区| 国产在线精品视频| 久久久久久久久久久97| 亚洲精品国产精品国产自| 偷拍精品精品一区二区三区| 亚洲在线不卡| 国产aⅴ精品一区二区三区色成熟| 国产午夜福利一区二区| 亚洲欧美激情视频| 国产精品原创视频| 国产又粗又长又爽视频| 成人av在线电影| 亚洲 国产 日韩 欧美| 久久久精品网站| 国产成人精品亚洲线观看| 国产在线青青草| ●精品国产综合乱码久久久久| 亚洲av少妇一区二区在线观看| 26uuu另类亚洲欧美日本一| 成人高清电影网站| 男插女视频网站| 91久久久免费一区二区| 综合久久2o19| 欧美日韩亚洲一区二区三区四区| 老司机精品视频在线| 日本三级视频在线| 色妞一区二区三区| 国产一区在线电影| av网站在线不卡| 调教+趴+乳夹+国产+精品| 男人资源在线播放| 国产一区在线免费观看| 久久精品99国产国产精| 日本少妇在线观看| 日韩视频免费看| 日韩欧美黄色|