Silverlight是微软最近主要的开发技术之一。渴望开发Silverlight应用程序的开发人员必须对Silverlight的问题和步骤有充分的认识。这篇文章中我们重点介绍创建Silverlight应用程序的过程。
Silverlight的发展符合微软技术的发展逻辑。微软技术中,除了用于交互以及创建Web应用程序的ASP(微软的{dy}个动态网页开发技术)以外的其他技术,都已经得到了很大的发展。正如前面文章所述,为了保持行业竞争力,微软决定xx重新设计并巩固所有开发技术到一个单一的平台中,即.NET Framework。所有微软开发技术从来都没有重新围绕.NET Framework设计,但是所有的技术却自2000年以来都被独立重新设计更新过。
.NET 框架是开发环境中应用的{zlx}和最通用的。.NET 框架的一个重点是ASP.NET。ASP.NET是ASP的.NET框架版本。ASP.NET用来创建非常强大的动态Web应用程序,用以处理那些在服务器上零散发生的处理流程。
Web经过多年的演变,企业和开发人员已经习惯了Web作为主要的开发平台。一个新词被用来形容新的Web应用程序:Web 2.0。Web 2.0规定Web应用程序应该简化原始开发人员的工作,而且应该能够引进其他公司或开发人员提供的服务。Web2.0应用程序的部分设计功能应该由最终用户参与定制到服务器上,并能够整合媒体和动画。
多年来,Web开发人员开始研究如何提升Web应用程序的性能。Web已经组合了数以百万计的互联网计算机,同时,大量零散的处理流程在服务器产生。Web 2.0表明网络,包括互联网,应该具有分布式计算能力的机群。绝大多数Web上的计算机,客户端计算机,多年以来一直作为哑终端。开发人员已经看到了如何利用那些连接到互联网中的客户端机器中未开发计算能力的方法。许多方法,例如ASP.NET AJAX,已经开发出了比标准Web应用程序能更多的在客户端机器上运行处理的平台。ASP.NET AJAX使用JavaScript,以XML的格式异步传输数据到服务器端,从而改善了用户对性能的感知,实现了更好的用户体验。旨在提高性能,为用户提供一个更好的用户体验的Web应用程序,被称为丰富的交互式应用程序(RIA)。
标准RIA解决方案的缺点是,他们使用JavaScrip执行客户端处理。JavaScript功能非常强大,但是直接由客户端浏览器执行,因此能否真确执行脚本主要依赖浏览器的能力。
微软开始尝试扩展ASP.NET AJAX来进一步控制客户端计算机环境。微软还希望确定如何可以提供类似于WPF技术那样,创建更神奇的用户界面的技术。因此,微软开发出一种新的可下载的插件技术来扩展ASP.NET AJAX,并且包含了WPF的效果和功能。由此产生了WPF/E的技术,并最终命名为Silverlight。
Silverlight有三个版本:1.0、2.0和3.0。1.0版本功能相当有限,而且JavaScript是{wy}的语言支持。2.0版本包括很多新的功能和许多.NET兼容的编程语言。3.0版本扩展并改进了Silverlight 2中的功能和特性。
Silverlight是WPF的一个自己和扩展,而且它采用了很多ASP.NET AJAX的很多功能和技术。随着大量针对Web的软件开发的涌现,许多开发人员质疑有了Silverlight,为什么还要开发WPF应用程序。答案是,这两种技术各有优势。Silverlight的优势在于它在Web上的可移植性。然而,Silverlight是跨平台跨浏览器变异的,因此它是平台无关的,而且不能依赖任何特定平台的优势和硬件支持,来实现更先进的图形功能要求。更先进的图形功能要求需要硬件的支持,而且必须采用特定平台的技术优势。因此,WPF中提供了先进的3-D图形功能,而且效果非常好。而Silverlight是不能提供这些功能的。Silverlight中不能依赖任何硬件,尤其是现在,更限制了它对3-D图像、语音和语音识别、录音等的硬件支持能力。尽管有少量第三方开发商在用Silverlight模拟3-D环境。
Silverlight 3同样限制在客户端访问本地硬件。然而,Silverlight 3引入了一个利用2-D图像模拟3-D的环境的新3-D仿真功能。新的3-D仿真功能叫做视角3-D。视角3-D使用一个简单的XAML元素来调整观察者的图片视角。视角3-D会在下篇文章中介绍。
Silverlight功能必须执行在一个安全的沙箱区域中,以提供安全的客户端环境。但是,安全的沙箱限制了Silverlight直接与宿主操作系统互操作的能力,以及直接进行I/O操作的能力。Silverlight 3通过“文件另存为”对话框扩展了一些客户端I/O交互的功能,而且用户还可以拥有离线浏览(OOB)运行Silverlight应用程序的能力。使用“文件另存为”对话框以及创建离线浏览应用程序,会在后面文章中介绍。
Silverlight和WPF的能力和约束实际上是设计平台环境影响的结果,使他们各自针对不同的平台。Silverlight是WPF的子集也仅仅是因为无法像WPF中那样充分应用色域。
Silverlight中有许多明显的竞争优势,包括它速度极快的渲染引擎和性能。一般应用在Web上的性能测试工具都可以说明Silverlight的性能优势。一个典型的工具就是BubbleMark,可在。该工具可以用来比较时下绝大多数开发环境的渲染速度。下图显示了BubbleMark的主页。
BubbleMark.com还推出了一个使用Silverlight模拟3-D环境的示例,如下图所示:
Silverlight插件可以直接下载和安装。用户只需要有一个支持的操作系统,并具有一个支持Silverlight应用程序的Web浏览器。
作为Silverlight 3的入门开发人员,你需要在Windows中安装4个组件:
● Silverlight 3 运行时
● Silverlight 3 软件开发包 (SDK)
● Silverlight 3 的Visual Studio 工具
● Silverlight 3 控件包
此外作为一个资深的Silverlight开发人员,你可能需要安装Expression Blend 3.Expression Blend是Expressiong 套件的组件之一,在后面文章会详细介绍。
预计要使用服务器端数据开发Silverlight应用程序的开发人员,需要安装.NET RIA服务网。.NET RIA服务会在后面文章中详细介绍。
Silverlight 3的帮助文档可以通过在线或手动下载的方式独立查看CHM帮助文件。
Silverlight 3运行时的安装初始窗体如下图所示。从这个窗体中,单击“立即安装”按钮开始安装。
Silverlight 3屏幕会显示安装成功。一旦安装完成后,单击“关闭”按钮。
Silverlight运行时还可以安装在Macintosh上。Silverlight 3安装向导包括一些额外的步骤和安装选项。
Silverlight 开发人员使用安装在Windows上的Visual Studio 2010,需要下载和安装Silverlight 3的Visual Studio工具。Visual Studio 2010工具的下载包括了Silverlight 3运行时和Silverlight软件开发包(SDK),以及Visual Studio 2010工具。如果你以开发人员的身份安装Silverlight,那么Visual Studio 2010工具是{wy}必要的。
Silverlight 3 的工具包是对Silverlight 2的升级和增强,并加入了额外的Silverlight控件和主题。
Expression Blend是微软设计工具套件Expression中的组件之一。Expression 套件中的工具是用来为WPF和Silverlight应用程序编辑媒体、图形以及用户界面的工具集。Expression Blend使用图形化的设计和XAML布局设计用户界面。
.NET RIA Services是一项新的服务平台,它运行在中间层中,控制数据访问,并提供一贯的和标准的创建RIA中间层和后端代码的方法。它可以将Silverlight和ASP.NET牢固的结合在一起。
Silverlight 3帮助文档可以在MSDN在线库中浏览:,或者自行下载微软帮助文档格式的文件。
许多供应商和开发商都在为使用Silverlight而积极创造编辑工具和设计工具。这里讨论两个主要Silverlight开发工具。
微软Visual Studio 2010是微软{zx1}的开发工具。微软所有的开发工具都已经被集成到了Visual Studio中。下面是Visual Studio 2010的启动界面。
Visual Stuido 2010可以开发所有微软提供的其他开发技术。因此,Visual Studio 2010到目前为止,比任何微软的开发工具和环境都包含更多的的技术和功能。
微软已经开发并发布了一整套叫做Expression套件的工具,这些工具可以用来为WPF和Silverlight应用程序设计用户界面、图形以及媒体。Experssion 套件中主要用于创建和操作Silverlight用户界面的工具是Expression Blend。下图显示了Expression Blend的起始窗体。
虽然Visual Studio 2010时微软所有开发人员的主要开发工具,但是Expression Blend也是满足设计者需求的必需的开发工具。通常情况下,应用程序开发人员非常喜欢Visual Studio提供的直接的技术和用户界面。而应用程序设计者去非常喜欢艺术性的富有创造性的{zy1}的用户界面。Expression Blend就能满足设计者的想法。
如前所述,无论Visual Studio 2010还是Expression Blend都支持搭建Silverlight项目架构,而且能够共享打开同一个Silverlight项目,这就使开发人员和设计者可以各自并行负责各自的工作。
Eclipse是一个用于Windows和Macintosh系统的流行的开发工具。Eclipse{dy}个由微软以外的供应商开发的可以用于创建Silverlight应用程序的代码编辑器。针对Silverlight的Eclipse工具可以在找到。Eclipse新建项目对话框显示了创建一个新的Silverlight项目的选项。
Silverlight 3包含一个CLR运行环境,以及基于.NET Framework的类库子集。Silverlight 3中还扩展了JavaScript和标准浏览器脚本执行环境。
Silverlight 有三个版本:1.0、2.0、3.0。1.0版本中,只支持JavaScript。2.0版本中扩展了执行环境,并提供了使用更多高级语言设计Silverlight应用程序的功能。此外,2.0版本中不仅开辟了可以使用跟多语言的Silverlight CLR,而且允许语言之间通过动态语言运行时进行无缝通信。
一个动态的编程语言是指语言和语言的运行时可以用来在运行时动态扩展应用程度功能。例如,动态语言应该可以可以在程序运行时而不是编译时加载、编译以及运行代码。Silverlight的DLR可以使Silverlight利用动态语言的优势功能。
JavaScript创建于20世纪90年代初,是网景公司和Sun公司共同努力的结果。JavaScript不是Java语言的子集,但是由于在创建时,Java语言比较受欢迎,所以JavaScript模仿了Java语言。JavaScript是一个xx动态的语言,包括许多面向对象的特性。尽管JavaScript很强大,但是.NET框架中的高级开发以及Silverlight 3,并不依赖于JavaScript。与其在Silverlight中使用JavaScript,不如使用更高级的.NET框架程序语言,还可以发挥Silverlight框架的全部优势。{zlx}的.NET框架下的编程语言是C#和Visual Basic。
C#是微软为创建.NET框架应用程序而定义的,原名为Visual C#.NET。C# 3.0是xx动态的语言,而且xx面向对象。
Visual Basic在20世纪90年代就已经出现了,当时作为BASIC语言和开发环境的改进版本。.NET框架中的Visual Basic已经xx被重新设计过,并被重新命名为Visual Basic.NET。从那时起,所有来自微软的.NET语言都放弃了“.NET”后缀。
Visual Basic目前是9.0版本,但它并不符合动态语言的要求。然而,正在制定的10.0版本,称作VBx,将是一个更精简的Visual Basic的动态版本,可以很好的支持Silverlight应用程序。VBx会随Visual Studio 2010一起发布。
IronPython是一个Python编程语言的动态版本,是微软设计出来用于.NET框架中的。Silverlight 3运行时支持使用IronPython。但是IronPython超出了我们这里讨论的范围。
IronRuby是另一种微软设计出来应用于.NET框架的动态编程语言。Silverlight 3运行时也支持使用IronRuby。IronRuby编程语言同样超出了我们讨论的范围。
ASP.NET是Web开发中的{lx1}技术,而且充分占据着市场。现在越来越多的ASP.NET应用程序开始部署Silverlight控件的集成,或者可以xx更新为Silverlight。微软意识到需要融合这两种开发技术并在ASP.NET 3.5扩展包中发布了一些Web计算功能和控件。
在微软ASP.NET 3.5扩展包中的一些新功能和技术,包含对ASP.NET、ASP.NET AJAX以及ADO.NET的集成的考虑,并开始在开发人员中进行适应性试验。
使用Silverlight运行时中包含的泛型类可以加载、操作和管理XAML文件。ASP.NET 3.5扩展包已经包含了一些通用控件用来在ASP.NET AJAX 页面显示Silverlight XAML文件——叫做Sytem.Web.UI.SilverlightControls.Silverlight 控件。asp:Silverlight控件可以加载并显示一个Silverlight XAML文件,然后就可以使用JavaScript或服务器端语言操作该XAML文件。
asp:Silverlight控件最终要的属性是Source属性。Source属性识别控件将要加载的XAML文件的名字,也可以选择包含宿主这个ASP.NET AJAX页面的路径相关信息。asp:Silverlight控件抛出三个最小的事件,其中一个是发生错误时触发,还有一个是XAML文件加载时触发。
当你要使用Visual Studio 2010创建一个新Silverlight项目时,如果添加Silverlight应用程序对话框中的“添加一个新的ASP.NET Web项目到解决方案以宿主Silverlight”选项被选中,那么Web 应用程序中就会创建一个ASP.NET AJAX页面来测试你的Silverlight内容。这个ASP.NET AJAX页面的名字与Silverlight应用程序名字相同,但是在名字中追加上了“TestPage”。 ASP.NET AJAX测试页使用asp:Silverlight控件创建,用来显示你的Silverlight内容。
asp:Silverlight控件可以通过从Visual Studio 2010工具箱中拖拽,轻易添加到现有的ASP.NET AJAX页面。通过拖拽到页面或者通过声明页面的标签来添加控件。
Silverlight的内容可以使用Visual Studio提供的控件,集成进现有的ASP.NET AJAX页面。可以遵循以下步骤:
ASP.NET AJAX页面中包含的XAML案例如下,它使用了asp:Silverlight控件:
1: <%@ Page Language="C#" AutoEventWireup="true" %>
2:
3: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
4: <html xmlns="http://www.w3.org/1999/xhtml" >
5: <head runat="server">
6: <title>SilverlightApplication In ASP.NET AJAX</title>
7: <style type="text/css">
8: html, body {
9: height: {bfb};
10: overflow: auto;
11: }
12: body {
13: padding: 0;
14: margin: 0;
15: }
16: #silverlightControlHost {
17: height: {bfb};
18: text-align:center;
19: }
20: </style>
21: <script type="text/javascript" src="Silverlight.js"></script>1:
2: <script type="text/javascript">3: function onSilverlightError(sender, args) {4: var appSource = "";5: if (sender != null && sender != 0) {6: appSource = sender.getHost().Source;
7: }
8:
9: var errorType = args.ErrorType;10: var iErrorCode = args.ErrorCode;11:
12: if (errorType == "ImageError" || errorType == "MediaError") {13: return;14: }
15:
16: var errMsg = "Unhandled Error in Silverlight Application " + appSource + "\n" ;17:
18: errMsg += "Code: "+ iErrorCode + " \n";19: errMsg += "Category: " + errorType + " \n";20: errMsg += "Message: " + args.ErrorMessage + " \n";21:
22: if (errorType == "ParserError") {23: errMsg += "File: " + args.xamlFile + " \n";24: errMsg += "Line: " + args.lineNumber + " \n";25: errMsg += "Position: " + args.charPosition + " \n";26: }
27: else if (errorType == "RuntimeError") {28: if (args.lineNumber != 0) {29: errMsg += "Line: " + args.lineNumber + " \n";30: errMsg += "Position: " + args.charPosition + " \n";31: }
32: errMsg += "MethodName: " + args.methodName + " \n";33: }
34:
35: throw new Error(errMsg);36: }
</script>
22: </head>
23: <body>
24: <form id="form1" runat="server" style="height:{bfb}">
25: <div id="silverlightControlHost">
26: <object data="data:application/x-silverlight-2," type="application/x-silverlight-2" width="{bfb}" height="{bfb}">
27: <param name="source" value="ClientBin/SilverlightApplicationInASPNETAJAX.xap"/>
28: <param name="onError" value="onSilverlightError" />
29: <param name="background" value="white" />
30: <param name="minRuntimeVersion" value="3.0.40818.0" />
31: <param name="autoUpgrade" value="true" />
32: <a href="http://go.microsoft.com/fwlink/?LinkID=149156&v=3.0.40818.0" style="text-decoration:none">
33: <img src="http://go.microsoft.com/fwlink/?LinkId=161376" alt="Get Microsoft Silverlight" style="border-style:none"/>
34: </a>
35: </object><iframe id="_sl_historyFrame" style="visibility:hidden;height:0px;width:0px;border:0px"></iframe></div>
36: </form>
37: </body>
38: </html>
此案例的显示结果如下,虽然包含的内容不多,但是它明确说明了如何使用asp:Silverlight控件。
使用asp:mediaPlayer控件,ASP.NET AJAX应用程序中可以很容易的包含音频、视频和媒体内容。asp:MediaPlayer控件控件包含在ASP.NET扩展包中。asp:MediaPlayer控件目的就是集成Silverlight的音频和视频功能。使用asp:MediaPlayer控件的好处是可以集成Silverlight音频和视频,而不需要开发人员具有XAML或JavaScript的知识。asp:MediaPlayer控件允许快速集成Silverlight到ASP.NET或ASP.NET AJAX应用程序,使开发人员可以用更多的精力去开发新的功能和技术。
asp:MediaPlayer控件现在支持Windows 视频(WMV)、Windows Media Audio(WMA)、以及MP3格式的媒体。asp:MediaPlayer控件可以抛出JavaScript的事件。另外,asp:MediaPlayer 控件可以包含显示并导航不同的媒体文件,以及自定义的导航界面。
虽然现有的应用程序可以集成Silverlight内容和媒体,大多数情况下,详尽的Silverlight应用程序应该是以新Silverlight应用程序的方式创建的。Silverlight 应用程序可以使用Visual Studio 2010或Expression Blend;然而,Visual Studio 2010可以在创建虚拟的项目时提供更多选择。
创建Silverlight应用程序的{dy}步是创建一个新的Silverlight项目。下图显示了Visual Studio 2010中的新建Silverlight项目对话框。
下图显示了Expression Blend中的新建项目对话框
当使用Visual Studio 2010新建项目对话框时,另一个对话框会提示你需要配置另外一个项目信息,而这个提示在Expression Blend中是没有的。下面是这个提示对话框的界面:
下面是这个对话框中选项的解释:
添加Silverlight应用程序对话框中的其他选项,取决于在{dy}个对话框中的选择。项目类型下拉列表中提供了可供选择的创建一个Web站点或一个Web应用程序。{zh1},在名称文本框中可以修改新网站的名字或使用默认名字。
当此项被选中后,解决方案浏览器中会出现两个项目。如下图所示;
上图中{dy}个项目是Silverlight测试工具Web项目,第二个项目是Silverlight应用程序。在Silverlight应用程序中,我们这次关心的文件时MainPage.xaml文件和相关代码后置文件,MainPage.xaml.cs。MainPage.xaml文件默认使用Visual Studio 2010 编辑。与Silverlight 2不同的是,使用Visual Studio 2010创建的Silverlight 3应用程序,必须通过XAML直接编辑和创建。当然也可以使用Expression Blend来创建和编辑Silverlight应用程序。Visual Studio 2010创建的Silverlight应用程序可以使用Expression Blend轻松打开。