WindowsRuntimeStreamExtensions クラス

定義

Windows ランタイム内のストリームと、Windows ストア アプリの.NET内のマネージド ストリームの間で変換するための拡張メソッドが含まれています。

public ref class WindowsRuntimeStreamExtensions abstract sealed
[System.Security.SecurityCritical]
public static class WindowsRuntimeStreamExtensions
[<System.Security.SecurityCritical>]
type WindowsRuntimeStreamExtensions = class
Public Module WindowsRuntimeStreamExtensions
継承
WindowsRuntimeStreamExtensions
属性

次の例では、 AsStreamForWriteAsStreamForRead

using System;
using System.IO;
using Windows.Storage;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;

namespace ExampleApplication
{
    public sealed partial class BlankPage : Page
    {
        public BlankPage()
        {
            this.InitializeComponent();
        }

        private async void CreateButton_Click(object sender, RoutedEventArgs e)
        {
            StorageFile newFile = await ApplicationData.Current.LocalFolder.CreateFileAsync("testfile.txt");
            var streamNewFile = await newFile.OpenAsync(FileAccessMode.ReadWrite);

            using (var outputNewFile = streamNewFile.GetOutputStreamAt(0))
            {
                using (StreamWriter writer = new StreamWriter(outputNewFile.AsStreamForWrite()))
                {
                    await writer.WriteLineAsync("content for new file");
                    await writer.WriteLineAsync(UserText.Text);
                }
            }
        }

        private async void VerifyButton_Click(object sender, RoutedEventArgs e)
        {
            StorageFile openedFile = await ApplicationData.Current.LocalFolder.GetFileAsync("testfile.txt");
            var streamOpenedFile = await openedFile.OpenAsync(FileAccessMode.Read);

            using (var inputOpenedFile = streamOpenedFile.GetInputStreamAt(0))
            {
                using (StreamReader reader = new StreamReader(inputOpenedFile.AsStreamForRead()))
                {
                    Results.Text = await reader.ReadToEndAsync();
                }
            }
        }
    }
}
Imports System.IO
Imports Windows.Storage

NotInheritable Public Class BlankPage
    Inherits Page

    Private Async Sub CreateButton_Click(sender As Object, e As RoutedEventArgs)
        Dim newFile As StorageFile = Await ApplicationData.Current.LocalFolder.CreateFileAsync("testfile.txt")
        Dim streamNewFile = Await newFile.OpenAsync(FileAccessMode.ReadWrite)

        Using outputNewFile = streamNewFile.GetOutputStreamAt(0)
            Using writer As StreamWriter = New StreamWriter(outputNewFile.AsStreamForWrite())
                Await writer.WriteLineAsync("content for new file")
                Await writer.WriteLineAsync(UserText.Text)
            End Using
        End Using
    End Sub

    Private Async Sub VerifyButton_Click(sender As Object, e As RoutedEventArgs)
        Dim openedFile As StorageFile = Await ApplicationData.Current.LocalFolder.GetFileAsync("testfile.txt")
        Dim streamOpenedFile = Await openedFile.OpenAsync(FileAccessMode.Read)

        Using inputOpenedFile = streamOpenedFile.GetInputStreamAt(0)

            Using reader As StreamReader = New StreamReader(inputOpenedFile.AsStreamForRead())
                Results.Text = Await reader.ReadToEndAsync()
            End Using
        End Using
    End Sub
End Class

前の例に関連付けられている XAML コードを次に示します。

<Page
    x:Class="ExampleApplication.BlankPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:ExampleApplication"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <StackPanel Background="{StaticResource ApplicationPageBackgroundBrush}" VerticalAlignment="Center" HorizontalAlignment="Center">
        <TextBlock Text="Provide text to write to file:"></TextBlock>
        <TextBox Name="UserText" Width="400"></TextBox>
        <Button Name="CreateButton" Content="Create File" Click="CreateButton_Click"></Button>
        <Button Name="VerifyButton" Content="Verify Contents" Click="VerifyButton_Click"></Button>
        <TextBlock Name="Results"></TextBlock>
    </StackPanel>
</Page>

注釈

これらの拡張メソッドは、Windowsストア アプリを開発する場合にのみ使用できます。 このメソッドは、Windows ストア アプリでストリームを操作する便利な方法を提供します。 WindowsRuntimeStreamExtensions クラスのインスタンスは作成しません。代わりに、<xref:Windows.Storage.Streams.IInputStream>インターフェイスと<xref:Windows.Storage.Streams.IOutputStream> インターフェイスとStream クラスのインスタンスからこれらのメソッドを使用します。

WindowsRuntimeStreamExtensions クラスには、マネージド Stream オブジェクトをWindows ランタイム内のストリームに変換するための 2 つのメソッドが含まれています。

WindowsRuntimeStreamExtensions クラスには、Windows ランタイム内のストリームを Stream オブジェクトに変換するための 3 つのオーバーロードされたメソッドが含まれています。

.NET Framework 4.5.1 以降、WindowsRuntimeStreamExtensions クラスには、ストリームを Windows ランタイム <xref:Windows.Storage.Streams.RandomAccessStream> に変換するためのメソッドが含まれています。

メソッド

名前 説明
AsInputStream(Stream)

.NET for Windows ストア アプリのマネージド ストリームを Windows ランタイムの入力ストリームに変換します。

AsOutputStream(Stream)

.NET for Windows ストア アプリのマネージド ストリームを Windows ランタイムの出力ストリームに変換します。

AsRandomAccessStream(Stream)

指定したストリームをランダム アクセス ストリームに変換します。

AsStream(IRandomAccessStream, Int32)

指定したバッファー サイズを使用して、Windows ランタイムのランダム アクセス ストリームを、Windows Store アプリの.NET内のマネージド ストリームに変換します。

AsStream(IRandomAccessStream)

Windows ランタイムのランダム アクセス ストリームを、Windows Store アプリの.NETのマネージド ストリームに変換します。

AsStreamForRead(IInputStream, Int32)

指定したバッファー サイズを使用して、Windows ランタイム内の入力ストリームを Windows 8.x ストア アプリの.NETのマネージド ストリームに変換します。

AsStreamForRead(IInputStream)

Windows ランタイム内の入力ストリームを、Windows ストア アプリの.NETのマネージド ストリームに変換します。

AsStreamForWrite(IOutputStream, Int32)

指定したバッファー サイズを使用して、Windows ランタイムの出力ストリームを、Windows ストア アプリの.NETのマネージド ストリームに変換します。

AsStreamForWrite(IOutputStream)

Windows ランタイムの出力ストリームを、Windows 8.x ストア アプリの.NETのマネージド ストリームに変換します。

適用対象