应用间文件访问

在前面的内容中介绍了如何使用文件选取器访问本地文件,而文件选取器除了能够访问本地文件外,还可以在一个应用中访问另一个应用中的文件。下面将通过一个具体的实例,介绍如何使用文件选取器调用其他应用并获取其中的文件。

本实例包含两个应用程序,第一个应用在被第二个应用调用时激活,用于读取一张应用内部的图片。第二个应用通过文件选取器调用第一个应用,并获得第一个应用读取的图片。接下来创建第一个应用程序。

1)创建提供文件的应用

启动Visual Studio 2012,新建一个Windows应用商店的空白应用程序项目,命名为FileProvider。由于本应用的功能是读取一张应用内部的图片,所以首先需要向项目中添加一个图片文件。在解决方案资源管理器中右键单击项目中的Assets文件夹,选择“添加”à“现有项”,在本地文件夹中选择并添加一个名为“蔬菜”的JPG图片文件。

完成图片的添加之后,接下来对应用进行设置以便能够在其他应用中使用文件选取器调用此应用,双击打开项目中的清单文件Package.appxmanifest,选择清单设计器窗口中的“声明”选项卡,在“可用声明”下拉列表中选择“文件打开选取器”,为应用添加一个文件打开选取器声明,接着在声明的“支持的文件类型”文本框中设置能够显示的文件类型。具体设置方法如图13-7所示:

 

