快速浏览Silverlight3:在浏览器外运行Silverlight应用

简介:

  Silverlight3一个很显著的特点就是其应用可以在浏览器外运行。就是说一个在浏览器中运行的应用可以被独立(detached)出来,并通过一个桌面和开始菜单栏图标来启动执行,不在需要有网络连接。这样给人的感觉其就像一个普通的桌面应用而不是一个浏览器应用程序。 

    为了实现独立(detached),用户必须对这类应用有个明确的选择:“该应用在没有用户通知的情况下是不可以detached它自己的。下面用一个例子“Hello World”来展示一下:

< UserControl  x:Class ="SilverlightApplication1.MainPage"
    xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation%22
    xmlns:x="
[url]http://schemas.microsoft.com/winfx/2006/xaml%22[/url]
    Width
="400"  Height ="300" >
    
< StackPanel  x:Name ="LayoutRoot"  Background ="White" >
        
< TextBlock
            
x:Name ="txtStatus"  Text ="Not Set"  HorizontalAlignment ="Center"  Margin ="10"   />
        
< Button
            
Content ="Click Me"
            Click
="OnClicked"
            Margin
="10" />
    
</ StackPanel >
</ UserControl >
 

     还有一些代码:
public   partial   class  MainPage : UserControl
{
    
public  MainPage()
    {
      InitializeComponent();
      OnExecutionStateChanged(
null null );
      App.Current.ExecutionStateChanged 
+=  OnExecutionStateChanged;
    }
    
void  OnExecutionStateChanged( object  sender, EventArgs e)
    {
      txtStatus.Text 
=  App.Current.ExecutionState.ToString();
    }
    
void  OnClicked( object  sender, RoutedEventArgs args)
    {
      App.Current.Detach();
    }
}

    然后我们在浏览器中运行它并看到一个新的鼠标右击菜单:
    其允许将该应用独立出来并安装到本地。并且你会注意到,该菜单项是灰色的。
    同样地,我们可以在按钮事件中加入一些代码并尝试分离这个应用。

void  OnClicked( object  sender, RoutedEventArgs args)
{
      App.Current.Detach();
}
  
    但它并没有启作用,因为右键菜单依旧是灰的.原因在于这个应用没有相应的元数据支持。
    为了提供元数据,我们要编辑一下 appmanifest.xml 文件:

< Deployment  xmlns ="http://schemas.microsoft.com/client/2007/deployment"
            xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml" >
  
< Deployment.Parts >
  
</ Deployment.Parts >
  
< Deployment.ApplicationIdentity >
    
< ApplicationIdentity
      
ShortName ="Mike's Silverlight App"
      Title
="Mike's App Window" >
      
< ApplicationIdentity.Blurb > Mikes Application Blurb </ ApplicationIdentity.Blurb >
      
< ApplicationIdentity.Icons >
        
< Icon  Size ="16x16" > icons/16x16.png </ Icon >
        
< Icon  Size ="32x32" > icons/32x32.png </ Icon >
        
< Icon  Size ="48x48" > icons/48x48.png </ Icon >
        
< Icon  Size ="128x128" > icons/128x128.png </ Icon >
      
</ ApplicationIdentity.Icons >
    
</ ApplicationIdentity >
  
</ Deployment.ApplicationIdentity >
</ Deployment >

    注:上面这些图标文件必须在VS中以内容"Content"的文件嵌入到XAP文件中。
但我并不确保你也需要这里所有的文件,特别是这个"128x128"(文件);
    这样当单击鼠标右键后该菜单项将会变成“有效”:


    接着,我们前面创建的这个按钮将会触发一个对话框,提供给我们两个选项:
