有時候我們做Android開發,需要彈一個用戶提示,但是有時候設計的提示彈窗是帶有圖片的,我們每次寫一個特別麻煩。所以我特地封裝了一個工具類,在需要彈窗的地方調用對應的方法即可,根據需要可以傳文字和圖片資源id,方便自定義Toast彈窗提示。
下面是效果圖
自定義工具類代碼
/** * Created by zzf on 2018/7/7. * 一個自定義的吐司工具類,可以修改任意布局 */ public class ToastUtils { private static Context mContext = OcreanSonicApplication.getContext(); public static void showToast(String toast) { Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show(); } /** * 帶圖片的吐司提示 * @param text */ public static void showCustomImgToast(String text) { LayoutInflater inflater = LayoutInflater.from(mContext); View view = inflater.inflate(R.layout.toast_view, null); ImageView imageView = (ImageView) view.findViewById(R.id.toast_image); imageView.setBackgroundResource(R.mipmap.pd_ic_finish); TextView t = (TextView) view.findViewById(R.id.toast_text); t.setText(text); Toast toast = null; if (toast != null) { toast.cancel(); } toast = new Toast(mContext); toast.setDuration(Toast.LENGTH_SHORT); toast.setView(view); toast.show(); } /** * 帶圖片的吐司提示 * 通過參數傳遞,可是設置吐司的圖片和文字內容 * @param text */ public static void showCustomImgToast(String text,int imgResId) { LayoutInflater inflater = LayoutInflater.from(mContext); View view = inflater.inflate(R.layout.toast_view, null); ImageView imageView = (ImageView) view.findViewById(R.id.toast_image); imageView.setBackgroundResource(R.mipmap.pd_ic_finish); TextView t = (TextView) view.findViewById(R.id.toast_text); t.setText(text); Toast toast = null; if (toast != null) { toast.cancel(); } toast = new Toast(mContext); toast.setDuration(Toast.LENGTH_SHORT); toast.setView(view); toast.show(); } /** * 不帶圖片的吐司提示 * @param text */ public static void showCustomToast(String text) { LayoutInflater inflater = LayoutInflater.from(mContext); View view = inflater.inflate(R.layout.toast_view, null); ImageView imageView = (ImageView) view.findViewById(R.id.toast_image); imageView.setVisibility(View.GONE); TextView t = (TextView) view.findViewById(R.id.toast_text); t.setText(text); Toast toast = null; if (toast != null) { toast.cancel(); } toast = new Toast(mContext); toast.setDuration(Toast.LENGTH_SHORT); toast.setView(view); toast.show(); } /** * 帶圖片的吐司,設置吐司彈出的位置為屏幕中心 * @param text */ public static void showCustomToastCenter(String text) { showCustomToastCenter(text, R.mipmap.pd_ic_finish); } /** * 帶圖片的吐司,設置吐司彈出的位置為屏幕中心 * 通過參數傳遞,可是設置吐司的圖片和文字內容 * @param text */ public static void showCustomToastCenter(String text, int imgResId) { LayoutInflater inflater = LayoutInflater.from(mContext); View view = inflater.inflate(R.layout.toast_view, null); ImageView imageView = (ImageView) view.findViewById(R.id.toast_image); imageView.setBackgroundResource(imgResId); TextView t = (TextView) view.findViewById(R.id.toast_text); t.setText(text); Toast toast = null; if (toast != null) { toast.cancel(); } toast = new Toast(mContext); toast.setDuration(Toast.LENGTH_SHORT); toast.setView(view); toast.setGravity(Gravity.CENTER, 0, 0); toast.show(); }}
在自定義Toast中引用xml布局,用來放置圖片和文字,設置id,可以任意在Java代碼中設置
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <!-- android:minHeight="80dp"--> <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:background="@drawable/shape_toast" android:minWidth="120dp" android:gravity="center" android:orientation="vertical" android:padding="5dp"> <!--android:background="@drawable/toast_bg"--> <ImageView android:id="@+id/toast_image" android:layout_width="30dp" android:layout_height="30dp" android:layout_gravity="center" android:layout_margin="2dp" android:background="@mipmap/pd_ic_finish"/> <TextView android:id="@+id/toast_text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_margin="2dp" android:layout_gravity="center" android:text="保存成功" android:textColor="#ffffff" android:textSize="15dp"/> </LinearLayout> </LinearLayout>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
|
新聞熱點
疑難解答