Silverlight 2 教程(三):Silverlight 2应用程序的部署
当开发完Silverlight 2的应用程序后,需要进行部署,比起以前版本的Silverlight,Silverlight 2应用程序的部署非常简单了。下面就是简单的部署过程:
1,由于Silverlight 2将所有的生成文件进行了ZIP打包,生成xap(读作:zap),因此,如果在IIS6以上版本部署,需要将这个新的扩展名在MIME Type里进行注册,方法是:
打开IIS->站点属性->HTTP头->MIME类型->新建:
扩展名:.xap
MIME类型:application/x-silverlight当然,也可以将下面的这个扩展名加进去
扩展名:.xaml
MIME类型:application/xaml+xml
2,如果是在ASP.NET Web网站或者Web应用程序里部署,只需要下面几个步骤:
1),在页面前面加入一个注册(以后的正式版可能不再需要这些):
<%@ Register Assembly="System.Web.Silverlight" Namespace="System.Web.UI.SilverlightControls" TagPrefix="asp" %>2),加入 <asp:ScriptManager ID="ScriptManager1" runat="server"></asp:ScriptManager>控件
3),将所有xap文件放在下面的控件里:
<asp:Silverlight ID="Silverlight1" runat="server" Height="300px" Source="~/ClientBin/SilverlightApplication1.xap" Width="400px" />
下面就是一个完整的例子:
<%@ Page Language="C#" AutoEventWireup="true" %>
<%@ Register Assembly="System.Web.Silverlight" Namespace="System.Web.UI.SilverlightControls" TagPrefix="asp" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" style="height: 100%;">
<head runat="server">
<title>Silverlight 2应用程序部署页面</title>
</head>
<body style="height: 100%; margin: 0;">
<form id="form1" runat="server" style="height: 100%;">
<table>
<tr>
<td>
<asp:ScriptManager ID="ScriptManager1" runat="server">
</asp:ScriptManager>
<asp:Silverlight ID="Xaml1" runat="server" Source="~/ClientBin/SilverlightApplication1.xap" Version="2.0" Width="400px" Height="300px" />
</td>
<td>
<asp:Silverlight ID="Silverlight1" runat="server" Height="300px" Source="~/ClientBin/SilverlightApplication1.xap" Width="400px" />
</td>
</tr>
</table>
</form>
</body>
</html>
3,如果是html页面,可以采用ActiveX的方法,在页面中放入object标签,设置相应的属性即可,具体格式:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html >
<head>
<script type="text/javascript">
function onErrorHandler(sender, args) { }
function onResizeHandler(sender, args) { }
</script>
</head>
<body>
<div id="silverlightControlHost">
<object
id="SilverlightPlugInID"
data="data:application/x-silverlight,"
type="application/x-silverlight"
width="100%" height="100%">
<param name="source" value=" SilverlightApplication1.xap" />
<param name="onError" value="onErrorHandler" />
<param name="onResize" value="onResizeHandler" />
</object>
<iframe style='visibility: hidden; height: 0; width: 0; border: 0px'></iframe>
</body>
</html>
下面这些属性是实现跨浏览器必须的一些属性:
• id、data、 type、 width和height属性;
• source、onError和onResize参数
• <iframe>标签
有些属性和参数是Silverlight插件控制实例化和脚本编程所必需的,这些强制的属性和参数是使用<object>标签确保跨浏览器正确显示所必需的最小配置参数。
必须的属性:
属性名称
|
说明
|
id
|
HTML DOM中插件实例的名称
|
data
|
简化实例化过程,这个属性是必须的,推荐设置为Silverlight应用程序的MIME类型:data:application/silverlight
|
type
|
设置加载Silverlight插件的版本的MIME类型。目前有2种版本:
Silverlight 1.0:application/x-silverlight
Silverlight 2 Beta 1:application/x-silverlight-2-b1
|
height
|
设置Silverlight程序显示区域的高度,设置为整数值或者百分比的格式
|
width
|
设置Silverlight程序显示区域的宽度,设置为整数值或者百分比的格式
|
必须的参数:
参数名称
|
说明
|
Source
|
指定源文件位置的URI,默认为null
|
必须的事件:
参数
|
描述
|
onError
|
Silverlight运行时组件发生错误是触发,这个错误可以是内部代码的产生,也可以是用户的代码产生的
|
onResize
|
当Silverlight插件的 ActualHeight 或 ActualWidth属性发生改变时触发。
|
可选参数:
参数/ 属性 |
描述 |
background |
插件背景颜色,默认值为null,等同于White (ARGB 值为 #FFFFFFFF) |
enableHtmlAccess |
设置是否允许Silverlight插件的内容访问HTML DOM |
initParams |
设置Silverlight对象模型内访问的参数信息 |
maxFramerate |
整数值,设置展现引擎使用的帧速。默认是60,上限大学依赖于系统加载和处理能力 |
splashScreenSource |
应用程序在加载的过程中显示的正在加载内容(比如显示进度或者显示正在加载) |
windowless |
插件以窗口形式还是以无窗口形式呈现。默认是false。只在Microsoft Windows系统中有效, |
onLoad |
插件成功加载时触发 |
onSourceDownloadComplete |
source属性指定的Silverlight应用程序下载完毕后触发 |
onSourceDownloadProgressChanged |
source属性指定的Silverlight应用程序下载过程中触发 |
可选的测试参数:
参数/属性 | 描述 |
enableRedrawRegions | 设置插件显示的每一帧是否重画 |
enableFramerateCounter | 设置是否在浏览器状态条中显示加载帧的计数。只在Microsoft Windows Internet Explorer浏览器支持 |