2020-04-08 17:05:30 +03:00
|
|
|
var pdfjsLib = window['pdfjs-dist/build/pdf'];
|
2020-04-29 17:57:55 +03:00
|
|
|
var pdfcanvas = "the-canvas";
|
|
|
|
|
var cnt = 100;
|
|
|
|
|
|
|
|
|
|
|
2020-04-08 17:05:30 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
function renderPage() {
|
2020-04-08 20:02:51 +03:00
|
|
|
|
2020-04-29 09:46:42 +03:00
|
|
|
var el_title = document.getElementById('pdfprogress');
|
2020-04-29 17:57:55 +03:00
|
|
|
|
2020-04-29 09:46:42 +03:00
|
|
|
|
|
|
|
|
el_title.innerHTML = 'Идет подготовка страницы ...';
|
2020-04-08 20:02:51 +03:00
|
|
|
|
2020-04-08 17:05:30 +03:00
|
|
|
pageRendering = true;
|
|
|
|
|
// Using promise to fetch the page
|
2020-04-28 22:35:13 +03:00
|
|
|
pdfDoc.getPage(pageNum).then(function(page) {
|
2020-04-08 17:05:30 +03:00
|
|
|
|
2020-04-29 17:57:55 +03:00
|
|
|
var canvas = document.getElementById(pdfcanvas);
|
2020-04-08 17:05:30 +03:00
|
|
|
var context = canvas.getContext('2d');
|
2020-04-29 15:01:25 +03:00
|
|
|
//var viewport = page.getViewport({scale: scale});
|
2020-04-29 15:07:29 +03:00
|
|
|
var viewport = page.getViewport({scale: 1.5});
|
2020-04-29 16:28:15 +03:00
|
|
|
// var viewport = page.getViewport(canvas.width / page.getViewport(0.5).width)
|
2020-04-29 15:01:25 +03:00
|
|
|
|
|
|
|
|
|
2020-04-08 17:05:30 +03:00
|
|
|
canvas.height = viewport.height;
|
|
|
|
|
canvas.width = viewport.width;
|
|
|
|
|
|
|
|
|
|
// Render PDF page into canvas context
|
|
|
|
|
var renderContext = {
|
|
|
|
|
canvasContext: context,
|
|
|
|
|
viewport: viewport
|
|
|
|
|
};
|
|
|
|
|
var renderTask = page.render(renderContext);
|
|
|
|
|
|
|
|
|
|
// Wait for rendering to finish
|
|
|
|
|
renderTask.promise.then(function() {
|
|
|
|
|
pageRendering = false;
|
|
|
|
|
if (pageNumPending !== null) {
|
|
|
|
|
// New page rendering is pending
|
|
|
|
|
renderPage(pageNumPending);
|
|
|
|
|
pageNumPending = null;
|
2020-04-29 09:52:03 +03:00
|
|
|
|
2020-04-08 17:05:30 +03:00
|
|
|
}
|
2020-04-29 19:57:50 +03:00
|
|
|
el_title.innerHTML = '';
|
2020-04-08 17:05:30 +03:00
|
|
|
});
|
|
|
|
|
});
|
2020-04-08 19:52:25 +03:00
|
|
|
|
2020-04-29 09:46:42 +03:00
|
|
|
|
2020-04-08 22:09:00 +03:00
|
|
|
|
2020-04-08 17:05:30 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-04-08 22:09:00 +03:00
|
|
|
function prevclick(){
|
|
|
|
|
prevurl = prevlink + '/'+ scale;
|
|
|
|
|
location.href = prevurl;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function nextclick(){
|
|
|
|
|
nexturl = nextlink + '/'+ scale;
|
|
|
|
|
location.href = nexturl;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-04-08 17:05:30 +03:00
|
|
|
function pdfzoomin(){
|
|
|
|
|
|
2020-04-08 19:52:25 +03:00
|
|
|
scale += 0.25;
|
2020-04-08 22:09:00 +03:00
|
|
|
setzoom(scale);
|
2020-04-08 17:05:30 +03:00
|
|
|
renderPage();
|
|
|
|
|
|
2020-04-08 22:09:00 +03:00
|
|
|
|
2020-04-08 17:05:30 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function pdfzoomout(){
|
|
|
|
|
|
2020-04-08 19:52:25 +03:00
|
|
|
scale -= 0.25;
|
2020-04-08 22:39:21 +03:00
|
|
|
setzoom(scale);
|
2020-04-08 17:05:30 +03:00
|
|
|
renderPage();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-08 22:09:00 +03:00
|
|
|
|
2020-04-29 14:41:23 +03:00
|
|
|
function resize_plus(){
|
2020-04-29 19:57:50 +03:00
|
|
|
cnt += 5;
|
2020-04-29 17:57:55 +03:00
|
|
|
newpdfzoom(cnt);
|
2020-04-29 14:41:23 +03:00
|
|
|
}
|
2020-04-29 17:57:55 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
function resize_minus(){
|
2020-04-29 19:57:50 +03:00
|
|
|
cnt -= 5;
|
2020-04-29 17:57:55 +03:00
|
|
|
newpdfzoom(cnt);
|
2020-04-29 14:41:23 +03:00
|
|
|
}
|
2020-04-29 16:28:15 +03:00
|
|
|
|
2020-04-29 17:57:55 +03:00
|
|
|
function newpdfzoom(czoom){
|
|
|
|
|
|
|
|
|
|
var status = czoom+"%";
|
|
|
|
|
|
2020-04-29 22:19:45 +03:00
|
|
|
document.getElementById(pdfcanvas).style.width = status;
|
|
|
|
|
document.getElementById('zoomstatus').innerHTML = status;
|
2020-04-29 16:28:15 +03:00
|
|
|
|
2020-04-29 22:19:45 +03:00
|
|
|
setzoom('pdfscale', czoom);
|
2020-04-08 22:09:00 +03:00
|
|
|
|
2020-04-29 17:57:55 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function getzoom( name ){
|
|
|
|
|
|
|
|
|
|
|
2020-04-08 22:39:21 +03:00
|
|
|
var results = document.cookie.match ( '(^|;) ?' + name + '=([^;]*)(;|$)' );
|
2020-04-08 22:09:00 +03:00
|
|
|
|
2020-04-08 22:39:21 +03:00
|
|
|
if ( results ){
|
|
|
|
|
return parseFloat(unescape(results[2]));
|
|
|
|
|
}
|
|
|
|
|
else {
|
2020-04-08 22:09:00 +03:00
|
|
|
return null;
|
2020-04-08 22:39:21 +03:00
|
|
|
}
|
2020-04-08 22:09:00 +03:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-29 17:57:55 +03:00
|
|
|
function setzoom( cname, cvalue, exdays = 30 ) {
|
2020-04-08 22:39:21 +03:00
|
|
|
|
2020-04-08 22:09:00 +03:00
|
|
|
var d = new Date();
|
|
|
|
|
d.setTime(d.getTime() + (exdays*24*60*60*1000));
|
|
|
|
|
|
2020-04-08 22:39:21 +03:00
|
|
|
|
|
|
|
|
var expires = "expires="+ d.toUTCString();
|
|
|
|
|
document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
|
|
|
|
|
|
|
|
|
|
}
|
2020-04-08 22:09:00 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-04-29 16:28:15 +03:00
|
|
|
|
2020-04-08 22:09:00 +03:00
|
|
|
|
2020-04-29 22:19:45 +03:00
|
|
|
function startpdfviewer(newcurr){
|
2020-04-08 22:39:21 +03:00
|
|
|
|
2020-04-29 22:19:45 +03:00
|
|
|
pdcurr = getzoom('pdcurr');
|
2020-04-29 17:57:55 +03:00
|
|
|
|
2020-04-29 22:19:45 +03:00
|
|
|
if (pdcurr == newcurr){
|
|
|
|
|
czoom = getzoom('pdfscale');
|
2020-04-29 21:28:45 +03:00
|
|
|
if (czoom > 10) {
|
2020-04-29 23:41:50 +03:00
|
|
|
cnt = czoom;
|
2020-04-29 17:57:55 +03:00
|
|
|
newpdfzoom(czoom);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else {
|
2020-04-29 22:19:45 +03:00
|
|
|
setzoom('pdcurr', newcurr);
|
2020-04-29 22:21:36 +03:00
|
|
|
setzoom('pdfscale', 100);
|
2020-04-29 17:57:55 +03:00
|
|
|
}
|
2020-04-29 16:34:33 +03:00
|
|
|
|
2020-04-08 17:05:30 +03:00
|
|
|
|
2020-04-08 20:02:51 +03:00
|
|
|
pdfjsLib.getDocument(url).promise.then(function(pdfDoc_) {
|
|
|
|
|
pdfDoc = pdfDoc_;
|
|
|
|
|
renderPage();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
}
|
2020-04-08 17:05:30 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|