Android中用Toast.cancel()方法优化toast内容的显示

产品在测试过程中发现一个bug,就是测试人员不停的疯狂的点击某个按钮,触发了toast以后,toast内容会一直排着队的显示出来,不能很快的消失。这样可能会影响用户的使用。

看到Toast有一个cancel()方法:

voidcancel()

Closetheviewifit'sshowing,ordon'tshowitifitisn'tshowingyet.

做程序员的,基本一看api就知道,用这个可以取消上一个toast的显示,然后显示下一个,这样就能解决出现的问题。可是在测试的过程中,发现却没有想象中的那么简单,不信可以百度一下,很多很多人发现toast的cancel()方法不起作用。还是不讲具体过程,只讲结果吧。

我把toast做成了一个应用类,方便使用,大家可以直接用:

packagecom.arui.framework.android.util;

importandroid.content.Context;

importandroid.os.Handler;

importandroid.os.Looper;

importandroid.widget.Toast;

/**

*Toastutilclass.

*

*@author<ahref="http://blog.csdn.net/arui319">http://blog.csdn.net/arui319</a>

*@version2011/11/30

*

*/

publicclassToastUtil{

privatestaticHandlerhandler=newHandler(Looper.getMainLooper());

privatestaticToasttoast=null;

privatestaticObjectsynObj=newObject();

publicstaticvoidshowMessage(finalContextact,finalStringmsg){

showMessage(act,msg,Toast.LENGTH_SHORT);

}

publicstaticvoidshowMessage(finalContextact,finalintmsg){

showMessage(act,msg,Toast.LENGTH_SHORT);

}

publicstaticvoidshowMessage(finalContextact,finalStringmsg,

finalintlen){

newThread(newRunnable(){

publicvoidrun(){

handler.post(newRunnable(){

@Override

publicvoidrun(){

synchronized(synObj){

if(toast!=null){

toast.cancel();

toast.setText(msg);

toast.setDuration(len);

}else{

toast=Toast.makeText(act,msg,len);

}

toast.show();

}

}

});

}

}).start();

}

publicstaticvoidshowMessage(finalContextact,finalintmsg,

finalintlen){

newThread(newRunnable(){

publicvoidrun(){

handler.post(newRunnable(){

@Override

publicvoidrun(){

synchronized(synObj){

if(toast!=null){

toast.cancel();

toast.setText(msg);

toast.setDuration(len);

}else{

toast=Toast.makeText(act,msg,len);

}

toast.show();

}

}

});

}

}).start();

}

}

代码的逻辑很简单。这里加了同步,这样做可以确保每一个toast的内容至少可以显示出来,而不是还没显示就取消掉了。这样做,是因为toast的内容不一定完全相同,如果没显示出来,也会有问题。

相关推荐