动画综合练习(延迟进入+页面向导+文本框抖动)

2024-08-31 23:58

本文主要是介绍动画综合练习(延迟进入+页面向导+文本框抖动),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、activity_welcome.xml(界面刚加载进入欢迎界面的布局)

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/ll_welcome_root"android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical" android:background="@drawable/welcome_back"android:gravity="center_horizontal|bottom"><ProgressBarandroid:id="@+id/progressBar1"android:layout_width="wrap_content"android:layout_height="wrap_content" android:indeterminateDrawable="@anim/image_progress"android:indeterminateDuration="500"/>
</LinearLayout>
2、image_progress.xml(欢迎界面启动后,屏幕底部会有一个旋转的加载进度条)

<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"android:fromDegrees="0"android:toDegrees="360"android:pivotX="50%"android:pivotY="50%"android:drawable="@drawable/progess2"/>

3、WelcomeActivity.java

package com.atguigu.l10_app2;import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.animation.AlphaAnimation;
import android.view.animation.Animation;
import android.view.animation.Animation.AnimationListener;
import android.widget.LinearLayout;
/*** 欢迎界面**/
public class WelcomeActivity extends Activity {private LinearLayout ll_welcome_root;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_welcome);ll_welcome_root = (LinearLayout) findViewById(R.id.ll_welcome_root);//调用启动动画效果showAnimation();}//接受消息、处理消息private Handler handler = new Handler(new Handler.Callback() {@Overridepublic boolean handleMessage(Message msg) {if(msg.what==1) {//接受到消息后,启动另一个界面startActivity(new Intent(WelcomeActivity.this, Guide1Activity.class));}return true;}});/*** 显示动画*/private void showAnimation() {//设置图片背景透明度AlphaAnimation animation = new AlphaAnimation(0.0f, 1.0f);animation.setDuration(2000);//设置动画监听animation.setAnimationListener(new AnimationListener() {@Overridepublic void onAnimationStart(Animation animation) {}@Overridepublic void onAnimationRepeat(Animation animation) {}@Overridepublic void onAnimationEnd(Animation animation) {//发送延迟的空消息handler.sendEmptyMessageDelayed(1, 1000);}});//欢迎界面的启动动画效果界面ll_welcome_root.startAnimation(animation);}
}
4、然后进入第一个向导界面如图


先看向导界面1的布局文件

activity_guide1.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context="com.atguigu.l10_app2.Guide1Activity" ><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="第一个设置" /><Buttonandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentBottom="true"android:layout_alignParentRight="true"android:text="下一步" android:onClick="next"/>
</RelativeLayout>
Guide1Activity.java(代码作用是启动界面向导二,以及显示向导界面1和2的切换效果)

package com.atguigu.l10_app2;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;public class Guide1Activity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_guide1);}public void next(View v) {startActivity(new Intent(this, Guide2Activity.class));//显示一个界面切换的动画overridePendingTransition(R.anim.anim_right_in, R.anim.anim_left_out);}
}
anim_left_out.xml(当前页面向左滑动)

<?xml version="1.0" encoding="utf-8"?>
<translatexmlns:android="http://schemas.android.com/apk/res/android"android:fromXDelta="0%"android:toXDelta="-100%" android:duration="1000">
</translate>
anim_right_in.xml(下一张页面向左滑动进入到当前页面)

<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"android:fromXDelta="100%" android:toXDelta="0%"android:duration="1000">
</translate>

5、接下来看向导页面2的布局



activity_guide2.xml(向导界面二,上图的布局文件)

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context="com.atguigu.l10_app2.Guide1Activity" ><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="第二个设置" /><Buttonandroid:id="@+id/button2"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentBottom="true"android:layout_alignParentRight="true"android:onClick="next"android:text="下一步" /><Buttonandroid:id="@+id/button1"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignBaseline="@+id/button2"android:layout_alignBottom="@+id/button2"android:layout_alignParentLeft="true"android:text="上一步" android:onClick="pre"/></RelativeLayout>
Guide2Activity.java(向导二的java代码,作用是点击下一张,和点击上一张,显示页面切换的滑动效果)

package com.atguigu.l10_app2;import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;public class Guide2Activity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_guide2);}public void next(View v) {startActivity(new Intent(this, MainActivity.class));}public void pre(View v) {finish();//显示一个界面切换的动画overridePendingTransition(R.anim.anim_left_in, R.anim.anim_right_out);}
}

另外附上点击返回上一张界面的xml文件

anim_left_in.xml

<?xml version="1.0" encoding="utf-8"?>
<translatexmlns:android="http://schemas.android.com/apk/res/android"android:fromXDelta="-100%" android:toXDelta="0%"android:duration="500">
</translate>
anim_right_out.xml

