Android官方开发文档Training系列课程中文版:动画视图之应用场景

原文链接:http://android.xsoftlab.net/training/transitions/transitions.html

在转场框架中,动画是由一帧帧的图像连续绘制形成的,这一帧帧的图像描述了启动场景到结束场景的整个过程。转场框架将这些动画作为一个转场对象,这个对象包含了动画的相关信息。如果要运行动画,需要提供一个转场对象,及结束场景对象给转场管理者。

这节课将会学习如何在场景转换中使用平移、缩放及淡入淡出动画。下节课将会学习如何定义自定义动画。

创建转场

在前面的课程中,我们学习了如何创建场景动画的相关知识。在定义了启动场景结束场景之后,还需要创建一个Transition对象。转场框架允许使用内置的转场对象或动态创建的转场对象。

由资源文件创建转场对象

这项技术的优点是,不用修改Java代码就可以实现转场定义的修改。这项技术还可以将复杂形式的转场定义代码分离成简单的形式,更多的信息请参见Specify Multiple Transitions。

如果要使用内置的转场资源,主要执行以下步骤:

  • 1.在工程中添加目录res/transition/。

  • 2.在上面的目录中创建一个新的XML资源文件。

  • 3.添加一个内置的转场节点到该文件中。

下面的示例代码使用了Fade转场动画:
res/transition/fade_transition.xml

<fade xmlns:android="http://schemas.android.com/apk/res/android" />

下面的代码段展示了如何加载转场资源:

Transition mFadeTransition =TransitionInflater.from(this).inflateTransition(R.transition.fade_transition);

动态创建转场对象

这项技术可以在代码中动态的创建转场对象,使得可以在代码中修改UI界面。创建简单的内置转场实例只需要少量的参数。

如果要创建内置的转场实例,需要调用类Transition子类其中的一个构造方法即可。下面的示例创建了一个Fade转场的实例:

Transition mFadeTransition = new Fade();

使用转场动画

通常需要使用转场动画来响应某些事件,比如用户的输入行为。考虑有这么一种情景,当用户输入了要搜索的关键词,按下了搜索按钮,接下来APP会变换场景,变换后的场景显示了搜索之后的结果,并且原来场景的输入框与搜索按钮会被隐藏。

为了使动画可以响应用户的某些输入,需要调用静态方法 TransitionManager.go(),并需要传入结束场景及转场动画:

TransitionManager.go(mEndingScene, mFadeTransition);

转场动画由转场实例所指定的结束场景开始,这里的启动场景是上一个转场动画的结束场景。如果没有上一个转场,那么启动场景会根据当前的UI状态自动决断。

如果没有指定转场实例,那么转场管理者会采用一种自动转场的动画。有关更多信息,请参见TransitionManager类。

选择指定的目标View

默认情况下,转场框架可以对所有的View执行转场。不过在某些情况下,可能需要将转场动画作用在View的子集上。比如,转场框架并不支持在ListView对象上使用动画,所以不要试图在ListView上使用动画。不过转场框架允许选择指定的View来使用动画。

每一个可以作用转场动画的View都被称为target.不过只可以选择其中一个与场景相关的部分.

如果要从target列表中要移除View,需要在启动转场之前调用removeTarget()方法。如果要往target列表中添加View,调用addTarget()方法即可。有关更多信息,请参见Transition类。

多重转场

为了能使动画引起更多的关注,应该使动画的类型与所发生的事件相匹配。比如说,在移除某些View的时候,使用淡出效果会在潜意识中告诉用户这个View不再可用。再比如,在屏幕上移动View,最好的方式就是使用动画可以描述整个移动过程,以便让用户注意到View移动到了新的位置上。

你大可不必纠结选哪一种动画才好,转场框架提供了一种整合动画的能力,它可以将内置动画或者自定义动画整合到一起一同执行。

如果要在XML中定义转场集合,需要在res/transitions/目录下创建一个资源文件,然后在文件中列出各个转场动画。下面的代码段定义了与AutoTransition类相同特性的定义:

