1
0
Fork 0
mirror of https://github.com/futurepress/epub.js.git synced 2025-10-02 14:49:16 +02:00

Fixes for page counting

This commit is contained in:
Fred Chasen 2017-08-09 17:19:02 -04:00
parent 8bfed1593c
commit 03e7ca085c
5 changed files with 28 additions and 24 deletions

View file

@ -1,6 +1,6 @@
{
"name": "epubjs",
"version": "0.3.44",
"version": "0.3.45",
"description": "Parse and Render Epubs",
"main": "lib/index.js",
"module": "src/index.js",

View file

@ -105,6 +105,7 @@ class Layout {
var colWidth;
var spreadWidth;
var pageWidth;
var delta;
if (this._spread && width >= this._minSpreadWidth) {
@ -135,14 +136,15 @@ class Layout {
width = colWidth;
}
spreadWidth = colWidth * divisor;
spreadWidth = (colWidth * divisor) + gap;
pageWidth = colWidth + (gap / 2);
delta = width;
// console.log(delta, width);
this.width = width;
this.height = _height;
this.spreadWidth = spreadWidth;
this.pageWidth = pageWidth;
this.delta = delta;
this.columnWidth = colWidth;
@ -152,6 +154,7 @@ class Layout {
this.props.width = width;
this.props.height = _height;
this.props.spreadWidth = spreadWidth;
this.props.pageWidth = pageWidth;
this.props.delta = delta;
this.props.columnWidth = colWidth;

View file

@ -547,6 +547,7 @@ class DefaultViewManager {
var container = this.container.getBoundingClientRect();
var left = 0;
let used = 0;
if(this.fullsize) {
left = window.scrollX;
@ -558,26 +559,30 @@ class DefaultViewManager {
let position = view.position().left;
let width = view.width();
let startPos = left + offset;
let endPos = startPos + this.layout.spreadWidth + this.layout.gap;
if (endPos > left + offset + width) {
endPos = left + offset + width;
// Find mapping
let start = left + container.left - position + used;
let end = start + this.layout.spreadWidth - used;
let mapping = this.mapping.page(view.contents, view.section.cfiBase, start, end);
// Find displayed pages
let startPos = left + used;
let endPos = startPos + this.layout.spreadWidth - used;
if (endPos > offset + width) {
endPos = offset + width;
used = this.layout.pageWidth;
}
let totalPages = this.layout.count(width).pages;
let currPage = Math.ceil((startPos - offset) / this.layout.spreadWidth);
let currPage = Math.floor((startPos - offset) / this.layout.pageWidth);
let pages = [];
let numPages = (endPos - startPos) / (this.layout.columnWidth + (this.layout.gap / 2));
let numPages = Math.floor((endPos - startPos) / this.layout.pageWidth);
for (var i = 1; i <= numPages; i++) {
let pg = currPage + i;
pages.push(pg);
}
let start = left + container.left - position;
let end = start + this.layout.spreadWidth + this.layout.gap;
let mapping = this.mapping.page(view.contents, view.section.cfiBase, start, end);
return {
index,
href,

View file

@ -253,11 +253,12 @@ class IframeView {
// Get the contentWidth by resizing the iframe
// Check with a min reset of the textWidth
// width = this.contentWidth(textWidth);
// Add padding back
if (width % this.layout.width > 0) {
width += this.layout.gap / 2;
}
/*
columns = Math.ceil(width / (this.settings.layout.columnWidth));
columns = Math.ceil(width / this.settings.layout.delta);
if ( this.settings.layout.divisor > 1 &&
this.settings.layout.name === "reflowable" &&
(columns % 2 > 0)) {
@ -266,11 +267,6 @@ class IframeView {
}
*/
// Add padding back
if (width % this.layout.width > 0) {
width += this.layout.gap / 2;
}
// Save the textWdith
this._textWidth = textWidth;

View file

@ -620,7 +620,7 @@ class Rendition {
}
if (end.index === this.book.spine.last().index &&
located.end.displayed.page === located.end.displayed.totalPages) {
located.end.displayed.page >= located.end.displayed.totalPages) {
located.atEnd = true;
}