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相关推荐

  1. Android自定义底部弹出窗-dialog(2种实现分析+源码)

    Android自定义底部弹出窗-dialog(2种实现分析+源码) 上线项目功能抽取,在项目开发中,我们会在许多地方会用到底部自定义弹窗,比如设置:个人账户退出,切换,照片的拍照或者相册的调出,或者一 ...

  2. android的底部弹出框炫酷的样式,Android自定义底部弹出框ButtomDialog

    本文实例为大家分享了Android自定义底部弹出框的具体代码,供大家参考,具体内容如下 先看看效果和你要的是否一样 一 .先来配置自定义控件需要的资源 1.在res文件夹下创建一个anim文件夹并创建 ...

  3. Android自定义类似ProgressDialog效果的Dialog

    2019独角兽企业重金招聘Python工程师标准>>> Android自定义类似ProgressDialog效果的Dialog. 方法如下: 1.首先准备两张自己要定义成哪样子的效果 ...

  4. Android自定义水波纹动画Layout

    Android自定义水波纹动画Layout 源码是双11的时候就写好了,但是我觉得当天发不太好,所以推迟了几天,没想到过了双11女友就变成了前女友,桑心.唉不说了,来看看代码吧. 展示效果 Hi前辈 ...

  5. android动画框架,GitHub - azhengyongqin/CustomAnimationFramework: Android自定义曲线路径动画框架...

    Android自定义曲线路径动画框架 最近在一个项目中需要一个像QQ打开个人爱好那样的动画效果如下图: 可以看出每个小球都是以顺时针旋转出来的,说明像这样的曲线动画用Android中自带的平移动画是很 ...

  6. Android自定义Activity切换动画完全解析

    Android自定义Activity切换动画完全解析 在Android开发中,Activity之间的切换是最常见的业务场景了,而且系统默认的Activity之间的切换都是带动画效果的(右进右出).但是 ...

  7. Android 自定义底部上拉控件的实现

    前言 又到了新的一月,今天提供一个Android自定义底部上拉布局的实现,起因是自己在项目中需要实现这样一个控件,干脆自己写一个练练手. 写完了觉得能想到的需求都基本有了(可能会有其它需求,不过基本上 ...

  8. android 自定义View 视差动画

    本系列自定义View全部采用kt **系统: **mac android studio: 4.1.3 **kotlin version:**1.5.0 gradle: gradle-6.5-bin.z ...

  9. Android 自定义底部导航栏消息显示

    转载请标明出处: http://blog.csdn.net/tyzlmjj/article/details/47186249 本文出自:[M家杰的博客] 概述 底部导航栏的做法多种多样,这次主要用到了 ...

最新文章

  1. 在GitHub上搭建GitHub Pages博客-- Jekyll
  2. 为什么要继承Serializable类?
  3. Oracle数据库的一些常用命令
  4. 55种网页常用小技巧(javascript) (转)
  5. Python之io概念
  6. 网管日志-06.09.26
  7. 科创板注册获批,优刻得将成为“公有云第一股”
  8. c语言给定一个非空整数数组_C程序检查给定整数的所有位是否为一(1)
  9. 操作系统(王道笔记第三章内存)
  10. Windows动态定义模板类对象
  11. 我的内核学习笔记4:sysfs学习
  12. java围棋毕业设计_(毕业论文)围棋游戏的设计与实现.doc
  13. (译)C++11中的Move语义和右值引用
  14. python简单代码大全-python代码大全
  15. python常用库大全文库_Python库参考手册
  16. python笔记整理
  17. IDEA 打包docker镜像详解
  18. 逻辑地址、物理地址、线性地址、虚拟地址、段基地址偏移地址的联系和区别
  19. Python学习记录 使用百度aip模块(API Python-SDK)实现人脸识别
  20. 机器学习--KNN算法应用,iris鸢尾花数据集的分类

热门文章

  1. SQL中NVL()用法
  2. 叮咚,您有一份专线链路带宽管理方案,请查收
  3. 曾经学舞度芳年(代序)
  4. ffmpeg 音频解码二
  5. 课程设计 单项选择题标准化考试系统
  6. 嵌入式系统基础及知识及接口技术总结
  7. Mysql索引的本质深入浅出(一)
  8. 软件测试需要学习些什么技能
  9. jQuery第三方插件
  10. 响铃和振动(转载的)