Win10系列:JavaScript 动画1

在应用程序中使用动画会使应用显得更加生动,进而给用户带来良好的视觉效果。例如,当用户将某个项添加到列表时,新项不会立即出现在列表中,而是采用动画形式到达相应位置,并且列表中的其他项也采用动画形式移动到新位置,以便为添加的项腾出空间。这样的动画效果能够让用户更清晰地看到变化过程,而不是只能看到变化之后的结果。

应用程序的动画效果可以使用Windows动画库来创建,开发人员无需自己编写动画效果代码即可获得Metro风格的动画外观和效果。另外还可以通过设置页面元素的style对象的相关属性来创建。下面介绍几种常用的动画效果。

(1)展开动画和折叠动画

展开动画和折叠动画是Windows动画库中的动画效果。展开动画可以在视图中腾出空间以显示更多信息,例如,显示错误消息时会使视图中的其他内容发生移动,以便为该消息腾出空间;折叠动画可以隐藏附加内容,以便显示有关特定项的较少信息。

创建展开动画可以使用WinJS.UI.Animation命名空间中的createExpandAnimation函数来实现,这个函数有两个参数,一个是revealed,另一个是affected。其中,revealed是一个Object类型的对象,表示要被展开的元素;affected也是一个Object类型的对象,表示当展开revealed元素时位置需要移动的元素。createExpandAnimation函数会返回一个Object类型的对象,通过这个对象调用execute函数来执行已创建的动画。

创建折叠动画可以使用WinJS.UI.Animation命名空间中的createCollapseAnimation函数来实现,这个函数也有两个参数,一个是hidden,另一个是affected。其中,hidden是一个Object类型的对象,表示要被折叠的元素;affected也是一个Object类型的对象,表示当折叠hidden元素时位置需要移动的元素。createCollapseAnimation函数同样会返回一个Object类型的对象,通过此对象的execute函数来执行动画。

下面以一个应用程序为例,来演示如何使用HTML5和JavaScript创建展开动画和折叠动画。在这个应用程序中,可以以动画的形式向应用程序界面中添加一个界面元素,也可以以动画的形式从界面中移除一个元素。

新建一个JavaScript的Windows应用商店的空白应用程序项目,将其命名为ExpandAndCollapseApp。打开default.html文件,在body元素中添加一个h3元素、一个按钮和四个div元素。其中,h3元素用来显示页面标题"展开-折叠动画示例";四个div元素用于定义四个文本区,内容分别为"原区域1"、"扩展区域"、"原区域2"和"原区域3",其中内容为"扩展区域"的文本区初始时不显示;按钮则用来在应用程序界面中添加或移除内容为"扩展区域"的文本区,初始文本内容为"展开"。相应的HTML代码片段如下所示:

<body>

<h2 class="articleTitle">展开-折叠动画示例</h2>

<br />

<button id="runAnimation">展开</button>

<br />

<div class="area">原区域1</div>

<div id="expandedItem" class="area" style="display: none">扩展区域</div>

<div class="area affectedItem">原区域2</div>

<div class="area affectedItem">原区域3</div>

</body>

在上面的代码中,为了便于设计CSS样式和检索控件,在添加控件时为其设置了类名和ID。其中,设置h2元素的class属性值为articleTitle,内容为"原区域1"和"扩展区域"的两个div元素的class属性值为area,而内容为"原区域2"和"原区域3"的两个div元素的class属性值都是area affectedItem;按钮的id属性值被设置为runAnimation,内容为"扩展区域"的div元素的id属性值则为expandedItem。

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

/*设置h2元素的字体大小和在应用程序界面中的显示位置*/

.articleTitle {

font-size: large;

margin: 20px 15px 10px 45px;

}

/*为class属性值为"area"的元素设置样式*/

.area {

height: 50px;

width: 100px;

margin: 0px 15px 10px 70px;

text-align: center;

color: white;

background: #808080;

}

/*为id属性值为"runAnimation"的元素设置样式*/

#runAnimation {

border-color: gray;

border-width: thin;

margin: 0px 20px 15px 75px;

}

/*为id属性值为"expandedItem"的元素设置背景色*/