<transitionSet xmlns:android="http://schemas.android.com/apk/res/android"android:transitionOrdering="sequential"><fade android:fadingMode="fade_out" /><changeBounds /><fade android:fadingMode="fade_in" />
</transitionSet>

如要加载上述的转场集合,需要调用TransitionInflater.from()方法。由于TransitionSet继承了Transition,所以可以像普通的Transition对象一样使用Transition对象集合。

在非场景中使用转场动画

更改View层级并不是修改UI界面的唯一方式。除此之外,还可以在单一层级中通过添加,修改,移除的方式更改用户界面。比如说,可以通过单一的布局来实现搜索界面。这个布局刚开始只显示了一个搜索的输入框与一个搜索图标。如果要显示搜索结果,需要在用户点击搜索按钮的时候通过调用ViewGroup.removeView()方法移除搜索按钮,然后通过ViewGroup.addView()方法添加搜索结果。

你可能在与上述情况相似的情况下采用过类似的解决方式。比起采用两个单独的布局文件而言,采用动态修改单个布局文件的方式也可以完成相同的效果。

如果要实现上面的情景,那么则不需要创建场景。相反,你可以使用延迟转场动画实现这种情况。转场框架的这个特性由当前View层级的状态开始,记录了该View层级的变化状态,最终在系统重绘UI时将转场应用到这个过程。

如果要使用单一的View层级创建延迟转场,需要执行以下步骤:

1.如果要触发转场事件的发生,则需要调用TransitionManager.beginDelayedTransition()方法,该方法暴露了两个参数:1.执行更改View的父View,2.要使用的转场动画。转场框架会存储更改View的当前状态及属性值。

2.要更改的View一定是跟使用情况相关的。转场框架会记录更改View的改变过程及属性。

3.在系统重绘用户界面的过程中,转场框架会在这个过程中执行动画。

下面的示例展示了如何使用延迟转场动画添加TextView。第一段定义了布局文件:
res/layout/activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/mainLayout"android:layout_width="match_parent"android:layout_height="match_parent" ><EditText
        android:id="@+id/inputText"android:layout_alignParentLeft="true"android:layout_alignParentTop="true"android:layout_width="match_parent"android:layout_height="wrap_content" />...
</RelativeLayout>

第二段定义了动画添加TextView的代码:

private TextView mLabelText;
private Fade mFade;
private ViewGroup mRootView;
...
// Load the layout
this.setContentView(R.layout.activity_main);
...
// Create a new TextView and set some View properties
mLabelText = new TextView();
mLabelText.setText("Label").setId("1");
// Get the root view and create a transition
mRootView = (ViewGroup) findViewById(R.id.mainLayout);
mFade = new Fade(IN);
// Start recording changes to the view hierarchy
TransitionManager.beginDelayedTransition(mRootView, mFade);
// Add the new TextView to the view hierarchy
mRootView.addView(mLabelText);
// When the system redraws the screen to show this update,
// the framework will animate the addition as a fade in

定义转场的生命周期回调

转场的生命周期与Activity的生命周期非常类似。它代表了由TransitionManager.go()方法开始到动画执行结束之间的完整的时间过程。在重要的生命过程中,转场框架会调用TransitionListener接口所定义的回调。

这些回调是极有用的,比如说,在场景转变的过程中复制View的属性值。你不能简单的将开始时View的值拷贝到结束时的View上,因为在转场完成之前结束中的View层级还没有完全被填充。相反的,你可以将值拷贝到一个变量中,然后在转场框架结束的时候将值拷贝到View层级中。为了可以在转场完成的时候获得通知,可以在Activity中实现TransitionListener.onTransitionEnd()方法。

有关更多信息,请参见TransitionListener类的相关说明。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/479064.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CAT 3.0 开源发布,支持多语言客户端及多项性能提升

