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() {
// 布局这里考虑只有分享到微信还有和朋友圈 所以没有用RecyclerView
View 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);
} @Override
public 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"> <TextView
android: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" /> <LinearLayout
android:id="@+id/share"
android:layout_width="match_parent"
android:layout_height="@dimen/y250"
android:layout_below="@id/tip"
android:orientation="horizontal"
android:weightSum="4"> <Button
android: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" /> <Button
android: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> <Button
android: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自定义类似ProgressDialog效果的Dialog

    Android自定义类似ProgressDialog效果的Dialog. 方法如下: 1.首先准备两张自己要定义成哪样子的效果的图片和背景图片(也可以不要背景). 如我要的效果: 2.定义loadin ...

  2. [置顶] android 自定义ListView实现动画特效

    通过自定义ListView实现动画特效,被点击元素A向前移,A之前元素往后移动. 重点在于动画的实现: 具体代码如下: package com.open.widget; import java.uti ...

  3. Android 自定义底部公用菜单

    注释:此案例主要展示自定义底部菜单,一处封装处处调用.使用起来相当方便 一.初始的Activity package com.example.myapi.buttommenu; import andro ...

  4. Android自定义View带有删除按钮的EditText

    转载请注明出处http://blog.csdn.net/xiaanming/article/details/11066685 今天给大家带来一个很实用的小控件ClearEditText,就是在Andr ...

  5. 手把手带你做一个超炫酷loading成功动画view Android自定义view

    写在前面: 本篇可能是手把手自定义view系列最后一篇了,实际上我也是一周前才开始真正接触自定义view,通过这一周的练习,基本上已经熟练自定义view,能够应对一般的view需要,那么就以本篇来结尾 ...

  6. 自定义PopupWindow弹出框(带有动画)

    使用PopupWindow来实现弹出框,并且带有动画效果 首先自定义PopupWindow public class LostPopupWindow extends PopupWindow { pub ...

  7. android 自定义动画

    android自定义动画注意是继承Animation,重写里面的initialize和applyTransformation,在initialize方法做一些初始化的工作,在applyTransfor ...

  8. Android—自定义Dialog

    在 Android 日常的开发中,Dialog 使用是比较广泛的.无论是提示一个提示语,还是确认信息,还是有一定交互的(弹出验证码,输入账号密码登录等等)对话框. 而我们去看一下原生的对话框,虽然随着 ...

  9. Android自定义View 画弧形,文字,并增加动画效果

    一个简单的Android自定义View的demo,画弧形,文字,开启一个多线程更新ui界面,在子线程更新ui是不允许的,但是View提供了方法,让我们来了解下吧. 1.封装一个抽象的View类   B ...

随机推荐

  1. Spring Cloud学习笔记-006

    服务容错保护:Spring Cloud Hystrix 在微服务架构中,我们将系统拆分成了很多服务单元,各单元的应用间通过服务注册与订阅的方式互相依赖.由于每个单元都在不同的进程中运行,依赖通过远程调 ...

  2. Override与Overload

    方法重写(Override) 方法重写是子类对父类(父类为抽象类)的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变.即外壳不变,核心重写! 方法的重写规则 1.参数列表必须完全与被重写 ...

  3. 重拾Python(4):Pandas之DataFrame对象的使用

    Pandas有两大数据结构:Series和DataFrame,之前已对Series对象进行了介绍(链接),本文主要对DataFrame对象的常用用法进行总结梳理. 约定: import pandas ...

  4. slab机制

    1.内部碎片和外部碎片 外部碎片 什么是外部碎片呢?我们通过一个图来解释: 假设这是一段连续的页框,阴影部分表示已经被使用的页框,现在需要申请一个连续的5个页框.这个时候,在这段内存上不能找到连续的5 ...

  5. Codeforces Round #460 D. Karen and Cards

    Description Karen just got home from the supermarket, and is getting ready to go to sleep. After tak ...

  6. ●BZOJ 2693 jzptab

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2693 题解: 莫比乌斯反演 先看看这个题,BZOJ 2154 Crash的数字表格,本题的升 ...

  7. 洛谷4月月赛R1

    T1.题目大意:n个人站成一排,有m个团队,每个人有且属于一个团队,可以让若干个人出队,任意交换这些人的位置后再站回去,问要让所有同一团队的人连续地站在一起,至少要出队几个.(n<=10^5,m ...

  8. Educational Codeforces Round 18

    A. New Bus Route 题目大意:给出n个不同的数,问差值最小的数有几对.(n<=200,000) 思路:排序一下,差值最小的一定是相邻的,直接统计即可. #include<cs ...

  9. poj2449 (第k条最短路)

    题意:求n个点中,a到b的第k条最短路 思路: 用最短路求出估价函数的h,再在搜索过程中记录g,利用A*求出 最开始想到的便是A*和最短路,但是脑子抽了,居然一个一个去求- -,TL了后才发现可以倒着 ...

  10. [APIO2009]

    来自FallDream的博客,不经允许,请勿转载,谢谢. ------------------------------------------------------ 1.Oil 给定一个n*m的矩阵 ...