自定义AlertDialog(圆角+退出动画+自定义布局)

2024-08-31 23:58

本文主要是介绍自定义AlertDialog(圆角+退出动画+自定义布局),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图片省略了不上传了。。。

首先看activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent" ><Buttonandroid:id="@+id/button"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerInParent="true"android:text="点击我,弹出AlertDialog" /></RelativeLayout>
MainActivity.java

package com.godinsec.alertdialog;import com.godinsec.alertdialog.ShowDeleDialog.onBtnClickListener;import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {new ShowDeleDialog(MainActivity.this, new onBtnClickListener(){@Overridepublic void onSure() {Toast.makeText(MainActivity.this, "进行确认操作", 0).show();}@Overridepublic void onExit() {Toast.makeText(MainActivity.this, "进行取消操作", 0).show();}}, "确定", "取消", "提示", "AlertDialog的内容").show();}});}}

接下来看自定义alertDialog

dele_allcontacts_dialog.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="fill_parent" ><RelativeLayoutandroid:id="@+id/re_tip_dialog"android:layout_width="300dp"android:layout_height="120dp"android:layout_centerInParent="true"android:background="@drawable/rounded_search_text"><TextViewandroid:id="@+id/appTitle"android:layout_width="wrap_content"android:layout_height="wrap_content" android:layout_marginLeft="10dp"android:layout_marginTop="10dp"android:text="标题"/><TextViewandroid:id="@+id/tips"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_below="@id/appTitle"android:layout_alignLeft="@id/appTitle"android:text="AlertDialog的内容"android:layout_marginTop="20dp"/><TextViewandroid:id="@+id/sure"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:text="确认"android:layout_below="@id/tips"android:layout_marginTop="20dp" /><TextViewandroid:id="@+id/cancel"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignBottom="@id/sure"android:text="取消"android:layout_marginRight="30dp"android:layout_toLeftOf="@id/sure" /></RelativeLayout></RelativeLayout>
rounded_search_text.xml(圆角)

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="rectangle" ><solid android:color="#FF7F24" /><cornersandroid:bottomLeftRadius="4dp"android:bottomRightRadius="4dp"android:topLeftRadius="4dp"android:topRightRadius="4dp" /></shape>
ShowDeleDialog.java

package com.godinsec.alertdialog;import android.app.Dialog;
import android.content.Context;
import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.view.animation.Animation;
import android.view.animation.Animation.AnimationListener;
import android.view.animation.ScaleAnimation;
import android.widget.RelativeLayout;
import android.widget.TextView;public class ShowDeleDialog extends Dialog implementsandroid.view.View.OnClickListener {private onBtnClickListener onBtnClickListener;private Context context;private String sure;private String cancle;private String appTitle;private String tips;private TextView tv_dele_sure;private TextView tv_dele_cancle;private TextView tv_appTitle;private TextView tv_tips;private RelativeLayout re_tip_dialog;public ShowDeleDialog(Context context,onBtnClickListener onBtnClickListener, String sure, String cancle,String appTitle, String tips) {super(context);this.onBtnClickListener = onBtnClickListener;this.context = context;this.appTitle = appTitle;this.tips = tips;this.sure = sure;this.cancle = cancle;}@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);// 去除默认的头部标题requestWindowFeature(Window.FEATURE_NO_TITLE);setContentView(R.layout.dele_allcontacts_dialog);tv_dele_sure = (TextView) findViewById(R.id.sure);tv_dele_cancle = (TextView) findViewById(R.id.cancel);tv_appTitle = (TextView) findViewById(R.id.appTitle);tv_tips = (TextView) findViewById(R.id.tips);re_tip_dialog = (RelativeLayout) findViewById(R.id.re_tip_dialog);tv_dele_cancle.setOnClickListener(this);tv_dele_sure.setOnClickListener(this);//进入动画是伪代码
ScaleAnimation scaleAnimation = new ScaleAnimation(1.0f, 1.0f,  
0.0f, 1.0f, Animation.RELATIVE_TO_SELF,  
0.5f, Animation.RELATIVE_TO_SELF,  
0.5f);  
scaleAnimation.setDuration(200);  
re_tip_dialog.startAnimation(scaleAnimation);
Window window = this.getWindow();WindowManager.LayoutParams params = this.getWindow().getAttributes();// 去除四角黑色背景window.setBackgroundDrawable(new BitmapDrawable());// 设置周围的暗色系数params.dimAmount = 0.5f;window.setAttributes(params);// 为各个textview赋值tv_dele_sure.setText(sure);tv_dele_cancle.setText(cancle);tv_appTitle.setText(appTitle);tv_tips.setText(tips);}public interface onBtnClickListener {public void onSure();public void onExit();}@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.cancel:onBtnClickListener.onExit();alertDialogExitAnim();break;case R.id.sure:onBtnClickListener.onSure();alertDialogExitAnim();break;default:break;}}private void alertDialogExitAnim() {ScaleAnimation scaleAnimation = new ScaleAnimation(1.0f, 0.0f,1.0f, 0.0f, Animation.ABSOLUTE,re_tip_dialog.getWidth() / 2, Animation.ABSOLUTE,re_tip_dialog.getHeight() / 2);scaleAnimation.setDuration(1000);re_tip_dialog.startAnimation(scaleAnimation);scaleAnimation.setAnimationListener(new AnimationListener() {@Overridepublic void onAnimationStart(Animation animation) {}@Overridepublic void onAnimationRepeat(Animation animation) {}@Overridepublic void onAnimationEnd(Animation animation) {ShowDeleDialog.this.dismiss();}});}}





这篇关于自定义AlertDialog(圆角+退出动画+自定义布局)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125366

相关文章

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

基于Spring实现自定义错误信息返回详解

《基于Spring实现自定义错误信息返回详解》这篇文章主要为大家详细介绍了如何基于Spring实现自定义错误信息返回效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景目标实现产出背景Spring 提供了 @RestConChina编程trollerAdvice 用来实现 HTT

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth

SpringBoot自定义注解如何解决公共字段填充问题

《SpringBoot自定义注解如何解决公共字段填充问题》本文介绍了在系统开发中,如何使用AOP切面编程实现公共字段自动填充的功能,从而简化代码,通过自定义注解和切面类,可以统一处理创建时间和修改时间... 目录1.1 问题分析1.2 实现思路1.3 代码开发1.3.1 步骤一1.3.2 步骤二1.3.3

dubbo3 filter(过滤器)如何自定义过滤器

《dubbo3filter(过滤器)如何自定义过滤器》dubbo3filter(过滤器)类似于javaweb中的filter和springmvc中的intercaptor,用于在请求发送前或到达前进... 目录dubbo3 filter(过滤器)简介dubbo 过滤器运行时机自定义 filter第一种 @A

CSS3 最强二维布局系统之Grid 网格布局

《CSS3最强二维布局系统之Grid网格布局》CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介... 深入学习 css3 目前最强大的布局系统 Grid 网格布局Grid 网格布局的基本认识Grid 网

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re