BlazorWebAssembly中使用pdf.js中的流
创始人
2024-12-22 01:30:05
0
  1. 首先,在Blazor WebAssembly项目中安装pdf.js包,可以通过命令行或NuGet包管理器来执行此操作。

  2. 在Blazor组件中添加以下代码,将pdf.js库和pdf.worker.js文件引入到您的项目中:

@inject IJSRuntime JsRuntime;
@implements IDisposable

private IJSObjectReference pdfjsLibrary;
private IJSObjectReference pdfjsWorker;

protected override async Task OnInitializedAsync()
{
    pdfjsLibrary = await JsRuntime.InvokeAsync(
        "import", "./_content/pdfjs-dist/build/pdf.min.js");
    pdfjsWorker = await JsRuntime.InvokeAsync(
        "import", "./_content/pdfjs-dist/build/pdf.worker.min.js");

    await base.OnInitializedAsync();
}

public async ValueTask DisposeAsync()
{
    if (pdfjsWorker != null)
    {
        await pdfjsWorker.DisposeAsync();
        pdfjsWorker = null;
    }

    if (pdfjsLibrary != null)
    {
        await pdfjsLibrary.DisposeAsync();
        pdfjsLibrary = null;
    }
}
  1. 然后,在Blazor组件中,您可以使用以下代码片段来检索pdf文件并将其从流中显示出来:
private async Task DisplayPdfAsync(DocumentFileStream documentStream)
{
    try
    {
        var memoryStream = new MemoryStream();
        await documentStream.CopyToAsync(memoryStream);
        memoryStream.Position = 0;
        await pdfjsWorker.InvokeVoidAsync("pdfjsWorkerGlobalScope.PDFJS.workerSrc",
            "./_content/pdfjs-dist/build/pdf.worker.min.js");

        var pdf = await pdfjsLibrary.InvokeAsync("getDocument", memoryStream.ToArray());
        var page = await pdf.InvokeAsync("getPage", 1);
        var scale = 1.5f;
        var viewport = await page.InvokeAsync("getViewport", (double)scale);

        var canvasRef = await canvasRefTask.Task;
        canvasRef.Width = viewport.width;
        canvasRef.Height = viewport.height;

        var renderOptions = new
        {
            canvasContext = await canvasRef.GetContext2DAsync(),
            viewport = viewport

相关内容

热门资讯

透视游戏!wpk是真的还是假的... 透视游戏!wpk是真的还是假的,德普之星辅助工具如何打开,详细教程(有挂工具)-哔哩哔哩1、德普之星...
透视透视!aapoker怎么提... 透视透视!aapoker怎么提高中牌率,wepoker辅助透视,玩家教程(有挂细节)-哔哩哔哩1)a...
透视了解!大菠萝手游辅助,hh... 透视了解!大菠萝手游辅助,hhpoker是真的还是假的,科技教程(真的有挂)-哔哩哔哩1、让任何用户...
透视了解!竞技联盟辅助,wep... 透视了解!竞技联盟辅助,wepoker祈福有用吗,教你攻略(有挂攻略)-哔哩哔哩1、下载好wepok...
黑科技辅助!wepoke辅助有... 黑科技辅助!wepoke辅助有挂,(Wepoke ios)原来真的有挂,必胜教程(有挂透视)-哔哩哔...
黑科技辅助!wpk有透视辅助,... 黑科技辅助!wpk有透视辅助,(WPK系统)原来真的有挂,教你攻略(详情)-哔哩哔哩;相信小伙伴都知...
黑科技辅助!wepoke可以看... 黑科技辅助!wepoke可以看有外挂,(WePoKe讲解)原来真的有挂,必赢方法(有挂透视)-哔哩哔...
黑科技辅助!微扑克辅助软件,(... 您好:微扑克辅助软件这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特...
黑科技辅助!wepower有外... 您好,WePoKe线上这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在...
黑科技辅助!aapoker有内... 您好:AAPoKerai机器人这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多...