zoukankan      html  css  js  c++  java
  • 自定义Dialog布局的弹窗功能的简单实现

    package com.loaderman.dialogdemo;
    
    import android.os.Bundle;
    import android.support.v7.app.AlertDialog;
    import android.support.v7.app.AppCompatActivity;
    import android.view.View;
    import android.widget.Toast;
    
    public class MainActivity extends AppCompatActivity {
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            findViewById(R.id.tv).setOnLongClickListener(new View.OnLongClickListener() {
                @Override
                public boolean onLongClick(View v) {
                    //长按显示弹窗
                    showDialog();
                    return true;
                }
            });
        }
        //显示弹窗
        private void showDialog() {
            AlertDialog.Builder builder = new AlertDialog.Builder(this);
            //自定义dialog的布局
            View view = View.inflate(this, R.layout.item_dialog, null);
            //设置View
            builder.setView(view);
            //根据builder设置好的一系列数据, 来构建一个dialog对象
            final AlertDialog dialog = builder.create();
            //删除点击事件
            view.findViewById(R.id.tv_delete).setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    Toast.makeText(MainActivity.this, "点击了删除", Toast.LENGTH_SHORT).show();
                    //弹窗消失
                    dialog.dismiss();
                }
            });
            //置顶点击事件
            view.findViewById(R.id.tv_top).setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    Toast.makeText(MainActivity.this, "点击了置顶", Toast.LENGTH_SHORT).show();
                    //弹窗消失
                    dialog.dismiss();
                }
            });
            //builder.show();
            dialog.show();
        }
    }
    

     activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:id="@+id/activity_main"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:paddingLeft="@dimen/activity_horizontal_margin"
        android:paddingRight="@dimen/activity_horizontal_margin"
        android:paddingTop="@dimen/activity_vertical_margin"
        android:paddingBottom="@dimen/activity_vertical_margin"
        tools:context="com.loaderman.dialogdemo.MainActivity">
    
        <TextView
            android:background="#ccc"
            android:id="@+id/tv"
            android:textColor="#f00"
            android:textSize="18sp"
            android:gravity="center"
            android:layout_width="match_parent"
            android:padding="10dp"
            android:layout_height="wrap_content"
            android:text="长按我,看效果" />
    </RelativeLayout>
    

     item_dialog.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">
    
        <TextView
            android:id="@+id/tv_delete"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:padding="10dp"
            android:text="点我删除"
            android:textSize="14sp"/>
    
        <TextView
            android:id="@+id/tv_top"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:padding="10dp"
            android:text="点我置顶"
            android:textSize="14sp"/>
    </LinearLayout>
    

     效果图:

  • 相关阅读:
    MySql中子查询,左链,右链,内链,关键字join
    MySql数据库约束,主键和外键约束的添加删除,代码实现,sql语句实现
    MySql查询,聚合函数,分组,分页,排序等复杂查询
    DQL简单语句和条件语句
    django vue
    离线部署Django工程
    数据处理与分析实战小案例系列(一)
    Python常用功能函数总结系列
    Python常用功能函数系列总结(六)
    Python常用功能函数系列总结(五)
  • 原文地址:https://www.cnblogs.com/loaderman/p/6494450.html
Copyright © 2011-2022 走看看