popupwindow 弹出自定义布局 点击其中内容 模拟点击按钮

这篇博客介绍了如何在Android中使用PopupWindow来弹出自定义布局,并实现点击布局内的内容后,模拟点击其他按钮的功能。通过LayoutInflater加载布局,创建PopupWindow对象,设置其大小、触摸和点击事件,然后显示在指定位置。同时,博客还展示了自定义布局XML文件,包含三个TextView,分别对应不同的操作选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//点击事件中写的

// 用于PopupWindowView
    View contentView=LayoutInflater.from(MainActivity.this).inflate(R.layout.popup, null, false);
   // 创建PopupWindow对象,其中:
     // 第一个参数是用于PopupWindow中的View,第二个参数是PopupWindow的宽度,
     // 第三个参数是PopupWindow的高度,第四个参数指定PopupWindow能否获得焦点
     PopupWindow window=new PopupWindow(contentView, 100, 100, true);
    // 设置PopupWindow的背景
   window.setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
    // 设置PopupWindow是否能响应外部点击事件
     window.setOutsideTouchable(true);
     // 设置PopupWindow是否能响应点击事件
    window.setTouchable(true);
    // 显示PopupWindow,其中:
     // 第一个参数是PopupWindow的锚点,第二和第三个参数分别是PopupWindow相对锚点的xy偏移
    window.showAsDropDown(btn,30,0);


    // 或者也可以调用此方法显示PopupWindow,其中:
     // 第一个参数是PopupWindow的父View,第二个参数是PopupWindow相对父View的位置,
    // 第三和第四个参数分别是PopupWindow相对父Viewxy偏移
  // window.showAtLocation(parent, gravity, x, y);
  //设置出入动画  自定义的
window.setAnimationStyle(R.style.popup);

//拿到自定义布局里的控件
TextView dai=contentView.findViewById(R.id.dai);
TextView yifu=contentView.findViewById(R.id.yifu);
TextView yixiao=contentView.findViewById(R.id.yixiao);

dai.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        
        //onefu是其他的按钮  不在自定义popup布局中
        onefu.performClick();
    }
});
yifu.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
       twofu.performClick();
    }
});
yifu.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        threefu.performClick();
    }
});

//popup的布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:background="#2510eb"
    >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="待支付"
        android:id="@+id/dai"
        />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="已支付"
        android:id="@+id/yifu"
        />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="已取消"
        android:id="@+id/yixiao"
        />

</LinearLayout>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值