91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android實現毛玻璃效果的對話框

發布時間:2020-09-15 18:15:10 來源:腳本之家 閱讀:430 作者:lvshaorong 欄目:移動開發

一個popwindow,在彈出的時候背景是原界面的截圖加高斯模糊效果:

Android實現毛玻璃效果的對話框

先給出popwindow的布局文件

<?xml version="1.0" encoding="utf-8"?> 
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:id="@+id/FrameLayout1" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:background="@drawable/roundcorner" > 
 
 <com.npi.blureffect.ScrollableImageView 
 android:id="@+id/imageView1" 
 android:background="@drawable/roundcorner" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:src="@drawable/roundcorner" /> 
 
 <RelativeLayout 
 android:id="@+id/RelativeLayout1" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" > 
 
 <TextView 
  android:id="@+id/textView1" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:layout_alignParentLeft="false" 
  android:layout_alignParentTop="false" 
  android:layout_centerHorizontal="true" 
  android:layout_centerInParent="false" 
  android:layout_centerVertical="false" 
  android:layout_marginLeft="33dp" 
  android:layout_marginTop="44dp" 
  android:text="這是提示語" /> 
 
 <TextView 
  android:id="@+id/textView2" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:layout_alignParentLeft="false" 
  android:layout_below="@+id/textView1" 
  android:layout_centerHorizontal="true" 
  android:layout_marginTop="49dp" 
  android:text="確定" 
  android:textAppearance="?android:attr/textAppearanceLarge" /> 
 
 </RelativeLayout> 
 
</FrameLayout> 

里面那個自定義imageView控件在我上一篇博客里,下面是activity的布局

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:tools="http://schemas.android.com/tools" 
 android:id="@+id/window" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:paddingBottom="@dimen/activity_vertical_margin" 
 android:paddingLeft="@dimen/activity_horizontal_margin" 
 android:paddingRight="@dimen/activity_horizontal_margin" 
 android:paddingTop="@dimen/activity_vertical_margin" 
 tools:context="com.npi.blureffect.TestActivity" > 
 
 <TextView 
 android:id="@+id/textView1" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:text="@string/hello_world" /> 
 
 <RatingBar 
 android:id="@+id/ratingBar1" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignLeft="@+id/textView1" 
 android:layout_below="@+id/textView1" 
 android:layout_marginTop="124dp" /> 
 
 <Switch 
 android:id="@+id/switch2" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignLeft="@+id/ratingBar1" 
 android:layout_below="@+id/ratingBar1" 
 android:layout_marginLeft="24dp" 
 android:layout_marginTop="81dp" 
 android:text="Switch" /> 
 
 <Button 
 android:id="@+id/button1" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignRight="@+id/ratingBar1" 
 android:layout_below="@+id/ratingBar1" 
 android:text="Button" /> 
 
 <Button 
 android:id="@+id/button2" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignBottom="@+id/ratingBar1" 
 android:layout_alignLeft="@+id/switch2" 
 android:layout_marginBottom="52dp" 
 android:text="Button" /> 
 
 <TextView 
 android:id="@+id/textView2" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignBottom="@+id/button1" 
 android:layout_alignLeft="@+id/ratingBar1" 
 android:text="Large Text" 
 android:textAppearance="?android:attr/textAppearanceLarge" /> 
 
</RelativeLayout> 

用于圓角的背景xml,放在drawable文件夾中

<?xml version="1.0" encoding="UTF-8" ?> 
<layer-list xmlns:android="http://schemas.android.com/apk/res/android"> 
 <item> 
  <shape> 
  <solid android:color="#efefef" /><!-- 連框顏色值 --> 
   
  <!-- 設置圓角邊框 --> 
   <corners 
   android:topLeftRadius="20dp"  
   android:topRightRadius="20dp"  
   android:bottomRightRadius="20dp"  
   android:bottomLeftRadius="20dp" 
   /> 
  </shape> 
 </item> 
 <!-- 主體背景顏色值 --> 
 <item android:bottom="20dp" android:top="20dp" android:left="20dp" android:right="20dp"> <!--上下左右四個邊框的寬度,為0的話就沒有了--> 
  <shape> 
  <solid android:color="#efefef" /> <!-- 背景白色 --> 
  </shape> 
 </item> 
 </layer>

activity的源碼