“将这个要运行在浏览器外的应用安装到桌面或开始菜单中”。



    注:那是个标准对话框,而通过使用我本人头像设置的对话框是下面这个样子:



    但我不打算这样做,我想还是显示标准对话框会好一些:)
    如果点击该对话框后,该应用会尝试 detach 它自身。对我而言,它所做的工作就是确保本地XAP文件的有效性。而不是去尝试把其它与它相关联的资源也获取到本地。


    注:第二个应用拷贝现在运行在了窗体中,它与浏览器窗体还是有一些区别的。
    现在我在桌面上有了该应用的一个图标:



    并且在开始菜单中也有:



    如果我从这两个地方运行这个应用时,会看到一个“非浏览器”的应用:



    此时当我在浏览器中运行这个原始(版本)的应用时,它显示了相同的“Detached”状态:



    好的,现在我修改一下原应用,将背景设置为"red":



   
    然后再次运行并发布这个新的XAP到WEB服务器上。起初,它显示“Detached”,然后它切换到“DetachedUpdatesAvailable".这意味着可以告诉用户该应用已被更新,并提示他们重启该应用:



     之后,将他们再运行该应用时,会获取到新的版本(我更新到服务器上的那个版本):


 
     如果想删除该应用,可以在本地的“detached”拷贝或浏览器中右击菜单:


     如果我点击上面菜单后,就会将开始菜单和桌面图标移除,这样在浏览器中该应用的状态就从“Detached”变成了“RunningOnline”.

 
     尽管 App.Current.ExecutionState属性返回“Detached”,但这与你在浏览器 或本 运行 该应用是无关的。这是需要有另一个标志来决定该应用是从浏览器还是从本地(分离) 启动。

     在Application中有一个标志即“RunningOffline”,看上去它会返回true/false  状态。 True 意味着当前应用是从本地独立启动的,而False则是在浏览器中启动的。
     就当前应用实际运行的代码而言,当其离线时(offline),存在一个进程(文件位于:Program Files\Microsoft Silverlight\VERSION\sllauncher.exe).看上去 它就是通过 应用名称 去运行相应程序。使用Reflector去浏览一下,发现其进程好像是非托管的 运行, 因此我不认为能 从中能获取一些内部信息。但其值得一说的是该launcher的roles之一 是保持应用的上下文安全。 即:如果应用是从域foo.com获取,那么该应用就必须本地化 运行。 尽管它是从 foo.com上启动( launched)的。
     还有要注意的是这种detached在功能上貌似依赖于Isolated Storage(隔离)存储。 因为我发 当把应用“detached”时,必须在打开Isolated Storage,真是如此。   
    

本文转自 daizhenjun 51CTO博客,原文链接:http://blog.51cto.com/daizhj/142599,如需转载请自行联系原作者
相关文章
|
2月前
|
Web App开发 数据采集 前端开发
纯技术讨论:如何让 SAP UI5 应用无法被别人在浏览器里调试 - 这种做法不推荐试读版
纯技术讨论:如何让 SAP UI5 应用无法被别人在浏览器里调试 - 这种做法不推荐试读版
15 0
|
4月前
|
IDE Linux 开发工具
如何在Linux运行RStudio Server并实现Web浏览器远程访问
如何在Linux运行RStudio Server并实现Web浏览器远程访问
81 0
|
8月前
|
数据可视化 Shell UED
SAP Corbu Theme 在浏览器和 SAPGUI 应用中的使用场景
SAP Corbu Theme 在浏览器和 SAPGUI 应用中的使用场景
46 0
|
8月前
|
Web App开发 测试技术
Selenium+python之不打开浏览器,来运行测试用例
Selenium+python之不打开浏览器,来运行测试用例
163 0
|
4月前
|
JavaScript 前端开发
nodejs配置express服务器,运行后自动打开浏览器
作为前端开发的项目,有的时候打包完后就想在本地测试是什么样子的,另外一些如cesium等程序,需要在服务的环境下才能启动三维球等。 这里使用nodejs+express搭建一个普通的服务器。
nodejs配置express服务器,运行后自动打开浏览器
|
5月前
|
Web App开发 数据采集 数据挖掘
还有这种骚操作:使用Golang实现无头浏览器浏览和截图
还有这种骚操作:使用Golang实现无头浏览器浏览和截图
105 0
|
5月前
|
Windows
穿越时光隧道!浏览器运行Windows 2000系统
探索一个数字时光机!今天,我用copy.sh浏览器中运行了Windows 2000系统,瞬间回到了那个令人怀念的年代。仿佛时光倒流,经典的启动音乐响起,熟悉的桌面出现在屏幕上,带着满满的年代感。在这个数字化的时代,重新体验Windows 2000给人带来的怀旧情感,仿佛时间停滞了 #云库工具#。
33 0
|
5月前
|
前端开发 JavaScript Java
Web应用中浏览器与服务端的编码和解码
Web应用中浏览器与服务端的编码和解码
70 0
|
6月前
vscode用浏览器预览运行html文件
vscode用浏览器预览运行html文件
57 2
|
6月前
|
数据采集 开发框架 JavaScript
基于.NET Core内置浏览器窗体应用程序界面框架
基于.NET Core内置浏览器窗体应用程序界面框架
49 0

热门文章

最新文章

相关实验场景

更多