Windows Store App 文件选取器

使用文件选取器能够访问除上面介绍的“应用程序存储”和“用户库”两个位置以外的本地文件或者文件夹。文件选取器是应用与系统进行交互的一个接口,经过文件选取器能够在应用中直接与文件系统进行交互,访问不一样位置的文件或将文件存储在指定位置。spa

文件选取器包含文件打开选取器和文件保存选取器,文件打开选取器由FileOpenPicker类表示,用来选择或打开文件,而文件保存选取器由FileSavePicker类表示,用来在保存文件时对文件的扩展名、存储位置等进行选择。这两种选择器的使用方法大体相同,因此下面以文件打开选取器为例进行介绍。orm

在使用文件打开选取器的过程当中,经过设置文件打开选取器的属性能够自定义文件选取器的视图模式、初始位置或文件类型集合。下面先来介绍一下文件打开选取器的几个经常使用属性。对象

q  ViewMode,获取或设置文件打开选取器用来展现文件或文件夹的视图模式。属性的值由PickerViewMode枚举指定,该枚举包含两个枚举成员,ListThumbnailList表示列表模式,Thumbnail则表示缩略图模式。接口

q  SuggestedStartLocation,获取或者设置文件打开选取器显示的初始位置。属性的值由PickerViewMode枚举指定,此枚举有8个枚举成员分别用来表示不一样的位置,包括计算机、图片库等,这里再也不一一列举。图片

q  FileTypeFilter,获取文件打开选取器显示的文件类型集合,这些文件类型能够是“.doc”、“.png”等。ip

在了解了经常使用属性以后,接下来给出一段建立文件打开选取器的示例代码。ci

//建立文件选取器element

FileOpenPicker openPicker = new FileOpenPicker();it

//ViewMode属性设为Thumbnailio

openPicker.ViewMode = PickerViewMode.Thumbnail;

//将文件选取器打开文件的开始位置设置为图片库

openPicker.SuggestedStartLocation = PickerLocationId.PicturesLibrary;

//设置选取器能够选取的文件格式

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

openPicker.FileTypeFilter.Add(".jpeg");

openPicker.FileTypeFilter.Add(".png");

代码建立了一个FileOpenPicker类的对象openPicker做为文件打开选取器,设置openPickerViewMode属性的值为PickerViewMode.Thumbnail,将视图模式设定为缩略图模式,经过SuggestedStartLocation属性将选择器的初始位置定位在图片库,并使用FileTypeFilter属性获取选择器显示的文件类型集合,而后调用Add方法将须要使用的文件类型添加到集合中。

建立了文件打开选取器以后,就能够经过文件打开选取器来选择文件了。当须要选择单个文件时,使用文件打开选取器的PickSingleFileAsync方法能够实现。示例代码以下所示:

Windows.Storage.StorageFile file = await openPicker.PickSingleFileAsync();

if (file != null)

{

    // 在页面中显示所选文件名称

}

else

{

    //在页面中提示用户没有文件返回

}

代码在获取到选定的文件file后,对file进行了判断,若是file不为空,则显示文件的名称,不然显示“没有文件返回”。

而当使用文件打开选取器选择多个文件时,须要调用选取器的PickMultipleFilesAsync方法,示例代码以下所示:

IReadOnlyList<Windows.Storage.StorageFile> files = await openPicker.PickMultipleFilesAsync();

if (files.Count > 0)

{

    // 显示全部文件名称

    foreach (Windows.Storage.StorageFile file in files)

    {

        //在页面中显示所选文件名称

    }

}

else

{

    //在页面中提示用户“没有文件返回”

}

代码首先获取选定的文件集合files,而后判断集合files的元素个数是否大于0,若是大于0,依次显示集合中全部文件的名称,不然显示提示信息“没有文件返回”。

相关文章
相关标签/搜索