自定义Toast

本文介绍了如何自定义Toast,从默认的Toast开始,逐步展示如何改变其位置、添加图片,最后通过XML布局和Java代码实现完全自定义的Toast效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Toast是一种轻量级提示工具,而且提示并不会聚焦,所以并不会影响用户的操作,在Toast上一个层级的activity依旧会是Resume状态,并不会进入Pause。
通常我们只是使用Toast的默认布局和纯文字显示,但是Toast是可以根据我们的需求进行功能自适应调整的。

1.默认Toast

//显示的上下文、内容、时间
Toast toast=Toast.makeText(context,text,duration);
//显示
toast.show();

视图:
默认Toast
2.Toast位置可调整

//显示的上下文、内容、时间
Toast toast=Toast.makeText(context,text,duration);
//设置位置、x轴偏移量、y轴偏移量
toast.setGravity(Gravity.TOP, int xOffset, int yOffset);
//显示
toast.show();

视图:
调整位置Toast
3.包含图片的Toast

//显示的上下文、内容、时间
Toast toast=Toast.makeText(context,text,duration);
//利用getView获得View对象,并强制转化为linearlayout
LinearLayout ll=(LinearLayout)toast.getView();
//创建一个ImageView对象,并且设置图片
ImageVIew iv=new ImageView(this);
iv.setImageResource(R.mipmap.ic_launcher);
//将image添加进toast的布局中
ll.addView(iv);
//显示
toast.show();

视图:
含图片的Toast
4.自定义Toast
因为自定义Toast需要借助xml文件来布局我们的显示效果,所以该内容还会贴出xml布局文件
layout文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:orientation="vertical"
              android:layout_width="match_parent"
              android:layout_height="match_parent">
    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@mipmap/ic_launcher"/>
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="这是自定义TOast"/>
</LinearLayout>

java源代码:

//创建一个Toast对象
Toast toast=new Toast(this);
返回一个填充了自定义布局的view
View view = LayoutInflater.from(this).inflate(R.layout.sublist,null);
//将view添加到Toast中
toast.setView(view);
//显示Toast
toast.show();

视图:
自定义Toast

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值