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 ...
随机推荐
- 学习React系列(六)——更新dom细节于原理
React更新dom的依据: 1.不同类型的elements会产生不同的树 2.通过render方法中包含key属性的子元素,开发者可以示意哪些子元素可能是稳定的. 更新过程: 一.根元素类型不同:旧 ...
- mysql索引类型和索引方法
索引类型 mysql索引类型normal,unique,full text的区别是什么? normal:表示普通索引 unique:表示唯一的,不允许重复的索引,如果该字段信息保证不会重复例如身份证号 ...
- [LeetCode] Poor Pigs 可怜的猪
There are 1000 buckets, one and only one of them contains poison, the rest are filled with water. Th ...
- nodejs和vue的那些事
nodejs >1.旨在提供一种简单的构建可伸缩网络程序的方法 官方网站:http://nodejs.cn/api/ Node.js 是一个基于Chromev8 JavaScript 运行时建立 ...
- [BJOI2006]狼抓兔子
题目描述 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...
- [ZJOI2011]看电影(MOVIE)
题目描述 到了难得的假期,小白班上组织大家去看电影.但由于假期里看电影的人太多,很难做到让全班看上同一场电影,最后大家在一个偏僻的小胡同里找到了一家电影院.但这家电影院分配座位的方式很特殊,具体方式如 ...
- [HNOI2008]越狱
题目描述 监狱有连续编号为1...N的N个房间,每个房间关押一个犯人,有M种宗教,每个犯人可能信仰其中一种.如果相邻房间的犯人的宗教相同,就可能发生越狱,求有多少种状态可能发生越狱 输入输出格式 输入 ...
- 【BZOJ4196】【Noi2015】软件包管理器
原题传送门 题意: 给你一棵树,有2种操作: 1.使得某个点到根节点路径上的所有点权值赋为1. 2.使得某节点的子树中所有节点权值赋为0. 每次操作要求输出权值更改的节点个数. 解题思路: 显然是用树 ...
- [BZOJ]4805: 欧拉函数求和
解题思路类似莫比乌斯函数之和 题目大意:求[1,n]内的欧拉函数$\varphi$之和.($n<=2*10^{9}$) 思路:令$ M(n)=\sum_{i=1}^{n}\varphi (i) ...
- hdu5634 BestCoder Round #73 (div.1)
Rikka with Phi Accepts: 5 Submissions: 66 Time Limit: 16000/8000 MS (Java/Others) Memory Limit: ...