`

Android自定义Toast

 
阅读更多

转于:http://blog.csdn.net/zhangweiwtmdbf/article/details/30031015

-------------------------------------------------------------------------------------------

一、引言

在开发的过程中你会发现Android自身的Toast提示有许多限制,比如我想自定义Toast的动画、自定义一个美观的View显示在Toast中、更多的是让Toast显示指定的时长等等。

首先一下效果如何:

 

二、原理

自定义的原理也很简单,就是给WindowManager添加View和删除View,不过需要设置WindowManager.LayoutParams和View的样式,使其看起来和Android系统的Toast看起来很相像。

具体代码如下:

 

[java] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. /** 
  2.  * Custom Toast 
  3.  *  
  4.  * @author Lucky 
  5.  *  
  6.  */  
  7. public class ToastHelper {  
  8.     public static final int LENGTH_LONG = 3500;  
  9.     public static final int LENGTH_SHORT = 2000;  
  10.     private WindowManager mWindowManager;  
  11.     private WindowManager.LayoutParams mWindowParams;  
  12.     private View toastView;  
  13.     private Context mContext;  
  14.     private Handler mHandler;  
  15.     private String mToastContent = "";  
  16.     private int duration = 0;  
  17.     private int animStyleId = android.R.style.Animation_Toast;  
  18.   
  19.     private final Runnable timerRunnable = new Runnable() {  
  20.   
  21.         @Override  
  22.         public void run() {  
  23.             removeView();  
  24.         }  
  25.     };  
  26.   
  27.     private ToastHelper(Context context) {  
  28.         // Notice: we should get application context  
  29.         // otherwise we will get error  
  30.         // "Activity has leaked window that was originally added"  
  31.         Context ctx = context.getApplicationContext();  
  32.         if (ctx == null) {  
  33.             ctx = context;  
  34.         }  
  35.         this.mContext = ctx;  
  36.         mWindowManager = (WindowManager) mContext  
  37.                 .getSystemService(Context.WINDOW_SERVICE);  
  38.         init();  
  39.     }  
  40.   
  41.     private void init() {  
  42.         mWindowParams = new WindowManager.LayoutParams();  
  43.         mWindowParams.flags = WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON  
  44.                 | WindowManager.LayoutParams.FLAG_NOT_TOUCHABLE  
  45.                 | WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;  
  46.         mWindowParams.alpha = 1.0f;  
  47.         mWindowParams.width = WindowManager.LayoutParams.WRAP_CONTENT;  
  48.         mWindowParams.height = WindowManager.LayoutParams.WRAP_CONTENT;  
  49.         mWindowParams.gravity = Gravity.CENTER_HORIZONTAL | Gravity.BOTTOM;  
  50.         mWindowParams.format = PixelFormat.TRANSLUCENT;  
  51.         mWindowParams.type = WindowManager.LayoutParams.TYPE_TOAST;  
  52.         mWindowParams.setTitle("ToastHelper");  
  53.         mWindowParams.packageName = mContext.getPackageName();  
  54.         mWindowParams.windowAnimations = animStyleId;// TODO  
  55.         mWindowParams.y = mContext.getResources().getDisplayMetrics().widthPixels / 5;  
  56.     }  
  57.   
  58.     @SuppressWarnings("deprecation")  
  59.     @SuppressLint("NewApi")  
  60.     private View getDefaultToastView() {  
  61.   
  62.         TextView view = new TextView(mContext);  
  63.         view.setText(mToastContent);  
  64.         view.setGravity(Gravity.CENTER_VERTICAL | Gravity.START);  
  65.         view.setFocusable(false);  
  66.         view.setClickable(false);  
  67.         view.setFocusableInTouchMode(false);  
  68.         view.setTextColor(android.graphics.Color.WHITE);  
  69.         Drawable drawable = mContext.getResources().getDrawable(  
  70.                 android.R.drawable.toast_frame);  
  71.   
  72.         if (Build.VERSION.SDK_INT < 16) {  
  73.             view.setBackgroundDrawable(drawable);  
  74.         } else {  
  75.             view.setBackground(drawable);  
  76.         }  
  77.         return view;  
  78.     }  
  79.   
  80.     public void show() {  
  81.         removeView();  
  82.         if (toastView == null) {  
  83.             toastView = getDefaultToastView();  
  84.         }  
  85.         mWindowParams.gravity = android.support.v4.view.GravityCompat  
  86.                 .getAbsoluteGravity(Gravity.CENTER_HORIZONTAL | Gravity.BOTTOM,  
  87.                         android.support.v4.view.ViewCompat  
  88.                                 .getLayoutDirection(toastView));  
  89.         removeView();  
  90.         mWindowManager.addView(toastView, mWindowParams);  
  91.         if (mHandler == null) {  
  92.             mHandler = new Handler();  
  93.         }  
  94.         mHandler.postDelayed(timerRunnable, duration);  
  95.     }  
  96.   
  97.     public void removeView() {  
  98.         if (toastView != null && toastView.getParent() != null) {  
  99.             mWindowManager.removeView(toastView);  
  100.             mHandler.removeCallbacks(timerRunnable);  
  101.         }  
  102.     }  
  103.   
  104.     /** 
  105.      * @param context 
  106.      * @param content 
  107.      * @param duration 
  108.      * @return 
  109.      */  
  110.     public static ToastHelper makeText(Context context, String content,  
  111.             int duration) {  
  112.         ToastHelper helper = new ToastHelper(context);  
  113.         helper.setDuration(duration);  
  114.         helper.setContent(content);  
  115.         return helper;  
  116.     }  
  117.   
  118.     /** 
  119.      * @param context 
  120.      * @param strId 
  121.      * @param duration 
  122.      * @return 
  123.      */  
  124.     public static ToastHelper makeText(Context context, int strId, int duration) {  
  125.         ToastHelper helper = new ToastHelper(context);  
  126.         helper.setDuration(duration);  
  127.         helper.setContent(context.getString(strId));  
  128.         return helper;  
  129.     }  
  130.   
  131.     public ToastHelper setContent(String content) {  
  132.         this.mToastContent = content;  
  133.         return this;  
  134.     }  
  135.   
  136.     public ToastHelper setDuration(int duration) {  
  137.         this.duration = duration;  
  138.         return this;  
  139.     }  
  140.   
  141.     public ToastHelper setAnimation(int animStyleId) {  
  142.         this.animStyleId = animStyleId;  
  143.         mWindowParams.windowAnimations = this.animStyleId;  
  144.         return this;  
  145.     }  
  146.   
  147.     /** 
  148.      * custom view 
  149.      *  
  150.      * @param view 
  151.      */  
  152.     public ToastHelper setView(View view) {  
  153.         this.toastView = view;  
  154.         return this;  
  155.     }  
  156. }  


另外分享一个自定义的Anim:

 

1.显示Toast的动画:

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:duration="300"  
  4.     android:fillAfter="true" >  
  5.   
  6.     <alpha  
  7.         android:fromAlpha="0.0"  
  8.         android:toAlpha="1.0" />  
  9.   
  10.     <translate  
  11.         android:fromYDelta="20%"  
  12.         android:toYDelta="0%" />  
  13.   
  14.     <scale  
  15.         android:fromXScale="0.5"  
  16.         android:fromYScale="0.5"  
  17.         android:pivotX="50%"  
  18.         android:pivotY="50%"  
  19.         android:toXScale="1.0"  
  20.         android:toYScale="1.0" />  
  21.   
  22. </set>  


2.退出Toast的动画:

 

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. <set xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     android:duration="300"  
  3.     android:fillAfter="true" >  
  4.   
  5.     <alpha  
  6.         android:fromAlpha="1.0"  
  7.         android:toAlpha="0.0" />  
  8.   
  9.     <translate  
  10.         android:fromYDelta="0%"  
  11.         android:toYDelta="20%" />  
  12.   
  13. </set>  



 

给WIndowManager中的View添加动画需要定义一个style,如下:

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. <style name="PopToast">  
  2.     <item name="@android:windowEnterAnimation">@anim/anim_toast_enter</item>  
  3.     <item name="@android:windowExitAnimation">@anim/anim_toast_exit</item>  
  4. </style>  


最后可以按照如下的方式去使用:

 

 

[java] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. ToastHelper  
  2.                     .makeText(this"hello world 你好,哈拉雷速度发说得对",  
  3.                             ToastHelper.LENGTH_SHORT)  
  4.                     .setAnimation(R.style.PopToast).show();  



 

三、参考资料:

SuperToast: https://github.com/JohnPersano/SuperToasts

 

 

分享到:
评论

相关推荐

    实验室设备管理系统 SSM毕业设计 附带论文.zip

    实验室设备管理系统 SSM毕业设计 附带论文 启动教程:https://www.bilibili.com/video/BV1GK1iYyE2B

    PPT高效插件神器推荐-最新发布.zip

    PPT高效插件神器推荐-最新发布.zip

    数据中心机房基础设计及规划方案.pdf

    数据中心机房是现代信息技术的核心设施,它承载着企业的重要数据和服务,因此,其基础设计与规划至关重要。在制定这样的方案时,需要考虑的因素繁多,包括但不限于以下几点: 1. **容量规划**:必须根据业务需求预测未来几年的数据处理和存储需求,合理规划机房的规模和设备容量。这涉及到服务器的数量、存储设备的容量以及网络带宽的需求等。 2. **电力供应**:数据中心是能源消耗大户,因此电力供应设计是关键。要考虑不间断电源(UPS)、备用发电机的容量,以及高效节能的电力分配系统,确保电力的稳定供应并降低能耗。 3. **冷却系统**:由于设备密集运行,散热问题不容忽视。合理的空调布局和冷却系统设计可以有效控制机房温度,避免设备过热引发故障。 4. **物理安全**:包括防火、防盗、防震、防潮等措施。需要设计防火分区、安装烟雾探测和自动灭火系统,设置访问控制系统,确保只有授权人员能进入。 5. **网络架构**:规划高速、稳定、冗余的网络架构,考虑使用光纤、以太网等技术,构建层次化网络,保证数据传输的高效性和安全性。 6. **运维管理**:设计易于管理和维护的IT基础设施,例如模块化设计便于扩展,集中监控系统可以实时查看设备状态,及时发现并解决问题。 7. **绿色数据中心**:随着环保意识的提升,绿色数据中心成为趋势。采用节能设备,利用自然冷源,以及优化能源管理策略,实现低能耗和低碳排放。 8. **灾难恢复**:考虑备份和恢复策略,建立异地灾备中心,确保在主数据中心发生故障时,业务能够快速恢复。 9. **法规遵从**:需遵循国家和地区的相关法律法规,如信息安全、数据保护和环境保护等,确保数据中心的合法运营。 10. **扩展性**:设计时应考虑到未来的业务发展和技术进步,保证机房有充足的扩展空间和升级能力。 技术创新在数据中心机房基础设计及规划方案中扮演了重要角色。例如,采用虚拟化技术可以提高硬件资源利用率,软件定义网络(SDN)提供更灵活的网络管理,人工智能和机器学习则有助于优化能源管理和故障预测。 总结来说,一个完整且高效的数据中心机房设计及规划方案,不仅需要满足当前的技术需求和业务目标,还需要具备前瞻性和可持续性,以适应快速变化的IT环境和未来可能的技术革新。同时,也要注重经济效益,平衡投资成本与长期运营成本,实现数据中心的高效、安全和绿色运行。

    Visio软件全套资源及教程-最新发布.zip

    Visio软件全套资源及教程-最新发布.zip

    2000-2022年中国地级市生态韧性数据集(含原始数据、计算代码及结果,最新).zip

    2000-2022年中国地级市生态韧性数据集(含原始数据、计算代码及结果,最新).zip

    Spring Cloud 配置相关项目.zip

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。

    全国2009-2021年农业高质量发展指数测算(重磅,更新!)乡村振兴

    1、资源内容地址:https://blog.csdn.net/abc6838/article/details/143778060 2、数据特点:今年全新,手工精心整理,放心引用,数据来自权威,且标注《数据来源》,相对于其他人的控制变量数据准确很多,适合写论文做实证用 ,不会出现数据造假问题 3、适用对象:大学生,本科生,研究生小白可用,容易上手!!! 4、课程引用: 经济学,地理学,城市规划与城市研究,公共政策与管理,社会学,商业与管理

    Jupyter_这本书被命名为《木星笔记》.zip

    Jupyter-Notebook

    1949-2021年中国民政统计年鉴-最新数据发布.zip

    1949-2021年中国民政统计年鉴-最新数据发布.zip

    Jupyter_用于plot dash的OOP组件,使仪表板组件可组合、可重用和可配置.zip

    Jupyter-Notebook

    Gartner推荐全球4家专注于通过自动化和人工智能支持SOC的优秀供应商.pdf

    Gartner推荐全球4家专注于通过自动化和人工智能支持SOC的优秀供应商.pdf

    Jupyter_AI 常用脚本.zip

    Jupyter-Notebook

    多种 Spring Boot 技术集成示例,涵盖数据持久化、工具集成、功能模块等方面.zip

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。

    53朱清清 劳动教育总结报告.doc

    53朱清清 劳动教育总结报告.doc

    Jupyter_CVPR2023强调了一种用于视频预测的动态多尺度体素流网络.zip

    Jupyter-Notebook

    Spss26统计软件最新版-最新发布.zip

    Spss26统计软件最新版-最新发布.zip

    基于springboot mybatis+Mysql 实现的图书管理系统 【web课程设计 】

    【作品名称】:基于springboot mybatis+Mysql 实现的图书管理系统 【web课程设计 】 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】: 主要功能 登录、注销、修改密码 管理员对图书信息的增删改查、查看读者、查看借阅记录 读者对图书信息的查看查询、修改个人信息、查看借阅记录 使用技术 数据库:mysql5.7 后端框架: SpringBoot HTML模板: ThymeLeaf 持久层: Mybatis UI: Bootstrap 登录验证和用户权限: SpringSecurity 使用说明 本项目使用maven进行管理,详细安装教程自行百度 需下载mysql图形化管理工具(例如Navicat),新建数据库library,右键数据库运行项目中的library.sql脚本 用IDE打开项目(建议使用i 【资源声明】:本资源作为“参考资料”而不是“定制需求”,代码只能作为参考,不能完全复制照搬。需要有一定的基础看懂代码,自行调试代码并解决报错,能自行添加功能修改代码。

    Python中的动态图形:使用Tkinter绘制跳动的心形

    内容概要:本文详细介绍了用Python的Tkinter库创建动态心脏图形的过程。程序主要由几个部分组成:首先定义了一系列数学函数用于计算心形图的心脏坐标以及散射、收缩效果;然后构建了一个‘BeatingHeart’类来生成不同帧的心跳动画点集;最后,在主函数里调用了这个类的方法绘制出连续的心跳图像,展示了心脏的搏动过程。 适合人群:熟悉Python语言并且对Tkinter库有一定了解的开发者,特别是那些希望利用Python创建图形化应用或者动画模拟的人群。 使用场景及目标:适用于希望快速理解和实现基于Tkinter的基本二维图形与动画制作的学习者或开发者;同时也可以作为图形算法和物理模拟(如粒子系统)的教学案例。 阅读建议:本文涉及到多个函数之间的复杂调用关系,读者需要仔细跟踪每一步操作的具体意义及其参数含义。对于初学者而言,可以先尝试运行示例代码查看实际效果,然后再逐步理解每个部分的功能实现机制。

    宏观面板数据整合(省市区三级)-最新数据.zip

    宏观面板数据整合(省市区三级)-最新数据.zip

    空间计量软件及学习资料-最新更新.zip

    空间计量软件及学习资料-最新更新.zip

Global site tag (gtag.js) - Google Analytics