WindowsRuntimeStreamExtensions Clase

Definición

Contiene métodos de extensión para convertir entre secuencias en Windows Runtime y flujos administrados en .NET para aplicaciones de la Tienda Windows.

public ref class WindowsRuntimeStreamExtensions abstract sealed
[System.Security.SecurityCritical]
public static class WindowsRuntimeStreamExtensions
[<System.Security.SecurityCritical>]
type WindowsRuntimeStreamExtensions = class
Public Module WindowsRuntimeStreamExtensions
Herencia
WindowsRuntimeStreamExtensions
Atributos

Ejemplos

En el ejemplo siguiente se muestra cómo usar el AsStreamForWrite y el AsStreamForRead

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

Este es el código XAML asociado al ejemplo anterior.

<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>

Comentarios

Estos métodos de extensión solo están disponibles cuando desarrollas aplicaciones de la Tienda Windows. Los métodos proporcionan formas cómodas de trabajar con secuencias en aplicaciones de la Tienda Windows. No se crea una instancia de la clase WindowsRuntimeStreamExtensions; en su lugar, se usan estos métodos desde instancias de las interfaces IInputStream y IOutputStream y la clase Stream.

La clase WindowsRuntimeStreamExtensions contiene dos métodos para convertir un objeto de Stream administrado en una secuencia de Windows Runtime:

La clase WindowsRuntimeStreamExtensions contiene tres métodos sobrecargados para convertir una secuencia en Windows Runtime en un objeto Stream:

A partir de .NET Framework 4.5.1, la clase WindowsRuntimeStreamExtensions contiene un método para convertir una secuencia en un RandomAccessStreamde Windows Runtime:

Métodos

AsInputStream(Stream)

Convierte una secuencia administrada en .NET para aplicaciones de la Tienda Windows en un flujo de entrada en Windows Runtime.

AsOutputStream(Stream)

Convierte una secuencia administrada en .NET para aplicaciones de la Tienda Windows en un flujo de salida en Windows Runtime.

AsRandomAccessStream(Stream)

Convierte la secuencia especificada en una secuencia de acceso aleatorio.

AsStream(IRandomAccessStream, Int32)

Convierte una secuencia de acceso aleatorio en Windows Runtime en una secuencia administrada en .NET para aplicaciones de la Tienda Windows con el tamaño de búfer especificado.

AsStream(IRandomAccessStream)

Convierte una secuencia de acceso aleatorio en Windows Runtime en una secuencia administrada en .NET para aplicaciones de la Tienda Windows.

AsStreamForRead(IInputStream, Int32)

Convierte un flujo de entrada en Windows Runtime en una secuencia administrada en las aplicaciones de la Tienda .NET para Windows 8.x con el tamaño de búfer especificado.

AsStreamForRead(IInputStream)

Convierte un flujo de entrada en Windows Runtime en una secuencia administrada en .NET para aplicaciones de la Tienda Windows.

AsStreamForWrite(IOutputStream, Int32)

Convierte un flujo de salida en Windows Runtime en una secuencia administrada en .NET para aplicaciones de la Tienda Windows con el tamaño de búfer especificado.

AsStreamForWrite(IOutputStream)

Convierte un flujo de salida en Windows Runtime en una secuencia administrada en .NET para aplicaciones de la Tienda Windows 8.x.

Se aplica a