在Silverlight中读取指定URL图片包数据

简介:
   在silverlight开发,允许我们获取指定URL压缩包(zip)并读取其中的图片文件。而实现这个功能也非常简单。下面是运行效果图:
                   
    
      首先,我们需要建立一个silverligth application ,名称为:DownLoadImg.
    
      下面就是相应的page.xaml代码:    
< Grid  x:Name ="LayoutRoot"  Background ="White" >
    
< Grid.RowDefinitions >
        
< RowDefinition  Height ="250"   />
        
< RowDefinition  Height ="100"   />
        
< RowDefinition  Height ="50"   />
    
</ Grid.RowDefinitions >
    
< StackPanel  Grid.Row ="1" >
        
< ListBox  x:Name ="ImageList" />
        
< Button  x:Name ="Download"  Click ="StartDownLoad"  Content ="下载该图片" />
    
</ StackPanel >

    
< StackPanel  Grid.Row ="0" >             
        
< ScrollViewer  HorizontalScrollBarVisibility ="Auto"   >
            
< Image  x:Name ="ImgToFill"   >            
            
</ Image >
        
</ ScrollViewer >
    
</ StackPanel >

    
< StackPanel  Grid.Row ="2" >
        
< Canvas  Canvas.Top ="70"   >
            
< Rectangle   Name ="progressRectangle"  Height ="10"  Width ="0"  Fill ="AliceBlue"   />
            
< Rectangle  Height ="12"   Width ="202"  StrokeThickness ="1"  Stroke ="Black"   />
            
< TextBlock  x:Name ="progressText"  Canvas.Left ="210"  Text ="0%"  FontSize ="12"   />
        
</ Canvas >
    
</ StackPanel >
</ Grid >

    接下来是 page.xaml.cs(相关内容见注释):
using  System;
using  System.Collections.Generic;
using  System.Linq;
using  System.Net;
using  System.Windows;
using  System.Windows.Controls;
using  System.Windows.Documents;
using  System.Windows.Input;
using  System.Windows.Media;
using  System.Windows.Media.Animation;
using  System.Windows.Shapes;

using  System.IO;
using  System.Windows.Resources;
using  System.Windows.Media.Imaging;

namespace  DownLoadImg
{
    
public   partial   class  Page : UserControl
    {
        WebClient wc 
=   new  WebClient();

        
public  Page()
        {
            InitializeComponent();
            
this .Loaded  +=   new  RoutedEventHandler(Page_Loaded);
        }

        
// 加载图片列表数据
         void  Page_Loaded( object  sender, RoutedEventArgs e)
        {
            ImageList.Items.Add(
" 1.jpg " );
            ImageList.Items.Add(
" 2.png " );
        }
        
// 实例化下载设置
         void  StartDownLoad( object  o, EventArgs e)
        {
            
// 初始化相应控件信息
            ImgToFill.Visibility  =  Visibility.Collapsed;
            progressRectangle.Width 
=   0 ;
            progressText.Text 
=   " 0% " ;
            
// 绑定下载过程中处理的事件
            wc.OpenReadCompleted  +=   new  OpenReadCompletedEventHandler(wc_OpenReadCompleted);
            wc.DownloadProgressChanged 
+=   new  DownloadProgressChangedEventHandler(wc_DownloadProgressChanged);
            
// 开始异步读取压缩包中的文件信息
            wc.OpenReadAsync( new  Uri( " img.zip " , UriKind.Relative), ImageList.SelectedItem);
        }
        
        
void  wc_OpenReadCompleted( object  sender, OpenReadCompletedEventArgs e)
        {
           
// 实例化流资源信息,准备获取其中的图片数据
            StreamResourceInfo sri  =   new  StreamResourceInfo(e.Result  as  Stream,  null );
            
// 要读取的图片路径信息
            String sURI  =  e.UserState  as  String;
            
// 从流资源中获取指定的URL图片流信息
            StreamResourceInfo imageStream  =  Application.GetResourceStream(sri,  new  Uri(sURI, UriKind.Relative));
            BitmapImage imgsrc 
=   new  BitmapImage();
            
// 绑定该URL图片信息并进行显示
            imgsrc.SetSource(imageStream.Stream);
            ImgToFill.Source 
=  imgsrc;
            ImgToFill.Visibility 
=  Visibility.Visible;
            ImgToFill.Stretch 
=  Stretch.Fill;
        }

        
void  wc_DownloadProgressChanged( object  sender, DownloadProgressChangedEventArgs e)
        {
            
// 下载过程中的进度显示
            progressText.Text  =  e.ProgressPercentage.ToString()  +   " % " ;
            progressRectangle.Width 
=  ( double )e.ProgressPercentage  *   2 ;
        }

    }
}


       好了,今天的内容就到这里了。