#expandedItem {

background: #00B6FF;

}

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

图19-23 前台界面效果图

布局好前台界面后,接下来介绍如何将一个内容为"扩展区域"的文本区在两个原区域之间添加和移除,并在此过程中配合展开和折叠动画效果。打开default.js文件,在"args.setPromise(WinJS.UI.processAll());"语句后添加如下代码,为"展开"按钮注册click事件的处理函数ExpandOrCollapse。

document.getElementById("runAnimation").addEventListener("click", ExpandOrCollapse);

以"runAnimation"为参数调用document对象的getElementById函数来查找id属性值为runAnimation的元素对象,并调用addEventListener函数为该元素对象,也就是"展开"按钮的click事件注册事件处理函数ExpandOrCollapse。

接着在default.js文件中的"app.onactivated = function (args) {...};"语句后添加"展开"按钮的click事件处理函数ExpandOrCollapse的代码。

function ExpandOrCollapse() {

var affectedElement = document.querySelectorAll(".affectedItem");

if (expandedItem.style.display === "none") {

ExpandItem(expandedItem, affectedElement);

runAnimation.innerText = "折叠";

}

else {

CollapseItem(expandedItem, affectedElement);

runAnimation.innerText = "展开";

}

}

在上面的代码中,首先以".affectedItem"作为参数调用document对象的querySelectorAll函数来查找class属性值为affectedItem的所有元素对象,并保存到变量affectedElement中。然后通过style对象中的样式属性display来判断id属性值为expandedItem的元素对象的显示状态,如果display属性值为none,说明id属性值为expandedItem的元素对象没有显示在页面中,则以expandedItem和affectedElement作为参数调用ExpandItem函数将其显示,并设置id属性值为runAnimation的元素对象的innterText属性值为"折叠",使得按钮的文本内容变为"折叠";如果display属性值不为none,说明 id属性值为expandedItem的元素对象已经显示在页面中,则以expandedItem和affectedElement作为参数调用CollapseItem函数将其隐藏,并将id属性值为runAnimation的元素对象的innterText属性赋值为"展开",使得按钮的文本内容变为"展开"。这里使用的ExpandItem和CollapseItem函数为自定义的函数,下面分别来介绍这两个函数的实现代码。

ExpandItem函数用来在应用程序界面中以动画的形式添加内容为"扩展区域"的文本区,该函数的代码添加在ExpandOrCollapse函数后,相应的JavaScript代码片段如下所示:

function ExpandItem(expansionElement, affectionElement) {

// 新建展开动画对象

var expandAnimation = WinJS.UI.Animation.createExpandAnimation(expansionElement, affectionElement);

// 设置待展开元素的样式属性

expansionElement.style.display = "block";

expansionElement.style.position = "inherit";

expansionElement.style.opacity = "1";

//执行展开动画

expandAnimation.execute();

}

代码中首先以Win10系列:JavaScript 动画1

时间: 2024-10-27 13:55:58

Win10系列:JavaScript 动画1的相关文章

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

× 目录 [1]原理介绍 [2]代码实现 [3]代码优化[4]拖拽冲突[5]IE兼容 前面的话 从本文开始,介绍javascript动画系列.javascript本身是具有原生拖放功能的,但是由于兼容性问题,以及功能实现的方式,用的不是很广泛.javascript动画广泛使用的还是模拟拖拽.本文将详细介绍该内容 原理介绍 模拟拖拽最终效果和在桌面上移动文件夹的效果类似 鼠标按下时,拖拽开始.鼠标移动时,被拖拽元素跟着鼠标一起移动.鼠标抬起时,拖拽结束 所以,拖拽的重点是确定被拖拽元素是如何移动的

Win10系列:JavaScript 控件的使用

向页面中添加的控件可分为两种类型:标准的HTML控件和WinJS库控件.其中标准的HTML控件是指HTML标准中定义的基本控件,如按钮和复选框:WinJS库控件是为开发基于JavaScript 的Windows应用商店应用提供的新控件,如ListView.HtmlControl和PageControl等.下面首先介绍如何添加这两种类型的控件,然后介绍如何为控件注册事件处理函数和设计控件的样式. (1)添加标准的HTML控件 向页面中添加标准的HTML控件可以通过定义相应的HTML元素来实现.例如

