终于学习完Adapter类相关的控件,当然除了讲解的那几个,还有其他很多的相关的控件,就不慢慢讲解了~有要的自行查阅文档,查看相关的用法,本节带来的是Android用于提示信息的个控件——Toast(吐司)!Toast是一种很方便的消息提示框,会在屏幕中显示个消息提示框,没任何按钮,也不会获得焦点一段时间过后自动消失!非常常用!本节就来学习Toast的使用!
1.直接调用Toast类的makeText()方法创建
这是用的最多的一种形式了!比如点个按钮,然后弹出Toast,用法 Toast.makeText(MainActivity.this, "提示的内容", Toast.LENGTH_LONG).show();第个是上下文对象!对二个是显示的内容!第三个是显示的时间,只有LONG和SHORT两种会生效,即时 定义了其他的值,最后调用的还是这两个!
另外Toast是非常常用的,可以把这些公共的部分抽取出来,写到个方法里!要显示Toast的时候直接调用这个方法就可以显示Toast,这样方便很多!示例如下
>void midToast(String str, int showTime) { Toast toast = Toast.makeText(global_context, str, showTime); toast.setGravity(Gravity.CENTER_VERTICAL|Gravity.CENTER_HORIZONTAL , 0, 0); //设置显示位置 TextView v = (TextView) toast.getView().findViewById(android.R.id.message); v.setTextColor(Color.YELLOW); //设置字体颜色 toast.show(); }
上面这个抽取出来的方法,发现可以调用setGravity设置Toast显示的位置以及获得通过findViewById(android.R.id.message)获得显示的文本,然后进行设置颜色,或者大小等!这就是第二种通过构造方法来定制Toast!
2.通过构造方法来定制Toast
上面定制了文本,以及显示位置,下面写两个简单的例子
1.定义个带有图片的Toast
效果图
关键代码
private void midToast(String str, int showTime) { Toast toast = Toast.makeText(mContext, str, showTime); toast.setGravity(Gravity.CENTER_HORIZONTAL|Gravity.BOTTOM , 0, 0); //设置显示位置 LinearLayout layout = (LinearLayout) toast.getView(); layout.setBackgroundColor(Color.BLUE); ImageView image = new ImageView(this); image.setImageResource(R.mipmap.ic_icon_qitao); layout.addView(image, 0); TextView v = (TextView) toast.getView().findViewById(android.R.id.message); v.setTextColor(Color.YELLOW); //设置字体颜色 toast.show(); }
2.Toast完全自定义
若上面的那种还满足不了 的话,那么 完全可以自己写个Toast的布局,然后显示出来;但是时间依旧控制不了!
运行效果图
关键代码
private void midToast(String str, int showTime) { LayoutInflater inflater = getLayoutInflater(); View view = inflater.inflate(R.layout.view_toast_custom, (ViewGroup) findViewById(R.id.lly_toast)); ImageView img_logo = (ImageView) view.findViewById(R.id.img_logo); TextView tv_msg = (TextView) view.findViewById(R.id.tv_msg); tv_msg.setText(str); Toast toast = new Toast(mContext); toast.setGravity(Gravity.CENTER, 0, 0); toast.setDuration(Toast.LENGTH_LONG); toast.setView(view); toast.show(); }
还有自定义Toast的布局以及圆角背景
圆角背景bg_toast.xml
<?xml version="1.0" encoding="UTF-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android"> <!-- 设置透明背景色 --> <solid android:color="#BADB66" /> <!-- 设置个黑色边框 --> <stroke android:width="1px" android:color="#FFFFFF" /> <!-- 设置四个圆角的半径 --> <corners android:bottomLeftRadius="50px" android:bottomRightRadius="50px" android:topLeftRadius="50px" android:topRightRadius="50px" /> <!-- 设置一下边距,让空间大一点 --> <padding android:bottom="5dp" android:left="5dp" android:right="5dp" android:top="5dp" /> </shape>
布局文件view_toast_custom.xml
<?xml version="1.0" encoding="UTF-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/lly_toast" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@drawable/bg_toast" android:orientation="horizontal"> <ImageView android:id="@+id/img_logo" android:layout_width="24dp" android:layout_height="24dp" android:layout_marginLeft="10dp" android:src="@mipmap/iv_lol_icon1" /> <TextView android:id="@+id/tv_msg" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginLeft="10dp" android:textSize="20sp" /> </LinearLayout>
嘿嘿~
3.示例代码下载
本节小结
讲解了Toast的基本使用,以及如何自定义Toast, 可以在实际开发中对自己的Toast进行定制~
尊贵的董事大人
英文标题不为空时 视为本栏投稿
需要关键字 描述 英文标题