5
  1. 我正在使用PDFMAKE创建一个 base64 编码的 pdf,我试图通过将编码的 base64 提供给 iframe src 来用 iframe 显示它。它适用于 PC,但不适用于移动设备(android 和 ios)。

    1. 所以,最后我偶然发现了Angularjs-PDF来显示 pdf。现在,我可以在移动设备中看到 pdf。但是当我尝试为设备提供自定义宽度和高度时,它需要。但是,当我使用缩放功能时,问题就出现了,页面被缩放了,但它离开了屏幕。我什至无法滑动或滑动查看屏幕外的内容。

我想在客户端制作一个 pdf,并在 Ionic 中使用缩放功能预览给用户。

如果有人对此有任何解决方案,请分享,谢谢。

4

1 回答 1

10

因此,对于我们公司的应用程序,我们使用了 angular-pdf 查看器:

这是 pdf 查看器模板的模板,放入 ion-scroll 可以进行缩放缩放,效果很好。

<div ng-show="notLoaded" class=" center bar bar-subheader">
    <h1 class="title">Loading PDF...</h1>
</div>
<div class="tabs tabs-icon-left">
    <a class="tab-item" ng-click="goPrevious()">
        <i class="icon ion-arrow-left-c"></i>
        Prev
    </a>
    <a class="tab-item" ng-click="goNext()">
        <i class="icon ion-arrow-right-c"></i>
        Next
    </a>
</div>

<ion-scroll zooming="true" direction="xy" class="has-header">
    <canvas class="padding" id="pdf" class="rotate0"></canvas>
</ion-scroll>

然后在显示pdf的页面上:

<ion-view>
    <div class="bar bar-header bar-positive">
        <button ng-click="$ionicGoBack()" class="button button-clear button-light icon-left ion-chevron-left">Go Back</button>
    </div>
    <div class="has-header">
        <ng-pdf template-url="components/pdfviewer/viewer.html" canvasid="pdf" scale="0.675">
        </ng-pdf>
    </div>
</ion-view>

您将模板提供给 pdf 查看器,它将显示在页面上。

要使用它首先包含正确的 js 文件:

<script src="bower_components/pdfjs-dist/build/pdf.js"></script>
<script src="bower_components/angular/angular.js"></script>
<script src="bower_components/angular-pdf-viewer/dist/angular-pdf-viewer.min.js"></script>

然后注入pdf:

var app = angular.module('App', ['pdf']);

你可以在这里阅读更多关于它的信息,但是将它与 ion-scroll 结合使用它就像你认为它应该在本机设备上一样工作:

https://github.com/winkerVSbecks/angular-pdf-viewer

于 2015-09-08T15:17:34.437 回答