package com.npi.blureffect; 
 
import android.annotation.SuppressLint; 
import android.app.Activity; 
import android.graphics.Bitmap; 
import android.graphics.Point; 
import android.os.Build; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.Display; 
import android.view.Gravity; 
import android.view.Menu; 
import android.view.MenuItem; 
import android.view.View; 
import android.view.View.OnClickListener; 
import android.view.ViewGroup.LayoutParams; 
import android.widget.PopupWindow; 
import android.widget.RelativeLayout; 
import android.widget.TextView; 
 
public class TestActivity extends Activity { 
TextView textView1; 
RelativeLayout window; 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_test); 
 textView1 = (TextView) findViewById(R.id.textView1); 
 window = (RelativeLayout)findViewById(R.id.window); 
 textView1.setOnClickListener(new OnClickListener() { 
  
  @Override 
  public void onClick(View v) { 
  // TODO Auto-generated method stub 
  initPopuptWindow(window); 
  } 
 }); 
  
 } 
PopupWindow popupWindow; 
 
 /** 
 * 創建PopupWindow 
 */ 
 protected void initPopuptWindow(View layout) { 
 // TODO Auto-generated method stub 
 //對當前頁面進行截屏 
 layout.setDrawingCacheEnabled(true); 
 layout.buildDrawingCache(); //啟用DrawingCache并創建位圖 
 Bitmap screen = Bitmap.createBitmap(layout.getDrawingCache()); //創建一個DrawingCache的拷貝,因為DrawingCache得到的位圖在禁用后會被回收 
 layout.setDrawingCacheEnabled(false); //禁用DrawingCahce否則會影響性能 
  
 //將截屏進行模糊 
 screen = Blur.fastblur(this, screen, 15); 
  
 // 獲取自定義布局文件activity_popupwindow_left.xml的視圖 
 final View popupWindow_view = getLayoutInflater().inflate(R.layout.ioswindow, null, 
  false); 
 // 創建PopupWindow實例,200,LayoutParams.MATCH_PARENT分別是寬度和高度 
 final ScrollableImageView background = (ScrollableImageView) popupWindow_view.findViewById(R.id.imageView1); 
 background.setoriginalImage(screen); 
 final int screenWidth = getScreenWidth(this); 
 final int screenHeight = screen.getHeight(); 
 final int heightless = getScreenHeight(this)-screenHeight; 
 Log.i("Alex", "屏幕寬度為"+screenWidth+"高度為"+screenHeight+"偏差為"+heightless); 
 popupWindow = new PopupWindow(popupWindow_view, (int) (screenWidth*0.8), (int) (screenWidth*0.85*0.5), true); //設置popwindow的大小 
 popupWindow.showAtLocation(textView1, Gravity.CENTER, 0, 0);//設置popwindow的位置 
 popupWindow_view.post(new Runnable() { 
  
  @Override 
  public void run() { 
  // TODO Auto-generated method stub 
  int left = screenWidth/10; 
  Log.i("Alex", screenHeight+"-"+screenWidth*0.85*0.5); 
  int top = (int) ((screenHeight-screenWidth*0.85*0.5)/2-heightless/2); 
  Log.i("Alex", "top是"+top); 
  background.handleScroll(top, left); 
  } 
 }); 
  
 // 設置動畫效果 
 // 點擊其他地方消失 
 TextView confirm = (TextView) popupWindow_view.findViewById(R.id.textView2); 
 confirm.setOnClickListener(new OnClickListener() { 
  
  @Override 
  public void onClick(View v) { 
  // TODO Auto-generated method stub 
  popupWindow.dismiss(); 
  } 
 }); 
  
 } 
 
 /** 
 * Get the screen width. 
 * 
 * @param context 
 * @return the screen width 
 */ 
 @SuppressWarnings("deprecation") 
 @SuppressLint("NewApi") 
 public static int getScreenWidth(Activity context) { 
 
 Display display = context.getWindowManager().getDefaultDisplay(); 
 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB_MR2) { 
  Point size = new Point(); 
  display.getSize(size); 
  return size.x; 
 } 
 return display.getWidth(); 
 } 
 
 /** 
 * Get the screen height. 
 * 
 * @param context 
 * @return the screen height 
 */ 
 @SuppressWarnings("deprecation") 
 @SuppressLint("NewApi") 
 public static int getScreenHeight(Activity context) { 
 
 Display display = context.getWindowManager().getDefaultDisplay(); 
 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB_MR2) { 
  Point size = new Point(); 
  display.getSize(size); 
  return size.y; 
 } 
 return display.getHeight(); 
 } 
} 

