超簡(jiǎn)單實(shí)現(xiàn)Android自定義Toast示例(附源碼)
Bamboy的自定義Toast,(以下稱作“BToast”)
特點(diǎn)在于使用簡(jiǎn)單, 并且自帶兩種樣式:
1)普通的文字樣式;
2)帶圖標(biāo)樣式。
其中圖標(biāo)有√和×兩種圖標(biāo)。
BToast還有另外一個(gè)特點(diǎn)就是:
系統(tǒng)自帶Toast采用的是隊(duì)列的方式,當(dāng)前Toast消失后,下一個(gè)Toast才能顯示出來;
而BToast會(huì)把當(dāng)前Toast頂?shù)簦?直接顯示最新的Toast。
那么,簡(jiǎn)單三步,我們現(xiàn)在就開始自定義一下吧!
(一)、Layout:
要自定義Toast,
首先我們需要一個(gè)XML布局。
但是在布局之前我們需要三個(gè)資源文件,分別是背景、√和×。
背景可以用XML畫出來:
toast_back.xml
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" > <corners android:radius="12dp" /> <solid android:color="#CC000000"/> </shape>
√和×就最好用圖片啦,源碼里面有這兩張圖片,這里就不貼出來了。
現(xiàn)在就可以寫布局了:
toast_layout.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/toast_back" android:gravity="center_vertical" android:padding="13dp" android:orientation="vertical" > <ImageView android:id="@+id/toast_img" android:layout_width="50dp" android:layout_height="50dp" android:background="@drawable/toast_y" android:layout_gravity="center_horizontal" android:layout_marginBottom="5dp" /> <TextView android:id="@+id/toast_text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginLeft="10dp" android:layout_marginRight="10dp" android:textColor="#FFFFFF" android:gravity="center" android:textSize="17sp" /> </LinearLayout>
所需要的XML現(xiàn)在已經(jīng)OK, 剩下的就是Java部分了。
(二)、Java:
寫一個(gè)BToast類,繼承Toast、成員變量自身單例、還有構(gòu)造函數(shù):
public class BToast extends Toast { /** * Toast單例 */ private static BToast toast; /** * 構(gòu)造 * * @param context */ public BToast(Context context) { super(context); } }
為了實(shí)現(xiàn)可以吧當(dāng)前Toast頂下去的需求,我們需要重寫幾個(gè)方法
/** * 隱藏當(dāng)前Toast */ public static void cancelToast() { if (toast != null) { toast.cancel(); } } public void cancel() { try { super.cancel(); } catch (Exception e) { } } @Override public void show() { try { super.show(); } catch (Exception e) { } }
現(xiàn)在我們就可以寫我們的邏輯了,首先當(dāng)然是引入我們的布局咯:
/** * 初始化Toast * * @param context 上下文 * @param text 顯示的文本 */ private static void initToast(Context context, CharSequence text) { try { cancelToast(); toast = new BToast(context); // 獲取LayoutInflater對(duì)象 LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); // 由layout文件創(chuàng)建一個(gè)View對(duì)象 View layout = inflater.inflate(R.layout.toast_layout, null); // 吐司上的圖片 toast_img = (ImageView) layout.findViewById(R.id.toast_img); // 吐司上的文字 TextView toast_text = (TextView) layout.findViewById(R.id.toast_text); toast_text.setText(text); toast.setView(layout); toast.setGravity(Gravity.CENTER, 0, 70); } catch (Exception e) { e.printStackTrace(); } }
一切準(zhǔn)備工作都已就緒,接下來就是顯示Toast的方法了:
/** * 圖標(biāo)狀態(tài) 不顯示圖標(biāo) */ private static final int TYPE_HIDE = -1; /** * 圖標(biāo)狀態(tài) 顯示√ */ private static final int TYPE_TRUE = 0; /** * 圖標(biāo)狀態(tài) 顯示× */ private static final int TYPE_FALSE = 1; /** * 顯示Toast * * @param context 上下文 * @param text 顯示的文本 * @param time 顯示時(shí)長(zhǎng) * @param imgType 圖標(biāo)狀態(tài) */ private static void showToast(Context context, CharSequence text, int time, int imgType) { // 初始化一個(gè)新的Toast對(duì)象 initToast(context, text); // 設(shè)置顯示時(shí)長(zhǎng) if (time == Toast.LENGTH_LONG) { toast.setDuration(Toast.LENGTH_LONG); } else { toast.setDuration(Toast.LENGTH_SHORT); } // 判斷圖標(biāo)是否該顯示,顯示√還是× if (imgType == TYPE_HIDE) { toast_img.setVisibility(View.GONE); } else { if (imgType == TYPE_TRUE) { toast_img.setBackgroundResource(R.drawable.toast_y); } else { toast_img.setBackgroundResource(R.drawable.toast_n); } toast_img.setVisibility(View.VISIBLE); // 動(dòng)畫 ObjectAnimator.ofFloat(toast_img, "rotationY", 0, 360).setDuration(1700).start(); } // 顯示Toast toast.show(); }
就是這么簡(jiǎn)單。
細(xì)心的朋友可能發(fā)現(xiàn)了,這個(gè)方法是private的,先別產(chǎn)生疑慮,聽我慢慢道來。
寫到這里, 其實(shí)你可以直接把這個(gè)方法改成Public, 這樣的話現(xiàn)在就已經(jīng)大功告成了, 但是這樣的話與原生Toast使用起來有什么區(qū)別?
還是需要寫那么長(zhǎng)一串參數(shù),唯一的好處就是不用寫.show()了。
咱們現(xiàn)在做的事情叫“自定義”, “自定義”的意思就是我們自己定義規(guī)則, 既然如此, 我們何不提升一下“用戶體驗(yàn)”呢?
何況這個(gè)“用戶”還是我們自己。
廢話不多說, 我們開始進(jìn)行最后一步。
(三)、升華:
/** * 顯示一個(gè)純文本吐司 * * @param context 上下文 * @param text 顯示的文本 */ public static void showText(Context context, CharSequence text) { showToast(context, text, Toast.LENGTH_SHORT, TYPE_HIDE); } /** * 顯示一個(gè)帶圖標(biāo)的吐司 * * @param context 上下文 * @param text 顯示的文本 * @param isSucceed 顯示【對(duì)號(hào)圖標(biāo)】還是【叉號(hào)圖標(biāo)】 */ public static void showText(Context context, CharSequence text, boolean isSucceed) { showToast(context, text, Toast.LENGTH_SHORT, isSucceed ? TYPE_TRUE : TYPE_FALSE); } /** * 顯示一個(gè)純文本吐司 * * @param context 上下文 * @param text 顯示的文本 * @param time 持續(xù)的時(shí)間 */ public static void showText(Context context, CharSequence text, int time) { showToast(context, text, time, TYPE_HIDE); } /** * 顯示一個(gè)帶圖標(biāo)的吐司 * * @param context 上下文 * @param text 顯示的文本 * @param time 持續(xù)的時(shí)間 * @param isSucceed 顯示【對(duì)號(hào)圖標(biāo)】還是【叉號(hào)圖標(biāo)】 */ public static void showText(Context context, CharSequence text, int time, boolean isSucceed) { showToast(context, text, time, isSucceed ? TYPE_TRUE : TYPE_FALSE); }
簡(jiǎn)簡(jiǎn)單單幾個(gè)方法,用戶體驗(yàn)瞬間直線飆升,來看一下使用的時(shí)候:
public void click(View view) { switch (view.getId()) { case R.id.btn_text: BToast.showText(this, "簡(jiǎn)單提示"); break; case R.id.btn_text_true: BToast.showText(this, "簡(jiǎn)單提示 正確圖標(biāo)", true); break; case R.id.btn_text_false: BToast.showText(this, "簡(jiǎn)單提示 錯(cuò)誤圖標(biāo)", false); break; case R.id.btn_text_long: BToast.showText(this, "簡(jiǎn)單提示 長(zhǎng)~ ", Toast.LENGTH_LONG); break; case R.id.btn_text_true_long: BToast.showText(this, "簡(jiǎn)單提示 正確圖標(biāo) 長(zhǎng)~ ", Toast.LENGTH_LONG, true); break; case R.id.btn_text_false_long: BToast.showText(this, "簡(jiǎn)單提示 錯(cuò)誤圖標(biāo) 長(zhǎng)~ ", Toast.LENGTH_LONG, false); break; } }
是不是比原生的Toast好用多了?
功德圓滿!
趕緊看一下我們的成果:
BamboyToast效果圖
源碼地址:BamboyToast_jb51.rar
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android Toast的用法總結(jié)(五種用法)
- Android使用Toast顯示消息提示框
- Android中使用Toast.cancel()方法優(yōu)化toast內(nèi)容顯示的解決方法
- Android控件系列之Toast使用介紹
- android之自定義Toast使用方法
- Android 5.0以上Toast不顯示的解決方法
- Android開發(fā)技巧之永不關(guān)閉的Toast信息框(長(zhǎng)時(shí)間顯示而非系統(tǒng)關(guān)閉)
- android自定義Toast設(shè)定顯示時(shí)間
- 如何解決android Toast重復(fù)顯示
- Android9.0上針對(duì)Toast的特殊處理圖文詳解
相關(guān)文章
Android 百度地圖marker中圖片不顯示的解決方法(推薦)
下面小編就為大家分享一篇Android 百度地圖marker中圖片不顯示的解決方法(推薦),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-01-01Android開發(fā)筆記之:一分鐘學(xué)會(huì)使用Logcat調(diào)試程序的詳解
本篇文章是對(duì)Android中Logcat調(diào)試程序的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05android-wheel控件實(shí)現(xiàn)三級(jí)聯(lián)動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了android-wheel控件實(shí)現(xiàn)三級(jí)聯(lián)動(dòng)效果的代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10Android中基于XMPP協(xié)議實(shí)現(xiàn)IM聊天程序與多人聊天室
這篇文章主要介紹了Android中基于XMPP協(xié)議實(shí)現(xiàn)IM聊天程序與多人聊天室的方法,XMPP基于XML數(shù)據(jù)格式傳輸,一般用于即時(shí)消息(IM)以及在線現(xiàn)場(chǎng)探測(cè),需要的朋友可以參考下2016-02-02Android程序報(bào)錯(cuò)程序包org.apache.http不存在問題的解決方法
這篇文章主要介紹了Android程序報(bào)錯(cuò)"程序包org.apache.http不存在——Android 6.0已經(jīng)不支持HttpClient" 問題的解決方法,感興趣的小伙伴們可以參考一下2016-06-06React Native中Android物理back鍵按兩次返回鍵即退出應(yīng)用
這篇文章主要給大家介紹了關(guān)于React Native中Android物理back鍵按兩次返回鍵即退出應(yīng)用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10Android自定義DataTimePicker實(shí)例代碼(日期選擇器)
本篇文章主要介紹了Android自定義DataTimePicker實(shí)例代碼(日期選擇器),非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-01-01Android開發(fā)人臉識(shí)別統(tǒng)計(jì)人臉數(shù)
這篇文章主要介紹了Android開發(fā)人臉識(shí)別統(tǒng)計(jì)人臉數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10