背水一戰 Windows 10 (91) - 文件系統: Application Data 中的文件操作, Application Data 中的“設置”操作, 通過 uri 引用 Application Data 中的媒體
作者:webabcd
介紹
背水一戰 Windows 10 之 文件系統
- Application Data 中的文件操作
- Application Data 中的“設置”操作
- 通過 uri 引用 Application Data 中的媒體
示例
1、演示如何在 Application Data(應用程序數據存儲)中對文件進行操作
FileSystem/AppData/FileDemo.xaml
<Page x:Class="Windows10.FileSystem.AppData.FileDemo" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:local="using:Windows10.FileSystem.AppData" 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="10 0 10 10"> <TextBlock Name="lblMsg" Margin="5" /> <Button Name="btnReadWrite" Content="讀寫 Application Data 中的文件" Click="btnReadWrite_Click" Margin="5" /> </StackPanel> </Grid> </Page>
FileSystem/AppData/FileDemo.xaml.cs
/* * 演示如何在 Application Data(應用程序數據存儲)中對文件進行操作 * * * StorageFile - 文件操作類 * public static IAsyncOperation<StorageFile> GetFileFromApplicationUriAsync(Uri uri) - 獲取本地指定 uri 的文件 * * * ApplicationData - 操作 Application Data 中數據的類 * Current - 返回當前的 ApplicationData 對象 * LocalFolder - 返回 StorageFolder 對象。本地存儲,永久保存 * 保存路徑:%USERPROFILE%\AppData\Local\Packages\{PackageId}\LocalState * 訪問協議:ms-appdata:///local/ * RoamingFolder - 返回 StorageFolder 對象。漫游存儲,同一微軟賬戶同一應用程序在不同設備間會自動同步 * 保存路徑:%USERPROFILE%\AppData\Local\Packages\{PackageId}\RoamingState * 訪問協議:ms-appdata:///roaming/ * TemporaryFolder - 返回 StorageFolder 對象。臨時存儲,系統在需要的時候可以將其刪除 * 保存路徑:%USERPROFILE%\AppData\Local\Packages\{PackageId}\TempState * 訪問協議:ms-appdata:///temp/ * RoamingStorageQuota - 從漫游存儲同步到雲端的數據的最大大小,只讀 * ClearAsync() - 刪除 Application Data 中的數據 * ClearAsync(ApplicationDataLocality locality) - 刪除指定存儲區的數據據 * ApplicationDataLocality.Local, ApplicationDataLocality.Roaming, ApplicationDataLocality.Temporary * * DataChanged - 從服務端向 app 同步漫游數據時所觸發的事件 * SignalDataChanged() - 強行觸發 DataChanged 事件 */ using System; using Windows.Storage; using Windows.UI.Core; using Windows.UI.Xaml; using Windows.UI.Xaml.Controls; using Windows.UI.Xaml.Navigation; namespace Windows10.FileSystem.AppData { public sealed partial class FileDemo : Page { StorageFolder _localFolder = ApplicationData.Current.LocalFolder; public FileDemo() { this.InitializeComponent(); } protected override void OnNavigatedTo(NavigationEventArgs e) { ApplicationData.Current.DataChanged += Current_DataChanged; base.OnNavigatedTo(e); } protected override void OnNavigatedFrom(NavigationEventArgs e) { ApplicationData.Current.DataChanged -= Current_DataChanged; base.OnNavigatedFrom(e); } // 從服務端向 app 同步漫游數據時 private async void Current_DataChanged(ApplicationData sender, object args) { await Dispatcher.RunAsync(CoreDispatcherPriority.Normal, () => { lblMsg.Text += Environment.NewLine; lblMsg.Text += "DataChanged 事件被觸發"; }); } private async void btnReadWrite_Click(object sender, RoutedEventArgs e) { // 寫 StorageFile fileWrite = await _localFolder.CreateFileAsync(@"webabcdTest\readWriteDemo.txt", CreationCollisionOption.ReplaceExisting); await FileIO.WriteTextAsync(fileWrite, "I am webabcd: " + DateTime.Now.ToString()); // 讀 // StorageFile fileRead = await _localFolder.GetFileAsync(@"webabcdTest\readWriteDemo.txt"); StorageFile fileRead = await StorageFile.GetFileFromApplicationUriAsync(new Uri("ms-appdata:///local/webabcdTest/readWriteDemo.txt", UriKind.Absolute)); string textContent = await FileIO.ReadTextAsync(fileRead); lblMsg.Text = textContent; // 強行觸發 DataChanged 事件(僅為演示用,實際項目中不需要) ApplicationData.Current.SignalDataChanged(); } } }
2、演示如何在 Application Data(應用程序數據存儲)中對“設置”進行操作
FileSystem/AppData/SettingsDemo.xaml
<Page x:Class="Windows10.FileSystem.AppData.SettingsDemo" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:local="using:Windows10.FileSystem.AppData" 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="10 0 10 10"> <TextBlock Name="lblMsg" Margin="5" /> <Button Name="btnReadWrite" Content="讀寫 Settings" Click="btnReadWrite_Click" Margin="5" /> <Button Name="btnReadWriteWithContainer" Content="分組 Settings" Click="btnReadWriteWithContainer_Click" Margin="5" /> <Button Name="btnReadWriteWithComposite" Content="父子 Settings" Click="btnReadWriteWithComposite_Click" Margin="5" /> <Button Name="btnSetVersion0" Content="將 Application Data 的版本號設置為 0" Click="btnSetVersion0_Click" Margin="5" /> <Button Name="btnSetVersion1" Content="將 Application Data 的版本號設置為 1" Click="btnSetVersion1_Click" Margin="5" /> </StackPanel> </Grid> </Page>
FileSystem/AppData/SettingsDemo.xaml.cs
/* * 演示如何在 Application Data(應用程序數據存儲)中對“設置”進行操作 * * ApplicationData - 操作 Application Data 中數據的類 * Current - 返回當前的 ApplicationData 對象 * LocalSettings - 返回 ApplicationDataContainer 對象。本地存儲,永久保存 * 保存路徑:%USERPROFILE%\AppData\Local\Packages\{PackageId}\Settings * RoamingSettings - 返回 ApplicationDataContainer 對象。漫游存儲,同一微軟賬戶同一應用程序在不同設備間會自動同步 * 保存路徑:%USERPROFILE%\AppData\Local\Packages\{PackageId}\Settings * Version - 獲取當前 Application Data 的版本號,默認值為 0,只讀(用於本地“設置”數據的版本控制) * SetVersionAsync() - 指定當前 Application Data 的版本號(用於本地“設置”數據的版本控制) * * ApplicationDataContainer - 操作“設置”數據的類 * Name - 容器的名稱,默認為空 * CreateContainer(string name, ApplicationDataCreateDisposition disposition) - 激活一個用於保存“設置”數據的容器,即分組“設置”數據 * name - 容器的名稱 * disposition - 容器的激活方式:Always - 始終激活;Existing - 容器存在才激活 * Containers - 容器集合 * DeleteContainer() - 刪除指定的容器 * Values - 保存“設置”數據,一個字典表 * 其數據可以是一個 ApplicationDataCompositeValue 類型的數據,ApplicationDataCompositeValue 也是一個字典表,這樣可將多個“設置”數據放到一個 key 里 * * * 備注: * 當 key 為 HighPriority 時,系統會以最快的速度在多個設備間同步 HighPriority 所對應的數據(支持 ApplicationDataCompositeValue 數據) * 示例如下: * ApplicationDataContainer.Values["HighPriority"] = "此處的值將會以系統最快的速度在多個設備間同步"; */ using System; using Windows.Storage; using Windows.UI.Core; using Windows.UI.Xaml; using Windows.UI.Xaml.Controls; namespace Windows10.FileSystem.AppData { public sealed partial class SettingsDemo : Page { public SettingsDemo() { this.InitializeComponent(); } // 操作“設置”數據的 demo private void btnReadWrite_Click(object sender, RoutedEventArgs e) { ApplicationDataContainer localSettings = ApplicationData.Current.LocalSettings; // 保存“設置”數據 localSettings.Values["key"] = "I am webabcd"; // 如果 key 為 HighPriority,則系統將會以最高優先級的速度在多個設備間同步 HighPriority 的值 // localSettings.Values["HighPriority"] = "I am webabcd"; // 刪除指定的“設置”數據 // localSettings.Values.Remove("key"); // 獲取“設置”數據 lblMsg.Text = (string)localSettings.Values["key"]; } // 分組“設置”數據,即在不同的容器中保存不同的數據 private void btnReadWriteWithContainer_Click(object sender, RoutedEventArgs e) { // 在 LocalSettings 中激活名為 groupName 的容器 ApplicationDataContainer container = ApplicationData.Current.LocalSettings; ApplicationDataContainer localSettings = container.CreateContainer("groupName", ApplicationDataCreateDisposition.Always); // 刪除指定的容器 // container.DeleteContainer("groupName"); // 在容器內保存“設置”數據 if (container.Containers.ContainsKey("groupName")) { container.Containers["groupName"].Values["key"] = "I am webabcd"; } // 從指定的容器內獲取“設置”數據 lblMsg.Text = (string)container.Containers["groupName"].Values["key"]; lblMsg.Text += Environment.NewLine; // 從指定的容器內獲取“設置”數據 lblMsg.Text += (string)localSettings.Values["key"]; } // 父子“設置”數據,即 key 中的數據是一個 ApplicationDataCompositeValue 對象,而 ApplicationDataCompositeValue 也是一個字典表 private void btnReadWriteWithComposite_Click(object sender, RoutedEventArgs e) { ApplicationDataContainer localSettings = ApplicationData.Current.LocalSettings; // 父子“設置”數據的保存 ApplicationDataCompositeValue parent1 = new ApplicationDataCompositeValue(); parent1["child1"] = "abc"; parent1["child2"] = "xyz"; localSettings.Values["parent1"] = parent1; // 父子“設置”數據的獲取 lblMsg.Text = (string)((ApplicationDataCompositeValue)localSettings.Values["parent1"])["child1"]; lblMsg.Text += Environment.NewLine; lblMsg.Text += (string)((ApplicationDataCompositeValue)localSettings.Values["parent1"])["child2"]; } private async void btnSetVersion0_Click(object sender, RoutedEventArgs e) { // 將 Application Data 的版本號設置為 0,並執行指定的方法 await ApplicationData.Current.SetVersionAsync(0, new ApplicationDataSetVersionHandler(SetVersionHandler)); } private async void btnSetVersion1_Click(object sender, RoutedEventArgs e) { // 將 Application Data 的版本號設置為 1,並執行指定的方法 await ApplicationData.Current.SetVersionAsync(1, new ApplicationDataSetVersionHandler(SetVersionHandler)); } // 根據當前版本號和將要設置成的版本號,將“設置”數據升級到最新版本 private async void SetVersionHandler(SetVersionRequest request) { // 異步操作 SetVersionDeferral deferral = request.GetDeferral(); await Dispatcher.RunAsync(CoreDispatcherPriority.Normal, () => { lblMsg.Text = "CurrentVersion: " + request.CurrentVersion; // 當前版本號 lblMsg.Text += Environment.NewLine; lblMsg.Text += "DesiredVersion: " + request.DesiredVersion; // 將要設置成的版本號 lblMsg.Text += Environment.NewLine; lblMsg.Text += "ApplicationData.Current.Version: " + ApplicationData.Current.Version; // 當前版本號 }); // 完成異步操作 deferral.Complete(); } } }
3、演示如何通過 uri 的方式引用 Application Data(應用程序數據存儲)中的媒體(圖片、視頻或音頻)文件
FileSystem/AppData/MediaReference.xaml
<Page x:Class="Windows10.FileSystem.AppData.MediaReference" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:local="using:Windows10.FileSystem.AppData" 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="10 0 10 10"> <Image Name="imgAppdata" Stretch="None" HorizontalAlignment="Left" Margin="5" /> <Image Name="imgAppx" Stretch="None" HorizontalAlignment="Left" Margin="5" /> </StackPanel> </Grid> </Page>
FileSystem/AppData/MediaReference.xaml.cs
/* * 演示如何通過 uri 的方式引用 Application Data(應用程序數據存儲)中的媒體(圖片、視頻或音頻)文件 * * ApplicationData 中的 LocalFolder 對應 ms-appdata:///local/ * ApplicationData 中的 RoamingFolder 對應 ms-appdata:///roaming/ * ApplicationData 中的 TemporaryFolder 對應 ms-appdata:///temp/ * * StorageFile - 文件操作類 * public static IAsyncOperation<StorageFile> GetFileFromApplicationUriAsync(Uri uri) - 獲取本地指定 uri 的文件 */ using System; using Windows.Storage; using Windows.UI.Xaml.Controls; using Windows.UI.Xaml.Navigation; namespace Windows10.FileSystem.AppData { public sealed partial class MediaReference : Page { public MediaReference() { this.InitializeComponent(); } protected async override void OnNavigatedTo(NavigationEventArgs e) { ApplicationData appData = ApplicationData.Current; try { // 將程序包內的文件保存到 ApplicationData 中的 TemporaryFolder StorageFile imgFile = await StorageFile.GetFileFromApplicationUriAsync(new Uri("ms-appx:///Assets/Logo.png")); await imgFile.CopyAsync(appData.TemporaryFolder, imgFile.Name, NameCollisionOption.ReplaceExisting); } catch { } // 引用 Application Data 內的圖片文件並顯示 imgAppdata.Source = new Windows.UI.Xaml.Media.Imaging.BitmapImage(new Uri("ms-appdata:///temp/Logo.png")); // 引用程序包內的圖片文件並顯示 imgAppx.Source = new Windows.UI.Xaml.Media.Imaging.BitmapImage(new Uri("ms-appx:///Assets/Logo.png")); // 也可以在 xaml 這樣寫 // <img src="ms-appdata:///temp/Logo.png" /> base.OnNavigatedTo(e); } } }
OK
[源碼下載]