微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

silverlight中顺序/倒序异步加载多张图片

相册/图片切换广告等很多常用小应用中,服务器返回一组图片的uri,然后silverlight利用WebClient异步加载,如果要严格控制加载顺序的话,可以利用Stack(堆栈)或Queue(堆栈)处理,思路:不要全部一起加载,先加载第一个,在完成的异步回调过程中,继续发起一下次异步。
 

回想我们在ajax开发中,有一种技术叫"http长连接",在每一次ajax异步请求完成时,继续发起下一个异步请求,这样客户端与服务端的连接就一直保持下去了。
 

这二者多么相象!再次印证了我的那句话:技术很多时候一通百通 :)
 

关键代码
 

@H_404_23@

using  System;
@H_404_23@

using  System.Collections.Generic;
@H_404_23@

using  System.Net;
@H_404_23@

using  System.Windows;
@H_404_23@

using  System.Windows.browser;
@H_404_23@

using  System.Windows.Controls;
@H_404_23@

using  System.Windows.Media.Imaging;
@H_404_23@

using  QueueLoad.controls;
@H_404_23@


@H_404_23@

namespace  QueueLoad
@H_404_23@

{
@H_404_23@

    
/// <summary>
@H_404_23@

    
/// 顺序,倒序异步加载一组图片(by 菩提树下的杨过 http://yjmyzz.cnblogs.com/)
@H_404_23@

    
/// </summary>

@H_404_23@

    public partial class MainPage : UserControl
@H_404_23@

    
{
@H_404_23@

        Stack
<string> _imgStack = new Stack<string>();//如要顺序加载,换成 Queue<string>
@H_404_23@

       
@H_404_23@

        WebClient _wc 
= new WebClient();
@H_404_23@


@H_404_23@

        
public MainPage()
@H_404_23@

        
{
@H_404_23@

            InitializeComponent();
@H_404_23@


@H_404_23@

            _imgStack.Push(
"gallery/Scenes/1.jpg");
@H_404_23@

            _imgStack.Push(
"gallery/Scenes/2.jpg");
@H_404_23@

            _imgStack.Push(
"gallery/Scenes/3.jpg");
@H_404_23@

            _imgStack.Push(
"gallery/Scenes/4.jpg");
@H_404_23@

            _imgStack.Push(
"gallery/Scenes/5.jpg");
@H_404_23@

            _imgStack.Push(
"gallery/Scenes/6.jpg");
@H_404_23@


@H_404_23@

            _wc.OpenReadCompleted 
+= _wc_OpenReadCompleted;
@H_404_23@

        }

@H_404_23@


@H_404_23@

        
void _wc_OpenReadCompleted(object sender, OpenReadCompletedEventArgs e)
@H_404_23@

        
{
@H_404_23@

            
if (e.Error == null)
@H_404_23@

            
{
@H_404_23@

                BitmapImage _bitMap 
= new BitmapImage();
@H_404_23@

                _bitMap.SetSource(e.Result);
@H_404_23@


@H_404_23@

                ImageItemBase _itemBase 
= e.UserState as ImageItemBase;
@H_404_23@


@H_404_23@

                _itemBase.img.source 
= _bitMap;
@H_404_23@

                _itemBase.img.Visibility 
= Visibility.Visible;
@H_404_23@

                _itemBase.loading.Visibility 
= Visibility.Collapsed;
@H_404_23@


@H_404_23@

                LoadImage();
//关键,继续加载下一个(是不是有点ajax中http长连接的意思,呵)
@H_404_23@


@H_404_23@

            }

@H_404_23@

        }

@H_404_23@


@H_404_23@

        
private void btnLoad_Click(object sender, RoutedEventArgs e)
@H_404_23@

        
@H_98_502@{
@H_404_23@

            LoadImage();
@H_404_23@

        }

@H_404_23@


@H_404_23@


@H_404_23@

        
void LoadImage()
@H_404_23@

        
{
@H_404_23@

            
if (_imgStack != null && _imgStack.Count > 0)
@H_404_23@

            
{
@H_404_23@

                ImageItemBase _itemBase 
= new ImageItemBase();
@H_404_23@

                _itemBase.loading.Visibility 
= Visibility.Visible;
@H_404_23@

                _itemBase.img.Visibility 
= Visibility.Collapsed;
@H_404_23@


@H_404_23@

                imgContainer.Children.Add(_itemBase);               
@H_404_23@


@H_404_23@

                Uri _imgur
= new Uri(HtmlPage.Document.DocumentUri, _imgStack.Pop());
@H_404_23@

                _wc.OpenReadAsync(_imguri, _itemBase);
@H_404_23@

            }

@H_404_23@

        }

@H_404_23@

    }

@H_404_23@

}

@H_404_23@

代码:http://files.cnblogs.com/yjmyzz/QueueLoad.rar

作者:Jimmy.Yang

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