Silverlight加载界面实现方法解析
创始人
2024-06-18 16:40:45
0

Silverlight加载界面的实现方法在这篇文章中将会为大家详细介绍。希望对一些又需要的朋友men有些帮助。在一个解决方案中,有SplashScreenSourceweb和SplashScreenSource两个项目。#t#

要往silverlight中加入自定义装载界面,需要加入到SplashScreenSourceweb项目中,这样,自定义装载界面就不会和其它xaml文件一起打包到silverlight程序包中。

Silverlight加载界面步骤如下:

1.右击silverlightapplicationweb项目,选择属性,选择启动选项,把SplashScreenSourceTestPage.html设为启动页面。

2.右击silverlightapplicationweb项目,选择添加新项,选择添加一个Silverlight JScript 页,命名为SplashScreen.xaml。

3.打开SplashScreen.xaml,换成如下代码:

 

  1. < Canvas 
  2. xmlns="http://schemas.microsoft.
    com/client/2007"   
  3. xmlns:x="http://schemas.
    microsoft.com/winfx/2006/xaml"   
  4. x:Name="parentCanvas"   
  5. Width="850" 
  6. Height="600" 
  7. Background="OldLace" 
  8. < Canvas Canvas.Top="228.834" 
    Canvas.Left="246.329" Width="357" 
    Height="31.379"> 
  9. < Rectangle Width="27.545" 
    Height="1" x:Name="uxProgress" 
    Canvas.Top="29.545" Canvas.Left="1.4"> 
  10. < Rectangle.RenderTransform> 
  11. < TransformGroup> 
  12. < ScaleTransform x:Name="uxProgressBar" 
    ScaleX="1" ScaleY="0"/> 
  13. < SkewTransform AngleX="0" AngleY="0"/> 
  14. < RotateTransform Angle="270"/> 
  15. < TranslateTransform X="0" Y="0"/> 
  16. < /TransformGroup> 
  17. < /Rectangle.RenderTransform> 
  18. < Rectangle.Fill> 
  19. < LinearGradientBrush EndPoint=
    "1,0.5" StartPoint="0,0.5"> 
  20. < GradientStop Color="#FFFFFFFF" 
    Offset="1"/> 
  21. < GradientStop Color="#FFFFFFFF" 
    Offset="0"/> 
  22. < GradientStop Color="#FF2975D0"
     Offset="0.28"/> 
  23. < GradientStop Color="#FF2975D0"
     Offset="0.72"/> 
  24. < /LinearGradientBrush> 
  25. < /Rectangle.Fill> 
  26. < /Rectangle> 
  27. < TextBlock x:Name="uxStatus" Height="25" 
    Canvas.Left="125" Text="Loading..." 
    TextWrapping="Wrap" Canvas.Top="4.16"/> 
  28. < Path Width="356.85" Height="1" 
    Fill="#FF3A3A3A" Stretch="Fill" 
    Stroke="#FF000000" Canvas.Top="0" 
    Data="M0,170.5 L356.84209,170.5" 
    Opacity="0.35"/> 
  29. < Path Width="1.662" Height="29.03" 
    Fill="#FF3A3A3A" Stretch="Fill" 
    Stroke="#FF000000" Canvas.Top="0.48" 
    Canvas.Left="0.2" Data="M360,168 L360,0" 
    Opacity="0.35" /> 
  30. < Path Width="357.84" Height="1"
     Fill="#FF3A3A3A" Stretch="Fill" 
    Stroke="#FF000000" Canvas.Top="29" 
    Data="M0,170.5 L356.84209,170.5" Opacity="0.35"/> 
  31. < Path Width="358.85" Height="1" Fill="#FFA2A2A2" 
    Stretch="Fill" Stroke="#FF000000" Canvas.Top="30" 
    Data="M0,170.5 L356.84209,170.5" Opacity="0.25"/> 
  32. < Path Width="1.662" Height="30" Fill="#FF3A3A3A" 
    Stretch="Fill" Stroke="#FF000000" 
    Canvas.Left="356.01" Data="M360,168 L360,0" 
    Opacity="0.35" Canvas.Top="-0.498"/> 
  33. < Path Width="1" Height="31" Fill="#FFA2A2A2" 
    Stretch="Fill" Stroke="#FF000000" 
    Canvas.Left="357.333" Data="M360,168 L360,0" 
    Opacity="0.245" Canvas.Top="-0.498" />   
  34. < /Canvas> 
  35. < /Canvas> 

 


Silverlight加载界面4.打开SplashScreenSourceTestPage.html,把代码

 

  1. < param name="source" 
    value="ClientBin/Splash
    ScreenSource.xap"/> 

改成

 

  1. < param name="source" 
    value="SplashScreenSource.xap"/>  

 

5.在解决方案资源管理器中,把ClientBin目录下的SplashScreenSource.xap拖到SplashScreenSourceWeb根目录下。

6.打开SplashScreenSourceTestPage.html,加入如下代码:

 

  1. < param name="splashscreensource" 
    value="SplashScreen.xaml"/> 
  2. < param name="onSourceDownload
    ProgressChanged" value=
    "onSourceDownloadProgressChanged" /> 

 

Silverlight加载界面7.打开SplashScreen.js,输入以下代码:

 

  1. function onSourceDownload
    ProgressChanged(sender, eventArgs)  
  2. {  
  3. sender.findName("uxStatus").
    Text = "Loading: " + Math.
    round((eventArgs.progress * 
    1000)) / 10 + "%";  
  4. sender.findName("uxProgressBar").
    ScaleY = eventArgs.progress * 356;  

 

8.打开SplashScreenSourceTestPage.html,加入以下代码:

 

  1. < script type="text/javascript" 
    src="splashscreen.js">< /script> 

 

9.运行Silverlight加载界面!

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...