• 一手遮天 Android


    项目地址 https://github.com/webabcd/AndroidDemo
    作者 webabcd

    一手遮天 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>
    

    项目地址 https://github.com/webabcd/AndroidDemo
    作者 webabcd

  • 相关阅读:
    41:和为S的两个数
    40:数组中只出现一次的数字
    39-2:平衡二叉树
    39:二叉树的深度
    38:数字在排序数组中出现的次数
    37:两个链表的第一个公共结点
    36:数组中的逆序对
    35:第一个只出现一次的字符
    34:丑数
    33:把数组排成最小的数
  • 原文地址:https://www.cnblogs.com/webabcd/p/android_view_flyout_PopupWindowDemo1.html
Copyright © 2020-2023  润新知