项目背景 CAT&#xff08;Central Application Tracking&#xff09;&#xff0c;是美团点评基于 Java 开发的一套开源的分布式实时监控系统。美团点评基础架构部希望在基础存储、高性能通信、大规模在线访问、服务治理、实时监控、容器化及集群智能调度等领域提供业界领先的、…

论文浅尝 - TACL2020 | TYDI QA:Google 发表一个多语言的问答语料库

论文笔记整理&#xff1a;吴林娟&#xff0c;天津大学硕士。链接&#xff1a;https://arxiv.org/ftp/arxiv/papers/2003/2003.05002.pdf动机具有挑战性、值得信赖的评估数据可以促进多语言模型的发展&#xff0c;为了鼓励对多语言问答技术的研究&#xff0c;作者提出了数据集Ty…

读博总结的总结:读博的那些事儿

文 | 胡津铭知乎本文已获作者授权&#xff0c;禁止二次转载我时常给同学们推荐各种我看过的优质读博总结与建议文章&#xff0c;今天有了些空&#xff0c;整理一下我看过的优质文章。排名不分先后&#xff0c;想到啥写啥。先推荐英文的资源好了&#xff0c;因为我最推荐的一篇文…

NLP事件抽取综述(上中下):中文事件抽取、开放域事件抽取、事件数据生成、跨语言事件抽取、小样本事件抽取、零样本事件抽取等类型

https://github.com/xiaoqian19940510/Event-Extraction 近年来事件抽取方法总结&#xff0c;包括中文事件抽取、开放域事件抽取、事件数据生成、跨语言事件抽取、小样本事件抽取、零样本事件抽取等类型 NLP事件抽取综述下&#xff1a;

Android官方开发文档Training系列课程中文版:动画视图之创建自定义转场动画

原文地址&#xff1a;http://android.xsoftlab.net/training/transitions/custom-transitions.html 自定义转场可以创建自定义动画。比如&#xff0c;可以定义一种动画来更改文本的颜色或者将输入框的颜色置灰以表示不可用。 自定义转场与内置转场相同&#xff0c;都作用在Vi…

LeetCode 55. 跳跃游戏(贪心)

1. 题目 给定一个非负整数数组&#xff0c;你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个位置。 示例 1:输入: [2,3,1,1,4] 输出: true 解释: 从位置 0 到 1 跳 1 步, 然后跳 3 步到达最后一个位置。 示例…

论文浅尝 - ICLR2020 | Abductive Commonsense Reasoning

论文笔记整理&#xff1a;毕祯&#xff0c;浙江大学硕士&#xff0c;研究方向&#xff1a;知识图谱、自然语言处理。链接&#xff1a;https://arxiv.org/pdf/1908.05739.pdf动机尽管长期以来人们一直认为归因是人们在自然语言界线之间进行解释和阅读的核心&#xff0c;但很少有…

【基本功】深入剖析Swift性能优化

简介 2014年&#xff0c;苹果公司在WWDC上发布Swift这一新的编程语言。经过几年的发展&#xff0c;Swift已经成为iOS开发语言的“中流砥柱”&#xff0c;Swift提供了非常灵活的高级别特性&#xff0c;例如协议、闭包、泛型等&#xff0c;并且Swift还进一步开发了强大的SIL&…

Android官方开发文档Training系列课程中文版:连接无线设备之网络服务搜索功能

原文地址&#xff1a;http://android.xsoftlab.net/training/connect-devices-wirelessly/index.html 引言 Android设备除了可以与服务器建立连接之外&#xff0c;Android无线API还允许处于同一网段下的两台设备建立连接&#xff0c;或者是物理距离相近的两台设备建立连接。N…

新年立个小目标!代码写得更规范!

知乎作者叶小飞:作为Oppo Reno2 超级夜景核心开发人员和奔驰San Jos Pilot落地工程师之一&#xff0c;我写代码基本尽可能地遵循Google Style. 在这里写几个自己的习惯Google Style里面几个常用的要点。自己的习惯动手写代码前尽量做到胸中有丘壑。现在这世界讲究格局&#xff…

