iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >超简单实现Android自定义Toast示例(附源码)
  • 548
分享到

超简单实现Android自定义Toast示例(附源码)

toast源码Android 2022-06-06 04:06:29 548人浏览 独家记忆
摘要

Bamboy的自定义Toast,(以下称作“BToast”) 特点在于使用简单, 并且自带两种样式: 1)普通的文字样式; 2)带图标样式。 其中图标有√和×两

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 {
  
  private static BToast toast;
  
  public BToast(Context context) {
    super(context);
  }
}

为了实现可以吧当前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) {
    }
  }

现在我们就可以写我们的逻辑了,首先当然是引入我们的布局咯:


  
  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;
  
  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()了。

咱们现在做的事情叫“自定义”, “自定义”的意思就是我们自己定义规则, 既然如此, 我们何不提升一下“用户体验”呢?

何况这个“用户”还是我们自己。

废话不多说, 我们开始进行最后一步。

(三)、升华:


  
  public static void showText(Context context, CharSequence text) {
    showToast(context, text, Toast.LENGTH_SHORT, TYPE_HIDE);
  }
  
  public static void showText(Context context, CharSequence text, boolean isSucceed) {
    showToast(context, text, Toast.LENGTH_SHORT, isSucceed ? TYPE_TRUE : TYPE_FALSE);
  }
  
  public static void showText(Context context, CharSequence text, int time) {
    showToast(context, text, time, TYPE_HIDE);
  }
  
  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显示,自定义Dialog等)Android Toast自定义显示时间基于Android LayoutInflater的使用介绍Android开发之获取LayoutInflater对象的方法总结Android LayoutInflater加载布局详解及实例代码Android布局加载之LayoutInflater示例详解Android开发实现自定义Toast、LayoutInflater使用其他布局示例


--结束END--

本文标题: 超简单实现Android自定义Toast示例(附源码)

本文链接: https://www.lsjlt.com/news/22384.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作