Flex移动应用程序开发的技巧和窍门(五)
This is Part 5 of a multipart series of articles that cover tips and tricks for Flex mobile development. Earlier parts focused on:
- Handling data when switching between views and between application executions
- Styling the ActionBar and tab components in your mobile app
- Controlling the visibility of the ActionBar and tab components, and moving the tab components to the top of your app
- Creating popup alerts
This article covers transitions when switching between views and when switching between tabs.
Using view transitions
While navigating through a Flex mobile application from view to view, by default one view slides off the screen as the new one slides on. You can change the animation or effect used in this view transition using one of four different classes that are available in the spark.transitions package in Flex 4.5:
- SlideViewTransition
- CrossFadeViewTransition
- FlipViewTransition
- ZoomViewTransition
Each of these transition classes can be applied with their default properties, or you can set the direction, duration, and mode (for some) to create a different effect. The following code snippets illustrate how each of these classes can be applied:
var flipTrans:FlipViewTransition = new FlipViewTransition(); flipTrans.direction = ViewTransitionDirection.UP; flipTrans.mode = FlipViewTransitionMode.CUBE; //or CARD mode navigator.pushView(SampleZoom,null,null,flipTrans); var zoomTrans:ZoomViewTransition = new ZoomViewTransition(); zoomTrans.direction = ViewTransitionDirection.RIGHT; zoomTrans.mode = ZoomViewTransitionMode.IN; //or OUT mode navigator.popToFirstView(zoomTrans); var slideTrans:SlideViewTransition = new SlideViewTransition(); slideTrans.direction = ViewTransitionDirection.DOWN; slideTrans.mode = SlideViewTransitionMode.UNCOVER; //or COVER and PUSH modes navigator.pushView(SampleZoom,null,null,slideTrans); var fadeTrans:CrossFadeViewTransition = new CrossFadeViewTransition(); fadeTrans.direction = ViewTransitionDirection.LEFT; // no modes are available for CrossFadeViewTransition navigator.pushView(SampleZoom,null,null,fadeTrans);
By default SlideViewTransition (with PUSH
mode and LEFT
direction) is used for the pushing and popping of all views. You can change the default transition used when a new view is pushed onto the stack by settingnavigator.defaultPushTransition
. Likewise, you can setnavigator.defaultPopTransition
to change the default transition used when the view is popped off the view stack (so the view beneath it is shown) .
In either case, you set the property to an instance of a transition class; for example:
navigator.defaultPushTransition = new FlipViewTransition(); navigator.defaultPopTransition = new FadeViewTransition();
You can set these properties on any navigator within the main ViewNavigatorApplication or TabbedViewNavigatorApplication. You can also set them on the View class itself. However, if you want the change to apply to the entire application, set it in the root application code.
To see how this works, download the sample files for this article and import ViewTransitionsSample.fxp into Flash Builder. The application (see Figure 1) demonstrates the transitions and shows how to use the different modes that are available. For example, with FlipViewTransition you can see the difference betweenCARD
and CUBE
mode. You can also test how applying an easing function such as Bounce
or Elastic
might affect how it plays. Fun stuff!

