Browse Source

jswenjian删除

dev_des
zhangminghao 1 month ago
parent
commit
28e279af9e
  1. 5916
      subPackages/other/components/chapters.js
  2. 310
      subPackages/other/read.vue

5916
subPackages/other/components/chapters.js

File diff suppressed because one or more lines are too long

310
subPackages/other/read.vue

@ -1,4 +1,3 @@
<!-- 根据需要更改需要根据实际项目更改的已经列出来了 --> <!-- 根据需要更改需要根据实际项目更改的已经列出来了 -->
<!-- 重要事项 <!-- 重要事项
1.由于阅读页截取整行的需要请确保文本格式和本插件中的text变量所示一致每一行的高度要一致 1.由于阅读页截取整行的需要请确保文本格式和本插件中的text变量所示一致每一行的高度要一致
@ -18,8 +17,7 @@
<view id="content" class="content"> <view id="content" class="content">
<view class="inner-box" :style="{height: `${innerHeight}px`}"> <view class="inner-box" :style="{height: `${innerHeight}px`}">
<view class="book-inner" id="preChapter" v-html="preChapter.text" <view class="book-inner" id="preChapter" v-html="preChapter.text"
:style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`}" :style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`}">
>
</view> </view>
</view> </view>
</view> </view>
@ -35,8 +33,7 @@
<view class="content"> <view class="content">
<view class="inner-box" :style="{height: `${innerHeight}px`}"> <view class="inner-box" :style="{height: `${innerHeight}px`}">
<view class="book-inner" id="curChapter" v-html="curChapter.text" <view class="book-inner" id="curChapter" v-html="curChapter.text"
:style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`}" :style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`}">
>
</view> </view>
</view> </view>
</view> </view>
@ -52,8 +49,7 @@
<view class="content"> <view class="content">
<view class="inner-box" :style="{height: `${innerHeight}px`}"> <view class="inner-box" :style="{height: `${innerHeight}px`}">
<view class="book-inner" id="nextChapter" v-html="nextChapter.text" <view class="book-inner" id="nextChapter" v-html="nextChapter.text"
:style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`}" :style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`}">
>
</view> </view>
</view> </view>
</view> </view>
@ -66,11 +62,9 @@
<!-- 根据需要更改封面 --> <!-- 根据需要更改封面 -->
<!-- ************************** --> <!-- ************************** -->
<!-- 封面 --> <!-- 封面 -->
<view class="cover container" :class="{container0: background === 1, container1: background === 2}" <view class="cover container" :class="{container0: background === 1, container1: background === 2}" :style="{zIndex: 201, transform: `translate${cover.pageTranslate[turnType]}`, transition: `transform ${showAnimation?turnPageTime:0}s`,
:style="{zIndex: 201, transform: `translate${cover.pageTranslate[turnType]}`, transition: `transform ${showAnimation?turnPageTime:0}s`, boxShadow:showShadow&&turnType===0?'0 0 10px 0 rgba(0,0,0,.4)':''}" @touchstart="coverTouchStart"
boxShadow:showShadow&&turnType===0?'0 0 10px 0 rgba(0,0,0,.4)':''}" @touchend="coverTouchEnd" @touchmove="coverTouchMove" @touchcancel="coverTouchcancel">
@touchstart="coverTouchStart" @touchend="coverTouchEnd" @touchmove="coverTouchMove" @touchcancel="coverTouchcancel"
>
<image> <image>
</image> </image>
@ -85,10 +79,8 @@
<!-- 阅读页结构和样式请和仅用于计算元素一致 --> <!-- 阅读页结构和样式请和仅用于计算元素一致 -->
<!-- 上一页 --> <!-- 上一页 -->
<view class="container" :class="{container0: background === 1, container1: background === 2}" <view class="container" :class="{container0: background === 1, container1: background === 2}" :style="{zIndex: 102, transform: `translate${prePage.pageTranslate[turnType]}`, transition: `transform ${showAnimation?turnPageTime:0}s`,
:style="{zIndex: 102, transform: `translate${prePage.pageTranslate[turnType]}`, transition: `transform ${showAnimation?turnPageTime:0}s`, boxShadow:showShadow&&turnType===0?'0 0 10px 0 rgba(0,0,0,.4)':''}">
boxShadow:showShadow&&turnType===0?'0 0 10px 0 rgba(0,0,0,.4)':''}"
>
<!-- 章节名 --> <!-- 章节名 -->
<view class="chapter"> <view class="chapter">
{{prePage.chapterName}} {{prePage.chapterName}}
@ -99,10 +91,8 @@
<!-- 内层class="inner-box"利用innerHeight将内容截取至整行防止文字不完整的情况出现 --> <!-- 内层class="inner-box"利用innerHeight将内容截取至整行防止文字不完整的情况出现 -->
<view class="inner-box" :style="{height: `${innerHeight}px`}" v-if="prePage.canRead"> <view class="inner-box" :style="{height: `${innerHeight}px`}" v-if="prePage.canRead">
<!-- 最里层class="book-inner"的用于获取文本总高度计算总页数注意不可以overflow:hidden --> <!-- 最里层class="book-inner"的用于获取文本总高度计算总页数注意不可以overflow:hidden -->
<view class="book-inner" v-html="prePage.text" <view class="book-inner" v-html="prePage.text" :style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`,color: `${colorList[background - 1]}`,
:style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`,color: `${colorList[background - 1]}`, transform: `translateY(-${prePage.pageNum*innerHeight}px)`}">
transform: `translateY(-${prePage.pageNum*innerHeight}px)`}"
>
</view> </view>
</view> </view>
<view style="display:flex;flex-flow: column;justify-content: center;align-items: center;height: 100%;" <view style="display:flex;flex-flow: column;justify-content: center;align-items: center;height: 100%;"
@ -130,11 +120,9 @@
</view> </view>
<!-- 本页 --> <!-- 本页 -->
<view class="container" :class="{container0: background === 1, container1: background === 2}" <view class="container" :class="{container0: background === 1, container1: background === 2}" :style="{zIndex: 101, transform: `translate${curPage.pageTranslate[turnType]}`, transition: `transform ${showAnimation?turnPageTime:0}s`,
:style="{zIndex: 101, transform: `translate${curPage.pageTranslate[turnType]}`, transition: `transform ${showAnimation?turnPageTime:0}s`, boxShadow:showShadow&&turnType===0?'0 0 10px 0 rgba(0,0,0,.4)':''}" @touchstart="touchStart" @touchend="touchEnd"
boxShadow:showShadow&&turnType===0?'0 0 10px 0 rgba(0,0,0,.4)':''}" @touchmove="touchMove" @touchcancel="touchcancel">
@touchstart="touchStart" @touchend="touchEnd" @touchmove="touchMove" @touchcancel="touchcancel"
>
<!-- 章节名 --> <!-- 章节名 -->
<view class="chapter"> <view class="chapter">
{{curPage.chapterName}} {{curPage.chapterName}}
@ -142,10 +130,8 @@
<view class="content"> <view class="content">
<!-- v-if="curPage.canRead" --> <!-- v-if="curPage.canRead" -->
<view class="inner-box" :style="{height: `${innerHeight}px`}"> <view class="inner-box" :style="{height: `${innerHeight}px`}">
<view class="book-inner" v-html="curPage.text" <view class="book-inner" v-html="curPage.text" :style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`,color: `${colorList[background - 1]}`,
:style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`,color: `${colorList[background - 1]}`, transform: `translateY(-${curPage.pageNum*innerHeight}px)`}">
transform: `translateY(-${curPage.pageNum*innerHeight}px)`}"
>
</view> </view>
</view> </view>
<!-- <view style="display:flex;flex-flow: column;justify-content: center;align-items: center;height: 100%;" <!-- <view style="display:flex;flex-flow: column;justify-content: center;align-items: center;height: 100%;"
@ -173,20 +159,16 @@
</view> </view>
<!-- 下一页 --> <!-- 下一页 -->
<view class="container" :class="{container0: background === 1, container1: background === 2}" <view class="container" :class="{container0: background === 1, container1: background === 2}" :style="{zIndex: 100, transform: `translate${nextPage.pageTranslate[turnType]}`,transition: `transform ${showAnimation?turnPageTime:0}s`,
:style="{zIndex: 100, transform: `translate${nextPage.pageTranslate[turnType]}`,transition: `transform ${showAnimation?turnPageTime:0}s`, boxShadow:showShadow&&turnType===0?'0 0 10px 0 rgba(0,0,0,.4)':''}">
boxShadow:showShadow&&turnType===0?'0 0 10px 0 rgba(0,0,0,.4)':''}"
>
<!-- 章节名 --> <!-- 章节名 -->
<view class="chapter"> <view class="chapter">
{{nextPage.chapterName}} {{nextPage.chapterName}}
</view> </view>
<view class="content"> <view class="content">
<view class="inner-box" :style="{height: `${innerHeight}px`}" v-if="nextPage.canRead"> <view class="inner-box" :style="{height: `${innerHeight}px`}" v-if="nextPage.canRead">
<view class="book-inner" v-html="nextPage.text" <view class="book-inner" v-html="nextPage.text" :style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`,color: `${colorList[background - 1]}`,
:style="{fontSize: `${fontSize}px`, lineHeight: `${lineHeight*fontSize}px`,color: `${colorList[background - 1]}`, transform: `translateY(-${nextPage.pageNum*innerHeight}px)`}">
transform: `translateY(-${nextPage.pageNum*innerHeight}px)`}"
>
</view> </view>
</view> </view>
<view style="display:flex;flex-flow: column;justify-content: center;align-items: center;height: 100%;" <view style="display:flex;flex-flow: column;justify-content: center;align-items: center;height: 100%;"
@ -214,13 +196,15 @@
</view> </view>
<!-- 菜单层 --> <!-- 菜单层 -->
<view class="menu" :style="{height: `100%`, width: `${windowWidth}px`}" <view class="menu" :style="{height: `100%`, width: `${windowWidth}px`}" v-if="menuShow" @touchend="closeMenu">
v-if="menuShow" @touchend="closeMenu">
<!-- 菜单层包含返回按钮的上半部分 --> <!-- 菜单层包含返回按钮的上半部分 -->
<view class="menu-top" :style="{height: `${statusBarHeight + 40}px`, top: itemShow ? 0 : `-100%`}" @touchend.stop> <view class="menu-top" :style="{height: `${statusBarHeight + 40}px`, top: itemShow ? 0 : `-100%`}"
@touchend.stop>
<view :style="{height: `${statusBarHeight}px`}"></view> <view :style="{height: `${statusBarHeight}px`}"></view>
<view class="head"> <view class="head">
<image class="back-icon" src="https://epic.js-dyyj.com/uploads/20250825/f7e4825867dbd90e2cd0721a49fad6eb.png" @click="back" mode="aspectFill" style="width: 40rpx;height: 40rpx;"></image> <image class="back-icon"
src="https://epic.js-dyyj.com/uploads/20250825/f7e4825867dbd90e2cd0721a49fad6eb.png"
@click="back" mode="aspectFill" style="width: 40rpx;height: 40rpx;"></image>
<!-- <text class="iconfont back" @click="back">&#xe71a;</text> --> <!-- <text class="iconfont back" @click="back">&#xe71a;</text> -->
</view> </view>
</view> </view>
@ -268,7 +252,8 @@
<view class="icon" @click="smallSize" v-if="fontSize>minFontSize">A-</view> <view class="icon" @click="smallSize" v-if="fontSize>minFontSize">A-</view>
<view class="icon" style="color: #666;border: #666 solid 1px;" v-else>A-</view> <view class="icon" style="color: #666;border: #666 solid 1px;" v-else>A-</view>
<view class="icon" @click="changeFont(2)" v-if="simplified === 1">繁體</view> <view class="icon" @click="changeFont(2)" v-if="simplified === 1">繁體</view>
<view class="icon" @click="changeFont(1)" v-else style="border: #FF9900 solid 1px;color: #FF9900">繁體</view> <view class="icon" @click="changeFont(1)" v-else style="border: #FF9900 solid 1px;color: #FF9900">繁體
</view>
</view> </view>
<view class="item"> <view class="item">
<view class="item-name">排版</view> <view class="item-name">排版</view>
@ -284,24 +269,33 @@
</view> </view>
<view class="item"> <view class="item">
<view class="item-name">翻页</view> <view class="item-name">翻页</view>
<view class="icon" :class="{active: turnType === 0}" style="padding: 5px 8px;" @click="changeTurnType(0)">覆盖</view> <view class="icon" :class="{active: turnType === 0}" style="padding: 5px 8px;"
<view class="icon" :class="{active: turnType === 1}" style="padding: 5px 8px;" @click="changeTurnType(1)">左右平移</view> @click="changeTurnType(0)">覆盖</view>
<view class="icon" :class="{active: turnType === 2}" style="padding: 5px 8px;" @click="changeTurnType(2)">上下平移</view> <view class="icon" :class="{active: turnType === 1}" style="padding: 5px 8px;"
@click="changeTurnType(1)">左右平移</view>
<view class="icon" :class="{active: turnType === 2}" style="padding: 5px 8px;"
@click="changeTurnType(2)">上下平移</view>
</view> </view>
<view class="item"> <view class="item">
<view class="item-name">背景</view> <view class="item-name">背景</view>
<view class="icon" style="background: url(https://epic.js-dyyj.com/uploads/20250918/fc242cdea0ebd7fd399e86b34d229a6e.jpg);" :class="{active: background === 1}" @click="changeBackground(1)"></view> <view class="icon"
<view class="icon" style="background-color: #000;" :class="{active: background === 2}" @click="changeBackground(2)"></view> style="background: url(https://epic.js-dyyj.com/uploads/20250918/fc242cdea0ebd7fd399e86b34d229a6e.jpg);"
:class="{active: background === 1}" @click="changeBackground(1)"></view>
<view class="icon" style="background-color: #000;" :class="{active: background === 2}"
@click="changeBackground(2)"></view>
</view> </view>
</view> </view>
<!-- 目录层 --> <!-- 目录层 -->
<view class="directory" :class="{container0: background === 1, container1: background === 2}" v-if="directoryShowBefore" <view class="directory" :class="{container0: background === 1, container1: background === 2}"
:style="{left: directoryShow ? 0 : '-100%',color: `${colorList[background - 1]}`,boxShadow:'0 0 10px 0 rgba(0,0,0,.4)'}" @touchend.stop> v-if="directoryShowBefore"
:style="{left: directoryShow ? 0 : '-100%',color: `${colorList[background - 1]}`,boxShadow:'0 0 10px 0 rgba(0,0,0,.4)'}"
@touchend.stop>
<view class="bookname">书名</view> <view class="bookname">书名</view>
<!-- :size="40"每一栏高度为40px :scrollHeight="windowHeight - 60"书名的高度为60px --> <!-- :size="40"每一栏高度为40px :scrollHeight="windowHeight - 60"书名的高度为60px -->
<virtualList :items="directoryList" :size="40" :remain="16" :active="curChapter.chapterIndex" :scrollHeight="windowHeight - 60"> <virtualList :items="directoryList" :size="40" :remain="16" :active="curChapter.chapterIndex"
:scrollHeight="windowHeight - 60">
<template v-slot="{item,active}"> <template v-slot="{item,active}">
<view class="directory-listItem" :class="{active: item.index == active}" <view class="directory-listItem" :class="{active: item.index == active}"
@click="goToChapter(item.index)"> @click="goToChapter(item.index)">
@ -315,17 +309,22 @@
</view> </view>
</template> </template>
<script> <script type="module">
import battery from './components/battery.vue' import battery from './components/battery.vue'
import virtualList from './components/virtualList.vue' import virtualList from './components/virtualList.vue'
import { traditionalized, simplized, dateToStr } from './components/utils.js' import {
traditionalized,
simplized,
dateToStr
} from './components/utils.js'
import directoryModule from './components/directory.js' import directoryModule from './components/directory.js'
//
import chapters from './components/chapters.js' import chapters from './components/chapters.js'
// import chapterss from 'https://des.dayunyuanjian.cn/data/2025/09/22/chaptersNN.json'
//
// import chapters from 'https://des.dayunyuanjian.cn/data/2025/09/19/chapters.js'
// directoryList // directoryList
const directoryListJs = directoryModule.chaptersList || directoryModule.default?.chaptersList || []; const directoryListJs = directoryModule.chaptersList || directoryModule.default?.chaptersList || [];
// const externalData = require('https://des.dayunyuanjian.cn/data/2025/09/22/chaptersNN.json')
export default { export default {
components: { components: {
battery, battery,
@ -340,7 +339,7 @@
progress: 0 progress: 0
}, },
directoryList: [], directoryList: [],
text: (chapters && chapters.length > 0 && chapters[0].content) ? chapters[0].content : '', text: '',
currentPage: 0, // currentPage: 0, //
innerHeight: 0, // innerHeight: 0, //
@ -455,13 +454,15 @@
lineHeight: '', //fontSize lineHeight: '', //fontSize
background: '', // background: '', //
colorList: ['#000', '#666'], // colorList: ['#000', '#666'], //
chapters: [],
chapterProgress: 0, // chapterProgress: 0, //
progressTouched: false // progressTouched: false //
} }
}, },
onLoad() { onLoad() {
// console.log(JSON.stringify(chapters),'externalData')
this.chapt()
this.getSystemInfo() this.getSystemInfo()
}, },
onUnload() { onUnload() {
@ -477,6 +478,7 @@
this.setStorage() this.setStorage()
}, },
mounted() { mounted() {
this.initPage() this.initPage()
}, },
computed: { computed: {
@ -489,6 +491,23 @@
}, },
methods: { methods: {
chapt() {
uni.request({
url: 'https://des.dayunyuanjian.cn/data/2025/09/22/chaptersN1.json',
method: 'GET',
success: (res) => {
console.log(res.data);
this.chapters = res.data; //
console.log("小程序端解析成功:", this.chapters);
this.text = this.chapters[0].content
// ...
},
fail: (err) => {
console.error('请求失败:', err);
}
});
},
setStorage() { setStorage() {
let history = uni.getStorageSync('history') let history = uni.getStorageSync('history')
if (typeof history !== 'object') { if (typeof history !== 'object') {
@ -524,7 +543,13 @@
**/ **/
getSystemInfo() { getSystemInfo() {
const { windowWidth, windowHeight, statusBarHeight, platform, pixelRatio } = uni.getSystemInfoSync() const {
windowWidth,
windowHeight,
statusBarHeight,
platform,
pixelRatio
} = uni.getSystemInfoSync()
// //
this.statusBarHeight = statusBarHeight this.statusBarHeight = statusBarHeight
this.windowWidth = windowWidth this.windowWidth = windowWidth
@ -536,7 +561,9 @@
plus.navigator.setFullscreen(true) plus.navigator.setFullscreen(true)
// ios // ios
let page = this.$mp.page.$getAppWebview() let page = this.$mp.page.$getAppWebview()
page.setStyle({ popGesture: 'none' }) page.setStyle({
popGesture: 'none'
})
if (this.platform === 'ios') { if (this.platform === 'ios') {
// ios // ios
@ -550,8 +577,7 @@
this.batteryLevel = dev.batteryLevel() * 100 this.batteryLevel = dev.batteryLevel() * 100
}, 1000) }, 1000)
} } else {
else {
// //
let main = plus.android.runtimeMainActivity(); let main = plus.android.runtimeMainActivity();
let Intent = plus.android.importClass('android.content.Intent'); let Intent = plus.android.importClass('android.content.Intent');
@ -658,10 +684,10 @@
// #ifdef APP-PLUS || MP-WEIXIN // #ifdef APP-PLUS || MP-WEIXIN
lineHeight = Math.floor(lineHeight * this.pixelRatio) / this.pixelRatio lineHeight = Math.floor(lineHeight * this.pixelRatio) / this.pixelRatio
// #endif // #endif
let lineNum = Math.floor((this.contentHeight + Math.floor((lineHeight - this.fontSize)/2)) / lineHeight) let lineNum = Math.floor((this.contentHeight + Math.floor((lineHeight - this.fontSize) / 2)) /
lineHeight)
this.innerHeight = lineNum * lineHeight this.innerHeight = lineNum * lineHeight
} } else {
else {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
this.$nextTick(() => { this.$nextTick(() => {
const query = uni.createSelectorQuery().in(this); const query = uni.createSelectorQuery().in(this);
@ -671,9 +697,11 @@
let lineHeight = this.fontSize * this.lineHeight; let lineHeight = this.fontSize * this.lineHeight;
// #ifdef APP-PLUS || MP-WEIXIN // #ifdef APP-PLUS || MP-WEIXIN
lineHeight = Math.floor(lineHeight*this.pixelRatio)/this.pixelRatio lineHeight = Math.floor(lineHeight * this.pixelRatio) / this
.pixelRatio
// #endif // #endif
let lineNum = Math.floor((height + Math.floor((lineHeight - this.fontSize)/2)) / lineHeight) let lineNum = Math.floor((height + Math.floor((lineHeight - this
.fontSize) / 2)) / lineHeight)
this.innerHeight = lineNum * lineHeight this.innerHeight = lineNum * lineHeight
resolve() resolve()
}).exec(); }).exec();
@ -806,8 +834,7 @@
this.delta = e.touches[0].clientX - this.touchX; this.delta = e.touches[0].clientX - this.touchX;
this.touchX = e.touches[0].clientX; this.touchX = e.touches[0].clientX;
} } else { //
else { //
delta = e.touches[0].clientY - this.touchStartY; delta = e.touches[0].clientY - this.touchStartY;
// //
@ -876,8 +903,7 @@
let delta = 0 let delta = 0
if (this.turnType === 0 || this.turnType === 1) { // if (this.turnType === 0 || this.turnType === 1) { //
delta = e.changedTouches[0].clientX - this.touchStartX; delta = e.changedTouches[0].clientX - this.touchStartX;
} } else { //
else { //
delta = e.changedTouches[0].clientY - this.touchStartY; delta = e.changedTouches[0].clientY - this.touchStartY;
} }
if (delta === 0) { if (delta === 0) {
@ -886,8 +912,7 @@
title: '已经是第一页了', title: '已经是第一页了',
icon: 'none' icon: 'none'
}) })
} } else if (e.changedTouches[0].clientX > this.windowWidth / 3 * 2) { //1/3
else if (e.changedTouches[0].clientX>this.windowWidth/3*2) { //1/3
this.cover.pageTranslate = [ this.cover.pageTranslate = [
`(${-this.windowWidth}px,0)`, `(${-this.windowWidth}px,0)`,
`(${-this.windowWidth}px,0)`, `(${-this.windowWidth}px,0)`,
@ -898,12 +923,11 @@
`(0,0)`, `(0,0)`,
`(0,0)` `(0,0)`
] ]
} } else if (e.changedTouches[0].clientX <= this.windowWidth / 3 * 2 && e.changedTouches[0].clientX >=
else if (e.changedTouches[0].clientX<=this.windowWidth/3*2 && e.changedTouches[0].clientX>=this.windowWidth/3) { //1/3 this.windowWidth / 3) { //1/3
this.showMenu() this.showMenu()
} }
} } else {
else {
if (this.next && this.delta <= 0) { // if (this.next && this.delta <= 0) { //
this.cover.pageTranslate = [ this.cover.pageTranslate = [
`(${-this.windowWidth}px,0)`, `(${-this.windowWidth}px,0)`,
@ -915,8 +939,7 @@
`(0,0)`, `(0,0)`,
`(0,0)` `(0,0)`
] ]
} } else if (this.next && this.delta > 0) { //
else if (this.next && this.delta > 0) { //
this.cover.pageTranslate = [ this.cover.pageTranslate = [
`(0,0)`, `(0,0)`,
`(0,0)`, `(0,0)`,
@ -986,8 +1009,7 @@
this.delta = e.touches[0].clientX - this.touchX; this.delta = e.touches[0].clientX - this.touchX;
this.touchX = e.touches[0].clientX; this.touchX = e.touches[0].clientX;
} } else { //
else { //
delta = e.touches[0].clientY - this.touchStartY; delta = e.touches[0].clientY - this.touchStartY;
// //
@ -1046,8 +1068,7 @@
/*****************************************/ /*****************************************/
} } else {
else {
this.prePage.pageTranslate = [ this.prePage.pageTranslate = [
`(${-this.windowWidth}px,0)`, `(${-this.windowWidth}px,0)`,
`(${-this.windowWidth+delta}px,0)`, `(${-this.windowWidth+delta}px,0)`,
@ -1064,8 +1085,7 @@
`(0,${this.windowHeight+delta}px)` `(0,${this.windowHeight+delta}px)`
] ]
} }
} } else if (this.nextChapter.ready) { //
else if (this.nextChapter.ready) { //
this.nextPage = { this.nextPage = {
ready: this.nextChapter.ready, ready: this.nextChapter.ready,
chapterName: this.nextChapter.chapterName, chapterName: this.nextChapter.chapterName,
@ -1114,8 +1134,7 @@
`(${delta}px,0)`, `(${delta}px,0)`,
`(0,${delta}px)` `(0,${delta}px)`
] ]
} } else {
else {
this.prePage.pageTranslate = [ this.prePage.pageTranslate = [
`(${-this.windowWidth+delta}px,0)`, `(${-this.windowWidth+delta}px,0)`,
`(${-this.windowWidth+delta}px,0)`, `(${-this.windowWidth+delta}px,0)`,
@ -1147,8 +1166,7 @@
`(${delta}px,0)`, `(${delta}px,0)`,
`(0,${delta}px)` `(0,${delta}px)`
] ]
} } else {
else {
this.prePage.pageTranslate = [ this.prePage.pageTranslate = [
`(${-this.windowWidth+delta}px,0)`, `(${-this.windowWidth+delta}px,0)`,
`(${-this.windowWidth+delta}px,0)`, `(${-this.windowWidth+delta}px,0)`,
@ -1165,8 +1183,7 @@
`(0,${this.windowHeight+delta}px)` `(0,${this.windowHeight+delta}px)`
] ]
} }
} } else if (this.preChapter.ready) { //
else if (this.preChapter.ready) { //
this.prePage = { this.prePage = {
ready: this.preChapter.ready, ready: this.preChapter.ready,
chapterName: this.preChapter.chapterName, chapterName: this.preChapter.chapterName,
@ -1209,26 +1226,22 @@
let delta = 0 let delta = 0
if (this.turnType === 0 || this.turnType === 1) { if (this.turnType === 0 || this.turnType === 1) {
delta = e.changedTouches[0].clientX - this.touchStartX; delta = e.changedTouches[0].clientX - this.touchStartX;
} } else {
else {
delta = e.changedTouches[0].clientY - this.touchStartY; delta = e.changedTouches[0].clientY - this.touchStartY;
} }
if (delta < 0.8 && delta > -0.8) { //delta===0 if (delta < 0.8 && delta > -0.8) { //delta===0
if (e.changedTouches[0].clientX < this.windowWidth / 3) { //1/3 if (e.changedTouches[0].clientX < this.windowWidth / 3) { //1/3
this.goPrePage() this.goPrePage()
} } else if (e.changedTouches[0].clientX > this.windowWidth / 3 * 2) { //1/3
else if (e.changedTouches[0].clientX>this.windowWidth/3*2) { //1/3
this.goNextPage() this.goNextPage()
} } else if (e.changedTouches[0].clientX <= this.windowWidth / 3 * 2 && e.changedTouches[0].clientX >=
else if (e.changedTouches[0].clientX<=this.windowWidth/3*2 && e.changedTouches[0].clientX>=this.windowWidth/3) { //1/3 this.windowWidth / 3) { //1/3
this.showMenu() this.showMenu()
} }
} } else {
else {
if (this.next && this.delta <= 0) { // if (this.next && this.delta <= 0) { //
this.goNextPage() this.goNextPage()
} } else if (this.next && this.delta > 0) { //
else if (this.next && this.delta > 0) { //
this.prePage.pageTranslate = [ this.prePage.pageTranslate = [
`(${-this.windowWidth}px,0)`, `(${-this.windowWidth}px,0)`,
`(${-this.windowWidth}px,0)`, `(${-this.windowWidth}px,0)`,
@ -1244,11 +1257,9 @@
`(${this.windowWidth}px,0)`, `(${this.windowWidth}px,0)`,
`(0,${this.windowHeight}px)` `(0,${this.windowHeight}px)`
] ]
} } else if (this.pre && this.delta >= 0) { //
else if (this.pre && this.delta >= 0) { //
this.goPrePage() this.goPrePage()
} } else if (this.pre && this.delta < 0) { //
else if (this.pre && this.delta < 0) { //
this.prePage.pageTranslate = [ this.prePage.pageTranslate = [
`(${-this.windowWidth}px,0)`, `(${-this.windowWidth}px,0)`,
`(${-this.windowWidth}px,0)`, `(${-this.windowWidth}px,0)`,
@ -1544,9 +1555,11 @@
this.$set(this.nextChapter, 'text', this.tmpChapter.text) this.$set(this.nextChapter, 'text', this.tmpChapter.text)
this.$set(this.nextChapter, 'canRead', this.tmpChapter.canRead) this.$set(this.nextChapter, 'canRead', this.tmpChapter.canRead)
this.calcNextChapter() this.calcNextChapter()
} else {
this.nextChapter = {
ready: true,
isEnd: true
} }
else {
this.nextChapter = {ready: true,isEnd: true}
} }
} }
if (type === 'pre') { if (type === 'pre') {
@ -1562,9 +1575,11 @@
this.$set(this.preChapter, 'text', this.tmpChapter.text) this.$set(this.preChapter, 'text', this.tmpChapter.text)
this.$set(this.preChapter, 'canRead', this.tmpChapter.canRead) this.$set(this.preChapter, 'canRead', this.tmpChapter.canRead)
this.calcPreChapter() this.calcPreChapter()
} else {
this.preChapter = {
ready: true,
isCover: true
} }
else {
this.preChapter = {ready: true,isCover: true}
} }
} }
}, },
@ -1587,8 +1602,7 @@
if (this.nextChapter.ready) { if (this.nextChapter.ready) {
this.chapterRotate('next') this.chapterRotate('next')
this.goToPage(0) this.goToPage(0)
} } else {
else {
uni.showLoading({ uni.showLoading({
title: '正在准备下一章' title: '正在准备下一章'
}) })
@ -1614,8 +1628,7 @@
if (this.preChapter.ready) { if (this.preChapter.ready) {
this.chapterRotate('pre') this.chapterRotate('pre')
this.goToPage(0) this.goToPage(0)
} } else {
else {
uni.showLoading({ uni.showLoading({
title: '正在准备上一章' title: '正在准备上一章'
}) })
@ -1655,8 +1668,7 @@
`(0,${-this.windowHeight}px)` `(0,${-this.windowHeight}px)`
] ]
} }
} } else {
else {
this.prePage = { this.prePage = {
ready: this.preChapter.ready, ready: this.preChapter.ready,
chapterName: this.preChapter.chapterName, chapterName: this.preChapter.chapterName,
@ -1671,8 +1683,7 @@
canRead: this.preChapter.canRead canRead: this.preChapter.canRead
} }
} }
} } else {
else {
this.prePage = { this.prePage = {
ready: true, ready: true,
chapterName: this.curChapter.chapterName, chapterName: this.curChapter.chapterName,
@ -1698,8 +1709,7 @@
`(0,${this.windowHeight}px)` `(0,${this.windowHeight}px)`
] ]
} }
} } else {
else {
this.nextPage = { this.nextPage = {
ready: this.nextChapter.ready, ready: this.nextChapter.ready,
chapterName: this.nextChapter.chapterName, chapterName: this.nextChapter.chapterName,
@ -1714,8 +1724,7 @@
canRead: this.nextChapter.canRead canRead: this.nextChapter.canRead
} }
} }
} } else {
else {
this.nextPage = { this.nextPage = {
ready: true, ready: true,
chapterName: this.curChapter.chapterName, chapterName: this.curChapter.chapterName,
@ -1805,8 +1814,7 @@
this.nextPage.text = traditionalized(this.nextPage.text) this.nextPage.text = traditionalized(this.nextPage.text)
this.simplified = 2 this.simplified = 2
uni.setStorageSync('simplified', 2) uni.setStorageSync('simplified', 2)
} } else { //
else { //
this.preChapter.text = simplized(this.preChapter.text) this.preChapter.text = simplized(this.preChapter.text)
this.curChapter.text = simplized(this.curChapter.text) this.curChapter.text = simplized(this.curChapter.text)
this.nextChapter.text = simplized(this.nextChapter.text) this.nextChapter.text = simplized(this.nextChapter.text)
@ -1825,8 +1833,7 @@
let progress = this.progress let progress = this.progress
if (lineHeight === this.lineHeight) { if (lineHeight === this.lineHeight) {
return return
} } else {
else {
this.lineHeight = lineHeight; this.lineHeight = lineHeight;
uni.setStorageSync('lineHeight', this.lineHeight) uni.setStorageSync('lineHeight', this.lineHeight)
this.calcHeight() this.calcHeight()
@ -1852,8 +1859,7 @@
changeTurnType(turnType) { changeTurnType(turnType) {
if (turnType === this.turnType) { if (turnType === this.turnType) {
return return
} } else {
else {
this.showAnimation = false this.showAnimation = false
this.turnType = turnType; this.turnType = turnType;
uni.setStorageSync('turnType', this.turnType) uni.setStorageSync('turnType', this.turnType)
@ -1866,8 +1872,7 @@
changeBackground(background) { changeBackground(background) {
if (background === this.background) { if (background === this.background) {
return return
} } else {
else {
this.background = background; this.background = background;
uni.setStorageSync('background', this.background) uni.setStorageSync('background', this.background)
} }
@ -1980,8 +1985,8 @@
// } // }
// //
console.log(chapters,'chapterschapters',chapterId); console.log(this.chapters, 'chapterschapters', chapterId);
const chapter = chapters.find(ch => ch.id == chapterId) const chapter = this.chapters.find(ch => ch.id == chapterId)
console.log(chapter, 'chapterchapter'); console.log(chapter, 'chapterchapter');
if (chapter) { if (chapter) {
this.tmpChapter.text = chapter.content this.tmpChapter.text = chapter.content
@ -2048,9 +2053,11 @@
text: this.tmpChapter.text, text: this.tmpChapter.text,
canRead: this.tmpChapter.canRead canRead: this.tmpChapter.canRead
} }
} else {
this.preChapter = {
ready: true,
isCover: true
} }
else {
this.preChapter = {ready: true,isCover: true}
} }
if (this.curChapter.chapterIndex !== this.directoryList.length - 1) { if (this.curChapter.chapterIndex !== this.directoryList.length - 1) {
@ -2061,9 +2068,11 @@
text: this.tmpChapter.text, text: this.tmpChapter.text,
canRead: this.tmpChapter.canRead canRead: this.tmpChapter.canRead
} }
} else {
this.nextChapter = {
ready: true,
isEnd: true
} }
else {
this.nextChapter = {ready: true,isEnd: true}
} }
await this.calcCurChapter() await this.calcCurChapter()
await this.calcPreChapter() await this.calcPreChapter()
@ -2092,9 +2101,11 @@
width: 100%; width: 100%;
height: 100%; height: 100%;
} }
.hidden { .hidden {
opacity: 0; opacity: 0;
} }
.action { .action {
position: fixed; position: fixed;
top: 0; top: 0;
@ -2103,11 +2114,13 @@
height: 100%; height: 100%;
display: flex; display: flex;
justify-content: center; justify-content: center;
.item { .item {
flex: 1; flex: 1;
height: 100%; height: 100%;
} }
} }
.container { .container {
position: fixed; position: fixed;
top: 0; top: 0;
@ -2121,6 +2134,7 @@
width: 100%; width: 100%;
background-color: #fff; background-color: #fff;
overflow: hidden; overflow: hidden;
.chapter { .chapter {
font-size: 14px; font-size: 14px;
color: $minor-text-color; color: $minor-text-color;
@ -2128,6 +2142,7 @@
width: 100%; width: 100%;
line-height: 30px; line-height: 30px;
} }
.bottom-bar { .bottom-bar {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
@ -2137,11 +2152,14 @@
height: 30px; height: 30px;
width: 100%; width: 100%;
} }
.content { .content {
flex: 1 1 auto; flex: 1 1 auto;
overflow: hidden; overflow: hidden;
.inner-box { .inner-box {
overflow: hidden; overflow: hidden;
.book-inner { .book-inner {
text-indent: 2em; text-indent: 2em;
text-align: justify; text-align: justify;
@ -2150,19 +2168,23 @@
} }
} }
.container0 { .container0 {
background: url(https://epic.js-dyyj.com/uploads/20250918/fc242cdea0ebd7fd399e86b34d229a6e.jpg); background: url(https://epic.js-dyyj.com/uploads/20250918/fc242cdea0ebd7fd399e86b34d229a6e.jpg);
background-color: #fff; background-color: #fff;
background-size: 100% 100%; background-size: 100% 100%;
} }
.container1 { .container1 {
background-color: #000; background-color: #000;
} }
.menu { .menu {
position: fixed; position: fixed;
top: 0; top: 0;
left: 0; left: 0;
z-index: 300; z-index: 300;
// transition: all .3s; // transition: all .3s;
.menu-top { .menu-top {
position: absolute; position: absolute;
@ -2170,6 +2192,7 @@
width: 100%; width: 100%;
background-color: #333; background-color: #333;
transition: top .3s; transition: top .3s;
.head { .head {
position: relative; position: relative;
// display: flex; // display: flex;
@ -2181,12 +2204,14 @@
line-height: 40px; line-height: 40px;
color: #fff; color: #fff;
} }
.back { .back {
position: absolute; position: absolute;
top: 0; top: 0;
left: 10px; left: 10px;
} }
} }
.directory { .directory {
position: absolute; position: absolute;
top: 0; top: 0;
@ -2195,11 +2220,13 @@
width: 600rpx; width: 600rpx;
height: 100%; height: 100%;
transition: left .1s; transition: left .1s;
.bookname { .bookname {
padding: 20px 0 20px 10px; padding: 20px 0 20px 10px;
height: 60px; height: 60px;
font-size: 18px; font-size: 18px;
} }
.directory-listItem { .directory-listItem {
display: flex; display: flex;
align-items: center; align-items: center;
@ -2208,10 +2235,12 @@
font-size: 14px; font-size: 14px;
border-bottom: #eee solid 1px; border-bottom: #eee solid 1px;
} }
.active { .active {
color: red color: red
} }
} }
.menu-bottom { .menu-bottom {
position: absolute; position: absolute;
left: 0; left: 0;
@ -2219,6 +2248,7 @@
background-color: #333; background-color: #333;
transition: bottom .3s; transition: bottom .3s;
color: #fff; color: #fff;
.show-chapter { .show-chapter {
position: absolute; position: absolute;
left: 50%; left: 50%;
@ -2230,6 +2260,7 @@
font-size: 13px; font-size: 13px;
background-color: #333; background-color: #333;
} }
.progress-box { .progress-box {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
@ -2239,12 +2270,14 @@
width: 100%; width: 100%;
font-size: 15px; font-size: 15px;
} }
.items-box { .items-box {
display: flex; display: flex;
justify-content: space-around; justify-content: space-around;
align-items: center; align-items: center;
height: 80px; height: 80px;
width: 100%; width: 100%;
.item-box { .item-box {
display: flex; display: flex;
flex-flow: column; flex-flow: column;
@ -2254,6 +2287,7 @@
} }
} }
} }
.setting { .setting {
position: absolute; position: absolute;
left: 0; left: 0;
@ -2265,15 +2299,18 @@
color: #fff; color: #fff;
background-color: #333; background-color: #333;
transition: bottom .3s; transition: bottom .3s;
.item { .item {
display: flex; display: flex;
align-items: center; align-items: center;
height: 70px; height: 70px;
.item-name { .item-name {
padding: 10px; padding: 10px;
color: #fff; color: #fff;
font-size: 14px; font-size: 14px;
} }
.icon { .icon {
margin-right: 10px; margin-right: 10px;
padding: 5px 20px; padding: 5px 20px;
@ -2285,6 +2322,7 @@
border-radius: 20px; border-radius: 20px;
border: #fff solid 1px; border: #fff solid 1px;
} }
.type-setting { .type-setting {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@ -2296,15 +2334,18 @@
width: 30px; width: 30px;
border-radius: 5px; border-radius: 5px;
border: #fff solid 1px; border: #fff solid 1px;
.line { .line {
width: 100%; width: 100%;
border-bottom: #fff solid 1px; border-bottom: #fff solid 1px;
} }
.lineActive { .lineActive {
width: 100%; width: 100%;
border-bottom: #FF9900 solid 1px; border-bottom: #FF9900 solid 1px;
} }
} }
.active { .active {
color: #FF9900; color: #FF9900;
border: #FF9900 solid 1px; border: #FF9900 solid 1px;
@ -2312,6 +2353,7 @@
} }
} }
} }
.cover { .cover {
image { image {
height: 400rpx; height: 400rpx;

Loading…
Cancel
Save