Android自定义组件系列【17】——教你如何高仿微信录音Toast
一、Toast介绍
平时我们在Android开发中会经常用到一个叫Toast的东西,官方解释如下
A toast is a view containing a quick little message for the user. The toast class helps you create and show those.
When the view is shown to the user, appears as a floating view over the application. It will never receive focus. The user will probably be in the middle of typing something else. The idea is to be as unobtrusive as possible, while still showing the user the information you want them to see. Two examples are the volume control, and the brief message saying that your settings have been saved.
Toast最基本的用法很简单,不用说大家都会(这里切记要调用show()去显示)
public static void showToast(Context context){
Toast.makeText(context, "欢迎关注水寒的CSDN博客", Toast.LENGTH_LONG).show();
}
二、自定义Toast
上面的Toast一般显示在手机偏下的一个位置上,有的时候我们需要将这个Toast的位置或者内容进行修改,比如让显示在屏幕中间,让内容里面有图片,这样的修改也比较容易,Toast有一个和ActionBar类似的方法setView(),这个方法就是提供给我们自定义Toast的。
public static void showToast(Context context){
LayoutInflater inflater = LayoutInflater.from(context);
View toastView = inflater.inflate(R.layout.toast_test_custome, null);
Toast toast = new Toast(context);
toast.setDuration(3000);
toast.setView(toastView); //设置自定义view
toast.setGravity(Gravity.CENTER, 0, 0); //控制显示到屏幕中间
toast.show(); //注意:一定要调用才能显示
}
布局文件如下
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/custom_toast_bg"
android:padding="15dip"
android:gravity="center_horizontal"
android:orientation="vertical" >
<ImageView
android:layout_width="80dip"
android:layout_height="80dip"
android:scaleType="centerCrop"
android:src="@drawable/shuihan"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="12dip"
android:textSize="16sp"
android:text="欢迎访问水寒的CSDN博客"
android:textColor="#ffffff"/>
</LinearLayout>
三、为什么要改变Toast的显示时长
上面的自定义非常简单,但是我们要改变Toast的显示时间就比较麻烦了,因为toast的setDuration方法只能填写两个值2000ms或者3000ms
不信你可以给setDuration设置一个10000它最长只显示3s,网上有各种延长Toast的方法,基本上都是通过定时器来延长显示的。
那么我们接下来就要思考一个问题了,我们为什么要延迟Toast的时间?为什么不用Dialog或者PopupWindow来替代?
其实原因很简单,Toast显示是不获取焦点的,所以Toast一般是用来提示用户的,而不影响用户的操作。我们可以用一个很简单的例子证明一下:
findViewById(R.id.test_toast_button).setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View view, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
//showToast();
showDialog();
Log.d("shuihan", "----down----");
break;
case MotionEvent.ACTION_MOVE:
Log.d("shuihan", "----move----");
break;
case MotionEvent.ACTION_UP:
Log.d("shuihan", "----up----");
break;
case MotionEvent.ACTION_CANCEL:
Log.d("shuihan", "----cancel----");
break;
default:
break;
}
return true;
}
});
我们分别去在ACTION_DOWN的时候去显示一下toast和dialog你再对照输出日志看一下,就会明白。
我们在微信里面录音的时候会有一个Toast大家应该都见过,如下:
这个Toast的一个很重要的特点就是只要你按着不放它就不消失,也就是说它的显示时间可以长于3s
四、实现显示时间长于3s的Toast
(本文出自水寒的CSDN博客:http://blog.csdn.net/dawanganban)
我们采用的方式也是使用定时器来实现重复显示一个toast从而延长它的时间,我们先来看一个androd里面的CountDownTimer的用法
new CountDownTimer(30000, 1000) {
public void onTick(long millisUntilFinished) {
mTextField.setText("seconds remaining: " + millisUntilFinished / 1000);
}
public void onFinish() {
mTextField.setText("done!");
}
}.start();
这是官方文档上的一个例子,一个30s的倒计时,每隔1s调用一次onTick方法,该方法返回一个倒计时剩余时间,ok,接下来我们来看看toast怎么让他显示30s
/**
* 显示Toast
* @param toast
* @param duration
*/
public static void showToast(final Toast toast, long duration, final OnToastStatus toastStatu) {
final long tickTime = 200;
mCountDownTimer = new CountDownTimer(duration, tickTime) {
@Override
public void onTick(long millisUntilFinished) {
if(millisUntilFinished <= 200){
showToast("最长可录制一分钟");
}else{
toast.show();
}
}
@Override
public void onFinish() {
toast.cancel();
if(toastStatu != null){
toastStatu.toastStop();
}
}
}.start();
}
public interface OnToastStatus{
public void toastStop();
}
/**
* 停止显示Toast
*/
public static void stopToast(Toast toast){
if(toast != null){
toast.cancel();
}
if(mCountDownTimer != null){
mCountDownTimer.cancel();
}
}
Android自定义组件系列【17】——教你如何高仿微信录音Toast的更多相关文章
- Android自定义组件系列【7】——进阶实践(4)
上一篇<Android自定义组件系列[6]--进阶实践(3)>中补充了关于Android中事件分发的过程知识,这一篇我们接着来分析任老师的<可下拉的PinnedHeaderExpan ...
- Android自定义组件系列【6】——进阶实践(3)
上一篇<Android自定义组件系列[5]--进阶实践(2)>继续对任老师的<可下拉的PinnedHeaderExpandableListView的实现>进行了分析,这一篇计划 ...
- Android自定义组件系列【5】——进阶实践(2)
上一篇<Android自定义组件系列[5]--进阶实践(1)>中对任老师的<可下拉的PinnedHeaderExpandableListView的实现>前一部分进行了实现,这一 ...
- Android自定义组件系列【4】——自定义ViewGroup实现双侧滑动
在上一篇文章<Android自定义组件系列[3]--自定义ViewGroup实现侧滑>中实现了仿Facebook和人人网的侧滑效果,这一篇我们将接着上一篇来实现双面滑动的效果. 1.布局示 ...
- Android自定义组件系列【3】——自定义ViewGroup实现侧滑
有关自定义ViewGroup的文章已经很多了,我为什么写这篇文章,对于初学者或者对自定义组件比较生疏的朋友虽然可以拿来主义的用了,但是要一步一步的实现和了解其中的过程和原理才能真真脱离别人的代码,举一 ...
- Android自定义组件系列【8】——遮罩文字动画
遮罩文字的动画我们在Flash中非常常见,作为Android的应用开发者你是否也想将这种动画做到你的应用中去呢?这一篇文章我们来看看如何自定义一个ImageView来实现让一张文字图片实现文字的遮罩闪 ...
- Android自定义组件系列【12】——非UI线程绘图SurfaceView
一.SurfaceView的介绍 在前面我们已经会自定义View,使用canvas绘图,但是View的绘图机制存在一些缺陷. 1.View缺乏双缓冲机制. 2.程序必须重绘整个View上显示的图片,比 ...
- Android自定义组件系列【1】——自定义View及ViewGroup
View类是ViewGroup的父类,ViewGroup具有View的所有特性,ViewGroup主要用来充当View的容器,将其中的View作为自己孩子,并对其进行管理,当然孩子也可以是ViewGr ...
- Android自定义组件系列【15】——四个方向滑动的菜单实现
今天无意中实现了一个四个方向滑动的菜单,感觉挺好玩,滑动起来很顺手,既然已经做出来了就贴出来让大家也玩弄一下. 一.效果演示 (说明:目前没有安装Android模拟器,制作的动态图片太卡了,就贴一下静 ...
随机推荐
- JavaScript高级程序设计学习笔记第五章--引用类型
一.object类型 1.创建object类型的两种方式: 第一种,使用构造函数 var person = new Object();或者是var person={};/与new Object()等价 ...
- [poj1986]Distance Queries(LCA)
解题关键:LCA模板题 复杂度:$O(n\log n)$ #pragma comment(linker, "/STACK:1024000000,1024000000") #incl ...
- js中match的用法
match() 方法将检索字符串 stringObject,以找到一个或多个与 regexp 匹配的文本.这个方法的行为在很大程度上有赖于 regexp 是否具有标志 g. 一.如果 regexp 没 ...
- SQL Server中的聚集索引(clustered index) 和 非聚集索引 (non-clustered index)
本文转载自 http://blog.csdn.net/ak913/article/details/8026743 面试时经常问到的问题: 1. 什么是聚合索引(clustered index) / ...
- php array数组(第二部分)
array_fill() 用给定的键值填充数组 参数 index 必须.规定返回数组的起始索引. 参数 number 必须.规定填充的元素的数量,其值必须大于0. 参数 value 必须.规定用于填充 ...
- SetCapture到底是什么?
函数功能:该函数在属于当前线程的指定窗口里设置鼠标捕获.一旦窗口捕获了鼠标,所有鼠标输入都针对该窗口,无论光标是否在窗口的边界内.同一时刻只能有一个窗口捕获鼠标.如果鼠标光标在另一个线程创建的窗口上, ...
- 51nod1065(set.upper_bound()/sort)
题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1065 题意:中文题诶- 思路: 解法1:set容器,将所有前 ...
- poj 2769 感觉♂良好 (单调栈)
poj 2769 感觉♂良好 (单调栈) 比尔正在研发一种关于人类情感的新数学理论.他最近致力于研究一个日子的好坏,如何影响人们对某个时期的回忆. 比尔为人的一天赋予了一个正整数值. 比尔称这个值为当 ...
- 判断当前浏览器是否是IE浏览器
今天修改后台人员遗留的兼容性问题时,遇到了有些样式只是在IE浏览器下面不正常,为了让自己记住,所以把代码贴一下 ## 代码 ##if (!!window.ActiveXObject || " ...
- HTML <!doctype>声明
昨天看代码的时候,发现在<!doctype>中添加了新的属性,以前写代码的时候并不会在该声明里添加新的属性.昨天看到了,就把它记下来学习一下,顺便整理成文档.以便日后复习. <!DO ...