Toast是一种简易的消息提示框,它无法获取焦点,按设置的时间来显示完以后会自动消失。一般用于帮助或提示。
当触发点击事件显示toast信息时,如果设置了时间长短类型为LENGTH_LONG,虽然回到后台运行,但是依然会显示toast信息,尤其是当连续点击时,toast就会排队等待直到所有toast显示完毕,这种界面的用户体验是很差的。
→ | 1 toast | 2 toast | 3 toast | 4 toast | 5 toast | → |
为了避免这种问题,可以在toast信息显示的地方加个判断,方法如下:
private Context mcontext; private Toast mtoast; if(mtoast!=null) { mtoast.setText(R.string.neterror); } else { /* * 第一个参数:当前的上下文环境,用this或getApplicationContext()表示。 * 第二个参数:显示的字符串,用R.string表示。 * 第三个参数:显示的时间长短。用LENGTH_LONG(长)或LENGTH_SHORT(短)表示,也可以用毫秒。 */ mtoast=Toast.makeText(mcontext,R.string.neterror, Toast.LENGTH_SHORT);
}
mtoast.show(); //显示toast信息
另外,还可以通过设置Toast的其他属性来设计自己风格的Toast消息框。