diff --git a/web/base_viewer.js b/web/base_viewer.js index 3b9b78ca40e1ad..519f35b112aa4a 100644 --- a/web/base_viewer.js +++ b/web/base_viewer.js @@ -725,6 +725,20 @@ class BaseViewer { } } + /** + * @private + */ + get _pageWidthScaleFactor() { + if ( + this.spreadMode !== SpreadMode.NONE && + this.scrollMode !== ScrollMode.HORIZONTAL && + !this.isInPresentationMode + ) { + return 2; + } + return 1; + } + _setScale(value, noScroll = false) { let scale = parseFloat(value); @@ -735,6 +749,7 @@ class BaseViewer { if (!currentPage) { return; } + const noPadding = this.isInPresentationMode || this.removePageBorders; let hPadding = noPadding ? 0 : SCROLLBAR_PADDING; let vPadding = noPadding ? 0 : VERTICAL_PADDING; @@ -743,8 +758,9 @@ class BaseViewer { [hPadding, vPadding] = [vPadding, hPadding]; // Swap the padding values. } const pageWidthScale = - ((this.container.clientWidth - hPadding) / currentPage.width) * - currentPage.scale; + (((this.container.clientWidth - hPadding) / currentPage.width) * + currentPage.scale) / + this._pageWidthScaleFactor; const pageHeightScale = ((this.container.clientHeight - vPadding) / currentPage.height) * currentPage.scale; @@ -1475,6 +1491,9 @@ class BaseViewer { } this._setCurrentPageNumber(pageNumber, /* resetCurrentPageView = */ true); this.update(); + if (this._currentScaleValue && isNaN(this._currentScaleValue)) { + this._setScale(this._currentScaleValue, true); + } } } diff --git a/web/pdf_single_page_viewer.js b/web/pdf_single_page_viewer.js index 1e835897d08962..20b340e1336d09 100644 --- a/web/pdf_single_page_viewer.js +++ b/web/pdf_single_page_viewer.js @@ -35,6 +35,10 @@ class PDFSinglePageViewer extends BaseViewer { return shadow(this, "_viewerElement", this._shadowViewer); } + get _pageWidthScaleFactor() { + return 1; + } + _resetView() { super._resetView(); this._previousPageNumber = 1;