Win10系列:JavaScript综合实例1

上面几个小节讲解了使用HTML5和JavaScript语言开发Windows 应用商店应用时会用到的一些技术,本小节将前面介绍的知识融合在一起创建一个菜谱应用程序,帮助读者更进一步地理解和掌握这些知识. 此菜谱应用程序主要的功能是介绍一些菜肴和主食的做法,其中包含三个页面:第一个页面为主页面,用于按类别显示一些菜肴和主食:第二个页面为分类页面,显示某个类别的信息和属于该类别的菜肴或主食:第三个页面为菜肴页面,显示某项菜肴或主食的详细信息,如名称.图片和具体做法.这三个页面可以相互跳转,例如,在主

Win10系列:JavaScript页内导航

页内导航是在一个页面内根据需要加载其他页面的内容,在开发基于JavaScript的Windows应用商店应用时,可以使用WinJS.Navigation.navigate函数传递要加载的页面地址并使用PageControlNavigator控件加载其他页面的内容.WinJS.Navigation.navigate函数以一个包含页面地址的对象为参数,在该函数执行时将触发WinJS.Navigation.onnavigated事件并把页面地址传递给该事件.PageControlNavigator控件

Win10系列:JavaScript 模板绑定

WinJS库模板提供了一种格式化显示多条数据的便捷方式,通过这种方式可以将模板与ListView或FlipView等控件结合使用以控制数据的显示格式.定义一个WinJS库模板的方法与定义WinJS库控件的方法相似:在页面中添加一个div元素,将div元素的data-win-control属性设置为WinJS.Binding.Template.定义WinJS库模板以后,需要在Win10系列:JavaScript 模板绑定

Win10系列:JavaScript多媒体

布局好前台界面后,下面来应用的后台逻辑功能.打开default.js文件,在文件中的"args.setPromise(WinJS.UI.processAll());"语句后添加如下代码,为"打开"按钮注册click事件处理函数,相关代码如下所示: document.getElementById("pickFileButton").addEventListener("click", pickFile); 代码调用getEleme

Win10系列:JavaScript页面导航

页面导航是在开发应用的过程中使用频率较高的技术,其中比较常用的导航方式有多页导航和页内导航,采用多页导航方式的应用程序包含一系列的页面,在一个页面中加入另一个页面的链接地址后,单击链接将跳转到指定页面,从而实现页面之间的导航.而页内导航方式是在一个页面内根据需要加载其他页面,使用页内导航方式的应用程序仍然包含一系列的页面,不同的是,这些页面是顺序被加载到一个选定的页面区域中,而不是从一个页面跳转到另一个页面.在传统的网站开发中,通常使用多页导航的方式,在开发基于JavaScript的Window

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

前面的话 前面分别介绍了拖拽模拟和磁性吸附,当可视区域内存在多个可拖拽元素,就出现碰撞检测的问题,这也是javascript动画的一个经典问题.本篇将详细介绍碰撞检测 原理介绍 碰撞检测的方法有很多,接下来使用九宫格分析法 假设黄色元素要与红色元素进行碰撞.将红色元素所处的区域分为9部分,自身处于第9部分,周围还存在8个部分.只要黄色元素进入红色元素的第9部分,就算碰撞.否则,都算未碰撞 总共分为以下5种情况: 1.处于上侧未碰撞区域——1.2.3区域 2.处于右侧未碰撞区域——3.4.5区域

Win10系列:C#应用控件基础14

ProgressBar控件 有时候用户需要执行比较复杂的任务,等待任务完成需要很长时间,在等待的过程中一般会使用进度条提示当前任务的执行进度,让用户更好的掌握任务的执行状态,例如在下载资源时会显示下载进度,发送文件时会显示发送进度等.使用ProgressBar控件能够在界面中为用户提供任务进度变化信息. ProgressBar控件分为确定进度条和不确定进度条两种进度显示样式.确定进度条通过从左到右用色块填充的方式表示一个较长操作的进度信息,而不确定进度条使用重复显示的动画证明任务仍在进行中. 在