效果图看我的原文
Android提醒控件,Dialog、Toast和Snakebar
上面这个Dialog是Material Design风格的,因为是在6.0系统上运行的,会自动赋予这样的风格。但是如果在老版本系统上运行,比如说2.3系统,会是什么样的效果?运行一下就知道了,效果如下图所示:
效果图看我的原文
Android提醒控件,Dialog、Toast和Snakebar
- android.support.v7.app.AlertDialog
慎用Dialog Dialog的作用是给用户一个提示信息,并让用户根据提示做出判断。而Dialog的特征就是,它会阻止你原本正在进行的操作,必须停止下来对Dialog进行处理。但是,大多数的人可能并不喜欢这样被打断,也许用户正在处理一项重要的操作,突然弹出一个Dialog遮挡住了他原本的操作,这时候用户就可能会对此感到很恼火。因此,一定要慎用Dialog。这时候我们就要思考如何弹出提示信息并且不干扰用户正在进行的操作你? --------------------------------------------------------------------------- 什么是Toast,Toast的实例
什么是Toast 说到不会阻挡用户原本正在进行的操作,就延伸到我们今天的第二个主题,Toast。Toast只会弹出一段信息,告诉用户某某事情已经发生了,过一段时间后就会自动消失。它完全不会阻挡用户的任何操作,甚至用户也可以完全不用理会Toast。 Toast的实例 Toast的基本用法 ``` Toast.makeText(context, "things happened", Toast.LENGTH_SHORT).show(); ``` 最后一个参数用于指定Toast显示的时长,Toast.LENGTH_SHORT表示显示时间较短,Toast.LENGTH_LONG表示显示时间较长。 Toast的缺点和改进 如果快速连续点击了五次Toast按钮,Toast也就触发了五次。这样的体验其实是不好的,因为也许用户是手抖了一下多点了几次,导致Toast就长时间关闭不掉了。又或者我们其实已在进行其他操作了,应该弹出新的Toast提示,而上一个Toast却还没显示结束。 因此,最佳的做法是将Toast的调用封装成一个接口,写在一个公共的类当中,如下所示: ``` public class Util { private static Toast toast; public static void showToast(Context context, String content) { if (toast == null) { toast = Toast.makeText(context, content, Toast.LENGTH_SHORT); } else { toast.setText(content); } toast.show(); } } ``` 这里和我们平时使用Toast的方式并不一样,这里会先判断Toast对象是否为空,如果是空的情况下才会调用makeText()方法来去生成一个Toast对象,否则就直接调用setText()方法来设置显示的内容,最后再调用show()方法将Toast显示出来。由于不会每次调用的时候都生成新的Toast对象,因此刚才我们遇到的问题在这里就不会出现了。 调用的时候也很简单,只需要把Context对象和Toast要显示的内容传进来就可以了: ``` Util.showToast(context, "things happened"); ``` 现在不管我们触发多少次Toast调用,都只会持续一次Toast显示的时长了。 慎用Toast Toast的作用是告诉用户现在发生了什么事情,不会阻挡用户的操作,但同时用户只能被动接收这个事情,因为没有什么办法来让用户是选择同意还是拒绝。 虽说Toast在用户体验方面要比Dialog好一些,但是也要慎用,尤其是涉及到一些敏感操作的时候。比如说删除数据,只给用户一个提示:“你的数据已被删除”,而不给用户选择是否要删除的机会,这时候用户可能就要暴走了。 ---------------------------------------------------------------------------
什么是Snakebar,Snakebar和Toast的区别
什么是Snakebar Snackbar是Android Support Design Library库支持的一个控件,具体的使用配置可以查看:Android Support Design Library配置指南,这篇文章说明了配置过程,以及可能遇到的问题,主要是跟NavigationLibrary开源库的冲突问题。 Snackbar使用的时候需要一个控件容器用来容纳Snackbar.官方推荐使用CoordinatorLayout这个另一个Android Support Design Library库支持的控件容纳。因为使用这个控件,可以保证Snackbar可以让用户通过向右滑动退出。 Snakebar和Toast的区别 Snackbar 是一种针对操作的轻量级反馈机制,常以一个小的弹出框的形式,出现在手机屏幕下方或者桌面左下方。它们出现在屏幕所有层的最上方,包括浮动操作按钮。 它们会在超时或者用户在屏幕其他地方触摸之后自动消失。Snackbar 可以在屏幕上滑动关闭。当它们主要用于提示系统消息的胶囊状的提示框 Toast。Toast 同 Snackbar 非常相似,但是 Toast 并不包含操作也不能从屏幕上滑动关闭。
- 当它显示一段时间后或用户与屏幕交互时它会自动消失。
- 可以自定义action-可选操作。 swiping it off the
- screen可以让FAB消失
- 它是context sensitive message(自己理解吧),所以这些消息是UIscreen的一部分并且它是显示在所有屏幕其它元素之上(屏幕最顶层),并不是像Toast一样覆盖在屏幕上。
- 同一时间只能显示一个snackbar。
- make() – 生成Snackbar消息
- setAction() – 设置action
- make() – 显示Snackbar消息
- make()方法的第一个参数是一个view, snackbar会试着寻找一个父view来hold这个view. Snackbar将遍历整个view tree 来寻找一个合适的父view,它可能是一个coordinatorLayout也可能是window decor’s content view,随便哪一个都行。
- 正如上面所提到,duration参数和Toast中的duration参数类似,只能是LENGTH_SHORT 或
- LENGTH_LONG,不能是其它任何随机数。
---------------------------------------------------------------------------
总结
总结
- Dialog:当提示信息是至关重要的,并且必须要由用户做出决定才能继续的时候,使用Dialog。
- Toast:当提示信息只是告知用户某个事情发生了,用户不需要对这个事情做出响应的时候,使用Toast。
- Snackbar:以上两者之外的任何其他场景,Snackbar可能会是你最好的选择。
没有评论:
发表评论