"交叉进出"动画也是Windows动画库中的动画效果。"交叉进出"动画的动画效果是在应用程序界面上隐藏一个元素并同时在相同位置显示另一个元素的时候,被隐藏的元素渐消失在应用程序界面上,而将要显示的元素渐显示在应用程序界面上。

创建"交叉进出"动画可以使用WinJS.UI.Animation.crossFade函数,该函数有两个Object类型的参数,第一个参数是将要显示的元素对象或元素对象数组,第二个参数是将要消失元素的元素对象或元素对象数组,下面以一个应用程序为例,来演示如何使用HTML5和JavaScript实现"交叉进出"动画。在这个应用程序运行后,初始界面显示一张花朵图片,单击应用程序界面上的"显示"按钮后,花朵图片逐渐淡出界面,在花朵图片相同的位置一张小河图片逐渐显示。

新建一个JavaScript的Windows应用商店的空白应用程序项目,将其命名为CrossFadeAnimation。接着添加项目中用到的图片文件,在项目默认新建的文件夹images上单击右键,选择"添加"à"现有项",在本地文件夹中选择一张花朵图片和一张小河图片并添加到项目中。

完成添加图片的操作后,接下来打开default.html文件,在default.html文件的body元素中添加两个img元素和一个"显示"按钮,设置第一个img元素的id属性值为"flowerImage",src属性值为花朵图片的地址,用于显示一张花朵图片;设置第二个img元素的id属性值为"waterImage",src属性为小河图片的地址,用于显示一张小河图片;为"显示"按钮的id属性赋值"runAnimationButton",用于控制两个图片的显示。相应的HTML代码片段如下所示:

<body>

<img id="flowerImage" src="/images/花.png" />

<img id="waterImage" src="/images/河水.png" />

<button id="runAnimationButton">显示</button>

</body>

为了控制应用程序界面的显示外观,在default.css文件中添加如下代码来控制default.html页面的布局。

/*设置body元素的边距*/

body {

margin-left:300px;

margin-top:200px;

}

/*设置id属性值分别为"flowerImage"和"waterImage"的元素的位置和边距*/

#flowerImage, #waterImage

{

position: absolute;

width: 150px;

height: 150px;

}

/*设置id属性值为"runAnimationButton"的元素的边距*/

#runAnimationButton {

margin-left:30px;

margin-top:160px;

}

完成前台界面的布局后,应用程序界面效果如图19-27所示。

图19-27 "交叉进出"动画初始界面

布局好前台界面后,接下来介绍如何实现"交叉进出"动画。打开default.js文件,在"args.setPromise(WinJS.UI.processAll());"语句后添加如下代码,为"显示"按钮注册click事件的处理函数runAnimationButton_Click,并设置初始状态下小河图片完全透明。

runAnimationButton.addEventListener("click", runAnimationButton_Click);

waterImage.style.opacity = "0";

在上面的代码中,调用id属性值为"runAnimationButton"的元素对象的addEventListener函数为相应元素注册click事件处理函数,函数名为runAnimationButton_Click。接着通过设置waterImage.style对象中的opacity属性值为0,把id属性值为"waterImage"的元素设置为完全透明。

下面在"app.onactivated = function (args) {......};"语句的后面添加代码,定义事件处理函数runAnimationButton_Click,实现两张图片转换时"交叉进出"的动画效果。

function runAnimationButton_Click() {

var incomingImage;

var outgoingImage;

//判断id属性值为flowerImage的元素的不透明度是否为0

if (flowerImage.style.opacity === "0") {

//将要显示的元素对象赋值给incomingImage变量

incomingImage = flowerImage;

//将要隐藏的元素对象赋值给outgoingImage变量

outgoingImage = waterImage;

} else {

incomingImage = waterImage;

outgoingImage = flowerImage;

}

//调用WinJS.UI.Animation.crossFade函数创建"交叉进出"动画

WinJS.UI.Animation.crossFade(incomingImage, outgoingImage);

}

在上面的代码中,首先定义了两个变量incomingImage和outgoingImage,分别用于保存将要显示的元素对象和将要隐藏的元素对象。接着判断id属性值为"flowerImage"的元素的不透明度是否为0,如果为0将该元素对象赋值给incomingImage变量,将id属性值为"waterImage"的元素对象赋值给outgoingImage变量;如果不为0,将id属性值为"waterImage"的元素对象赋值给incomingImage变量,将id属性值为"flowerImage"的元素对象赋值给outgoingImage变量。最后,调用WinJS.UI.Animation.crossFade函数以incomingImage和outgoingImage为参数创建"交叉进出"动画。

启动调试,应用程序的初始界面如图19-27所示,单击"显示"按钮,界面上的花朵图片逐渐淡出,小河图片逐渐显示,小河图片显示后的效果如图19-28所示。

图19-28 "交叉进出"动画显示后的界面

