一手遮天 Android - view(弹出类): PopupWindow 基础
示例如下:
/view/flyout/PopupWindowDemo1.java
/**
* PopupWindow - 悬浮框(与 AlertDialog 不同的是,PopupWindow 没有背景自动灰色半透明的效果)
*
* 本例会演示如何弹出一个自定义 view 的悬浮框,如何控制点击空白处和返回键的逻辑,以及如何指定悬浮框的位置和动画等
*/
package com.webabcd.androiddemo.view.flyout;
import android.graphics.drawable.ColorDrawable;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.PopupWindow;
import android.widget.TextView;
import android.widget.Toast;
import com.webabcd.androiddemo.R;
public class PopupWindowDemo1 extends AppCompatActivity {
private Button mButton1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_view_flyout_popupwindowdemo1);
mButton1 = findViewById(R.id.button1);
sample();
}
private void sample() {
mButton1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// 从布局文件中加载 PopupWindow 需要显示的 view
View customView = LayoutInflater.from(PopupWindowDemo1.this).inflate(R.layout.popupwindow_view_layout_popupwindowdemo1, null, false);
// 设置自定义 view 中的显示内容
((TextView) customView.findViewById(R.id.textViewTitle)).setText("标题");
((TextView) customView.findViewById(R.id.textViewContent)).setText("内容");
((Button) customView.findViewById(R.id.buttonClose)).setText("X");
((Button) customView.findViewById(R.id.buttonConfirm)).setText("确认");
((Button) customView.findViewById(R.id.buttonCancel)).setText("取消");
// 实例化 PopupWindow,并指定其需要显示的 view 以及宽和高
final PopupWindow popupWindow = new PopupWindow(customView, ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
// setFocusable()
// true - 点击空白处或点击返回键会自动隐藏 PopupWindow,如果是 android 5.0 以下系统还需要另外设置 setBackgroundDrawable()
// false - 点击空白处不会自动隐藏 PopupWindow,点击返回键会连同父页面一起退出
// 如果需要点击返回键只让 PopupWindow 退出的话,可以重写页面的 onBackPressed() 方法并在其中增加 popupWindow.dismiss() 逻辑
popupWindow.setFocusable(true);
popupWindow.setBackgroundDrawable(new ColorDrawable(0x00000000));
// 设置 PopupWindow 的宽和高(也可以在构造函数中指定)
// popupWindow.setWidth(ViewGroup.LayoutParams.WRAP_CONTENT);
// popupWindow.setHeight(ViewGroup.LayoutParams.WRAP_CONTENT);
// setAnimationStyle() - 设置 PopupWindow 的显示和隐藏动画(参见 res/values/styles.xml 中的 MyPopupWindowStyle)
popupWindow.setAnimationStyle(R.style.MyPopupWindowStyle);
// showAsDropDown() - 设置 PopupWindow 的显示位置并显示
// 第 1 个参数:参照 view
// 第 2 个参数:相对于参照 view 的左侧的 x 方向的偏移量
// 第 3 个参数:相对于参照 view 的下侧的 y 方向的偏移量
// popupWindow.showAsDropDown(v, 0, 0);
// showAtLocation() - 设置 PopupWindow 的显示位置并显示
// 第 1 个参数:页面上的任意 view 均可
// 第 2 个参数:参照点相对于整个页面的位置
// 第 3 个参数:相对于参照点的 x 方向的距离
// 第 4 个参数:相对于参照点的 y 方向的距离
popupWindow.showAtLocation(v, Gravity.TOP | Gravity.LEFT, 0, 0);
// 自定义 view 中的关闭按钮的点击事件
customView.findViewById(R.id.buttonClose).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(PopupWindowDemo1.this, "点击了关闭按钮", Toast.LENGTH_SHORT).show();
// dismiss() - 隐藏 PopupWindow
popupWindow.dismiss();
}
});
// 自定义 view 中的确认按钮的点击事件
customView.findViewById(R.id.buttonConfirm).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(PopupWindowDemo1.this, "点击了确认按钮", Toast.LENGTH_SHORT).show();
// dismiss() - 隐藏 PopupWindow
popupWindow.dismiss();
}
});
// 自定义 view 中的取消按钮的点击事件
customView.findViewById(R.id.buttonCancel).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(PopupWindowDemo1.this, "点击了取消按钮", Toast.LENGTH_SHORT).show();
// dismiss() - 隐藏 PopupWindow
popupWindow.dismiss();
}
});
}
});
}
}
/layout/activity_view_flyout_popupwindowdemo1.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAllCaps="false"
android:text="弹出一个 PopupWindow" />
</LinearLayout>
/layout/popupwindow_view_layout_popupwindowdemo1.xml
<?xml version="1.0" encoding="utf-8"?>
<!--
自定义 AlertDialog 显示的 view(参见:/view/flyout/AlertDialogDemo2.java)
-->
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/RelativeLayout1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/yellow"
android:orientation="vertical">
<RelativeLayout
android:id="@+id/layoutTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:background="@color/red"
android:padding="5dp">
<TextView
android:id="@+id/textViewTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:text="title"
android:textColor="@color/white"
android:textSize="18sp"
android:textStyle="bold" />
<Button
android:id="@+id/buttonClose"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_alignParentRight="true"
android:padding="0dp"
android:text="close"
android:textSize="14sp" />
</RelativeLayout>
<LinearLayout
android:id="@+id/layoutDetail"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/layoutTitle"
android:layout_alignParentLeft="true"
android:layout_centerInParent="true"
android:orientation="vertical">
<TextView
android:id="@+id/textViewContent"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:layout_marginTop="20dp"
android:text="content"
android:textColor="@color/green"
android:textSize="18sp" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/layoutDetail"
android:layout_marginTop="10dp"
android:orientation="horizontal">
<Button
android:id="@+id/buttonConfirm"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_margin="5dp"
android:layout_weight="1"
android:text="confirm"
android:textColor="@color/blue"
android:textSize="16sp" />
<Button
android:id="@+id/buttonCancel"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_margin="5dp"
android:layout_weight="1"
android:text="cancel"
android:textColor="@color/blue"
android:textSize="16sp" />
</LinearLayout>
</RelativeLayout>