android 自定义 对号,超简单实现Android自定义Toast
原標題:超簡單實現Android自定義Toast
Bamboy的自定義Toast,(以下稱作“BToast”)
特點在于使用簡單,
并且自帶兩種樣式:
1)普通的文字樣式;
2)帶圖標樣式。
其中圖標有√和×兩種圖標。
BToast還有另外一個特點就是:
系統自帶Toast采用的是隊列的方式,
等當前Toast消失后,
下一個Toast才能顯示出來;
而BToast會把當前Toast頂掉,
直接顯示最新的Toast。
看效果先:
簡單三步,
我們現在就開始自定義一下吧!
(一)、Layout:
要自定義Toast,
首先我們需要一個XML布局。
但是在布局之前我們需要三個資源文件,
分別是背景、√和×。
背景可以用XML畫出來:
toast_back.xml
√和×就最好用圖片啦,
源碼里面有這兩張圖片,
這里就不貼出來了。
現在就可以寫布局了:
toast_layout.xml
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">
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"/>
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"/>
所需要的XML現在已經OK,
剩下的就是Java部分了。
(二)、Java:
寫一個BToast類,繼承Toast、
成員變量自身單例、
還有構造函數:
publicclassBToastextendsToast{
/**
* Toast單例
*/
privatestaticBToast toast;
/**
* 構造
*
* @paramcontext
*/
publicBToast(Context context){
super(context);
}
}
為了實現可以吧當前Toast頂下去的需求,
我們需要重寫幾個方法
/**
* 隱藏當前Toast
*/
publicstaticvoidcancelToast{
if(toast != null) {
toast.cancel;
}
}
publicvoidcancel{
try{
super.cancel;
} catch(Exception e) {
}
}
@Override
publicvoidshow{
try{
super.show;
} catch(Exception e) {
}
}
現在我們就可以寫我們的邏輯了,
首先當然是引入我們的布局咯:
/**
* 初始化Toast
*
* @paramcontext 上下文
* @paramtext 顯示的文本
*/
privatestaticvoidinitToast(Context context, CharSequence text){
try{
cancelToast;
toast = newBToast(context);
// 獲取LayoutInflater對象
LayoutInflater inflater =
(LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
// 由layout文件創建一個View對象
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;
}
}
一切準備工作都已就緒,
接下來就是顯示Toast的方法了:
/**
* 圖標狀態 不顯示圖標
*/
privatestaticfinalintTYPE_HIDE = - 1;
/**
* 圖標狀態 顯示√
*/
privatestaticfinalintTYPE_TRUE = 0;
/**
* 圖標狀態 顯示×
*/
privatestaticfinalintTYPE_FALSE = 1;
/**
* 顯示Toast
*
* @paramcontext 上下文
* @paramtext 顯示的文本
* @paramtime 顯示時長
* @paramimgType 圖標狀態
*/
privatestaticvoidshowToast(Context context, CharSequence text, inttime, intimgType){
// 初始化一個新的Toast對象
initToast(context, text);
// 設置顯示時長
if(time == Toast.LENGTH_LONG) {
toast.setDuration(Toast.LENGTH_LONG);
} else{
toast.setDuration(Toast.LENGTH_SHORT);
}
// 判斷圖標是否該顯示,顯示√還是×
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);
// 動畫
ObjectAnimator.ofFloat(toast_img, "rotationY", 0, 360).setDuration( 1700).start;
}
// 顯示Toast
toast.show;
}
就是這么簡單。
細心的朋友可能發現了,
這個方法是private的,
先別產生疑慮,
聽我慢慢道來。
寫到這里,
其實你可以直接把這個方法改成Public,
這樣的話現在就已經大功告成了,
但是這樣的話與原生Toast使用起來有什么區別?
還是需要寫那么長一串參數,
唯一的好處就是不用寫.show了。
咱們現在做的事情叫“自定義”,
既然如此,
我們何不提升一下“用戶體驗”呢?
我們開始進行最后一步。
/**
* 顯示一個純文本吐司
*
* @paramcontext 上下文
* @paramtext 顯示的文本
*/
publicstaticvoidshowText(Context context, CharSequence text){
showToast(context, text, Toast.LENGTH_SHORT, TYPE_HIDE);
}
/**
* 顯示一個帶圖標的吐司
*
* @paramcontext 上下文
* @paramtext 顯示的文本
* @paramisSucceed 顯示【對號圖標】還是【叉號圖標】
*/
publicstaticvoidshowText(Context context, CharSequence text, booleanisSucceed){
showToast(context, text, Toast.LENGTH_SHORT, isSucceed ? TYPE_TRUE : TYPE_FALSE);
}
/**
* 顯示一個純文本吐司
*
* @paramcontext 上下文
* @paramtext 顯示的文本
* @paramtime 持續的時間
*/
publicstaticvoidshowText(Context context, CharSequence text, inttime){
showToast(context, text, time, TYPE_HIDE);
}
/**
* 顯示一個帶圖標的吐司
*
* @paramcontext 上下文
* @paramtext 顯示的文本
* @paramtime 持續的時間
* @paramisSucceed 顯示【對號圖標】還是【叉號圖標】
*/
publicstaticvoidshowText(Context context, CharSequence text, inttime, booleanisSucceed){
showToast(context, text, time, isSucceed ? TYPE_TRUE : TYPE_FALSE);
}
publicvoid click(View view) {
switch (view.getId) {
case R.id.btn_text:
BToast.showText( this, "簡單提示");
break;
case R.id.btn_text_true:
BToast.showText( this, "簡單提示 正確圖標", true);
break;
case R.id.btn_text_false:
BToast.showText( this, "簡單提示 錯誤圖標", false);
break;
case R.id.btn_text_long:
BToast.showText( this, "簡單提示 長~ ", Toast.LENGTH_LONG);
break;
case R.id.btn_text_true_long:
BToast.showText( this, "簡單提示 正確圖標 長~ ", Toast.LENGTH_LONG, true);
break;
case R.id.btn_text_false_long:
BToast.showText( this, "簡單提示 錯誤圖標 長~ ", Toast.LENGTH_LONG, false);
break;
}
}
是不是比原生的Toast好用多了?
是不是逼格滿滿?
http://download.csdn.net/download/bamboy_/9751189
本Demo有更新,
去掉了對號和叉號圖標,
換用背景顏色來替代,
感興趣的同學可以克隆Bamboy合集:
Git地址:https: //github.com/Bamboy120315/bamboy.git
手機瀏覽器掃碼直接下載安裝 返回搜狐,查看更多
責任編輯:
總結
以上是生活随笔為你收集整理的android 自定义 对号,超简单实现Android自定义Toast的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux文件目录详解
- 下一篇: DataSource接口,一个被大多数程