快速浏览Silverlight3 Beta: 在多个Silverlight应用间传递信息

快速浏览Silverlight3 Beta: 在多个Silverlight应用间传递信息,第1张

概述       在去年我曾经写过一篇文章,介绍如何在同一页面下多个Silverlight应用间传递事件信息, 当时所使用的技巧就是借助HTML页面元素来传递,当然这种方式也支持向其它第三方ActiveX控 件传递信息。但因为引入了JS代码,让开发者感觉有些别扭。必定这种消息传递写在 CS代码中 会更容易被接受。      好在Silverlight3 beta中提供了两个重要的类,它们都是以“Loc

 

     在去年我曾经写过一篇文章,介绍如何在同一页面下多个Silverlight应用间传递事件信息,
当时所使用的技巧就是借助HTML页面元素来传递,当然这种方式也支持向其它第三方ActiveX控
件传递信息。但因为引入了Js代码,让开发者感觉有些别扭。必定这种消息传递写在 CS代码中
会更容易被接受。

     好在Silverlight3 beta中提供了两个重要的类,它们都是以“LocalMessage”打头,其位于
“System.windows.Messaging”名空间下:

     LocalMessageSender :消息发送器类
     LocalMessageReceiver:消息接收器类
 
     顾名思义,它们就是所谓消息的“发送方”和“接收方”。
   
     而使用它们也很简单,首先我们要先创建一个Silverlight3 Beta项目,名为:LocalMessage。
然后将下面的XAML代码复制到MainPage.xaml文件中:

< UserControl  x:Class ="LocalMessage.MainPage"
    xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
    xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"  
    WIDth
="400"  Height ="200" >
    
< StackPanel  x:name ="LayoutRoot"  Background ="AliceBlue" >
        
< TextBox
            
margin ="10"
            FontSize
="24"
            x:name
="txtMessage"   />
        
< button
            
Content =" 发 送 "
            HorizontalAlignment
="Right"
            margin
="10"
            Click
="OnSendMessage"   />
        
< TextBlock  textwrapPing ="Wrap"
            Foreground
="Blue"
            FontSize
="12"
            x:name
="txtResponse"
            HorizontalAlignment
="Center"   />
    
</ StackPanel >
</ UserControl >

 

    下面是相应的CS代码:   

voID  OnSendMessage( object  sender, RoutedEventArgs args)
{
    LocalMessageSender msgSender 
=   new  LocalMessageSender( " MessageContact " " localhost " );

    EventHandler
< SendCompletedEventArgs >  handler  =   null ;

    handler 
=  (s, e)  =>
      {
          dispatcher.BeginInvoke(() 
=>
          {
              msgSender.SendCompleted 
-=  handler;

              
if  (e.Error  !=   null )
              {
                  txtResponse.Text 
=  String.Format( " 错误 [{0}] " , e.Error.Message);
              }
              
else
              {
                  txtResponse.Text 
=  String.Format( " 响应 [{0}] " , e.Response  ==   null   ?   " None "  : e.Response);
              }
          });
      };
    msgSender.SendCompleted 
+=  handler;

    msgSender.SendAsync(txtMessage.Text);
}

    
     在上面代码中,先声明一个 LocalMessageSender对象,因为该类的构造方法被重载,支持两个
方式,相应参数说明如下:

 

    Receivername: 接收器名称,因为发送与接收方必须使用相应的Receivername,这一点大家可以
                  想一想我们平时打电话必须拨某一号码才能与某人通信。
                  
    ReceiverDomain:获取LocalMessageReceiver的域信息(只有指定的域才能获取消息),这主要 
                  是解决跨域和安全性问题


                  
     这里ReceiverDomain还可使用System.windows.Messaging.LocalMessageSender.Global,这样就
设置为Global域了。

     在绑定相应的方法(SendCompleted)之后就可发送异步消息了。
   
   
     接下来介绍一下接收方代码。
   
     首先要先创建一个接收方的Silverlight应用,这里命名为“LocalMessageReceiver”。下面是
相应的XAML代码:

< UserControl  x:Class ="LocalMessageReceiver.MainPage"
    xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
    xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"  
    WIDth
="400"  Height ="200" >
    
< GrID  x:name ="LayoutRoot"  Background ="Blue"   >
        
< TextBlock
            
Foreground ="White"
            FontSize
="12"
            x:name
="txtMessage"
            HorizontalAlignment
="Center"
            VerticalAlignment
="Center" />
    
</ GrID >
</ UserControl >

 

    而CS代码如下所示:
    

voID  OnLoaded( object  sender, RoutedEventArgs args)
{
    List
< string >  allowedSenderDomains  =   new  List < string > ();
    allowedSenderDomains.Add( 
" silverlightshow.net "  );
    allowedSenderDomains.Add( 
" http://www.silverlightshow.net/ "  );
    allowedSenderDomains.Add(
" localhost " );
    
    
// 下面使用全命名主要是项目名称与已有的LocalMessageReceiver重名所致
    System.windows.Messaging.LocalMessageReceiver receiver  =  
        
new  System.windows.Messaging.LocalMessageReceiver( " MessageContact " , ReceivernameScope.Domain, allowedSenderDomains);

    receiver.MessageReceived 
+=  (s, e)  =>
      {
          e.Response 
=   " 接收方收到消息! " ;

          dispatcher.BeginInvoke(() 
=>
            {
                txtMessage.Text 
=  String.Format( " 收到信息 [{0}] " , e.Message);
            });
      };

    receiver.Listen();
}        

       

    我们看到这里LocalMessageReceiver类实例实始化参数,其中:     

    Receivername:参见上面的LocalMessageSender
    nameScope: ReceivernameScope.Domain, 该枚举参数用于标识是Domain还是Global。
    AllowedSenderDomains: 允许发送的域信息。

    
    因为之前发送方已指定了域信息,即“localhost”,所以这里在列表变量:allowedSenderDomains
中添加了“localhost”,并标识以 ReceivernameScope.Domain。

    下面我们看一下效果:
   


    
  
     当然如果发送方没有采用与接收方相同的Receivername或者发送方的ReceiverDomain未出现在接收
方的AllowedSenderDomains列表中,就会出现错误。这一点大家下载源码后运行一下就可以了。

     另外就是如果发送方设置的是LocalMessageSender.Global,那么在接收方必须相应是:    
      ReceivernameScope.Global
    
     这样才能确保信息的传递,源码下载:http://files.cnblogs.com/daizhj/LocalMessage.rar。

总结

以上是内存溢出为你收集整理的快速浏览Silverlight3 Beta: 在多个Silverlight应用间传递信息全部内容,希望文章能够帮你解决快速浏览Silverlight3 Beta: 在多个Silverlight应用间传递信息所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1051733.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存