本文转自 daizhenjun 51CTO博客,原文链接:http://blog.51cto.com/daizhj/82425,如需转载请自行联系原作者
相关文章
|
12月前
|
Java
Java开发实现图片URL地址检验,如何编码?
【10月更文挑战第14天】Java开发实现图片URL地址检验,如何编码?
373 4
【微信公众平台对接】有关【上传图文消息内的图片获取URL】调用示例
【微信公众平台对接】有关【上传图文消息内的图片获取URL】调用示例
369 0
|
XML JSON 缓存
Java实现根据商品短连接(真实URL)获取1688商品详情用数据API方法
Java实现根据商品短连接(真实URL)获取1688商品详情用数据API方法
|
小程序 前端开发 PHP
PHP实现生成小程序二维码带参数进入指定页面、小程序URL scheme实现携带数据跳转小程序
PHP实现生成小程序二维码带参数进入指定页面、小程序URL scheme实现携带数据跳转小程序
349 0
|
12月前
|
消息中间件 数据采集 数据库
小说爬虫-03 爬取章节的详细内容并保存 将章节URL推送至RabbitMQ Scrapy消费MQ 对数据进行爬取后写入SQLite
小说爬虫-03 爬取章节的详细内容并保存 将章节URL推送至RabbitMQ Scrapy消费MQ 对数据进行爬取后写入SQLite
178 1
|
数据采集 存储 前端开发
Java爬虫开发:Jsoup库在图片URL提取中的实战应用
Java爬虫开发:Jsoup库在图片URL提取中的实战应用
【微信公众平台对接】有关【上传图文消息内的图片获取URL】调用示例
【微信公众平台对接】有关【上传图文消息内的图片获取URL】调用示例
322 0
|
前端开发 JavaScript
react-qr-code的第三方库来将URL转换成二维码图片
在React中,你可以使用一个叫做react-qr-code的第三方库来将URL转换成二维码图片并保存。首先,你需要安装这个库: ``` npm install react-qr-code ``` 然后,在你的组件中引入react-qr-code: ``` import QRCode from 'react-qr-code'; ``` 接着,在render方法中使用QRCode组件,将URL作为一个属性传递进去: ``` render() { const url = 'https://www.example.com'; return ( <div> <Q
1219 0
|
Java 机器人 API
JAVA实现自动打开URL对应的网页并保存为图片-不借助第三方API
JAVA实现自动打开URL对应的网页并保存为图片-不借助第三方API
128 9
|
缓存 Java Apache
Spring一行代码搞定图片url地址转换为Base64,超简单!!!!
这段内容讲述了如何将URL指向的图片转换为Base64字符串。首先通过`org.apache.commons.io.IOUtils`或Java标准库读取URL的字节流,然后用Java 8的`Base64`类编码。示例代码提供了两种实现方式:一种依赖Apache Commons IO,另一种仅使用Java内置类。在第二种方式中,自定义了`toByteArray()`方法处理输入流并转换为字节数组,最后关闭输入流释放资源。