From e797cedf99cc31361a0950657b50e97c83da7813 Mon Sep 17 00:00:00 2001 From: Book Pauk Date: Fri, 1 Feb 2019 21:10:32 +0700 Subject: [PATCH] =?UTF-8?q?=D0=9E=D0=BF=D1=82=D0=B8=D0=BC=D0=B8=D0=B7?= =?UTF-8?q?=D0=B0=D1=86=D0=B8=D1=8F=20(=D0=BF=D1=80=D0=B5=D0=BA=D0=B5?= =?UTF-8?q?=D1=88=D0=B8=D1=80=D0=BE=D0=B2=D0=B0=D0=BD=D0=B8=D0=B5)=20?= =?UTF-8?q?=D0=BF=D1=80=D0=B8=20=D1=81=D0=BA=D1=80=D0=BE=D0=BB=D0=BB=D0=B8?= =?UTF-8?q?=D0=BD=D0=B3=D0=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../components/Reader/TextPage/TextPage.vue | 28 ++++++++++++++++--- 1 file changed, 24 insertions(+), 4 deletions(-) diff --git a/client/components/Reader/TextPage/TextPage.vue b/client/components/Reader/TextPage/TextPage.vue index 894a1872..d1b7a33d 100644 --- a/client/components/Reader/TextPage/TextPage.vue +++ b/client/components/Reader/TextPage/TextPage.vue @@ -434,6 +434,7 @@ class TextPage extends Vue { await this.$nextTick(); await sleep(50); + this.cachedPos = -1; const page = this.$refs.scrollingPage; let i = 0; while (!this.stopScrolling) { @@ -470,10 +471,29 @@ class TextPage extends Vue { draw() { if (this.doingScrolling) { - const lines = this.getLines(this.bookPos); - this.linesDown = lines.linesDown; - this.linesUp = lines.linesUp; - this.page1 = this.drawPage(lines.linesDown); + if (this.cachedPos == this.bookPos) { + this.linesDown = this.linesCached.linesDown; + this.linesUp = this.linesCached.linesUp; + this.page1 = this.pageCached; + } else { + const lines = this.getLines(this.bookPos); + this.linesDown = lines.linesDown; + this.linesUp = lines.linesUp; + this.page1 = this.drawPage(lines.linesDown); + } + + //caching next + if (this.cachedPageTimer) + clearTimeout(this.cachedPageTimer); + this.cachedPageTimer = setTimeout(() => { + if (this.linesDown && this.linesDown.length > this.pageLineCount && this.pageLineCount > 0) { + this.cachedPos = this.linesDown[1].begin; + this.linesCached = this.getLines(this.cachedPos); + this.pageCached = this.drawPage(this.linesCached.linesDown); + } + this.cachedPageTimer = null; + }, 20); + this.debouncedDrawStatusBar(); return; }