silverlight 学习点滴

本文介绍在Silverlight中如何正确地从WorkerThread更新UI,通过使用Dispatcher进行异步调用。此外还讨论了在设计Grid内容控件时设置长度和高度的注意事项。

1.在Worker thread 中更新 UI

 WebRequest 对象去向某个页面 Post 一些内容更新UI,直接更新是不行的,

原因是因为silvelight调用的服务全都是异步。

 

如下面的代码:

 

ExpandedBlockStart.gif代码
 void ResponseReady(IAsyncResult asyncResult)
        {
            WebRequest request 
= asyncResult.AsyncState as WebRequest;
            WebResponse response 
= request.EndGetResponse(asyncResult);

            
using (Stream responseStream = response.GetResponseStream())
            {
                StreamReader reader 
= new StreamReader(responseStream);
                
//this.lbPrice.Text = "价格:" + reader.ReadToEnd();
                
//在异步更新UI可以这样使用
                lbPrice.Dispatcher.BeginInvoke(new UpdatePriceDelegate(UpdatePrice), reader.ReadToEnd()); 
            }
        }

 

 

直接写lbprice.text等于返回内容,是有错误的。

在多线程异步更新问题上,在winform中可以用Control.Invoke,

而在silverlight当中,DependencyObject 类有一个属性 Dispatcher,可以通过它来更新相关 UI 对象。

 

代码如下:

 

ExpandedBlockStart.gif代码
    void ResponseReady(IAsyncResult asyncResult)
        {
            WebRequest request 
= asyncResult.AsyncState as WebRequest;
            WebResponse response 
= request.EndGetResponse(asyncResult);

            
using (Stream responseStream = response.GetResponseStream())
            {
                StreamReader reader 
= new StreamReader(responseStream);
                
//this.lbPrice.Text = "价格:" + reader.ReadToEnd();
                
//在异步更新UI可以这样使用
                lbPrice.Dispatcher.BeginInvoke(new UpdatePriceDelegate(UpdatePrice), reader.ReadToEnd()); 
            }
        }
        
//委托
        private delegate void UpdatePriceDelegate(string price);
        
private void UpdatePrice(string price)
        {
            lbPrice.Text 
= "price:" + price;
        }

 

 

 

2.在设计Grid内容控件的时候,设置长度,高度是不能加单位的,否则会报错,如下图:

 

转载于:https://www.cnblogs.com/lbg280/archive/2010/09/02/1816348.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值