Freigeben über


WebView.BuildLocalStreamUri(String, String) Methode

Definition

Erstellt einen URI, den Sie an NavigateToLocalStreamUri übergeben können.

public:
 virtual Uri ^ BuildLocalStreamUri(Platform::String ^ contentIdentifier, Platform::String ^ relativePath) = BuildLocalStreamUri;
Uri BuildLocalStreamUri(winrt::hstring const& contentIdentifier, winrt::hstring const& relativePath);
public System.Uri BuildLocalStreamUri(string contentIdentifier, string relativePath);
function buildLocalStreamUri(contentIdentifier, relativePath)
Public Function BuildLocalStreamUri (contentIdentifier As String, relativePath As String) As Uri

Parameter

contentIdentifier
String

Platform::String

winrt::hstring

Ein eindeutiger Bezeichner für den Inhalt, auf den der URI verweist. Dadurch wird der Stamm des URI definiert.

relativePath
String

Platform::String

winrt::hstring

Der Pfad zur Ressource relativ zum Stamm.

Gibt zurück

Der URI, der durch Kombinieren und Normalisieren von contentIdentifier und relativePath erstellt wird.

Beispiele

Im folgenden Codebeispiel wird gezeigt, wie Sie diese Methode mit einem Resolver verwenden, der eine Datei aus dem App-Paket bereitstellt. Ein vollständiges Beispiel finden Sie im Xaml-WebView-Steuerelementbeispiel.

public sealed partial class TestPage : Page
{
    // ... other code ...

    protected override void OnNavigatedTo(NavigationEventArgs e)
    {
        // The 'Host' part of the URI for the ms-local-stream protocol needs to be a combination of the package name
        // and an application-defined key, which identifies the specific resolver, in this case 'MyTag'.

        Uri url = webView4.BuildLocalStreamUri("MyTag","/Minesweeper/default.html");
        StreamUriWinRTResolver myResolver = new StreamUriWinRTResolver();

        // Pass the resolver object to the navigate call.
        webView4.NavigateToLocalStreamUri(url, myResolver);
    }
}

public sealed class StreamUriWinRTResolver : IUriToStreamResolver
{
    public IAsyncOperation<IInputStream> UriToStreamAsync(Uri uri)
    {
        if (uri == null)
        {
            throw new Exception();
        }
        string path = uri.AbsolutePath;

        // Because of the signature of the this method, it can't use await, so we 
        // call into a separate helper method that can use the C# await pattern.
        return GetContent(path).AsAsyncOperation();
    }

    private async Task<IInputStream> GetContent(string path)
    {
        // We use a package folder as the source, but the same principle should apply
        // when supplying content from other locations
        try
        {
            Uri localUri= new Uri("ms-appx:///html" + path);
            StorageFile f = await StorageFile.GetFileFromApplicationUriAsync(localUri);
            IRandomAccessStream stream = await f.OpenAsync(FileAccessMode.Read);
            return stream.GetInputStreamAt(0);
        }
        catch (Exception) { throw new Exception("Invalid path"); }
    }
}

Gilt für:

Weitere Informationen