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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 基于自定义Toast全面解析

    Toast一般用来显示一行文字,用法比较固定: Toast.makeText(Context context,String message,int duration); 但是有时候想用toast 来显示复杂的view甚至是带有图片的view时这时候就要用到自定义的Toast,自定义Toast主要用到一下几个方法如图: 1.setView()方法用来显示用户自定义的view. 2. setGravity()用来确定Toast显示的位置. 3.setDuration()用来设置Toast显示的时间长

  • Android 自定义 Toast 显示时间

    Android 自定义 Toast 显示时间 实现代码: package com.wm.realname.util; import android.content.Context; import android.os.Handler; import android.view.View; import android.widget.Toast; /** * Toast自定义显示时间 * 使用方法 * 1.先初始化类 MyToast myToast = new MyToast(this); * 2.

  • 微信小程序 Toast自定义实例详解

    微信小程序 Toast自定义实例详解 实现类似于Android的Toast提示 index.js: var timer; var inputinfo = ""; var app = getApp() Page({ data: { animationData:"", showModalStatus:false }, onLoad: function () { }, showModal: function () { // 显示遮罩层 var animation = wx

  • 微信小程序 自定义Toast实例代码

    微信小程序 自定义Toast实例代码 Toast样式可以根据需求自定义,本例中是圆形 <!--按钮--> <view class="btn" bindtap="btn_toast">自定义Toast</view> <!--以下为toast显示的内容 opacity为透明度--> <view class="toast_box" style="opacity:{{0.9}}"

  • android之自定义Toast使用方法

    Android系统默认的Toast十分简洁,使用也非常的简单.但是有时我们的程序使用默认的Toast时会和程序的整体风格不搭配,这个时候我们就需要自定义Toast,使其与我们的程序更加融合. 使用自定义Toast,首先我们需要添加一个布局文件,该布局文件的结构和Activity使用的布局文件结构一致,在该布局文件中我们需设计我们Toast的布局,例如: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> &

  • android自定义toast(widget开发)示例

    1.Toast控件: 通过查看源代码,发现Toast里面实现的原理是通过服务Context.LAYOUT_INFLATER_SERVICE获取一个LayoutInflater布局管理器,从而获取一个View对象(TextView),设置内容将其显示 复制代码 代码如下: public static Toast makeText(Context context, CharSequence text, int duration) {        Toast result = new Toast(c

  • Android编程实现自定义toast示例

    本文实例讲述了Android编程实现自定义toast.分享给大家供大家参考,具体如下: 效果图: 代码: //自定义布局的toast customViewToast.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast toast = Toast.makeText(ToastTest.this, "top", Toast.LENGTH_SHORT); /

  • 分享Android中Toast的自定义使用

    1.Toast源码分析 老规矩,我们先去看Toast的源码. Toast有两种显示布局方式,一种最常见调用Toast.makeText()  ,看源码是这样写的 public static Toast makeText(Context context, CharSequence text, @Duration int duration) { Toast result = new Toast(context); LayoutInflater inflate = (LayoutInflater) c

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

    Bamboy的自定义Toast,(以下称作"BToast") 特点在于使用简单, 并且自带两种样式: 1)普通的文字样式: 2)带图标样式. 其中图标有√和×两种图标. BToast还有另外一个特点就是: 系统自带Toast采用的是队列的方式,当前Toast消失后,下一个Toast才能显示出来: 而BToast会把当前Toast顶掉, 直接显示最新的Toast. 那么,简单三步,我们现在就开始自定义一下吧! (一).Layout: 要自定义Toast, 首先我们需要一个XML布局. 但

  • 简单实现Android学生管理系统(附源码)

    本文实例讲述了Android实现学生管理系统,分享给大家供大家参考.具体如下: (1)管理系统实现的功能主要是:学生.教师的注册登录,和选课,以及修改学生的成绩等基本简单的功能,最主要的是实现一些Dialog的使用. 界面如下: (2)主要代码如下:(个人留作笔记,如需要完整代码,在最下边免费下载) 下边是一个适配器,适配器是为了一个listvie进行设置值,其中加载的是一个itemview,适配器中还是用了继承的方法,用于通知适配器进行更新. public class CourseAdapte

  • 自定义Android六边形进度条(附源码)

    本文实例讲述了Android自定义圆形进度条,分享给大家供大家参考.具体如下: 大家也可以参考这两篇文章进行学习: <自定义Android圆形进度条(附源码)>   <Android带进度的圆形进度条> 运行效果截图如下: 主要代码: package com.sxc.hexagonprogress; import java.util.Random; import android.content.Context; import android.content.res.ColorSta

  • Android 自定义相机及分析源码

    Android 自定义相机及分析源码 使用Android 系统相机的方法: 要想让应用有相机的action,咱们就必须在清单文件中做一些声明,好让系统知道,如下 <intent-filter> <action android:name="android.intent.action.IMAGE_CAPTURE" /> <category android:name="android.intent.category.DEFAULT" />

  • c# WPF中通过双击编辑DataGrid中Cell的示例(附源码)

    背景 在很多的时候我们需要编辑DataGrid中每一个Cell,编辑后保存数据,原生的WPF中的DataGrid并没有提供这样的功能,今天通过一个具体的例子来实现这一个功能,在这个例子中DataGrid中的数据类型可能是多种多样的,有枚举.浮点类型.布尔类型.DateTime类型,每一种不同的类型需要双击以后呈现不同的效果,本文通过使用Xceed.Wpf.DataGrid这个动态控件库来实现这个功能,当前使用的Dll版本是2.5.0.0,不同的版本可能实现上面有差别,这个在使用的时候需要特别注意

  • python实现web邮箱扫描的示例(附源码)

    信息收集是进行渗透测试的关键部分,掌握大量的信息对于攻击者来说是一件非常重要的事情,比如,我们知道一个服务器的版本信息,我们就可以利用该服务器框架的相关漏洞对该服务器进行测试.那么如果我们掌握了该服务器的管理员的邮箱地址,我们就可以展开一个钓鱼攻击.所以,对web站点进行邮箱扫描,是进行钓鱼攻击的一种前提条件. 下面,我们利用python脚本来实现一个web站点的邮箱扫描爬取.目的是在实现这个脚本的过程中对python进行学习 最后有完整代码 基本思路 我们向工具传入目标站点之后,首先要对输入进

  • 一款简单的jQuery图片标注效果附源码下载

    为了提高用户体验度,在一些电商网站和家居网站上我们会看到,一张图片中显示多种商品,点击每个商品可以弹出对应商品的简单介绍,包括价格等等,设计非常的人性化,今天我们通过实例给大家分享使用jQuery插件来实现这一效果. 先给大家展示下效果图: 效果演示          源码下载 HTML 首先,我们加载jQuery库和easypin插件. <script src="jquery.min.js"></script> <script src="jqu

  • 基于jQuery实现带动画效果超炫酷的弹出对话框(附源码下载)

    这是一款基于jQuery的弹出对话框插件,这个jQuery对话框插件的最大特点是弹出和关闭都带有非常炫酷的动画特效,比如旋转飞入.上下抖动飞入等.效果图如下: 效果演示    源码下载 html代码: <div class="container"> <h1>jQuery gDialog Plugin Exampels</h1> <button class="btn demo-1">Alert Dialog Box<

  • 基于Redis实现短信验证码登录项目示例(附源码)

    目录 Redis短信登录流程描述 短信验证码的发送 短信验证码的验证 是否登录的验证 源码分析 模拟发送短信验证码 短信验证码的验证 校验是否登录 登录验证优化 Redis短信登录流程描述 短信验证码的发送 用户提交手机号,系统验证手机号是否有效,毕竟无效手机号会消耗你的短信验证次数还会导致系统的性能下降.如果手机号为无效的话就让用户重新提交手机号,如果有效就生成验证码并将该验证码作为value保存到redis中对应的key是手机号,之所以这么做的原因是保证key的唯一性,如果使用固定字符串作为

  • 自定义Android圆形进度条(附源码)

    本文实例讲述了Android自定义圆形进度条,分享给大家供大家参考.具体如下: 运行效果截图如下: 具体代码如下: 自定义的View: import com.example.circlepregress.R; import android.content.Context; import android.content.res.TypedArray; import android.graphics.Canvas; import android.graphics.Color; import andr

随机推荐