修改PDF以使用离子cordova中的javascript添加按钮

时间:2015-08-23 03:06:45

标签: javascript cordova ionic-framework jspdf

我有一个杂志查看应用程序,旨在观看杂志

杂志是一系列现有的网址,每个网页都有一页杂志 因此,如果一本杂志有十页,我将有十种不同的PDF格式。

我想下载第一个(使用Cordova文件传输http://ngcordova.com/docs/plugins/fileTransfer/),然后查看它(使用cordova fileOpener)

我的问题是我如何允许用户从pdf应用程序中传递到下一页(因为它将打开一个单独的pdf,它不会显示其他不相关的页面)。

我在想在pdf上添加按钮,但我不知道如何使用js

来解决它

1 个答案:

答案 0 :(得分:1)

对于我们的公司应用,我们使用angular-pdf-viewer

它非常简单易用,它可以让您轻松添加按钮并将它们连接到指令功能。如果需要,它甚至可以显示页码和旋转页面。

在index.html文件中包含js后,只需注入模块

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

然后将指令放在您的页面上。您还可以为您的杂志阵列设置双向数据绑定。

<pdf-viewer
    delegate-handle="my-pdf-container"
    url="pdfUrl"
    scale="1"
    show-toolbar="true"
    headers="{ 'x-you-know-whats-awesome': 'EVERYTHING' }"></pdf-viewer>

以下是您可以使用的方法列表(您还可以使用不同的句柄来拥有多个pdf查看器

pdfDelegate.$getByHandle('my-pdf-container').zoomIn();
•prev
•next
•zoomIn(amount) default amount = 0.2
•zoomOut(amount) default amount = 0.2
•zoomTo(amount)
•rotate (clockwise by 90 degrees)
•getPageCount
•getCurrentPage
•goToPage(pageNumber)
•load

要更改加载的pdf,您可以使用双向数据绑定更改pdfUrl,也可以使用pdf委托句柄:

pdfDelegate
    .$getByHandle('my-pdf-container')
    .load('url-of-the-new-file.pdf');

编辑: 抱歉,我给了你很多pdf模块中的一个,这实际上是我们使用的模块,另一个可能更好,如果你需要不同的观众虽然(不止一个)这里是我们使用的那个:https://github.com/sayanee/angularjs-pdf

这是页面上的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>

然后我们有了一个viewer.html模板

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

这是他们演示的控制器代码:

   angular.module('testApp', ['pdf']).controller('AppCtrl', [
    '$scope',
    'pdfDelegate',
    function ($scope, pdfDelegate, $log) {
        $scope.relativity = 'https://s3-us-west-2.amazonaws.com/s.cdpn.io/149125/relativity.pdf';
        $scope.material = 'https://s3-us-west-2.amazonaws.com/s.cdpn.io/149125/material-design-2.pdf';
        $scope.pdfUrl = $scope.material;
    }
]);