手把手教你用Keras实现英文到中文机器翻译 seq2seq+LSTM

原文链接&#xff1a;https://blog.csdn.net/qq_44635691/article/details/106919244 该模型实现的是英文到中文的翻译&#xff0c;下图为了更好展示模型架构借用大佬的图(这里没有用到Embeddings)&#xff1a; 本文完整代码:Github 目录 一、处理文本数据 1.获得翻译前后的句子…

LeetCode 45. 跳跃游戏 II(贪心/BFS,难)

文章目录1. 题目2. 解题2.1 贪心2.2 BFS1. 题目 给定一个非负整数数组&#xff0c;你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 你的目标是使用最少的跳跃次数到达数组的最后一个位置。 示例:输入: [2,3,1,1,4] 输出: 2 解释: 跳到最…

Android官方开发文档Training系列课程中文版:连接无线设备之通过WIFI创建P2P连接

原文地址&#xff1a;http://android.xsoftlab.net/training/connect-devices-wirelessly/wifi-direct.html#permissions Wi-Fi peer-to-peer (P2P) APIs可以使程序与附近的设备进行直接通讯&#xff0c;Android的Wi-Fi P2P框架由Wi-Fi Direct™提供技术支持。WI-FI P2P技术可…

深度剖析开源分布式监控CAT

CAT&#xff08;Central Application Tracking&#xff09;是一个实时和接近全量的监控系统&#xff0c;它侧重于对Java应用的监控&#xff0c;基本接入了美团上海侧所有核心应用。目前在中间件&#xff08;MVC、RPC、数据库、缓存等&#xff09;框架中得到广泛应用&#xff0c…

论文浅尝 | ​ADRL:一个基于注意力机制的知识图谱深度强化学习框架

论文笔记整理&#xff1a;谭亦鸣&#xff0c;东南大学博士。来源&#xff1a;Knowledge-Based Systems 197 (2020) 105910链接&#xff1a;https://www.sciencedirect.com/science/article/abs/pii/S0957417419306839概要与动机知识图谱推理是图谱构建的关键技术之一&#xff0…

新年第二弹|卖萌屋私藏书单大公开

夕本尊 &夕小瑶 推荐作为一个互联网人&#xff0c;不仅要懂技术&#xff0c;还应该了解行业的基本运作原理。这其中一个重要的问题是&#xff1a;为什么互联网产品&#xff08;基本&#xff09;都是免费的&#xff0c;甚至纷纷给用户送钱&#xff0c;它们却能有这么强的盈利…

LeetCode 437. 路径总和 III(双重递归)

1. 题目 给定一个二叉树&#xff0c;它的每个结点都存放着一个整数值。 找出路径和等于给定数值的路径总数。 路径不需要从根节点开始&#xff0c;也不需要在叶子节点结束&#xff0c;但是路径方向必须是向下的&#xff08;只能从父节点到子节点&#xff09;。 二叉树不超过…

2020年美团技术团队最受欢迎的16篇技术文章

2020年美团技术团队最受欢迎的16篇技术文章&#xff1a;https://tech.meituan.com/2021/01/01/2020-summary.html

论文浅尝 - ESWA | 知识图谱的自动扩充方法

论文笔记整理&#xff1a;谭亦鸣&#xff0c;东南大学博士。来源&#xff1a;ESWA141(2020)链接&#xff1a;https://www.sciencedirect.com/science/article/abs/pii/S0957417419306839为了使计算机理解人类语言&#xff0c;并且实现推理&#xff0c;人类知识需要被表示并储存…

美团大脑:知识图谱的建模方法及其应用

作为人工智能时代最重要的知识表示方式之一&#xff0c;知识图谱能够打破不同场景下的数据隔离&#xff0c;为搜索、推荐、问答、解释与决策等应用提供基础支撑。美团大脑围绕吃喝玩乐等多种场景&#xff0c;构建了生活娱乐领域超大规模的知识图谱&#xff0c;为用户和商家建立…