Below is a short video clip of the application running on an iPod Touch. It's nothing fancy, but you can see the different effects played when the four different view transition types are used.
All of the ViewTransition classes extend ViewTransitionBase. The ViewTransitionBase class (and all that extend it) will dispatch FlexEvent.TRANSITION_START
and FlexEvent.TRANSITION_END
events when the transition starts and ends respectively. You can create your own custom transitions by extending ViewTransitionBase. If you plan to do so though, you should first review the Flex 4.5 ViewTransition specification. Note that this is the original specification and some names of properties, events, and other details have changed.
Implementing tab transitions
The ViewTransition classes are great for applying an effect to your view navigation within a ViewNavigator. However, you cannot use the ViewTransition classes when switching between tabs, because you are no longer operating within the same ViewNavigator, but rather between ViewNavigator containers. It is, however, still possible to apply similar effects to those provided by ViewTransition, and I've outlined one approach below.
First, you need to add an IndexChangeEvent handler to the implicit tabbedNavigator
property in your TabbedViewNavigatorApplication on applicationComplete
; for example:
protected function tabbedviewnavigatorapplication1_applicationCompleteHandler(event:FlexEvent):void { this.tabbedNavigator.addEventListener(IndexChangeEvent.CHANGE,onChange); }
The IndexChangeEvent.CHANGE
event is dispatched when a tab is selected, so you can perform any necessary handling within the handler. In this case, you want to apply a Spark Effect to the View that is being selected. You can check the newIndex
property on the IndexChangeEvent
and play different effects for each tab if you want.
You'll need to set up some effects to use. For example, you can define the following in the root application MXML:
<fx:Declarations> <s:Sequence id="seqEffect"> <s:Parallel> <s:Scale duration="800" id="scaleUp" scaleXBy=".8"/> <s:Rotate3D angleYFrom="0.0" angleYTo="360" duration="1600" repeatCount="{2}" repeatBehavior="reverse"/> </s:Parallel> <s:Scale duration="300" id="scaleDown" scaleXBy="-.8"/> </s:Sequence> <s:Move3D id="moveEffect" duration="300" xFrom="400" xTo="0"/> <s:Fade duration="800" id="fadeEffect" alphaFrom="0" alphaTo="1.0"/> </fx:Declarations>
Note: If you're not familiar with Spark Effects, check out Tour de Flex under Flex 4 > Components > Effects to see examples of how to use them all.
In the onChange
handler, simply check the event index and set the target of the effect to the matching ViewNavigator container's activeView
property:
protected function onChange(event:IndexChangeEvent):void { if (event.newIndex == 0) seqEffect.play([v1.activeView]); else if (event.newIndex == 1) moveEffect.play([v2.activeView]); else if (event.newIndex == 2) fadeEffect.play([v3.activeView]); }
Since you're handling the IndexChangeEvent.CHANGE
event and not theIndexChangeEvent.CHANGING
event, you can be sure that activeView
has been set to the ViewNavigator container's new active view.
When the effects are played you will see a transition of sorts similar to what you might see when using a ViewTransition. You can see that you could also create more complex transitions using a sequence or parallel set of effects, and even add an easing function if desired. To simply mimic the ViewTransition classes, you would likely use the Spark Fade, Move, Rotate3D, and Scale effects alone to replicate the CrossFadeViewTransition, SlideViewTransition, FlipViewTransition, and ZoomViewTransition classes respectively. The code above will cause the effect to apply to the View itself, similar to how the ViewTransition classes work by default. However, you could also have the effect include the action bar in the animation as well by changing the code as follows:
protected function onChange(event:IndexChangeEvent):void { if (event.newIndex == 0) seqEffect.play([v1]); else if (event.newIndex == 1) moveEffect.play([v2]); else if (event.newIndex == 2) fadeEffect.play([v3]); }
Here is the full source for the main TabbedViewNavigatorApplication class:
<?xml version="1.0" encoding="utf-8"?> <s:TabbedViewNavigatorApplication xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" applicationComplete="tabbedviewnavigatorapplication1_applicationCompleteHandler(event)"> <fx:Style source="styles.css"/> <fx:Script> <![CDATA[ import mx.events.FlexEvent; import spark.events.IndexChangeEvent; import views.SlideView; protected function tabbedviewnavigatorapplication1_applicationCompleteHandler(event:FlexEvent):void { this.tabbedNavigator.addEventListener(IndexChangeEvent.CHANGE,onChange); } protected function onChange(event:IndexChangeEvent):void { if (event.newIndex == 0) seqEffect.play([v1.activeView]); else if (event.newIndex == 1) moveEffect.play([v2.activeView]); else if (event.newIndex == 2) fadeEffect.play([v3.activeView]); } ]]> </fx:Script> <fx:Declarations> <s:Sequence id="seqEffect"> <s:Parallel> <s:Scale duration="800" id="scaleUp" scaleXBy=".8"/> <s:Rotate3D angleYFrom="0.0" angleYTo="360" duration="1600" repeatCount="{2}" repeatBehavior="reverse"/> </s:Parallel> <s:Scale duration="300" id="scaleDown" scaleXBy="-.8"/> </s:Sequence> <s:Move3D id="moveEffect" duration="300" xFrom="400" xTo="0"/> <s:Fade duration="800" id="fadeEffect" alphaFrom="0" alphaTo="1.0"/> </fx:Declarations> <s:ViewNavigator id="v1" label="Welcome" width="100%" height="100%" firstView="views.WelcomeView" activate="seqEffect.play([v1.activeView])"/> <s:ViewNavigator id="v2" label="Slide View" width="100%" height="100%" firstView="views.SlideView" /> <s:ViewNavigator id="v3" label="Fade View" width="100%" height="100%" firstView="views.FadeInView" /> </s:TabbedViewNavigatorApplication>
If you want to play an initial effect when the application is run on the first view, you can also add anactivate
event handler on the ViewNavigator and play the effect on the active view in the same manner, such as:
<s:ViewNavigator id="v1" label="Welcome" width="100%" height="100%" firstView="views.WelcomeView" activate="effect1.play([v1.activeView])"/>
Here's a short, 28-second video of this running on my iPhone 4:
The full source code for the sample application (see Figure 2) is available with the sample files for this article.