第二種樣式,比第一種簡單但是效果更明顯也更大眾化

Android實現毛玻璃效果的對話框

這個是在原來布局的最上層加上了一個不可見的imageView,在彈出popwindow之前用這個imageView蓋住底下的東西

布局如下

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:tools="http://schemas.android.com/tools" 
 android:id="@+id/window" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 tools:context="com.npi.blureffect.DialogActivity" > 
 
 <TextView 
 android:id="@+id/textView1" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:text="@string/hello_world" /> 
 <RatingBar 
 android:id="@+id/ratingBar1" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignLeft="@+id/textView1" 
 android:layout_below="@+id/textView1" 
 android:layout_marginTop="124dp" /> 
 
 <Switch 
 android:id="@+id/switch2" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignLeft="@+id/ratingBar1" 
 android:layout_below="@+id/ratingBar1" 
 android:layout_marginLeft="24dp" 
 android:layout_marginTop="81dp" 
 android:text="Switch" /> 
 
 <Button 
 android:id="@+id/button1" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignRight="@+id/ratingBar1" 
 android:layout_below="@+id/ratingBar1" 
 android:text="Button" /> 
 
 <Button 
 android:id="@+id/button2" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignBottom="@+id/ratingBar1" 
 android:layout_alignLeft="@+id/switch2" 
 android:layout_marginBottom="52dp" 
 android:text="Button" /> 
 
 <TextView 
 android:id="@+id/textView2" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignBottom="@+id/button1" 
 android:layout_alignLeft="@+id/ratingBar1" 
 android:text="Large Text" 
 android:textAppearance="?android:attr/textAppearanceLarge" /> 
 
 <ProgressBar 
 android:id="@+id/progressBar1" 
  
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignParentBottom="true" 
 android:layout_marginBottom="49dp" 
 android:layout_toLeftOf="@+id/button1" /> 
 
 <ProgressBar 
 android:id="@+id/progressBar2" 
  
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_below="@+id/switch2" 
 android:layout_toRightOf="@+id/switch2" /> 
 
 <RadioButton 
 android:id="@+id/radioButton1" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_above="@+id/progressBar1" 
 android:layout_alignLeft="@+id/switch2" 
 android:text="RadioButton" /> 
 
 <Button 
 android:id="@+id/button3" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignLeft="@+id/progressBar2" 
 android:layout_below="@+id/progressBar2" 
 android:text="Button" /> 
 
 <ImageView 
 android:id="@+id/background" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:background="#fff" 
 android:visibility="gone" /> 
 
</RelativeLayout> 

activity 如下

package com.npi.blureffect; 
 
import android.annotation.SuppressLint; 
import android.app.Activity; 
import android.graphics.Bitmap; 
import android.graphics.BitmapFactory; 
import android.graphics.Matrix; 
import android.graphics.Point; 
import android.os.Build; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.Display; 
import android.view.Gravity; 
import android.view.Menu; 
import android.view.MenuItem; 
import android.view.View; 
import android.view.View.OnClickListener; 
import android.widget.ImageView; 
import android.widget.PopupWindow; 
import android.widget.RelativeLayout; 
import android.widget.TextView; 
 