<?xml version="1.0" encoding="utf-8"?>
<translatexmlns:android="http://schemas.android.com/apk/res/android"android:fromXDelta="0%"android:toXDelta="100%" android:duration="500">
</translate>


6、接下来进入主界面了(这个效果是文本框抖动效果)

activity_main.xml(先看主页面的布局文件)

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context="com.atguigu.l10_app2.MainActivity" ><EditTextandroid:id="@+id/et_main_number"android:layout_width="fill_parent"android:layout_height="wrap_content"android:text="@string/hello_world" /><Buttonandroid:id="@+id/button1"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_below="@id/et_main_number"android:text="提交" android:onClick="submit"/></RelativeLayout>
MainActivity.java

package com.atguigu.l10_app2;import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.EditText;public class MainActivity extends Activity {private EditText et_main_number;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);et_main_number = (EditText) findViewById(R.id.et_main_number);}public void submit(View v) {//水平振动Animation animation = AnimationUtils.loadAnimation(this, R.anim.shake);et_main_number.startAnimation(animation);}
}

实现水平震动的需要下面xml文件支持

cycle_6.xml

<?xml version="1.0" encoding="utf-8"?>
<cycleInterpolator xmlns:android="http://schemas.android.com/apk/res/android"android:cycles="6"/>

shake.xml

<?xml version="1.0" encoding="utf-8"?>
<translatexmlns:android="http://schemas.android.com/apk/res/android"android:fromXDelta="0.1"android:toXDelta="1.0"android:duration="500"android:interpolator="@anim/cycle_6"><!-- 配置文件里不能有f出现 -->
</translate>





这篇关于动画综合练习(延迟进入+页面向导+文本框抖动)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Flutter监听当前页面可见与隐藏状态的代码详解

《Flutter监听当前页面可见与隐藏状态的代码详解》文章介绍了如何在Flutter中使用路由观察者来监听应用进入前台或后台状态以及页面的显示和隐藏,并通过代码示例讲解的非常详细,需要的朋友可以参考下... flutter 可以监听 app 进入前台还是后台状态,也可以监听当http://www.cppcn

MySQL表锁、页面锁和行锁的作用及其优缺点对比分析

《MySQL表锁、页面锁和行锁的作用及其优缺点对比分析》MySQL中的表锁、页面锁和行锁各有特点,适用于不同的场景,表锁锁定整个表,适用于批量操作和MyISAM存储引擎,页面锁锁定数据页,适用于旧版本... 目录1. 表锁(Table Lock)2. 页面锁(Page Lock)3. 行锁(Row Lock

禁止HTML页面滚动的操作方法

《禁止HTML页面滚动的操作方法》:本文主要介绍了三种禁止HTML页面滚动的方法:通过CSS的overflow属性、使用JavaScript的滚动事件监听器以及使用CSS的position:fixed属性,每种方法都有其适用场景和优缺点,详细内容请阅读本文,希望能对你有所帮助... 在前端开发中,禁止htm

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

四种简单方法 轻松进入电脑主板 BIOS 或 UEFI 固件设置

《四种简单方法轻松进入电脑主板BIOS或UEFI固件设置》设置BIOS/UEFI是计算机维护和管理中的一项重要任务,它允许用户配置计算机的启动选项、硬件设置和其他关键参数,该怎么进入呢?下面... 随着计算机技术的发展,大多数主流 PC 和笔记本已经从传统 BIOS 转向了 UEFI 固件。很多时候,我们也

最好用的WPF加载动画功能

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

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

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

使用JavaScript将PDF页面中的标注扁平化的操作指南

《使用JavaScript将PDF页面中的标注扁平化的操作指南》扁平化(flatten)操作可以将标注作为矢量图形包含在PDF页面的内容中,使其不可编辑,DynamsoftDocumentViewer... 目录使用Dynamsoft Document Viewer打开一个PDF文件并启用标注添加功能扁平化

SpringBoot如何访问jsp页面

《SpringBoot如何访问jsp页面》本文介绍了如何在SpringBoot项目中进行Web开发,包括创建项目、配置文件、添加依赖、控制层修改、测试效果以及在IDEA中进行配置的详细步骤... 目录SpringBoot如何访问JSP页python面简介实现步骤1. 首先创建的项目一定要是web项目2. 在

MyBatis延迟加载的处理方案

《MyBatis延迟加载的处理方案》MyBatis支持延迟加载(LazyLoading),允许在需要数据时才从数据库加载,而不是在查询结果第一次返回时就立即加载所有数据,延迟加载的核心思想是,将关联对... 目录MyBATis如何处理延迟加载?延迟加载的原理1. 开启延迟加载2. 延迟加载的配置2.1 使用