pdfjs
Published
2023-04-02
浏览次数 : 103
<?php
/**
* this file is for display the pdf catalog with pdf.js
*
*/
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>浙江景祥空调设备有限公司画册</title>
<meta name="description" content="浙江景祥专业生产换热器和铜配件" />
<link rel="stylesheet" href="<?php bloginfo('template_url'); ?>/css/vendor/all.min.css">
<style>
.top-bar {
background-color: #333;
color: #fff;
padding: 1rem;
}
.btn {
background: coral;
color: #fff;
border: none;
outline: none;
cursor: pointer;
padding: 0.7rem 2rem;
}
.btn:hover {
opacity: 0.9;
}
.page-info {
margin-left: 1rem;
}
.error {
background-color: orangered;
color: #fff;
padding: 1rem;
}
/* Make the canvas responsive */
canvas {
max-width: 100%;
height: auto;
width: auto\9; /* IE8 and below */
}
/* Adjust font sizes based on screen size */
@media screen and (max-width: 767px) {
.top-bar {
padding: 0.5rem;
}
.btn {
font-size: 0.8rem;
padding: 0.5rem 1rem;
}
.page-info {
font-size: 0.8rem;
}
.error {
font-size: 0.8rem;
padding: 0.5rem;
}
}
@media screen and (min-width: 768px) and (max-width: 991px) {
.top-bar {
padding: 0.7rem;
}
.btn {
font-size: 1rem;
padding: 0.7rem 1.5rem;
}
.page-info {
font-size: 1rem;
}
.error {
font-size: 1rem;
padding: 0.7rem;
}
}
@media screen and (min-width: 992px) {
.top-bar {
padding: 1rem;
}
.btn {
font-size: 1.2rem;
padding: 0.7rem 2rem;
}
.page-info {
font-size: 1.2rem;
}
.error {
font-size: 1.2rem;
padding: 1rem;
}
}
</style>
</head>
<body>
<div class="top-bar">
<button id="prev-page" class="btn"><i class="fas fa-arrow-circle-left"></i>上一页</button>
<button id="next-page" class="btn">下一页<i class="fas fa-arrow-circle-right"></i></button>
<span class="page-info">Page <span id="page-num"></span> of <span id="page-count"></span></span>
<button id="scale-in">放大</button>
<button id="scale-out">缩小</button>
</div>
<div id="loading" style="display: none;">
<!-- <h2 style="color:red">内容正在加载预计20秒时间请稍后,加载一次后面每次秒开.</h2> -->
<img src="<?php echo get_template_directory_uri() . '/img/loading.gif' ?>" alt="Loading icon">
</div>
<canvas id="pdf-render"></canvas>
<script src="<?php bloginfo('template_url'); ?>/js/pdf.js"></script>
</body>
<!-- send the script here -->
<script type="text/javascript">
<?php
$absolute_path = get_post_meta( get_the_ID(),'catalog_pdf',true );
$relative_path = str_replace(site_url(), '', $absolute_path);
$relative_path = '../..' . $relative_path;
?>
const url = `<?php echo $relative_path; ?>`;
let pdfDoc = null,
pageNum = 1,
pageIsRendering = false,
pageNumIsPending = null;
const canvas = document.querySelector('#pdf-render'),
ctx = canvas.getContext('2d');
const renderPage = (num, scale) => {
pageIsRendering = true;
const loadingElement = document.getElementById('loading');
loadingElement.style.display = 'block';
pdfDoc.getPage(num).then(page => {
const viewport = page.getViewport({ scale });
canvas.height = viewport.height;
canvas.width = viewport.width;
const renderContext = {
canvasContext: ctx,
viewport,
disableAutoFetch: true, // Disable automatic fetching of pages
disableStream: true, // Disable streaming
};
page.render(renderContext).promise.then(() => {
pageIsRendering = false;
if (pageNumIsPending !== null) {
renderPage(pageNumIsPending, scale);
pageNumIsPending = null;
}
loadingElement.style.display = 'none'; // Hide loading element when done
}).catch(error => {
console.error('Error rendering page:', error);
});
document.querySelector('#page-num').textContent = num;
});
};
const queueRenderPage = (num, scale) => {
if (pageIsRendering) {
pageNumIsPending = num;
} else {
renderPage(num, scale);
}
};
const showPrevPage = () => {
if (pageNum <= 1) {
return;
}
pageNum--;
queueRenderPage(pageNum, scale);
};
const showNextPage = () => {
if (pageNum >= pdfDoc.numPages) {
pageNum = 1; // Set the page number to 1
} else {
pageNum++;
}
queueRenderPage(pageNum, scale);
};
const initPdfViewer = (url, scale) => {
const loadingElement = document.getElementById('loading');
loadingElement.style.display = 'block';
pdfjsLib.GlobalWorkerOptions.workerSrc = '<?php bloginfo('template_url'); ?>/js/pdf.worker.js';
pdfjsLib.getDocument(url, {
worker: true,
workerSrc: 'pdf.worker.js',
disableAutoFetch: true, // Disable automatic fetching of pages
disableStream: true, // Disable streaming
}).promise.then(pdfDoc_ => {
pdfDoc = pdfDoc_;
document.querySelector('#page-count').textContent = pdfDoc.numPages;
renderPage(pageNum, scale);
loadingElement.style.display = 'none'; // Hide loading element when done
}).catch(err => {
const div = document.createElement('div');
div.className = 'error';
div.appendChild(document.createTextNode(err.message));
document.querySelector('body').insertBefore(div, canvas);
document.querySelector('.top-bar').style.display = 'none';
});
};
var scale = 0.5;
initPdfViewer(url, scale);
document.querySelector('#prev-page').addEventListener('click', showPrevPage);
document.querySelector('#next-page').addEventListener('click', showNextPage);
let startPointX = 0;
let endPointX = 0;
//支持触屏换页, 勿删
// const handleTouchStart = (e) => {
// startPointX = e.touches[0].clientX;
// };
// const handleTouchEnd = (e) => {
// endPointX = e.changedTouches[0].clientX;
// if (startPointX - endPointX > 50) {
// showNextPage();
// } else if (endPointX - startPointX > 50) {
// showPrevPage();
// }
// };
// canvas.addEventListener('touchstart', handleTouchStart);
// canvas.addEventListener('touchend', handleTouchEnd);
const scaleInButton = document.querySelector('#scale-in');
const scaleOutButton = document.querySelector('#scale-out');
const handleScaleIn = () => {
scale += 0.1;
renderPage(pageNum, scale);
};
const handleScaleOut = () => {
if (scale <= 0.2) {
return;
}
scale -= 0.1;
renderPage(pageNum, scale);
};
scaleInButton.addEventListener('click', handleScaleIn);
scaleOutButton.addEventListener('click', handleScaleOut);
</script>
</html>
- 标签1
- 标签1
- 标签1