From 300c9e790fd04de30c982a05f8d7cd157f442b45 Mon Sep 17 00:00:00 2001 From: litian <2804272236@qq.com> Date: 星期三, 24 四月 2024 14:42:39 +0800 Subject: [PATCH] shuzi --- src/views/home.vue | 1410 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 1,364 insertions(+), 46 deletions(-) diff --git a/src/views/home.vue b/src/views/home.vue index 321ae97..ec58c69 100644 --- a/src/views/home.vue +++ b/src/views/home.vue @@ -4,6 +4,7 @@ <p>鏁板瓧鏁欐潗骞冲彴</p> </div> <div class="contentBox"> + <!-- 鑿滃崟 --> <div class="menuBox"> <div :class="['menuItem', activeMenu == index ? 'active' : '']" @@ -16,48 +17,412 @@ </div> <p>{{ item.name }}</p> </div> + <!-- 璁剧疆 --> + <el-popover placement="right" :width="200" trigger="click"> + <div class="settingBox"> + <el-form :model="settingForm" label-width="auto" style="max-width: 400px"> + <el-form-item label="绛旈闊虫晥"> + <el-switch v-model="settingForm.acoustics" /> + </el-form-item> + <el-form-item label="绛旈鍔ㄧ敾"> + <el-switch v-model="settingForm.animation" /> + </el-form-item> + </el-form> + </div> + <template #reference> + <div class="setting hover"> + <img :src="setting" /> + <div>璁剧疆</div> + </div> + </template> + </el-popover> </div> - <div class="pageBox"></div> + <!-- 鑿滃崟鍐呭 --> + <div class="menuContent" v-if="menuState.open"> + <div class="searchBox"> + <div class="inputBox"> + <el-input class="custom-input" placeholder="璇疯緭鍏ュ唴瀹�"> + <template #prefix> + <el-icon><Search /></el-icon> + </template> + </el-input> + </div> + </div> + <!-- 鐩綍 --> + <div class="" v-if="activeMenu == 0"></div> + <!-- 绗旇 --> + <div class="notesBox" v-if="activeMenu == 1"> + <div class="screenBox"> + <div class="title">绛涢��</div> + <div class="flex1 hover" @click="searchClick('all')"> + <div :class="menuState.notesColor == 'all' ? ' allActive' : 'all'">鍏ㄩ儴</div> + </div> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="searchClick(item)" + > + <div + :style="{ background: item.key }" + :class="item.key == menuState.notesColor ? 'activeScribe scribeItem' : 'scribeItem'" + ></div> + </div> + </div> + </div> + <!-- 璧勬簮 --> + <div class="" v-if="activeMenu == 2"></div> + <!-- 鐭ヨ瘑鍥捐氨 --> + <div class="" v-if="activeMenu == 3"></div> + <!-- 鎴浘 --> + <div class="" v-if="activeMenu == 4"></div> + <!-- 鏍囩 --> + <div class="" v-if="activeMenu == 5"></div> + </div> + <!-- 鑿滃崟鍐呭鏀惰捣 --> + <div class="menuStateBox" v-if="menuState.open"> + <img :src="shouqiL" @click="menuState.open = false" /> + </div> + <!-- 涓棿鍐呭 --> + <div class="pageBox"> + <!-- 澶撮儴鏄剧ず --> + <div class="pageBox-header"> + <div class="classTime"> + <div class="qureIcon"></div> + <div class="">宸蹭笂璇撅細{{ headerData.classTime }}</div> + </div> + <div class="progress">{{ headerData.process }}</div> + <div class="rightBox"> + <div class="pageSizeBox"> + <div><img :src="zoomIn" @click="changePageSize('add')" /></div> + <div>{{ headerData.pageSize }}%</div> + <div><img :src="zoomOut" @click="changePageSize('reduce')" /></div> + </div> + <div class="brushImgBox"> + <div><img :src="huabi2" class="brushImg" />鐢荤瑪</div> + <!-- <el-switch v-model="headerData.brushToolShow" @change="brushToolShow"/> --> + </div> + </div> + </div> + <!-- 寰簲鐢ㄧ洅瀛� --> + <div class="pageBox-content"> + <div id="container"></div> + <!-- 鐢荤瑪鐢诲竷 --> + <div class="canvas-box"> + <canvas + @mousedown="mousedown" + @mousemove.stop.prevent="mousemove" + @mouseup="mouseup" + ref="canvas" + width="100%" + height="100%" + ></canvas> + </div> + </div> + </div> + <!-- 鏁欏缁勪欢 --> <div class="toolBox"> - <el-menu default-active="2" :collapse="isCollapse" @open="handleOpen" @close="handleClose"> - <el-sub-menu index="1"> - <template #title> - <el-icon><location /></el-icon> - <span>Navigator One</span> + <div class="toolTitle"> + 鏁欏缁勪欢 + <div class="text"></div> + </div> + <div class="menuList"> + <ul class="menu"> + <li + v-for="item in teachToolsMenuData" + :key="item.key" + :class="item.name === activeTool ? 'activeItem hover' : 'menuItem hover'" + :style="!toolState.open ? 'padding:10px 15px' : ''" + @click="selectTeachTools(item)" + > + <img :src="item.icon" alt="" /> + <span v-if="toolState.open">{{ item.name }}</span> + </li> + </ul> + </div> + <div :class="['openBox', toolState.open ? 'right' : '']"> + <img :src="shouqiR" v-if="toolState.open" @click="toolState.open = false" /> + <img :src="shouqiL" v-if="!toolState.open" @click="toolState.open = true" /> + </div> + <div class="classRoomBox" v-if="toolState.open"> + <el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick"> + <el-tab-pane label="澶囪缁勪欢" name="first"> + <div class="tabBox"> + <div class="insertSelect"> + <div + :class="selectType == 'resource' ? 'typeActive' : 'selectItem hover'" + @click="selectTypeClick('resource')" + > + <img :src="selectType == 'resource' ? charuziyuan_blue : charuziyuan" /> + <div>鎻掑叆璧勬簮</div> + </div> + <div + :class="selectType == 'answer' ? 'typeActive' : 'selectItem hover'" + @click="selectTypeClick('answer')" + > + <img :src="selectType == 'answer' ? dati_charu_blue : dati_charu" /> + <div>鎻掑叆绛旈</div> + </div> + </div> + </div> + </el-tab-pane> + <el-tab-pane label="涓婅缁勪欢" name="second"> + <div class="tabBox"> + <div class="giveLessons hover" @click="giveLessonsClick()"> + <img :src="xiake" /> + <span>{{ classStart ? '涓婅' : '涓嬭' }}</span> + </div> + </div> + </el-tab-pane> + </el-tabs> + </div> + </div> + <!-- 鐢荤瑪宸ュ叿鏍� --> + <div + draggable="true" + class="draggableBox" + @dragstart="dragstart($event)" + @dragend="dragend($event)" + :style="`left:${floatingToolData.elLeft}px;top:${floatingToolData.elTop}px`" + > + <div + class="hover" + v-for="item in floatingToolBox" + :key="item.name" + @click="floatItemHandle(item)" + @mouseover="floatOverHander(item)" + @mouseout="floatOutHander(item)" + > + <el-popover + placement="right" + :width=" + floatingToolData.activeToolData == '鏍囨敞' + ? 120 + : floatingToolData.activeToolData == '娓呴櫎' + ? 200 + : 250 + " + trigger="click" + v-if=" + floatingToolData.activeToolData == '鐢荤瑪' || + floatingToolData.activeToolData == '娓呴櫎' || + floatingToolData.activeToolData == '鏂囧瓧' || + floatingToolData.activeToolData == '鏍囨敞' + " + > + <div class="popinnerBox"> + <div class="brush" v-if="floatingToolData.activeToolData == '鐢荤瑪'"> + <div class="thickness"> + <div + :class="floatingToolData.thicknessActive == 'small' ? 'small active' : 'small'" + @click="selectThickness('small')" + ></div> + <div + :class=" + floatingToolData.thicknessActive == 'middle' ? 'middle active' : 'middle' + " + @click="selectThickness('middle')" + ></div> + <div + :class="floatingToolData.thicknessActive == 'large' ? 'large active' : 'large'" + @click="selectThickness('large')" + ></div> + </div> + <div class="lineStyle"> + <div class="lineTypeBox"> + <div + :class=" + floatingToolData.lineTypeActive == 'solid' + ? 'typeItem lineTypeActive' + : 'typeItem' + " + @click="selectLineType('solid')" + > + <div class="solid"></div> + <div class="activeIcon" v-if="floatingToolData.lineTypeActive == 'solid'"> + <img :src="xuanzhong" /> + </div> + </div> + <div + :class=" + floatingToolData.lineTypeActive == 'dashed' + ? 'typeItem lineTypeActive' + : 'typeItem' + " + @click="selectLineType('dashed')" + > + <div class="dashed"></div> + <div class="activeIcon" v-if="floatingToolData.lineTypeActive == 'dashed'"> + <img :src="xuanzhong" /> + </div> + </div> + </div> + <div class="colorSelectBox"> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="lineColorSelect(item)" + > + <div :style="{ background: item.key }" class="scribeItem"> + <img :src="xuanzhong" v-if="item.key == floatingToolData.lineColorActive" /> + </div> + </div> + </div> + </div> + </div> + <div class="cleanup" v-if="floatingToolData.activeToolData == '娓呴櫎'"> + <div class="cleanupItem hover" @click="cleanUpSelect('prev')"> + <img :src="clearPrevious" /> + <div>娓呴櫎涓婁竴姝�</div> + </div> + <div class="cleanupItem hover" @click="cleanUpSelect('all')"> + <img :src="clear" /> + <div>娓呴櫎鍏ㄩ儴</div> + </div> + </div> + <div class="write" v-if="floatingToolData.activeToolData == '鏂囧瓧'"> + <div class="thickness"> + <div + :class="floatingToolData.thicknessActive == 'small' ? 'small active' : 'small'" + @click="selectThickness('small')" + ></div> + <div + :class=" + floatingToolData.thicknessActive == 'middle' ? 'middle active' : 'middle' + " + @click="selectThickness('middle')" + ></div> + <div + :class="floatingToolData.thicknessActive == 'large' ? 'large active' : 'large'" + @click="selectThickness('large')" + ></div> + </div> + <div class="lineStyle"> + <div class="colorSelectBox"> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="lineColorSelect(item)" + > + <div :style="{ background: item.key }" class="scribeItem"> + <img :src="xuanzhong" v-if="item.key == floatingToolData.lineColorActive" /> + </div> + </div> + </div> + </div> + </div> + <div class="label" v-if="floatingToolData.activeToolData == '鏍囨敞'"> + <div class="labelItem hover" @click="labelShow('hide')"> + <img :src="hide" /> + <div>闅愯棌</div> + </div> + <div class="labelItem hover" @click="labelShow('show')"> + <img :src="show" /> + <div>鏄剧ず</div> + </div> + </div> + </div> + <template #reference> + <div class="floatToolItem"> + <img :src="item.icon" alt="" /> + <div class="text">{{ item.name }}</div> + </div> </template> - <el-menu-item-group> - <template #title><span>Group One</span></template> - <el-menu-item index="1-1">item one</el-menu-item> - <el-menu-item index="1-2">item two</el-menu-item> - </el-menu-item-group> - <el-menu-item-group title="Group Two"> - <el-menu-item index="1-3">item three</el-menu-item> - </el-menu-item-group> - <el-sub-menu index="1-4"> - <template #title><span>item four</span></template> - <el-menu-item index="1-4-1">item one</el-menu-item> - </el-sub-menu> - </el-sub-menu> - <el-menu-item index="2"> - <el-icon><icon-menu /></el-icon> - <template #title>Navigator Two</template> - </el-menu-item> - <el-menu-item index="3" disabled> - <el-icon><document /></el-icon> - <template #title>Navigator Three</template> - </el-menu-item> - <el-menu-item index="4"> - <el-icon><setting /></el-icon> - <template #title>Navigator Four</template> - </el-menu-item> - </el-menu> + </el-popover> + <div class="floatToolItem" v-else> + <img :src="item.icon" alt="" /> + <div class="text">{{ item.name }}</div> + </div> + </div> + </div> + <!-- 閫変腑宸ュ叿鏍� --> + <div + class="dialogToolBox" + id="dialogToolBox" + v-show="showToolBox" + :style="{ top: `${dialogToolData.top}px`, left: `${dialogToolData.left}px` }" + > + <div + class="colorSelectBox" + v-if="toolActive == '楂樹寒' || toolActive == '鍒掔嚎' || toolActive == '绗旇'" + > + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="clickSelect(item)" + > + <div :style="{ background: item.key }" class="scribeItem"> + <img :src="xuanzhong" v-if="item.key == colorActive" /> + </div> + </div> + </div> + <div class="toolSelectBox"> + <div + :class="item.name == toolActive ? 'dialogToolItem active' : 'dialogToolItem'" + v-for="item in dialogToolList" + :key="item.icon" + @click="dialogToolHandle(item)" + @mouseover="dialogOverHander(item)" + @mouseout="dialogOutHander(item)" + > + <img :src="item.name == toolActive ? item.activeIcon : item.icon" alt="" /> + <span>{{ item.name }}</span> + </div> + </div> </div> </div> </div> + <el-dialog title="娣诲姞绗旇" v-model="addNoteVisble" width="400"> + <div class="formBox"> + <el-form ref="form" :model="formData" label-width="80px"> + <el-form-item label="绗旇鏍囬"> + <el-input v-model="formData.name"></el-input> + </el-form-item> + <el-form-item label="绗旇鍐呭"> + <el-input type="textarea" v-model="formData.desc"></el-input> + </el-form-item> + </el-form> + </div> + <template #footer> + <span class="dialog-footer"> + <el-button @click="addNoteVisble = false">鍙� 娑�</el-button> + <el-button type="primary" @click="addNote">纭� 瀹�</el-button> + </span> + </template> + </el-dialog> + <el-dialog title="AI鏅鸿兘闂瓟" v-model="wendaVisible" width="26%"> + <div class="wendabox"> + <iframe src="https://yiyan.baidu.com/" frameborder="0"></iframe> + </div> + </el-dialog> + <el-dialog title="璇嶅吀" v-model="cidianVisible" width="60%"> + <div class="wendabox"> + <iframe src="https://www.vocabulary.com/" frameborder="0"></iframe> + </div> + </el-dialog> + <el-dialog title="GGB鍑芥暟宸ュ叿" v-model="functionVisible" width="60%"> + <div class="wendabox"> + <iframe src="https://www.geogebra.org/calculator" frameborder="0"></iframe> + </div> + </el-dialog> + <el-dialog title="鎬濈淮瀵煎浘" v-model="siweiVisble" width="80%"> + <div class="wendabox"> + <iframe src="https://www.iodraw.com/mind" frameborder="0"></iframe> + </div> + </el-dialog> + <el-dialog title="妯″瀷宸ュ叿" v-model="modelToolVisble" width="80%"> + <div class="wendabox"> + <iframe src="https://adjam93.github.io/threejs-model-viewer/#" frameborder="0"></iframe> + </div> + </el-dialog> </template> <script setup lang="ts"> -import { ref, reactive, watch } from 'vue' +import { ref, reactive, watch, onMounted } from 'vue' +import { ElMessage } from 'element-plus' import mulu from '@/assets/images/menu/mulu.png' import biji from '@/assets/images/menu/biji.png' import ziyuan from '@/assets/images/menu/ziyuan.png' @@ -65,7 +430,74 @@ import jietu from '@/assets/images/menu/jietu.png' import biaoqian from '@/assets/images/menu/biaoqian.png' import topbg from '@/assets/images/header/top-bg.png' +import setting from '@/assets/images/operation/setting.png' +import aIzhinengwenda from '@/assets/images/menu/AIzhinengwenda.png' +import aIyuyinyuedu from '@/assets/images/menu/AIyuyinyuedu.png' +import cidian from '@/assets/images/menu/cidian.png' +import shengzikapian from '@/assets/images/menu/shengzikapian.png' +import hudongwenda from '@/assets/images/menu/hudongwenda.png' +import siweidaotu from '@/assets/images/menu/siweidaotu.png' +import GGB from '@/assets/images/menu/GGB.png' +import jihe from '@/assets/images/menu/jihe.png' +import python from '@/assets/images/menu/python.png' +import cjiajia from '@/assets/images/menu/C++.png' +import javascript from '@/assets/images/menu/Javascript.png' +import moxinggongju from '@/assets/images/menu/moxinggongju.png' +import shouqiR from '@/assets/images/menu/shouqi-R.png' +import shouqiL from '@/assets/images/menu/shouqi-L.png' +import charuziyuan from '../assets/images/operation/charuziyuan.png' +import charuziyuan_blue from '../assets/images/operation/charuziyuan_blue.png' +import dati_charu from '../assets/images/operation/dati_charu.png' +import dati_charu_blue from '../assets/images/operation/dati_charu_blue.png' +import xiake from '../assets/images/operation/xiake.png' + +import huabi from '../assets/images/operation/huabi-w.png' +import huabi1 from '../assets/images/operation/huabi-b.png' +import qingchu from '../assets/images/operation/Clearaway-w.png' +import qingchu1 from '../assets/images/operation/Clearaway-b.png' +import wenzi from '../assets/images/operation/wenzi-w.png' +import wenzi1 from '../assets/images/operation/wenzi-b.png' +import biaoqianw from '../assets/images/operation/biaoqian-w.png' +import biaoqian1 from '../assets/images/operation/biaoqian-b.png' +import baiban from '../assets/images/operation/baiban-w.png' +import baiban1 from '../assets/images/operation/baiban-b.png' +import biaozhu from '../assets/images/operation/biaozhu-w.png' +import biaozhu1 from '../assets/images/operation/biaozhu-b.png' +import jieping from '../assets/images/operation/screenshot-w.png' +import jieping1 from '../assets/images/operation/screenshot-b.png' +import clear from '../assets/images/operation/clear.png' +import clearPrevious from '../assets/images/operation/clearPrevious.png' +import hide from '../assets/images/operation/hide.png' +import show from '../assets/images/operation/show.png' + +import gaoliang from '../assets/images/operation/gaoliang.png' +import gaoliang1 from '../assets/images/operation/gaoliang-b.png' +import huaxian from '../assets/images/operation/huaxian.png' +import huaxian1 from '../assets/images/operation/huaxian1.png' +import biji2 from '../assets/images/operation/biji.png' +import biji1 from '../assets/images/operation/biji-b.png' +import biaozhu2 from '../assets/images/operation/biaozhu.png' +import biaozhu3 from '../assets/images/operation/biaozhu1.png' +import fuzhi from '../assets/images/operation/fuzhi.png' +import fuzhi1 from '../assets/images/operation/fuzhi-b.png' +import AIyuedu from '../assets/images/operation/AIyuedu.png' +import AIyuedu1 from '../assets/images/operation/AIyuedu-b.png' +import cidian2 from '../assets/images/operation/cidian.png' +import cidian1 from '../assets/images/operation/cidian-b.png' +import yuyinyuedu from '../assets/images/operation/yuyinyuedu.png' +import yuyinyuedu1 from '../assets/images/operation/yuyinyuedu-b.png' +import xuanzhong from '../assets/images/operation/xuanzhong.png' + +import zoomIn from '../assets/images/operation/zoomIn.png' +import zoomOut from '../assets/images/operation/zoomOut.png' +import huabi2 from '../assets/images/operation/huabi.svg' +import { start } from 'qiankun' +onMounted(() => { + + start() + +}) // 鑿滃崟 const menuData = reactive([ { @@ -93,28 +525,530 @@ icon: biaoqian } ]) - // 閫変腑鑿滃崟 const activeMenu = ref(0) - -// // 鐩戝惉璺敱鍙樺寲锛岄粯璁ら�変腑鑿滃崟 -// watch( -// () => router.currentRoute.value, -// (newRoute) => { -// console.log(newRoute.path) - -// const index = menuData.findIndex((item) => item.router == newRoute.path) -// activeMenu.value = index > -1 ? index : 0 -// } -// ) // 鑿滃崟鐐瑰嚮 const menuItemClick = (index) => { activeMenu.value = index + menuState.open = true +} +const menuState = reactive({ + open: true, + notesColor: '' +}) +const settingForm = reactive({ + acoustics: false, + animation: false +}) +//绗旇棰滆壊绛涢�� +const searchClick = (item) => { + if (item != 'all') { + menuState.notesColor = item.key + } else { + menuState.notesColor = 'all' + } } // 鍙充晶宸ュ叿 -const isCollapse = ref(false) +const teachToolsMenuData = reactive([ + { + name: 'AI鏅鸿兘闂瓟', + icon: aIzhinengwenda + }, + { + name: 'AI璇煶闃呰', + icon: aIyuyinyuedu + }, + { + name: '璇嶅吀', + icon: cidian + }, + { + name: '鐢熷瓧鍗$墖', + icon: shengzikapian + }, + { + name: '浜掑姩闂瓟', + icon: hudongwenda + }, + { + name: '鎬濈淮瀵煎浘', + icon: siweidaotu + }, + { + name: 'GGB鍑芥暟宸ュ叿', + icon: GGB + }, + { + name: '鍑犱綍宸ュ叿', + icon: jihe + }, + { + name: 'Python', + icon: python + }, + { + name: 'C++', + icon: cjiajia + }, + { + name: 'Javascript', + icon: javascript + }, + { + name: '妯″瀷宸ュ叿', + icon: moxinggongju + } +]) +const wendaVisible = ref(false) +const cidianVisible = ref(false) +const functionVisible = ref(false) +const siweiVisble = ref(false) +const modelToolVisble = ref(false) +const activeTool = ref(0) +const toolState = reactive({ + open: true +}) + +const selectTeachTools = (item) => { + activeTool.value = item.name + switch (item.name) { + case 'AI鏅鸿兘闂瓟': + wendaVisible.value = true + break + case 'GGB鍑芥暟宸ュ叿': + functionVisible.value = true + break + case '鎬濈淮瀵煎浘': + siweiVisble.value = true + break + case '妯″瀷宸ュ叿': + modelToolVisble.value = true + break + case '璇嶅吀': + cidianVisible.value = true + break + } +} + +const activeName = ref('first') +const handleClick = (tab: TabsPaneContext, event: Event) => { + console.log(tab, event) +} +const selectType = ref('') +const selectTypeClick = (type) => { + if (selectType.value == 'resource' || selectType.value == 'answer') { + selectType.value = '' + } else { + selectType.value = type + } +} +const classStart = ref(true) +const giveLessonsClick = () => { + if (classStart.value) { + classStart.value = false + // 鍚姩璁℃椂鍣� + updateTimer() + } else { + classStart.value = true + stopTimer() + } +} + +//鐢诲竷鎮诞鎿嶄綔 +const floatingToolBox = reactive([ + { + icon: huabi, + name: '鐢荤瑪' + }, + { + icon: qingchu, + name: '娓呴櫎' + }, + { + icon: wenzi, + name: '鏂囧瓧' + }, + { + icon: biaozhu, + name: '鏍囨敞' + }, + { + icon: biaoqianw, + name: '鏍囩' + }, + { + icon: baiban, + name: '鐧芥澘' + }, + { + icon: jieping, + name: '鎴睆' + } +]) + +const floatingToolData = reactive({ + activeToolData: '', //閫変腑宸ュ叿 + elLeft: 380, + elTop: 300, + startclientx: 0, + startclienty: 0, + thicknessActive: 'middle', //鐢荤瑪閫変腑绮楃粏 + lineTypeActive: 'solid', //鐢荤瑪閫変腑绾跨被鍨� + lineColorActive: '' //鐢荤瑪閫変腑绾块鑹� +}) + +//鐢诲竷 +const canvas = ref<any>() //鑾峰彇鐢诲竷 +let ctx: CanvasRenderingContext2D //鑾峰彇canvas鎿嶄綔api鐨勫叆鍙g殑绫诲瀷 +let painting = false +let key = 1 + +const floatOverHander = (item) => { + const curIndex = floatingToolBox.findIndex((f) => f.name == item.name) + switch (curIndex) { + case 0: + floatingToolBox[0].icon = huabi1 + break + case 1: + floatingToolBox[1].icon = qingchu1 + break + case 2: + floatingToolBox[2].icon = wenzi1 + break + case 3: + floatingToolBox[3].icon = biaozhu1 + break + case 4: + floatingToolBox[4].icon = biaoqian1 + break + case 5: + floatingToolBox[5].icon = baiban1 + break + case 6: + floatingToolBox[6].icon = jieping1 + break + } +} +const floatOutHander = (item) => { + const curIndex = floatingToolBox.findIndex((f) => f.name == item.name) + switch (curIndex) { + case 0: + floatingToolBox[0].icon = huabi + break + case 1: + floatingToolBox[1].icon = qingchu + break + case 2: + floatingToolBox[2].icon = wenzi + break + case 3: + floatingToolBox[3].icon = biaozhu + break + case 4: + floatingToolBox[4].icon = biaoqianw + break + case 5: + floatingToolBox[5].icon = baiban + break + case 6: + floatingToolBox[6].icon = jieping + break + } +} +//娴獥宸ュ叿鏍忕偣鍑讳簨浠� +const floatItemHandle = (item) => { + floatingToolData.activeToolData = item.name + // switch (item.name) { + // case '鐢荤瑪': + // break + // } +} +const dragend = (e) => { + let x = e.clientX - floatingToolData.startclientx + let y = e.clientY - floatingToolData.startclienty + if (floatingToolData.elLeft + x > 0 || floatingToolData.elTop + y > 0) { + floatingToolData.elLeft = e.x - 40 + floatingToolData.elTop = e.y - 60 + } +} +const dragstart = (e) => { + console.log(e) + floatingToolData.startclientx = e.clientX + floatingToolData.startclienty = e.clientY +} + +//閫変腑鐢荤瑪绮楃粏 +const selectThickness = (str) => { + floatingToolData.thicknessActive = str +} + +const selectLineType = (str) => { + floatingToolData.lineTypeActive = str +} +//鐢荤瑪棰滆壊閫夋嫨 +const lineColorSelect = (item) => { + floatingToolData.lineColorActive = item.key +} +// 鐢荤嚎娈� +const paint = ( + startX: number, + startY: number, + endX: number, + endY: number, + ctx: CanvasRenderingContext2D +) => { + ctx.beginPath() + ctx.globalAlpha = 1 + ctx.lineWidth = 2 + ctx.strokeStyle = '#000' + ctx.moveTo(startX, startY) // 鐢荤嚎璧风偣 + ctx.lineTo(endX, endY) // 鐢荤嚎缁堢偣 + ctx.closePath() + ctx.stroke() // 鎻忕粯绾挎潯 +} +// 瀹氫箟榧犳爣鍒濆鐐瑰嚮鐨勪綅缃� +let startX = 0 +let startY = 0 + +// 榧犳爣鎸変笅 +const mousedown = (event: MouseEvent) => { + ;[startX, startY] = getOffset(event) + painting = true // 灏嗙粯鐢荤姸鎬佹敼鎴恡rue +} + +// 榧犳爣绉诲姩 +const mousemove = (event: MouseEvent) => { + if (painting) { + // 鍦ㄩ紶鏍囩Щ鍔ㄧ殑鏈熼棿锛岃幏鍙栭紶鏍囩殑浣嶇疆 + const [endX, endY] = getOffset(event) + paint(startX, startY, endX, endY, ctx) + // 涓嬮潰涓よ浠g爜鏄洿鏂扮嚎鏉$殑璧风偣 + startX = endX + startY = endY + } +} + +// 榧犳爣鏉惧紑 +const mouseup = (event: MouseEvent) => { + // 鏉惧紑榧犳爣鍚� 绂佹鐢荤嚎鏉� + if (painting) painting = false +} + +//娓呴櫎涓婁竴姝�/鍏ㄩ儴 +const cleanUpSelect = (str) => {} +//鏍囩鏄剧ず闅愯棌 +const labelShow = (str) => {} + +//閫変腑鏂囧瓧宸ュ叿鏍� +const selectText = ref('') //閫変腑鏂囧瓧 +const showToolBox = ref(false) +const dialogToolData = reactive({ + left: 500, + top: 300 +}) +const toolActive = ref('楂樹寒') +const colorActive = ref('') +const dialogToolList = reactive([ + { icon: gaoliang, activeIcon: gaoliang1, name: '楂樹寒' }, + { icon: huaxian, activeIcon: huaxian1, name: '鍒掔嚎' }, + { icon: biji2, activeIcon: biji1, name: '绗旇' }, + { icon: biaozhu2, activeIcon: biaozhu3, name: '鏍囨敞' }, + { icon: fuzhi, activeIcon: fuzhi1, name: '澶嶅埗' }, + { icon: AIyuedu, activeIcon: AIyuedu1, name: 'AI闃呰' }, + { icon: cidian2, activeIcon: cidian1, name: '璇嶅吀' }, + { icon: yuyinyuedu, activeIcon: yuyinyuedu1, name: '璇煶闃呰' } +]) +const colorSelectList = reactive([ + { + label: '绾㈣壊', + key: '#FF0000' + }, + { + label: '钃濊壊', + key: '#004DFF' + }, + { + label: '缁胯壊', + key: '#01BA51' + }, + { + label: '榛勮壊', + key: '#FFF700' + }, + { + label: '婢勮壊', + key: '#FF8800' + } +]) + +//绗旇寮圭獥 +const addNoteVisble = ref(false) +const formData = ref({ + name: '', + desc: '' +}) +//璇嶅吀 + +const synth = window.speechSynthesis +//宸ュ叿鏍忔柟娉� +const dialogOverHander = (item) => { + const curIndex = dialogToolList.findIndex((f) => f.name == item.name) + switch (curIndex) { + case 0: + dialogToolList[0].icon = gaoliang1 + break + case 1: + dialogToolList[1].icon = huaxian1 + break + case 2: + dialogToolList[2].icon = biji1 + break + case 3: + dialogToolList[3].icon = biaozhu3 + break + case 4: + dialogToolList[4].icon = fuzhi1 + break + case 5: + dialogToolList[5].icon = AIyuedu1 + break + case 6: + dialogToolList[6].icon = cidian1 + break + case 7: + dialogToolList[7].icon = yuyinyuedu1 + break + } +} +const dialogOutHander = (item) => { + const curIndex = dialogToolList.findIndex((f) => f.name == item.name) + switch (curIndex) { + case 0: + dialogToolList[0].icon = gaoliang + break + case 1: + dialogToolList[1].icon = huaxian + break + case 2: + dialogToolList[2].icon = biji2 + break + case 3: + dialogToolList[3].icon = biaozhu2 + break + case 4: + dialogToolList[4].icon = fuzhi + break + case 5: + dialogToolList[5].icon = AIyuedu + break + case 6: + dialogToolList[6].icon = cidian2 + break + case 7: + dialogToolList[7].icon = yuyinyuedu + break + } +} +const dialogToolHandle = (item) => { + toolActive.value = item.name + colorActive.value = '' + switch (item.name) { + case 'AI闃呰': + const utterance = new SpeechSynthesisUtterance(selectText.value) + utterance.lang = 'zh-CN' // 璁剧疆璇█涓轰腑鏂� + synth.speak(utterance) + break + case '鍒掔嚎': + break + case '楂樹寒': + break + case '绗旇': + formData.value.name = '' + formData.value.desc = '' + break + case '鏍囨敞': + break + case '澶嶅埗': + try { + var successful = document.execCommand('copy') //鎵ц澶嶅埗鍛戒护 + var msg = successful ? '鎴愬姛' : '澶辫触' + ElMessage.success({ + message: '宸插鍒舵枃鏈�', + type: 'success' + }) + } catch (err) { + ElMessage.error('鏃犳硶澶嶅埗鏂囨湰锛�' + err) + } + showToolBox.value = false + break + case '璇嶅吀': + cidianVisible.value = true + break + } +} + +const clickSelect = (item) => { + colorActive.value = item.key + if (toolActive.value == '绗旇') { + addNoteVisble.value = true + } +} + +//鍐呭鍖哄煙椤堕儴鏄剧ず + +const headerData = reactive({ + classTime: '00:00:00', + seconds: 0, + minutes: 0, + hours: 0, + process: '42%', + pageSize: 100, + brushToolShow: true +}) +//涓婅鏃堕暱璁℃椂鍣� +const timer = ref(null) +const updateTimer = () => { + // 娓呴櫎涔嬪墠鐨勫畾鏃跺櫒锛岄槻姝㈠涓畾鏃跺櫒鍚屾椂杩愯 + stopTimer() + timer.value = setInterval(() => { + headerData.seconds++ + if (headerData.seconds === 60) { + headerData.seconds = 0 + headerData.minutes++ + } + if (headerData.minutes === 60) { + headerData.minutes = 0 + headerData.hours++ + } + // 鏍煎紡鍖栨椂闂� + const formattedTime = `${headerData.hours.toString().padStart(2, '0')}:${headerData.minutes.toString().padStart(2, '0')}:${headerData.seconds.toString().padStart(2, '0')}` + headerData.classTime = formattedTime + }, 1000) // 闂撮殧1绉� +} +const stopTimer = () => { + if (timer.value) { + clearInterval(timer.value) + timer.value = null + headerData.classTime = '00:00:00' + } +} + +const changePageSize = (str) => { + if (str == 'add') { + headerData.pageSize = Number(headerData.pageSize) + 5 + } else { + headerData.pageSize = Number(headerData.pageSize) - 5 + } +} + +const brushToolShow = () => { + console.log(headerData.brushToolShow, 123) + if (headerData.brushToolShow) { + ctx = canvas.value.getContext('2d') as CanvasRenderingContext2D + } +} </script> <style lang="less"> @@ -146,6 +1080,8 @@ border-right: 1px solid #e6e7e8; padding-bottom: 20px; box-sizing: border-box; + position: relative; + box-shadow: 10px 0 10px -10px rgba(0, 0, 0, 0.07); .menuItem { text-align: center; line-height: 1; @@ -165,12 +1101,394 @@ margin-bottom: 4px; } } + .setting { + width: 80px; + position: absolute; + bottom: 30px; + text-align: center; + } + } + .menuContent { + width: 270px; + height: calc(100vh - 48px); + overflow-y: auto; + background: #e0f2ff; + .searchBox { + width: 100%; + height: 60px; + background: #ffffff; + display: flex; + justify-content: center; + align-items: center; + .inputBox { + .custom-input { + border: 1px solid #0093ff !important; + border-radius: 50px; + overflow: hidden; + } + .is-focus, + .el-input__wrapper { + box-shadow: none !important; + } + } + } + .screenBox { + display: flex; + padding: 0 10px; + .title { + margin: 10px 0; + line-height: 40px; + padding: 0 10px; + border: none; + } + + .flex1 { + flex: 1; + display: flex; + align-items: center; + justify-content: space-between; + } + + .all { + width: 50px; + height: 20px; + border-radius: 17px; + margin: 10px 10px 10px 0; + border: 1px solid #d8d8d8; + text-align: center; + line-height: 17px; + font-size: 12px; + } + + .allActive { + width: 50px; + height: 20px; + border-radius: 17px; + margin: 10px 10px 10px 0; + text-align: center; + line-height: 17px; + color: #fff; + background: #0093ff; + border: 1px solid #0093ff; + font-size: 12px; + } + + .scribeItem { + width: 18px; + height: 18px; + border-radius: 50%; + margin: 10px auto; + border: none; + } + + .activeScribe { + border: 1px solid #0093ff; + } + } + } + .menuStateBox { + width: 25px; + height: 25px; + border-radius: 3px 0px 0px 3px; + border: 1px solid #bce3ff; + position: fixed; + line-height: 22px; + top: 50%; + left: 325px; + text-align: center; + box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.16); + img { + height: 10px; + width: 18px; + } } .pageBox { flex: 1; overflow: auto; + font-size: 16px; + .pageBox-header { + height: 57px; + padding: 0 20px; + background: #fff; + display: flex; + align-items: center; + justify-content: space-between; + .classTime { + display: flex; + align-items: center; + background: rgba(0, 147, 255, 0.1); + border-radius: 20px 20px 20px 20px; + color: #0093ff; + padding: 8px; + .qureIcon { + width: 9px; + height: 9px; + border-radius: 50%; + background: #0093ff; + margin: 0 5px; + } + } + .rightBox { + display: flex; + .pageSizeBox { + display: flex; + align-items: center; + padding: 0 20px; + border-right: 1px solid #d8d8d8; + div { + padding: 5px; + } + } + .brushImgBox { + display: flex; + align-items: center; + div { + padding: 5px; + display: flex; + align-items: center; + } + .brushImg { + width: 22px; + margin-left: 20px; + margin-right: 5px; + } + } + } + } + .pageBox-content { + height: calc(100% - 57px); + position: relative; + #container { + background: #fbf9f4; + height: 100%; + } + .canvas-box { + height: 100%; + width: 100%; + position: absolute; + top: 0; + left: 0; + } + } } + .toolBox { + position: relative; + box-shadow: -3px 0px 6px 1px rgba(0, 0, 0, 0.07); + .toolTitle { + height: 57px; + line-height: 53px; + text-align: center; + border-bottom: 1px solid #efefef; + .text { + width: 43px; + height: 3px; + margin: 0 auto; + background: #0093ff; + border-radius: 3px 3px 0px 0px; + } + } + .menu { + padding-top: 20px; + li { + height: 50px; + padding: 10px 36px; + font-size: 16px; + display: flex; + align-items: center; + color: #333; + + img { + width: 29px; + height: 29px; + } + + span { + margin-left: 10px; + } + } + } + .openBox { + width: 25px; + height: 25px; + background: #fff; + border-radius: 3px 0px 0px 3px; + border: 1px solid #bce3ff; + position: fixed; + line-height: 22px; + top: 50%; + right: 50px; + text-align: center; + box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.16); + img { + height: 10px; + width: 18px; + } + } + .right { + right: 183px !important; + border-radius: 0px 3px 3px 0px !important; + } + .classRoomBox { + position: absolute; + bottom: 0; + width: 100%; + .el-tabs__nav { + width: 100% !important; + } + .el-tabs__item { + flex: 1 !important; + padding: 0 !important; + } + .el-tabs__active-bar { + width: 43px !important; + left: 30px !important; + height: 3px; + bottom: 1px; + border-radius: 3px 3px 0px 0px; + } + .tabBox { + height: 100px; + padding: 10px 17px; + text-align: center; + .insertSelect { + display: flex; + justify-content: space-between; + .selectItem { + text-align: center; + background: rgba(207, 207, 207, 0.13); + padding: 10px; + border-radius: 5px; + border: 2px solid #cfcfcf; + } + .typeActive { + text-align: center; + color: #0093ff; + border: 2px solid #0093ff; + padding: 10px; + border-radius: 5px; + background: rgba(0, 147, 255, 0.13); + } + } + .giveLessons { + color: #0093ff; + width: 90px; + margin: 10px auto; + padding: 5px; + border-radius: 20px; + border: 1px solid #0093ff; + display: flex; + align-items: center; + justify-content: center; + span { + margin-left: 10px; + } + } + } + } + } + + .draggableBox { + width: 85px; + background-image: linear-gradient(to bottom, #0093ff, #005dff); + position: fixed; + height: 430px; + top: 300px; + left: 400px; + z-index: 999; + border-radius: 10px; + padding: 5px; + overflow: hidden; + .floatToolItem { + height: 60px; + display: flex; + justify-content: center; + align-items: center; + border-radius: 5px; + color: #fff; + img { + margin-right: 8px; + } + .text { + margin-right: 5px; + } + } + } + .floatToolItem:hover { + background-color: #fff; + color: #0093ff; + } + + .dialogToolBox { + position: fixed; + z-index: 2; + + .toolSelectBox { + height: 57px; + display: flex; + justify-content: center; + align-items: center; + border-radius: 12px; + overflow: hidden; + padding: 5px; + background-image: linear-gradient(to right, #0093ff, #005dff); + .dialogToolItem { + user-select: none; + width: 60px; + font-size: 12px; + border-radius: 5px; + padding: 5px 0; + cursor: pointer; + text-align: center; + img { + margin: 0 auto; + display: block; + margin-bottom: 5px; + height: 16px; + } + span { + color: #fff; + } + } + .dialogToolItem:hover, + .active { + background-color: #fff; + span { + color: #0093ff; + } + } + } + } + .colorSelectBox { + padding: 5px 10px; + width: 190px; + display: flex; + background: #ffffff; + box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.16); + border-radius: 5px; + margin-bottom: 10px; + .flex1 { + flex: 1; + .scribeItem { + width: 18px; + height: 18px; + border-radius: 3px; + margin: 10px auto; + border: none; + display: flex; + justify-content: center; + align-items: center; + } + } + } + } +} +.wendabox { + width: 100%; + height: 700px; + iframe { + width: 100%; + height: 100%; } } </style> -- Gitblit v1.9.1