Android自定义底部带有动画的Dialog
Android自定义底部带有动画的Dialog
效果图
先看效果图,是不是你想要的呢
自定义Dialog
package …….view;import android.app.Dialog;
import android.content.Context;
import android.view.Gravity;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.widget.Button;import com.bitmain.btccom.R;
import com.bitmain.btccom.interfaces.ShareOnClickListener;/*** 分享框*/
public class ShareDialog extends Dialog implements View.OnClickListener {private ShareOnClickListener mShareOnClickListener;public ShareDialog(Context context, ShareOnClickListener shareOnClickListener) {super(context, R.style.ShareDialog);initView();mShareOnClickListener = shareOnClickListener;}private void initView() {// 布局这里考虑只有分享到微信还有和朋友圈 所以没有用RecyclerViewView view = View.inflate(getContext().getApplicationContext(), R.layout.view_share, null);// 初始化分享页面Button shareFriend = (Button) view.findViewById(R.id.share_friend);Button shareCirFriend = (Button) view.findViewById(R.id.share_cir_friend);Button cancel = (Button) view.findViewById(R.id.cancel);shareFriend.setOnClickListener(this);shareCirFriend.setOnClickListener(this);cancel.setOnClickListener(this);// 加载布局setContentView(view);// 设置Dialog参数Window window = getWindow();WindowManager.LayoutParams params = window.getAttributes();params.width = WindowManager.LayoutParams.MATCH_PARENT;params.height = WindowManager.LayoutParams.WRAP_CONTENT;params.gravity = Gravity.BOTTOM;window.setAttributes(params);}@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.share_friend:mShareOnClickListener.onClickPosition(0);dismiss();break;case R.id.share_cir_friend:mShareOnClickListener.onClickPosition(1);dismiss();break;case R.id.cancel:dismiss();break;}}
}
布局
因为这里只有两个分享,项目为了赶进度,直接用了两个Button,没有使用RecyclerView
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="wrap_content"android:background="#FFF5F5F5"><TextViewandroid:id="@+id/tip"android:layout_width="match_parent"android:layout_height="@dimen/y87"android:gravity="center"android:text="@string/send_and_share"android:textColor="#FF888888"android:textSize="@dimen/x24" /><LinearLayoutandroid:id="@+id/share"android:layout_width="match_parent"android:layout_height="@dimen/y250"android:layout_below="@id/tip"android:orientation="horizontal"android:weightSum="4"><Buttonandroid:id="@+id/share_friend"android:layout_width="0dp"android:layout_height="match_parent"android:layout_marginBottom="@dimen/y40"android:layout_marginTop="@dimen/y30"android:layout_weight="1"android:background="@android:color/transparent"android:drawableTop="@drawable/selector_share_friend_icon"android:text="@string/share_friend"android:textColor="#FF888888"android:textSize="@dimen/x20" /><Buttonandroid:id="@+id/share_cir_friend"android:layout_width="0dp"android:layout_height="match_parent"android:layout_marginBottom="@dimen/y40"android:layout_marginTop="@dimen/y30"android:layout_weight="1"android:background="@android:color/transparent"android:drawableTop="@drawable/selector_share_cir_friend_icon"android:text="@string/share_cir_friend"android:textColor="#FF888888"android:textSize="@dimen/x20" /></LinearLayout><Buttonandroid:id="@+id/cancel"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_below="@id/share"android:background="#FFFFFFFF"android:text="@string/cancel"android:textColor="#FF888888"android:textSize="@dimen/x24" /></RelativeLayout>
接口
这里我为了让Activity能够拿到点击的回调,我写了一个接口,大家可以参考,也可以根据自己的需求来写,灵活应用。
package …….interfaces;public interface ShareOnClickListener {public void onClickPosition(int position);
}
自定义样式(重点)
重点来了,这个自定义的Dialog我们加载了一个自己的style
super(context, R.style.ShareDialog);
看一下我们自定义的样式是怎么实现的吧
res/values/styles.xml
<resources>……<style name="AnimBottom" parent="@android:style/Animation"><item name="android:windowEnterAnimation">@anim/dialog_bottom_in</item><item name="android:windowExitAnimation">@anim/dialog_bottom_out</item></style><style name="ShareDialog" parent="@android:style/Animation.Dialog"><item name="android:windowAnimationStyle">@style/AnimBottom</item><item name="android:windowFrame">@null</item><item name="android:windowIsFloating">true</item><item name="android:windowIsTranslucent">true</item><item name="android:windowNoTitle">true</item><!-- 设置背景色 透明--><item name="android:background">@android:color/transparent</item><item name="android:windowBackground">@android:color/transparent</item><!-- 设置是否显示背景 --><item name="android:backgroundDimEnabled">true</item><!-- 设置背景透明度 0 全透明 1 全不透明--><item name="android:backgroundDimAmount">0.8</item><!-- 设置点击空白消失 --><item name="android:windowCloseOnTouchOutside">true</item></style>……</resources>
动画
res/anim/dialog_bottom_in.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"><!-- 自下向上滑入 --><translate android:duration="500"android:fromYDelta="100%p"android:toYDelta="0" /> </set>
res/anim/dialog_bottom_out.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"><!-- 自上向下滑出 --><translate android:duration="500"android:fromYDelta="0"android:toYDelta="100%p" /> </set>
Android自定义底部带有动画的Dialog相关推荐
- Android自定义底部弹出窗-dialog(2种实现分析+源码)
Android自定义底部弹出窗-dialog(2种实现分析+源码) 上线项目功能抽取,在项目开发中,我们会在许多地方会用到底部自定义弹窗,比如设置:个人账户退出,切换,照片的拍照或者相册的调出,或者一 ...
- android的底部弹出框炫酷的样式,Android自定义底部弹出框ButtomDialog
本文实例为大家分享了Android自定义底部弹出框的具体代码,供大家参考,具体内容如下 先看看效果和你要的是否一样 一 .先来配置自定义控件需要的资源 1.在res文件夹下创建一个anim文件夹并创建 ...
- Android自定义类似ProgressDialog效果的Dialog
2019独角兽企业重金招聘Python工程师标准>>> Android自定义类似ProgressDialog效果的Dialog. 方法如下: 1.首先准备两张自己要定义成哪样子的效果 ...
- Android自定义水波纹动画Layout
Android自定义水波纹动画Layout 源码是双11的时候就写好了,但是我觉得当天发不太好,所以推迟了几天,没想到过了双11女友就变成了前女友,桑心.唉不说了,来看看代码吧. 展示效果 Hi前辈 ...
- android动画框架,GitHub - azhengyongqin/CustomAnimationFramework: Android自定义曲线路径动画框架...
Android自定义曲线路径动画框架 最近在一个项目中需要一个像QQ打开个人爱好那样的动画效果如下图: 可以看出每个小球都是以顺时针旋转出来的,说明像这样的曲线动画用Android中自带的平移动画是很 ...
- Android自定义Activity切换动画完全解析
Android自定义Activity切换动画完全解析 在Android开发中,Activity之间的切换是最常见的业务场景了,而且系统默认的Activity之间的切换都是带动画效果的(右进右出).但是 ...
- Android 自定义底部上拉控件的实现
前言 又到了新的一月,今天提供一个Android自定义底部上拉布局的实现,起因是自己在项目中需要实现这样一个控件,干脆自己写一个练练手. 写完了觉得能想到的需求都基本有了(可能会有其它需求,不过基本上 ...
- android 自定义View 视差动画
本系列自定义View全部采用kt **系统: **mac android studio: 4.1.3 **kotlin version:**1.5.0 gradle: gradle-6.5-bin.z ...
- Android 自定义底部导航栏消息显示
转载请标明出处: http://blog.csdn.net/tyzlmjj/article/details/47186249 本文出自:[M家杰的博客] 概述 底部导航栏的做法多种多样,这次主要用到了 ...
最新文章
- 在GitHub上搭建GitHub Pages博客-- Jekyll
- 为什么要继承Serializable类?
- Oracle数据库的一些常用命令
- 55种网页常用小技巧(javascript) (转)
- Python之io概念
- 网管日志-06.09.26
- 科创板注册获批,优刻得将成为“公有云第一股”
- c语言给定一个非空整数数组_C程序检查给定整数的所有位是否为一(1)
- 操作系统(王道笔记第三章内存)
- Windows动态定义模板类对象
- 我的内核学习笔记4:sysfs学习
- java围棋毕业设计_(毕业论文)围棋游戏的设计与实现.doc
- (译)C++11中的Move语义和右值引用
- python简单代码大全-python代码大全
- python常用库大全文库_Python库参考手册
- python笔记整理
- IDEA 打包docker镜像详解
- 逻辑地址、物理地址、线性地址、虚拟地址、段基地址偏移地址的联系和区别
- Python学习记录 使用百度aip模块(API Python-SDK)实现人脸识别
- 机器学习--KNN算法应用,iris鸢尾花数据集的分类