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() {
        // 布局这里考虑只有分享到微信还有和朋友圈 所以没有用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的更多相关文章
- Android自定义类似ProgressDialog效果的Dialog
		
Android自定义类似ProgressDialog效果的Dialog. 方法如下: 1.首先准备两张自己要定义成哪样子的效果的图片和背景图片(也可以不要背景). 如我要的效果: 2.定义loadin ...
 - [置顶] android 自定义ListView实现动画特效
		
通过自定义ListView实现动画特效,被点击元素A向前移,A之前元素往后移动. 重点在于动画的实现: 具体代码如下: package com.open.widget; import java.uti ...
 - Android 自定义底部公用菜单
		
注释:此案例主要展示自定义底部菜单,一处封装处处调用.使用起来相当方便 一.初始的Activity package com.example.myapi.buttommenu; import andro ...
 - Android自定义View带有删除按钮的EditText
		
转载请注明出处http://blog.csdn.net/xiaanming/article/details/11066685 今天给大家带来一个很实用的小控件ClearEditText,就是在Andr ...
 - 手把手带你做一个超炫酷loading成功动画view  Android自定义view
		
写在前面: 本篇可能是手把手自定义view系列最后一篇了,实际上我也是一周前才开始真正接触自定义view,通过这一周的练习,基本上已经熟练自定义view,能够应对一般的view需要,那么就以本篇来结尾 ...
 - 自定义PopupWindow弹出框(带有动画)
		
使用PopupWindow来实现弹出框,并且带有动画效果 首先自定义PopupWindow public class LostPopupWindow extends PopupWindow { pub ...
 - android 自定义动画
		
android自定义动画注意是继承Animation,重写里面的initialize和applyTransformation,在initialize方法做一些初始化的工作,在applyTransfor ...
 - Android—自定义Dialog
		
在 Android 日常的开发中,Dialog 使用是比较广泛的.无论是提示一个提示语,还是确认信息,还是有一定交互的(弹出验证码,输入账号密码登录等等)对话框. 而我们去看一下原生的对话框,虽然随着 ...
 - Android自定义View 画弧形,文字,并增加动画效果
		
一个简单的Android自定义View的demo,画弧形,文字,开启一个多线程更新ui界面,在子线程更新ui是不允许的,但是View提供了方法,让我们来了解下吧. 1.封装一个抽象的View类 B ...
 
随机推荐
- [LeetCode] Max Chunks To Make Sorted 可排序的最大块数
			
Given an array arr that is a permutation of [0, 1, ..., arr.length - 1], we split the array into som ...
 - ueditor图片无法左右对齐的解决
			
找到ueditor的配置文件ueditor.config.js,里面搜索 whiteList 然后在下面找到img,在里面添加 'style'. 添加后如下: img : [ 'src', 'alt' ...
 - [HNOI2010]PLANAR
			
题目描述 若能将无向图G=(V,E)画在平面上使得任意两条无重合顶点的边不相交,则称G是平面图.判定一个图是否为平面图的问题是图论中的一个重要问题.现在假设你要判定的是一类特殊的图,图中存在一个包含所 ...
 - [HNOI2012]排队
			
题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...
 - 51 nod 1439 互质对(Moblus容斥)
			
1439 互质对 题目来源: CodeForces 基准时间限制:2 秒 空间限制:131072 KB 分值: 160 难度:6级算法题 有n个数字,a[1],a[2],…,a[n].有一个集合,刚开 ...
 - APIO 2016
			
我好菜啊都不会 T1.boats 题目大意:给你N段区间,按顺序决定每段区间可以选一个数或不选,若选则选的这个数必须大于所有在这之前选的数,求有多少种方案.(N<=500,区间在[1,1e9]范 ...
 - [UOJ UR #2]树上GCD
			
来自FallDream的博客,未经允许,请勿转载,谢谢. 传送门 看完题目,一般人都能想到 容斥稳了 .这样我们只要统计有多少点对满足gcd是i的倍数. 考虑长链剖分,每次合并的时候,假设我已经求出轻 ...
 - UVA 1146 Now or later
			
The Terminal Radar Approach CONtrol (TRACON) controls aircraft approaching and departing when they a ...
 - hdu5634 BestCoder Round #73 (div.1)
			
Rikka with Phi Accepts: 5 Submissions: 66 Time Limit: 16000/8000 MS (Java/Others) Memory Limit: ...
 - WebDNN:Web浏览器上最快的DNN执行框架
			
WebDNN:Web浏览器上最快的DNN执行框架 为什么需要WebDNN? 深层神经网络(DNN)在许多应用中受到越来越多的关注. 然而,它需要大量的计算资源,并且有许多巨大的过程来设置基于执行环境的 ...