Win10系列:JavaScript动画3的更多相关文章

  1. javascript动画系列第一篇——模拟拖拽

    × 目录 [1]原理介绍 [2]代码实现 [3]代码优化[4]拖拽冲突[5]IE兼容 前面的话 从本文开始,介绍javascript动画系列.javascript本身是具有原生拖放功能的,但是由于兼容 ...

  2. javascript动画系列第三篇——碰撞检测

    前面的话 前面分别介绍了拖拽模拟和磁性吸附,当可视区域内存在多个可拖拽元素,就出现碰撞检测的问题,这也是javascript动画的一个经典问题.本篇将详细介绍碰撞检测 原理介绍 碰撞检测的方法有很多, ...

  3. 梅须逊雪三分白,雪却输梅一段香——CSS动画与JavaScript动画

    CSS动画并不是绝对比JavaScript动画性能更优越,开源动画库Velocity.js等就展现了强劲的性能. 一.两者的主要区别 先开门见山的说说两者之间的区别. 1)CSS动画: 基于CSS的动 ...

  4. JavaScript动画知多少?

    今天,小学生以自己浅薄的见地,在前辈大能的基础上写这篇文章,希望给大家打开一扇窥探JavaScript(以下简称JS)动画的窗户. JS如何制造出动画效果? 结合浏览器提供的 setInterval ...

  5. Javascript动画效果(三)

    Javascript动画效果(三) 前面我们已经介绍了速度动画.透明度动画.多物体运动和任意值变化,并且我们在Javascript动画效果(二)中介绍到我们封装了一个简单的插件雏形,接下来我们对前面的 ...

  6. Javascript动画效果(一)

    Javascript动画效果(一) 前面我们介绍了Javascript的回到顶部效果,今天呢,我们对Javascript动画做进一步的研究.在这篇博文中我们只介绍简单的匀速运动.简单的缓冲运动和简单的 ...

  7. Javascript动画效果(二)

    Javascript动画效果(二) 在前面的博客中讲了简单的Javascript动画效果,这篇文章主要介绍我在改变之前代码时发现的一些问题及解决方法. 在前面的多物体宽度变化的例子中,我们给其增加代码 ...

  8. Javascript动画效果(四)

    Javascript动画效果(四) 前面我们自己写了一个小小的关于js动画的插件,下面我们来使用之前的框架来完成我们想要的动画效果.我们经常在淘宝网中看到,鼠标经过某一图片时,该图片有从上滚出而又从下 ...

  9. [Unity3D插件]2dtoolkit系列二 动画精灵的创建以及背景图的无限滚动

    经过昨天2dtoolkit系列教程一的推出,感觉对新手还有有一定的启发作用,引导学习使用unity 2dToolKit插件的使用过程,今天继续系列二——动画精灵的创建,以及背景图的无限循环滚动,在群里 ...

  10. 给力的轻量级JavaScript动画框架 - jsMorph

    jsMorph 是一个独立的轻量级 JavaScript 动画框架,可以用它来操纵多个 HTML 元素的样式,实现动画效果.此框架会自动检测起始位置.转换单位.调整渲染的速度,以此来获得更流畅的渲染体 ...

随机推荐

  1. 关于VUE调用父实例($parent) 根实例 中的数据和方法

    this.$parent或者 this.$root 在子组件中判断this.$parent获取的实例是不是父组件的实例 在子组件中console.log(this.$parent)  在父组件中con ...

  2. react面试问题总结

    1. 在生命周期中的哪一步你应该发起 AJAX 请求? 我们应当将AJAX 请求放到 componentDidMount 函数中执行,主要原因有下: 放到componentWillMount不好.  ...

  3. leecode第四十六题(全排列)

    class Solution { public: vector<vector<int>> permute(vector<int>& nums) { int ...

  4. 《剑指offer》第四十八题(最长不含重复字符的子字符串)

    // 面试题48:最长不含重复字符的子字符串 // 题目:请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子 // 字符串的长度.假设字符串中只包含从'a'到'z'的字符. #inclu ...

  5. 在浏览器端用es6,babel+browserify打包

    写得最清楚的是这个系列: 一个普通的写网页的人如何过渡到ES6 (一) 感觉比babel官网写得还清楚点. 看完这个才有点理解node原来不只是用来起express后端web server,更主要用途 ...

  6. lua中的闭包概念的学习笔记

    1.闭包的由来: 个人理解,lua中之所以出现闭包的概念,完全是因为lua中允许函数的嵌套定义,并且在内嵌函数中使用了外包函数中定义的局部变量,例如c.c#就不允许函数的嵌套定义(但是允许函数的嵌套调 ...

  7. 推送消息 web push notification

    参考 : https://developers.google.com/web/fundamentals/engage-and-retain/push-notifications/   ( step b ...

  8. (转)UCOSII在任务切换与出入中断时堆栈指针的使用

    1 uc/os ii在M3中的堆栈结构 1.1 M3入账序列  1.2 加上手工入栈序列  2 PendSV在Cortex-M3中的应用 Systick为嵌入到内核中,优先级比一般中断优先级高.若在一 ...

  9. English trip EM2-LP-3A Gifts Teacher:Patrick

    课上内容(Lesson) 词汇(Key Word ) Identify   vt. 确定:识别:使参与:把…看成一样 objects  n. 物体(object的复数):目标  # UFO   =   ...

  10. 『PyTorch』第三弹_自动求导

    torch.autograd 包提供Tensor所有操作的自动求导方法. 数据结构介绍 autograd.Variable 这是这个包中最核心的类. 它包装了一个Tensor,并且几乎支持所有的定义在 ...