您的位置:首页 > 其它

Windows 8 应用开发权威指南 之 应用程序的数据存储(1)应用程序安装目录操作

2013-04-23 19:03 369 查看

应用程序安装目录

前面介绍了如何对本地应用存储空间中的文件以及文件夹进行操作,在应用中除了可以对本地应用存储空间进行操作之外,还可以对应用程序安装目录进行相关操作。本节将通过一个示例,详细讲解如何对应用程序安装目录中的文件进行操作,此示例可以实现获取应用程序安装目录下的图片文件并将其显示,还可以实现复制安装目录下的文件。

在Visual Studio 2012中新建一个Windows应用商店的空白应用程序项目,并命名为InstalledLocationApp。双击打开项目的MainPage.xaml文件,在Grid元素中添加如下代码,布局前台界面。

<StackPanel HorizontalAlignment="Left" VerticalAlignment="Top" >

<StackPanel Orientation="Horizontal" >

<!--添加开始复制按钮-->

<Button x:Name="CopyFileButton" Click="CopyFile_Click" Content="开始复制" Width="194" Height="63" FontSize="30" Margin="50,50"/>

<TextBlock x:Name="tbMessage" FontSize="35" Width="500" Height=" 50" VerticalAlignment="Center"/>

</StackPanel>

<StackPanel Orientation="Horizontal" Margin="50,50">

<!--添加显示图片按钮-->

<Button x:Name="ViewPictureButton" Click="ViewPictureButton_Click" Content="显示图片" FontSize="30" Width="194" Height="63"></Button>

<ListView x:Name="ShowPicture" Width="300" Height=" 200">

<ListView.ItemTemplate>

<DataTemplate >

<Image Source="{Binding Uri}"></Image>

</DataTemplate>

</ListView.ItemTemplate>

</ListView>

</StackPanel>

</StackPanel>

上面的代码为应用添加了两个按钮、一个文本块和一个ListView控件,并在ListView控件中添加了一个Image控件,两个按钮分别为“开始复制”和“显示图片”,其中“开始复制”按钮用来对安装目录中的XML文件进行复制,“显示图片”按钮用于获取安装目录中的图片文件,并将获得的图片在ListView的Image控件中显示。这里通过数据绑定为ListView创建了数据模板,将图片的地址绑定到Image控件,关于数据绑定的介绍请查看相关章节。

布局了前台界面后,下面介绍后台功能的实现,为了方便对图片进行管理,我们首先在MainPage.xaml.cs文件中创建表示图片的Picture类,并在其中定义代表图片路径的Uri属性。代码如下所示:

public class Picture

{

public String Uri { get; set; }

}

接下来将陆续实现“开始复制”和“显示图片”按钮的功能,分别为按钮添加实现其功能的单击事件处理方法,首先来看“显示图片”按钮,实现其功能的单击事件处理方法ViewPictureButton_Click如下所示。

async private void ViewPictureButton_Click(object sender, RoutedEventArgs e)

{

List<Picture> pictureList = new List<Picture>();

//获得picture文件夹

StorageFolder folder = await Windows.ApplicationModel.Package.Current.InstalledLocation.GetFolderAsync("picture");

IReadOnlyCollection<StorageFile> files = await folder.GetFilesAsync();

//获得图片

foreach (StorageFile file in files)

{

pictureList.Add(new Picture { Uri = "picture/" + file.Name });

}

ShowPicture.ItemsSource = pictureList;

}

方法首先创建了一个List集合pictureList,然后使用GetFolderAsync获得安装目录中的picture文件夹,通过GetFilesAsync方法异步获取文件夹中的图片,并将获得的图片保存在只读集合files中,使用foreach循环遍历files,调用Add方法将其中保存的图片添加到集合pictureList里面,最后将pictureList绑定到ListView中。

现在已经实现了“显示图片”按钮的功能,不过在运行程序之前还需要做一些必要的准备工作,由于这里显示的是应用程序安装目录中picture文件夹下的图片文件,而创建项目时默认是没有picture文件夹的,因此需要在项目的解决方案资源管理器中新建一个picture文件夹,并在文件中放入一些图片文件。

完成上面的准备工作之后,按F5键运行程序,单击“显示图片”按钮,界面的显示效果如图13-2所示。





图13-2 显示图片

接下来继续来实现“开始复制”按钮的功能,实现按钮功能的单击事件处理方法如下所示。

async private void CopyFile_Click(object sender, RoutedEventArgs e)

{

//获取应用程序安装目录下名为Model的文件夹

StorageFolder copyFolder = await Windows.ApplicationModel.Package.Current.InstalledLocation.GetFolderAsync("Model");

//获取Model文件夹下名为“word.xml”的文件

StorageFile copyFile = await copyFolder.GetFileAsync("word.xml");

//读取文件内容

IBuffer buffer = await FileIO.ReadBufferAsync(copyFile);

//在本地应用存储空间中新建一个名为“word.xml”的文件

StorageFile file = await ApplicationData.Current.LocalFolder.CreateFileAsync("word.xml", CreationCollisionOption.OpenIfExists);

//将读取的内容写入到该文件中

await FileIO.WriteBufferAsync(file, buffer);

tbMessage.Text = "复制文件成功!";

}

代码使用异步方法GetFolderAsync获得安装目录下名为Model的文件夹,通过GetFileAsync方法获取其中的word.xml文件,并使用StorageFile类型的copyFile将其保存,以copyFile为参数调用FileIO类的ReadBufferAsync方法异步读取word.xml文件中的内容,接着通过CreateFileAsync方法在本地应用存储空间中新建一个名为word.xml的文件,最后使用FileIO类的WriteBufferAsync方法将读取到的内容写入到新建的word.xml文件中。

这样就实现了“开始复制”按钮的功能,与上面的情况一样,在运行程序之前需要在项目的解决方案资源管理器中新建一个Model文件夹,并在文件中放入一个word.xml文件。

完成准备工作之后,按F5键运行程序,单击“开始复制”按钮,界面的显示效果如图13-3所示。





图13-3 复制成功提示信息

这时定位到本地应用存储空间,会发现word.xml文件已经复制到其中。

注:本文选自机械工业出版社3月出品的《Windows 8 应用开发权威指南》第12章 传感器
另外:为在4月27日举办的微软云体验营免费活动做一下宣传。

4月27日 微软云训练营活动,期待您的报名参加,本次活动无需任何费用。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