Flex移动应用程序开发的技巧和窍门(五)的更多相关文章
- Flex移动应用程序开发的技巧和窍门(三)
这是关于 Flex 移动应用程序开发的技巧和窍门系列文章的第三部分内容.第一部分内容主要集中讨论了视图之间以及应用程序执行之间切换时的数据处理.第二部分则主要涵盖了应用程序动作条和标签组件风格化方面的 ...
- Flex移动应用程序开发的技巧和窍门(二)
范例文件 flex-mobile-dev-tips-tricks-pt2.zip 这是关于Flex移动应用程序开发的技巧和窍门的一系列文章中的第二部分.第一部分 内容主要集中讨论了视图之间以及应用程序 ...
- Flex移动应用程序开发的技巧和窍门(一)
这是一个由多个部分组成的系列文章的第一部分,它包含了Flex移动开发的若干技巧.如果你过去习惯于桌面和Web编程,你会发现,开发移动应用程序将面临一系列新的挑战. 除了重新思考你的对数据存储和处理的策 ...
- Flex移动应用程序开发的技巧和窍门(四)
范例文件 flex-mobile-dev-tips-tricks-pt4.zip 这是本系列文章的第四部分,该系列文章涵盖Flex移动开发的秘诀与窍门. 第一部分关注切换视图以及切换执行应用时的数据处 ...
- 微信小程序开发调试技巧
1. 查看线上小程序console a. 先打开开发小程序console b. 再打开线上小程序,此时可以查看console
- 微信小程序开发小技巧——单击事件传参、动态修改样式、轮播样式修改等
一. 脚本部分: 1. 表达式无效的处理: 如果你发现自己编写的表达式无效或者数据不展示,那么请先检查你的表达式是否有添加{{}},小程序中全部都要添加的,只要是在模板中调用js中的数据 2. 获取元 ...
- 微信小程序开发小技巧:
小技巧:输入view.tabs_content就可以生成下面的代码. 输入p10,就可以得到: 输入jc:c得到:文字水平对齐 输入d:f得到: 输入ai:c得到: 输入bb得到: currentCo ...
- flex开发小技巧集锦
关于flex开发网上有非常多的相关信息介绍,因此我们要想学习关于flex开发的知识信息技能是一件非常简单和方便的事情.而针对于flex开发小编要告诉大家的是一些flex开发小技巧.利用这些小技巧能够有 ...
- 【Abode Air程序开发】Flex air文件打包和运行
1 安装Adobe AIR 运行时,和java的JVM类似. Adobe AIR 运行时允许在桌面运行AIR应用程序,脱离游览器的束缚. 下载安装文件http://get.adobe.com/cn/a ...
随机推荐
- Python 100例(上)
如果你已经把基础看完,可以尝试一下看看以下例子了,如果不会做也不要紧,你要尝试手动把所有的代码都敲一边.别嫌麻烦,因为都是从麻烦到简单的. 实例1: 题目:有1.2.3.4个数字,能组成多少个相互不同 ...
- xtrabackup数据库备份
xtrabackup备份 一.Xtrabackup概述 1.1.简介 Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Ho ...
- selenium firefox
https://github.com/SeleniumHQ/selenium/blob/master/java/CHANGELOG https://github.com/mozilla/geckodr ...
- 无源RS232转RS485(转)
源:无源RS232转RS485 RS232 -485转换器主要包括了电源.232电平转换.485电路三部分.本电路的232电平转换电路采用了NIH232或者也可以直接使用MAX232集成电路,485 ...
- 一、Hbase的安装
一.Hbase配置 这个是我从网上找的一个版本,网上说配置成功. 先决条件: (1)hadoop的版本与hbase的版本要对应,主要是hadoop目录下的hadoop-core-1.0.4.jar的版 ...
- ios开发获取SIM卡信息
.加入一个Framework(CoreTelephony.framework). .引入头文件 #import<CoreTelephony/CoreTelephonyDefines.h> ...
- hellocharts-android开源图表库(效果非常好)
泡在网上的日子 发表于 2014-11-07 12:28 第 33156 次阅读 chart 2 编辑推荐:稀土掘金,这是一个高质量的技术干货分享社区,web前端.Android.iOS.设计资源和产 ...
- 16、手把手教你Extjs5(十六)Grid金额字段单位MVVM方式的选择
这一节来完成Grid中的金额字段的金额单位的转换.转换旰使用MVVM特性,总体上和控制菜单的几种模式类似.首先在目录app/view/main/menu下建立文件Monetary.js,用于放金额单位 ...
- JAVA判断32位还是64位,调用不同的DLL(转)
源:JAVA判断32位还是64位,调用不同的DLL 通过获取sun.arch.data.model可判断是32还是64的JAVA 将32或者64位的DLL放不同的目录,实现自适应调用DLL Prope ...
- 全方位分析Objcetive-C Runtime
本文详细整理了 Cocoa 的 Runtime 系统的知识,它使得 Objective-C 如虎添翼,具备了灵活的动态特性,使这门古老的语言焕发生机.主要内容如下: 引言 简介 与Runtime交互 ...