自定義toast外形,多次點(diǎn)擊不會(huì)總是彈出toast的實(shí)現(xiàn)方法
效果如下所示:

我封裝了一個(gè)類(lèi)出來(lái):
package com.amt.appstore.widgets;
import com.amt.appstore.R;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;
public class CustomerToast {
static Toast toast;
public static void showToast(Context context, String content) {
LayoutInflater inflater = LayoutInflater.from(context);
View view = inflater.inflate(R.layout.toast_custome, null);
TextView tv = (TextView) view.findViewById(R.id.text);
tv.setText(content);
//防止多次點(diǎn)擊按鈕出現(xiàn)很多toast一直不消失
if (toast != null) {
toast.setView(view);
} else {
toast = new Toast(context);
toast.setView(view);
toast.setDuration(Toast.LENGTH_SHORT);
}
toast.show();
}
}
toast_custome里的代碼如下所示:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:background="@drawable/selected_etoast_background" >
<ImageView
android:id="@+id/toast"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="13dp"
android:layout_marginTop="10dp"
android:src="@drawable/toast" />
<TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="12dp"
android:layout_marginTop="5dp"
android:layout_toRightOf="@id/toast"
android:text="請(qǐng)先選擇類(lèi)別"
android:textColor="@color/white"
android:textSize="24sp" />
<TextView
android:layout_width="10dp"
android:layout_height="5dp"
android:layout_toRightOf="@id/text" />
<TextView
android:layout_width="wrap_content"
android:layout_height="5dp"
android:layout_below="@id/text" />
</RelativeLayout>
下面的兩個(gè)TextView是分別讓toast變寬一些,和變高一些,這樣會(huì)好看一些。
在drawable/selected_etoast_background里的代碼如下所示:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- 內(nèi)部顏色 -->
<solid android:color="@color/black" />
<!-- 邊緣線(xiàn)條顏色 -->
<stroke
android:width="1dp"
android:color="#00ffde" />
<!-- 圓角的幅度 -->
<corners
android:radius="1dp" />
</shape>
上面的感嘆號(hào)圖片,如下所示:

這樣在Activity里用的時(shí)候,如下代碼所示:
CustomerToast.showToast(AppWallActivity.this, "請(qǐng)先選擇類(lèi)型!");
結(jié)束。
以上這篇自定義toast外形,多次點(diǎn)擊不會(huì)總是彈出toast的實(shí)現(xiàn)方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 自定義Toast工具類(lèi)ToastUtil防止多次點(diǎn)擊時(shí)Toast不消失的方法
- 超簡(jiǎn)單實(shí)現(xiàn)Android自定義Toast示例(附源碼)
- Android編程實(shí)現(xiàn)Toast自定義布局簡(jiǎn)單示例
- Android編程實(shí)現(xiàn)自定義toast示例
- 分享Android中Toast的自定義使用
- Android編程經(jīng)典代碼集錦(復(fù)制,粘貼,瀏覽器調(diào)用,Toast顯示,自定義Dialog等)
- android自定義toast(widget開(kāi)發(fā))示例
- android之自定義Toast使用方法
相關(guān)文章
Android自定義View之簡(jiǎn)約風(fēng)歌詞控件實(shí)戰(zhàn)指南
一些接觸Android不久的朋友對(duì)自定義View都有一絲畏懼感,總感覺(jué)這是一個(gè)比較高級(jí)的技術(shù),但其實(shí)自定義View并不復(fù)雜,有時(shí)候只需要簡(jiǎn)單幾行代碼就可以完成了,這篇文章主要給大家介紹了關(guān)于Android自定義View之簡(jiǎn)約風(fēng)歌詞控件的相關(guān)資料,需要的朋友可以參考下2021-07-07
Android文件下載進(jìn)度條的實(shí)現(xiàn)代碼
我們今天開(kāi)始學(xué)習(xí)的是下載進(jìn)度的實(shí)現(xiàn)。今天的這段代碼是網(wǎng)上找的,自己做了些小改,通過(guò)模擬器測(cè)試。文件下載進(jìn)度條控制(就是為了高清壁紙加個(gè)進(jìn)度條),自己研究了好久,但是進(jìn)度條只能顯示緩存寫(xiě)入文件的進(jìn)度,不能顯示下載進(jìn)度。找了好久,終于找到一段用的代碼,所以記錄下來(lái),大家分享2013-01-01
Android數(shù)據(jù)庫(kù)LitePal的基本用法詳解
這篇文章主要介紹了Android數(shù)據(jù)庫(kù)LitePal的基本用法詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
Android編程之Activity中onDestroy()調(diào)用分析
這篇文章主要介紹了Android編程之Activity中onDestroy()調(diào)用方法,針對(duì)onDestroy引起的內(nèi)存泄露及解決方法進(jìn)行了分析,并給出了解決方案,需要的朋友可以參考下2015-12-12
Android開(kāi)發(fā)技巧之Fragment的懶加載
我們都知道fragment放在viewPager里面,viewpager會(huì)幫我們預(yù)先加載一個(gè),但是當(dāng)我們要看fragment里面的內(nèi)容時(shí),我們也許只會(huì)去看第一個(gè),不會(huì)去看第二個(gè),如果這時(shí)候不去實(shí)現(xiàn)fragment的懶加載的話(huà),就會(huì)多余的去加載一些數(shù)據(jù),造成用戶(hù)多消耗流量。下面來(lái)一起看看吧。2016-10-10