9QWD2P}LRPHK_`4O{6{JAPM

13-7 应用清单设计器界面

完成了清单文件的设置之后,双击打开项目中的MainPage.xaml文件,在文件的Grid元素中添加以下代码,用于应用前台界面的展示

<StackPanel HorizontalAlignment="Left" Orientation="Vertical" Margin="120,20,0,0">

    <TextBlock FontSize="18">点击下面的按钮,将在本地文件中选择一个图片</TextBlock>

    <Button Content="选择图片" Click="AddLocalFileButton_Click" Height="40" FontSize="20" />

</StackPanel>

在上面的代码中,添加了一个文本块和一个“选择图片”按钮,文本块用于显示提示信息,“选择图片”按钮则用于读取图片。界面显示效果如图13-8所示。

$_MHYGGINGF9[OMS31}3SMJ

 

13-8 FileProvider应用前台界面

布局了前台界面之后,接着来看后台功能的实现。当应用被其他应用通过文件选取器激活时,会触发相应的事件,App.xaml.cs文件中的OnFileOpenPickerActivated方法是Windows应用商店应用处理此事件的默认方法,这里通过重写此方法在应用被文件选取器激活时进行相应处理。代码如下所示:

protected override void OnFileOpenPickerActivated(FileOpenPickerActivatedEventArgs args)

{

    var newPage = new MainPage();

    newPage.AppActivate(args);

}

在上面的代码中,创建了一个MainPage类型的对象newPage,然后以args为参数调用了MainPage类中的AppActivate方法,实现对激活事件的具体处理。

在介绍MainPage.xaml.cs中的AppActivate方法之前,为了能够实现被其他应用激活,这里先在MainPage类中定义一个FileOpenPickerUI类型的成员变量,代码如下所示:

FileOpenPickerUI fileOpenPickerUI = null;

现在给出MainPage.xaml.csAppActivate方法的代码,代码使用参数argsFileOpenPickerUI属性值初始化fileOpenPickerUI,并调用Activate方法激活当前页面。

public void AppActivate (FileOpenPickerActivatedEventArgs args)

{

    //初始化fileOpenPickerUI对象

    fileOpenPickerUI = args.FileOpenPickerUI;

    //激活MainPage页面

    Window.Current.Content = this;

    Window.Current.Activate();

}

下面继续来实现上面添加的“选择图片”按钮的功能,该按钮实现读取应用内部的一张图片,实现此功能的单击事件处理方法如下所示。

private async void AddLocalFileButton_Click(object sender, RoutedEventArgs e)

{

    StorageFile file = await Package.Current.InstalledLocation.GetFileAsync(@"Assets\蔬菜.jpg");

    fileOpenPickerUI.AddFile("imgKey", file);

}

代码首先使用GetFileAsync方法获得本应用Assets文件夹下的名为“蔬菜.jpg”的图片文件,将其保存在StorageFile类型的对象file中,接着调用AddFile方法将file对象添加到fileOpenPickerUI对象中,并为其指定了唯一的标记imgKey

这样就创建好了第一个应用FileProvider,下面来实现第二个应用。

2)创建获取文件的应用

打开Visual Studio 2012,新建一个名为FileFetcherWindows应用商店的空白应用程序项目,在MainPage.xaml文件中添加如下代码,用于应用界面的展示。

<StackPanel HorizontalAlignment="Left" Margin="600,300,0,0">

    <TextBlock x:Name="OutputTextBlock" FontSize="14"></TextBlock>

    <StackPanel HorizontalAlignment="Center">

        <Image Height="200" Width="200"  x:Name="ShowImg"></Image>

        <Button Click="AddPhotoButton_Click">单击选择FileProvider应用</Button>

    </StackPanel>

</StackPanel>

代码为应用添加了一个文本块、一个Image控件和一个按钮,文本块用来显示图片的名称,Image控件则用于展示图片文件,而“单击选择FileProvider应用”按钮用来通过文件选取器选择FileProvider应用。

布局好应用的界面后,接下来在MainPage.xaml.cs文件中为“单击选择FileProvider应用”按钮添加单击事件处理方法,实现按钮的功能,这里使用的单击事件处理方法如下所示。

private async void AddPhotoButton_Click(object sender, RoutedEventArgs e)

{

    //创建一个可写入和更新的位图对象

    WriteableBitmap writeAbleBitmap = new WriteableBitmap(200, 200);

    //创建文件选择器,并指定选择器显示文件的方式,选择器可以选择的文件类型。

    FileOpenPicker fileOpenPicker = new FileOpenPicker();

    fileOpenPicker.ViewMode = PickerViewMode.Thumbnail;

    fileOpenPicker.FileTypeFilter.Add(".jpg");

    StorageFile file = await fileOpenPicker.PickSingleFileAsync();

    if (file != null)

    {

        //打开图形文件,并将图形写入到数据流中

        IRandomAccessStream stream = await file.OpenAsync(FileAccessMode.Read);

        //从数据流中读取图形数据并保存到位图对象中

        await writeAbleBitmap.SetSourceAsync(stream);

        ShowImg.Source = writeAbleBitmap;

        OutputTextBlock.Text = file.Name;

    }

}

代码首先新建一个可写入和更新的位图对象writeAbleBitmap,又创建了一个文件选取器对象fileOpenPicker,通过将其ViewMode属性的值设置为PickerViewMode.Thumbnail把选取器的视图模式设定为缩略图模式,并为选取器添加了.jpg文件的显示支持,然后调用PickSingleFileAsync方法选取一个图片文件,将其保存在file对象中,使用OpenAsync方法以数据流的形式读取file对象,并检查file对象是否为空,如果不为空把读到的数据保存在stream对象中,通过SetSourceAsync方法将stream对象设置为writeAbleBitmap的图像源,并将writeAbleBitmap对象赋值给Image控件的Source属性,把图片显示出来,最后在OutputTextBlock文本块中显示图片的名称。

至此第二个应用FileFetcher也实现了,查看运行效果时,这两个应用FileFetcherFileProvider需要有运行的先后顺序,首先部署并运行FileProvider应用,然后启动FileFetcher应用,点击“单击选择FileProvider应用”按钮,会出现文件选取器窗口,在文件选取器窗口中选择FileProvider应用,FileProvider应用会被激活,如图13-9所示。

YEE6M)`7T2I[5)UZCC{Q_@S

 

13-9 FileProvider应用运行界面

单击图13-9中的“选择图片”按钮,文件选取器将获得FileProvider应用中的图片文件,单击文件选取器右下角的“打开”按钮,在FileFetcher应用界面中将显示名为“蔬菜.jpg”的图片,如图13-10

4H@2YCX~~DVF8EGH3G17(LA

所示。13-10 FileFetcher应用图片显示

 

 注:本博客内容,选择机械工业出版社3月出版的《Windows 8 应用开发权威指南》第13章

posted on 2013-05-02 09:02  冯瑞涛  阅读(1294)  评论(2编辑  收藏  举报