手把手教你做安豆计算器(八)-动画效果

2023-11-21 08:21

本文主要是介绍手把手教你做安豆计算器(八)-动画效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第9节 动画效果

当用户点击了以后,为了让结果区域的显示和表达式区域的清空显得很优雅,我们可以为它们添加淡如淡出的效果:让结果区域的文字淡入,让表达式区域的文字淡出。

这种效果可以使用动画实现。

安卓系统的动画可以分成,

  1. 逐帧动画:就像电影胶片那样,通过连续放映一张一张差距不大的图片实现动画效果;
  2. 属性动画:一点点改变控件的某个属性值,从而产生动画的视觉效果;
  3. 渐变动画:产生控件的透明效果 平移效果 缩放效果或者旋转效果

我们准备加入的文字淡入淡出效果,就是渐变动画的透明效果

9.1 定义动画

  1. 项目浏览框,找到res目录,点击右键,选择new->android resource file;

  2. 在对应栏位按照下图填写,创建一个淡入动画;

  3. 打开刚创建好的xml文件,定义淡入动画;android:fromAlpha指定动画开始时,动画对象的透明度;android:toAlpha指定动画结束时,动画对象的透明度;android:duration指定了动画持续的时间,单位是毫秒;android:interpolator指定了动画显示过程中变化的速度;

    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android"><alpha
            android:fromAlpha="0.0"android:toAlpha="1.0"android:duration="1500"android:interpolator="@android:anim/linear_interpolator"/>
    </set>
  4. 根据前面的操作,继续创建一个淡出动画,叫做fade_out

    <set xmlns:android="http://schemas.android.com/apk/res/android"><alpha
            android:fromAlpha="1.0"android:toAlpha="0.0"android:duration="1500"android:interpolator="@android:anim/linear_interpolator"/>
    </set>

9.2 使用动画

9.2.1 使用淡入效果

  1. 在源码中,使用AnimationUtils.loadAnimation()函数加载我们定义的动画;
  2. 为要使用动画的对象通过startAnimation()方法设置对象;
public void onClick(View view){switch (view.getId()) {......case R.id.btn_equ: {TextView formula = (TextView) findViewById(R.id.formula_area);String strContent = formula.getText().toString();try {Symbols s = new Symbols();double res = s.eval(strContent);TextView result = (TextView) findViewById(R.id.result_area);result.setText(String.valueOf(res));Animation fadeIn = AnimationUtils.loadAnimation(MainActivity.this, R.anim.fade_in);result.startAnimation(fadeIn);formula.setText("");} catch (SyntaxException e) {......}}break;       }}

9.2.2 使用淡出效果

如果使用9.2.1中的方式,直接对对象使用淡出效果,会发现对象一开始就消失不见了,而不是逐步消失的。因为在动画开始之前,我们就已经通过formula.setText("");将表达式区域设置成空了。因此,需要在淡出动画完成后,再把表达式区域设置成空。

  1. 在源码中,使用AnimationUtils.loadAnimation()函数加载我们定义的动画;
  2. 为动画添加监听,掌握动画进行的过程;
  3. 在动画结束时,将表达式区域设置成空;
public void onClick(View view){switch (view.getId()) {......case R.id.btn_equ: {TextView formula = (TextView) findViewById(R.id.formula_area);String strContent = formula.getText().toString();try {......Animation fadeOut = AnimationUtils.loadAnimation(MainActivity.this, R.anim.fade_out);formula.startAnimation(fadeOut);fadeOut.setAnimationListener(new Animation.AnimationListener() {@Overridepublic void onAnimationStart(Animation animation) {}@Overridepublic void onAnimationEnd(Animation animation) {TextView formula = (TextView) findViewById(R.id.formula_area);formula.setText("");}@Overridepublic void onAnimationRepeat(Animation animation) {}
});} catch (SyntaxException e) {......}}break;       }}

至此,整个动画的添加就完成了,运行程序,开始计算操作,可以看到动画效果了。


/*******************************************************************/
* 版权声明
* 本教程只在CSDN和安豆网发布,其他网站出现本教程均属侵权。
/*******************************************************************/

后记

经过前面的学习和实践,我们已经开发出了一款简单的计算器应用,对安卓应用开发有了整体的认识。

安卓开发的学习还有更多有趣好玩的道路需要走,下面给出一些学习的建议和方法:

  1. 安豆网上有配套的《大话安卓开发》,会将这里没有深入展开的内容,按照知识体系进行进一步的讲解。当我们对安卓的开发有了大概的认识后,可以去看看成体系的介绍和学习,让我们对开发的认识和理解更进一步;
  2. 对于困惑或者根本没有任何头绪的问题,去搜索引擎上尝试寻找答案,也许别人也遇到过类似的问题,站在前人的肩上,总会节约不少时间;
  3. 在时间允许的情况下,多做测试程序,把从书上、网上看到的内容消化成自己知识体系的一部分;
  4. 常去安卓开发的官网看看,上面有很多关于安卓应用开发的第一首资料;
  5. 对网上看到的有矛盾的资料,去官网查看权威的API文档;
  6. 乐于与别人分享自己在学习或者实践中遇到的问题和解决方法,与大家共同进步;

/*******************************************************************/
* 版权声明
* 本教程只在CSDN和安豆网发布,其他网站出现本教程均属侵权。

*另外,我们还推出了Arduino智能硬件相关的教程,您可以在我们的网店跟我学Arduino编程中购买相关硬件。同时也感谢大家对我们这些码农的支持。

*最后再次感谢各位读者对安豆的支持,谢谢:)
/*******************************************************************/

这篇关于手把手教你做安豆计算器(八)-动画效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/401095

相关文章

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

使用Python实现生命之轮Wheel of life效果

《使用Python实现生命之轮Wheeloflife效果》生命之轮Wheeloflife这一概念最初由SuccessMotivation®Institute,Inc.的创始人PaulJ.Meyer... 最近看一个生命之轮的视频,让我们珍惜时间,因为一生是有限的。使用python创建生命倒计时图表,珍惜时间

Qt QWidget实现图片旋转动画

《QtQWidget实现图片旋转动画》这篇文章主要为大家详细介绍了如何使用了Qt和QWidget实现图片旋转动画效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、效果展示二、源码分享本例程通过QGraphicsView实现svg格式图片旋转。.hpjavascript

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

防近视护眼台灯什么牌子好?五款防近视效果好的护眼台灯推荐

在家里,灯具是属于离不开的家具,每个大大小小的地方都需要的照亮,所以一盏好灯是必不可少的,每个发挥着作用。而护眼台灯就起了一个保护眼睛,预防近视的作用。可以保护我们在学习,阅读的时候提供一个合适的光线环境,保护我们的眼睛。防近视护眼台灯什么牌子好?那我们怎么选择一个优秀的护眼台灯也是很重要,才能起到最大的护眼效果。下面五款防近视效果好的护眼台灯推荐: 一:六个推荐防近视效果好的护眼台灯的

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

用Unity2D制作一个人物,实现移动、跳起、人物静止和动起来时的动画:中(人物移动、跳起、静止动作)

上回我们学到创建一个地形和一个人物,今天我们实现一下人物实现移动和跳起,依次点击,我们准备创建一个C#文件 创建好我们点击进去,就会跳转到我们的Vision Studio,然后输入这些代码 using UnityEngine;public class Move : MonoBehaviour // 定义一个名为Move的类,继承自MonoBehaviour{private Rigidbo