zoukankan      html  css  js  c++  java
  • 重新想象 Windows 8 Store Apps (25) 选取器: 文件选取窗口, 文件夹选取窗口, 文件保存窗口

    [源码下载]


    重新想象 Windows 8 Store Apps (25) - 选取器: 文件选取窗口, 文件夹选取窗口, 文件保存窗口



    作者:webabcd


    介绍
    重新想象 Windows 8 Store Apps 之 选取器

    • FileOpenPicker - 选择一个文件或多个文件
    • FolderPicker - 选择一个文件夹
    • FileSavePicker - 保存文件到指定路径



    示例
    1、演示如何通过 FileOpenPicker 选择一个文件或多个文件
    Picker/FileOpenPickerDemo.xaml

    <Page
        x:Class="XamlDemo.Picker.FileOpenPickerDemo"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="using:XamlDemo.Picker"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        mc:Ignorable="d">
    
        <Grid Background="Transparent">
            <StackPanel Margin="120 0 0 0">
                
                <TextBlock Name="lblMsg" FontSize="14.667" />
                
                <Button Name="btnPickFile" Content="pick a file" Click="btnPickFile_Click_1" Margin="0 10 0 0" />
    
                <Button Name="btnPickFiles" Content="pick multiple files" Click="btnPickFiles_Click_1" Margin="0 10 0 0" />
    
            </StackPanel>
        </Grid>
    </Page>

    Picker/FileOpenPickerDemo.xaml.cs

    /*
     * 演示如何通过 FileOpenPicker 选择一个文件或多个文件
     * 
     * FileOpenPicker - 文件选择窗口
     *     ViewMode - 文件选择窗口的视图模式,Windows.Storage.Pickers.PickerViewMode 枚举(List 或 Thumbnail)
     *     SuggestedStartLocation - 文件选择窗口所显示的初始路径,Windows.Storage.Pickers.PickerLocationId 枚举
     *         DocumentsLibrary, ComputerFolder, Desktop,, Downloads, HomeGroup, MusicLibrary, PicturesLibrary,VideosLibrary
     *     FileTypeFilter - 允许显示在文件选择窗口的文件类型集合
     *     CommitButtonText - 文件选择窗口的提交按钮的显示文本,此按钮默认显示的文本为“打开”
     *     PickSingleFileAsync() -  弹出文件选择窗口,以让用户选择一个文件
     *     PickMultipleFilesAsync() - 弹出文件选择窗口,以让用户选择多个文件
     */
    
    using System;
    using System.Collections.Generic;
    using Windows.Storage;
    using Windows.Storage.AccessCache;
    using Windows.Storage.Pickers;
    using Windows.UI.Xaml;
    using Windows.UI.Xaml.Controls;
    
    namespace XamlDemo.Picker
    {
        public sealed partial class FileOpenPickerDemo : Page
        {
            public FileOpenPickerDemo()
            {
                this.InitializeComponent();
            }
    
            private async void btnPickFile_Click_1(object sender, RoutedEventArgs e)
            {
                if (XamlDemo.Common.Helper.EnsureUnsnapped())
                {
                    // 选择一个文件
                    FileOpenPicker openPicker = new FileOpenPicker();
                    openPicker.CommitButtonText = "选中此文件";
                    openPicker.ViewMode = PickerViewMode.Thumbnail;
                    openPicker.SuggestedStartLocation = PickerLocationId.PicturesLibrary;
                    openPicker.FileTypeFilter.Add(".jpg");
                    openPicker.FileTypeFilter.Add(".gif");
                    openPicker.FileTypeFilter.Add(".png");
    
                    // 弹出文件选择窗口
                    StorageFile file = await openPicker.PickSingleFileAsync(); // 用户在“文件选择窗口”中完成操作后,会返回对应的 StorageFile 对象
                    if (file != null)
                    {
                        lblMsg.Text = "选中文件: " + file.Name;
                    }
                    else
                    {
                        lblMsg.Text = "取消了";
                    }
                }
            }
    
            private async  void btnPickFiles_Click_1(object sender, RoutedEventArgs e)
            {
                if (XamlDemo.Common.Helper.EnsureUnsnapped())
                {
                    // 选择多个文件
                    FileOpenPicker openPicker = new FileOpenPicker();
                    openPicker.ViewMode = PickerViewMode.List;
                    openPicker.SuggestedStartLocation = PickerLocationId.DocumentsLibrary;
                    openPicker.FileTypeFilter.Add("*");
    
                    // 弹出文件选择窗口
                    IReadOnlyList<StorageFile> files = await openPicker.PickMultipleFilesAsync(); // 用户在“文件选择窗口”中完成操作后,会返回对应的 StorageFile 对象
                    if (files.Count > 0)
                    {
                        lblMsg.Text = "选中文件: ";
                        lblMsg.Text += Environment.NewLine;
                        foreach (StorageFile file in files)
                        {
                            lblMsg.Text += (file.Name);
                            lblMsg.Text += Environment.NewLine;
                        }
                    }
                    else
                    {
                        lblMsg.Text = "取消了";
                    }
                }
            }
        }
    }


    2、演示如何通过 FolderPicker 选择一个文件夹
    Picker/FolderPickerDemo.xaml

    <Page
        x:Class="XamlDemo.Picker.FolderPickerDemo"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="using:XamlDemo.Picker"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        mc:Ignorable="d">
    
        <Grid Background="Transparent">
            <StackPanel Margin="120 0 0 0">
    
                <TextBlock Name="lblMsg" FontSize="14.667" />
    
                <Button Name="btnPickFolder" Content="pick a folder" Click="btnPickFolder_Click_1" Margin="0 10 0 0 " />
    
            </StackPanel>
        </Grid>
    </Page>

    Picker/FolderPickerDemo.xaml.cs

    /*
     * 演示如何通过 FolderPicker 选择一个文件夹
     * 
     * FolderPicker - 文件夹选择窗口
     *     ViewMode - 文件夹选择窗口的视图模式,Windows.Storage.Pickers.PickerViewMode 枚举(List 或 Thumbnail)
     *     SuggestedStartLocation - 文件夹选择窗口所显示的初始路径,Windows.Storage.Pickers.PickerLocationId 枚举
     *         DocumentsLibrary, ComputerFolder, Desktop,, Downloads, HomeGroup, MusicLibrary, PicturesLibrary,VideosLibrary
     *     FileTypeFilter - 允许显示在文件夹选择窗口的文件类型集合(只能显示符合要求的文件,但是无法选中)
     *     CommitButtonText - 文件夹选择窗口的提交按钮的显示文本,此按钮默认显示的文本为“选择这个文件夹”
     *     PickSingleFolderAsync() - 弹出文件夹选择窗口,以让用户选择一个文件夹
     */
    
    using System;
    using Windows.Storage;
    using Windows.Storage.Pickers;
    using Windows.UI.Xaml;
    using Windows.UI.Xaml.Controls;
    
    namespace XamlDemo.Picker
    {
        public sealed partial class FolderPickerDemo : Page
        {
            public FolderPickerDemo()
            {
                this.InitializeComponent();
            }
    
            private async void btnPickFolder_Click_1(object sender, RoutedEventArgs e)
            {
                if (XamlDemo.Common.Helper.EnsureUnsnapped())
                {
                    // 选择一个文件夹
                    FolderPicker folderPicker = new FolderPicker();
                    folderPicker.SuggestedStartLocation = PickerLocationId.Desktop;
                    folderPicker.FileTypeFilter.Add(".docx");
                    folderPicker.FileTypeFilter.Add(".xlsx");
                    folderPicker.FileTypeFilter.Add(".pptx");
    
                    // 弹出文件夹选择窗口
                    StorageFolder folder = await folderPicker.PickSingleFolderAsync(); // 用户在“文件夹选择窗口”中完成操作后,会返回对应的 StorageFolder 对象
                    if (folder != null)
                    {
                        lblMsg.Text = "选中文件夹: " + folder.Name;
                    }
                    else
                    {
                        lblMsg.Text = "取消了";
                    }
                }
            }
        }
    }


    3、演示如何通过 FileSavePicker 保存文件到指定路径
    Picker/FileSavePickerDemo.xaml

    <Page
        x:Class="XamlDemo.Picker.FileSavePickerDemo"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="using:XamlDemo.Pikcer"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        mc:Ignorable="d">
    
        <Grid Background="Transparent">
            <StackPanel Margin="120 0 0 0">
    
                <TextBlock Name="lblMsg" FontSize="14.667" />
    
                <Button Name="btnSaveFile" Content="save a file" Click="btnSaveFile_Click_1" Margin="0 10 0 0" />
    
            </StackPanel>
        </Grid>
    </Page>

    Picker/FileSavePickerDemo.xaml.cs

    /*
     * 演示如何通过 FileSavePicker 保存文件到指定路径
     * 
     * FileSavePicker - 文件保存窗口
     *     SuggestedStartLocation - 文件保存窗口所显示的初始路径,Windows.Storage.Pickers.PickerLocationId 枚举
     *         DocumentsLibrary, ComputerFolder, Desktop,, Downloads, HomeGroup, MusicLibrary, PicturesLibrary,VideosLibrary
     *     SuggestedFileName - 需要保存的文件的默认文件名
     *     SuggestedSaveFile - 需要保存的文件的默认 StorageFile 对象
     *     FileTypeChoices - 可保存的扩展名集合
     *     DefaultFileExtension - 默认扩展名
     *     CommitButtonText - 文件保存窗口的提交按钮的显示文本,此按钮默认显示的文本为“保存”
     *     PickSaveFileAsync() - 弹出文件保存窗口,以让用户保存文件
     */
    
    using System;
    using System.Collections.Generic;
    using Windows.Storage;
    using Windows.Storage.Pickers;
    using Windows.Storage.Provider;
    using Windows.UI.Xaml;
    using Windows.UI.Xaml.Controls;
    
    namespace XamlDemo.Picker
    {
        public sealed partial class FileSavePickerDemo : Page
        {
            public FileSavePickerDemo()
            {
                this.InitializeComponent();
            }
    
            private async void btnSaveFile_Click_1(object sender, RoutedEventArgs e)
            {
                if (XamlDemo.Common.Helper.EnsureUnsnapped())
                {
                    FileSavePicker savePicker = new FileSavePicker();
                    savePicker.SuggestedStartLocation = PickerLocationId.DocumentsLibrary;
    
                    // 在扩展名选择框中将会显示:文本(.txt)
                    savePicker.FileTypeChoices.Add("文本", new List<string>() { ".txt" });
                    savePicker.SuggestedFileName = "webabcdFileSavePicker";
    
                    // 弹出文件保存窗口
                    StorageFile file = await savePicker.PickSaveFileAsync(); // 用户在“文件保存窗口”中完成操作后,会返回对应的 StorageFile 对象
                    if (file != null)
                    {
                        /*
                         * 运行到此,只是在目标地址创建了一个没有任何内容的空白文件而已,接下来开始向文件写入内容
                         */
    
                        // 告诉 Windows ,从此时开始要防止其它程序更新指定的文件
                        CachedFileManager.DeferUpdates(file);
    
                        // 将指定的内容保存到指定的文件
                        string textContent = "I am webabcd";
                        await FileIO.WriteTextAsync(file, textContent);
    
                        // 告诉 Windows ,从此时开始允许其它程序更新指定的文件
                        FileUpdateStatus status = await CachedFileManager.CompleteUpdatesAsync(file);
                        if (status == FileUpdateStatus.Complete)
                        {
                            lblMsg.Text = "文件 " + file.Name + " 保存成功";
                        }
    
                        lblMsg.Text += Environment.NewLine;
                        lblMsg.Text += "FileUpdateStatus: " + status.ToString();
                    }
                    else
                    {
                        lblMsg.Text = "取消了";
                    }
                }
            }
        }
    }



    OK
    [源码下载]

  • 相关阅读:
    SQL学习笔记 where子句用法,like关键字 嵌套查询
    Mvc视图构建辅助方法
    EXtjs 解决ie9 不支持extjs对象的 “createContextualFragment”属性或方法
    认识MVC
    Mvc基本切入及controller认识
    Extjs4.0 下载文件的说明
    Extjs4 Panel中使用autoload无法加载页面文件
    Mvc视图表单辅助方法
    js倒计时方法
    web confing 处理全局编码方式
  • 原文地址:https://www.cnblogs.com/webabcd/p/3075014.html
Copyright © 2011-2022 走看看