欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android中使用Toast.cancel()方法優(yōu)化toast內(nèi)容顯示的解決方法

 更新時(shí)間:2013年05月10日 08:56:26   作者:  
做程序員的,基本一看api就知道,用這個(gè)可以取消上一個(gè)toast的顯示,然后顯示下一個(gè),這樣就能解決出現(xiàn)的問題。可是在測(cè)試的過(guò)程中,發(fā)現(xiàn)卻沒有想象中的那么簡(jiǎn)單,不信可以百度一下,很多很多人發(fā)現(xiàn)toast的cancel()方法不起作用

產(chǎn)品在測(cè)試過(guò)程中發(fā)現(xiàn)一個(gè)bug,就是測(cè)試人員不停的瘋狂的點(diǎn)擊某個(gè)按鈕,觸發(fā)了toast以后,toast內(nèi)容會(huì)一直排著隊(duì)的顯示出來(lái),不能很快的消失。這樣可能會(huì)影響用戶的使用。

看到Toast有一個(gè)cancel()方法:

復(fù)制代碼 代碼如下:

void cancel()
Close the view if it's showing, or don't show it if it isn't showing yet.

做程序員的,基本一看api就知道,用這個(gè)可以取消上一個(gè)toast的顯示,然后顯示下一個(gè),這樣就能解決出現(xiàn)的問題??墒窃跍y(cè)試的過(guò)程中,發(fā)現(xiàn)卻沒有想象中的那么簡(jiǎn)單,不信可以百度一下,很多很多人發(fā)現(xiàn)toast的cancel()方法不起作用。還是不講具體過(guò)程,只講結(jié)果吧。

我把toast做成了一個(gè)應(yīng)用類,方便使用,大家可以直接用:

復(fù)制代碼 代碼如下:

package com.arui.framework.android.util; 

import android.content.Context; 
import android.os.Handler; 
import android.os.Looper; 
import android.widget.Toast; 

復(fù)制代碼 代碼如下:

/**   
 * Toast util class.   
 *    
 * @author <A >http://jb51.net</A>   
 * @version 2011/11/30   
 *    
 */  
public class ToastUtil { 

    private static Handler handler = new Handler(Looper.getMainLooper()); 

    private static Toast toast = null; 

    private static Object synObj = new Object(); 

    public static void showMessage(final Context act, final String msg) { 
        showMessage(act, msg, Toast.LENGTH_SHORT); 
    } 

    public static void showMessage(final Context act, final int msg) { 
        showMessage(act, msg, Toast.LENGTH_SHORT); 
    } 

    public static void showMessage(final Context act, final String msg, 
            final int len) { 
        new Thread(new Runnable() { 
            public void run() { 
                handler.post(new Runnable() { 
                    @Override 
                    public void run() { 
                        synchronized (synObj) { 
                            if (toast != null) { 
                                toast.cancel(); 
                                toast.setText(msg); 
                                toast.setDuration(len); 
                            } else { 
                                toast = Toast.makeText(act, msg, len); 
                            } 
                            toast.show(); 
                        } 
                    } 
                }); 
            } 
        }).start(); 
    } 

 
    public static void showMessage(final Context act, final int msg, 
            final int len) { 
        new Thread(new Runnable() { 
            public void run() { 
                handler.post(new Runnable() { 
                    @Override 
                    public void run() { 
                        synchronized (synObj) { 
                            if (toast != null) { 
                                toast.cancel(); 
                                toast.setText(msg); 
                                toast.setDuration(len); 
                            } else { 
                                toast = Toast.makeText(act, msg, len); 
                            } 
                            toast.show(); 
                        } 
                    } 
                }); 
            } 
        }).start(); 
    } 



代碼的邏輯很簡(jiǎn)單。這里加了同步,這樣做可以確保每一個(gè)toast的內(nèi)容至少可以顯示出來(lái),而不是還沒顯示就取消掉了。這樣做,是因?yàn)閠oast的內(nèi)容不一定完全相同,如果沒顯示出來(lái),也會(huì)有問題。

相關(guān)文章

最新評(píng)論