超简单实现Android自定义Toast示例(附源码)
发布时间 - 2026-01-10 22:58:28 点击率:次Bamboy的自定义Toast,(以下称作“BToast”)

特点在于使用简单, 并且自带两种样式:
1)普通的文字样式;
2)带图标样式。
其中图标有√和×两种图标。
BToast还有另外一个特点就是:
系统自带Toast采用的是队列的方式,当前Toast消失后,下一个Toast才能显示出来;
而BToast会把当前Toast顶掉, 直接显示最新的Toast。
那么,简单三步,我们现在就开始自定义一下吧!
(一)、Layout:
要自定义Toast,
首先我们需要一个XML布局。
但是在布局之前我们需要三个资源文件,分别是背景、√和×。
背景可以用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>
√和×就最好用图片啦,源码里面有这两张图片,这里就不贴出来了。
现在就可以写布局了:
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现在已经OK, 剩下的就是Java部分了。
(二)、Java:
写一个BToast类,继承Toast、成员变量自身单例、还有构造函数:
public class BToast extends Toast {
/**
* Toast单例
*/
private static BToast toast;
/**
* 构造
*
* @param context
*/
public BToast(Context context) {
super(context);
}
}
为了实现可以吧当前Toast顶下去的需求,我们需要重写几个方法
/**
* 隐藏当前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) {
}
}
现在我们就可以写我们的逻辑了,首先当然是引入我们的布局咯:
/**
* 初始化Toast
*
* @param context 上下文
* @param text 显示的文本
*/
private static void initToast(Context context, CharSequence text) {
try {
cancelToast();
toast = new BToast(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的方法了:
/**
* 图标状态 不显示图标
*/
private static final int TYPE_HIDE = -1;
/**
* 图标状态 显示√
*/
private static final int TYPE_TRUE = 0;
/**
* 图标状态 显示×
*/
private static final int TYPE_FALSE = 1;
/**
* 显示Toast
*
* @param context 上下文
* @param text 显示的文本
* @param time 显示时长
* @param imgType 图标状态
*/
private static void showToast(Context context, CharSequence text, int time, int imgType) {
// 初始化一个新的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()了。
咱们现在做的事情叫“自定义”, “自定义”的意思就是我们自己定义规则, 既然如此, 我们何不提升一下“用户体验”呢?
何况这个“用户”还是我们自己。
废话不多说, 我们开始进行最后一步。
(三)、升华:
/**
* 显示一个纯文本吐司
*
* @param context 上下文
* @param text 显示的文本
*/
public static void showText(Context context, CharSequence text) {
showToast(context, text, Toast.LENGTH_SHORT, TYPE_HIDE);
}
/**
* 显示一个带图标的吐司
*
* @param context 上下文
* @param text 显示的文本
* @param isSucceed 显示【对号图标】还是【叉号图标】
*/
public static void showText(Context context, CharSequence text, boolean isSucceed) {
showToast(context, text, Toast.LENGTH_SHORT, isSucceed ? TYPE_TRUE : TYPE_FALSE);
}
/**
* 显示一个纯文本吐司
*
* @param context 上下文
* @param text 显示的文本
* @param time 持续的时间
*/
public static void showText(Context context, CharSequence text, int time) {
showToast(context, text, time, TYPE_HIDE);
}
/**
* 显示一个带图标的吐司
*
* @param context 上下文
* @param text 显示的文本
* @param time 持续的时间
* @param isSucceed 显示【对号图标】还是【叉号图标】
*/
public static void showText(Context context, CharSequence text, int time, boolean isSucceed) {
showToast(context, text, time, isSucceed ? TYPE_TRUE : TYPE_FALSE);
}
简简单单几个方法,用户体验瞬间直线飙升,来看一下使用的时候:
public void 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好用多了?
功德圆满!
赶紧看一下我们的成果:
BamboyToast效果图
源码地址:BamboyToast_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# android
# 自定义toast
# android中自定义toast
# Android Toast的用法总结(五种用法)
# Android使用Toast显示消息提示框
# Android中使用Toast.cancel()方法优化toast内容显示的解决方法
# Android控件系列之Toast使用介绍
# android之自定义Toast使用方法
# Android 5.0以上Toast不显示的解决方法
# Android开发技巧之永不关闭的Toast信息框(长时间显示而非系统关闭)
# android自定义Toast设定显示时间
# 如何解决android Toast重复显示
# Android9.0上针对Toast的特殊处理图文详解
# 自定义
# 几个
# 两种
# 时长
# 就可以
# 这样的话
# 的是
# 来了
# 功德圆满
# 你可以
# 就不
# 可以用
# 大功告成
# 重写
# 我们现在
# 写到
# 另外一个
# 既然如此
# 会把
# 看一下
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel怎么自定义错误页面_Laravel修改404和500页面模板
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
在centOS 7安装mysql 5.7的详细教程
千库网官网入口推荐 千库网设计创意平台入口
IOS倒计时设置UIButton标题title的抖动问题
如何确保西部建站助手FTP传输的安全性?
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
如何为不同团队 ID 动态生成多个“认领值班”按钮
如何为不同团队 ID 动态生成多个非值班状态按钮
如何用景安虚拟主机手机版绑定域名建站?
如何快速上传自定义模板至建站之星?
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
昵图网官方站入口 昵图网素材图库官网入口
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
简历在线制作网站免费版,如何创建个人简历?
如何基于PHP生成高效IDC网络公司建站源码?
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧
Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程
使用spring连接及操作mongodb3.0实例
Laravel中的Facade(门面)到底是什么原理
Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】
简单实现Android文件上传
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
Thinkphp 中 distinct 的用法解析
JavaScript实现Fly Bird小游戏
网易LOFTER官网链接 老福特网页版登录地址
猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】
Laravel怎么清理缓存_Laravel optimize clear命令详解
Android利用动画实现背景逐渐变暗
Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
Laravel中的withCount方法怎么高效统计关联模型数量
Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能
宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法
零服务器AI建站解决方案:快速部署与云端平台低成本实践
Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】
利用 Google AI 进行 YouTube 视频 SEO 描述优化
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
打开php文件提示内存不足_怎么调整php内存限制【解决方案】
如何打造高效商业网站?建站目的决定转化率
如何自定义建站之星模板颜色并下载新样式?
Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用
用yum安装MySQLdb模块的步骤方法
Laravel如何使用.env文件管理环境变量?(最佳实践)
详解Android图表 MPAndroidChart折线图
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
如何登录建站主机?访问步骤全解析