public class DialogActivity extends Activity { 
TextView textView1; 
RelativeLayout window; 
ImageView background; 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_dialog); 
 textView1 = (TextView) findViewById(R.id.textView1); 
 window = (RelativeLayout)findViewById(R.id.window); 
 background = (ImageView) findViewById(R.id.background); 
 
 textView1.setOnClickListener(new OnClickListener() { 
 
 @Override 
 public void onClick(View v) { 
 // TODO Auto-generated method stub 
 initPopuptWindow(window); 
 } 
 }); 
 } 
 
 PopupWindow popupWindow; 
 
 
 /** 
 * 創建PopupWindow 
 */ 
 protected void initPopuptWindow(View layout) { 
 // TODO Auto-generated method stub 
 //對當前頁面進行截屏 
 layout.setDrawingCacheEnabled(true); 
 layout.buildDrawingCache(); //啟用DrawingCache并創建位圖 
 Bitmap screen = Bitmap.createBitmap(layout.getDrawingCache()); //創建一個DrawingCache的拷貝,因為DrawingCache得到的位圖在禁用后會被回收 
 layout.setDrawingCacheEnabled(false); //禁用DrawingCahce否則會影響性能 
 Log.i("Alex", "轉換前bitmap的大小是"+screen.getWidth()+" : "+screen.getHeight()); 
 screen = scaleBitmap(screen, screen.getWidth()/2, screen.getHeight()/2);//壓縮bitmap到指定大小 
 Log.i("Alex", "轉換后bitmap的大小是"+screen.getWidth()+" : "+screen.getHeight()); 
 //將截屏進行模糊 
 screen = Blur.fastblur(this, screen, 10); 
 
 // 獲取自定義布局文件activity_popupwindow_left.xml的視圖 
 final View popupWindow_view = getLayoutInflater().inflate(R.layout.ioswindow, null, 
 false); 
 
 // 創建PopupWindow實例,200,LayoutParams.MATCH_PARENT分別是寬度和高度 
 background.setImageBitmap(screen); 
 background.setVisibility(View.VISIBLE); 
 final int screenWidth = getScreenWidth(this); 
 popupWindow = new PopupWindow(popupWindow_view, (int) (screenWidth*0.8), (int) (screenWidth*0.85*0.5), true); //設置popwindow的大小 
 popupWindow.showAtLocation(textView1, Gravity.CENTER, 0, 0);//設置popwindow的位置 
 popupWindow_view.post(new Runnable() { 
 
 @Override 
 public void run() { 
 // TODO Auto-generated method stub 
 int left = screenWidth/10; 
 } 
 }); 
 
 // 設置動畫效果 
 // 點擊其他地方消失 
 TextView confirm = (TextView) popupWindow_view.findViewById(R.id.textView2); 
 confirm.setOnClickListener(new OnClickListener() { 
 
 @Override 
 public void onClick(View v) { 
 // TODO Auto-generated method stub 
 background.setVisibility(View.GONE); 
 popupWindow.dismiss(); 
 } 
 }); 
 
 } 
 
 /** 
 * Get the screen width. 
 * 
 * @param context 
 * @return the screen width 
 */ 
 @SuppressWarnings("deprecation") 
 @SuppressLint("NewApi") 
 public static int getScreenWidth(Activity context) { 
 
 Display display = context.getWindowManager().getDefaultDisplay(); 
 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB_MR2) { 
 Point size = new Point(); 
 display.getSize(size); 
 return size.x; 
 } 
 return display.getWidth(); 
 } 
 
 /** 
 * 把一個bitmap壓縮,壓縮到指定大小 
 * @param bm 
 * @param width 
 * @param height 
 * @return 
 */ 
 private static Bitmap scaleBitmap(Bitmap bm, float width, float height) { 
 if (bm == null) { 
 return null; 
 } 
 int bmWidth = bm.getWidth(); 
 int bmHeight = bm.getHeight(); 
 float scaleWidth = width / bmWidth; 
 float scaleHeight = height / bmHeight; 
 Matrix matrix = new Matrix(); 
 matrix.postScale(scaleWidth, scaleHeight); 
 
 if (scaleWidth == 1 && scaleHeight == 1) { 
 return bm; 
 } else { 
 Bitmap resizeBitmap = Bitmap.createBitmap(bm, 0, 0, bmWidth, 
  bmHeight, matrix, false); 
 bm.recycle();//回收圖片內存 
 bm.setDensity(240); 
 return resizeBitmap; 
 } 
 } 
} 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

秭归县| 葫芦岛市| 南郑县| 西华县| 海阳市| 桃江县| 桑植县| 淮北市| 元江| 潮安县| 土默特右旗| 香河县| 永福县| 奎屯市| 灯塔市| 酒泉市| 杂多县| 冀州市| 黄冈市| 博罗县| 汉寿县| 仁化县| 宿迁市| 清流县| 北海市| 铜山县| 阿拉善盟| 肥乡县| 宁城县| 平陆县| 渭南市| 崇州市| 石城县| 保亭| 新丰县| 来安县| 焉耆| 大同县| 宜川县| 石台县| 舟曲县|