裏面使用了vuex vue vue-route storeJshtml
storeJs 用來持久化vuex狀態vue
沒有使用electron內置的-webkit-app-region: drag
由於使用他那個有不少問題
好比事件沒法使用 右鍵沒法使用 以及不能使用手型等!git
安裝的時候沒有截圖 因此就參考下我其餘的文章吧
storeJs 安裝github
npm install storejs
export default new Router({ routes: [ {path: '/', name: 'home', component: ()=> import('@/view//home')}, {path: '/suspension', name: 'suspension', component: ()=> import('@/view/components/suspension')} ] })
頁面路徑 /src/renderer/view/components/suspension.vue
web
<template> <div id="suspension"> <div class="logo"></div> <div class="content_body"> <div class="upload">拖拽上傳</div> </div> </div> </template> <script> export default { name: "suspension", mounted() { let win = this.$electron.remote.getCurrentWindow(); let biasX = 0; let biasY = 0; let that = this; document.addEventListener('mousedown', function (e) { switch (e.button) { case 0: biasX = e.x; biasY = e.y; document.addEventListener('mousemove', moveEvent); break; case 2: that.$electron.ipcRenderer.send('createSuspensionMenu'); break; } }); document.addEventListener('mouseup', function () { biasX = 0; biasY = 0; document.removeEventListener('mousemove', moveEvent) }); function moveEvent(e) { win.setPosition(e.screenX - biasX, e.screenY - biasY) } } } </script> <style> * { padding: 0; margin: 0; } .upload { height: 25px; line-height: 25px; font-size: 12px; text-align: center; color: #74A1FA; } .logo { width: 40px; background: #5B9BFE url("../../assets/img/logo@2x.png") no-repeat 2px 3px; background-size: 80%; } .content_body { background-color: #EEF4FE; width: 100%; } #suspension { -webkit-user-select: none; cursor: pointer; overflow: hidden; } #suspension { cursor: pointer !important; height: 25px; border-radius: 4px; display: flex; border: 1px solid #3388FE; } </style>
路徑: /src/main/window.js
vuex
import {BrowserWindow, ipcMain, screen, Menu, shell, app, webContents} from 'electron' var win = null; const window = BrowserWindow.fromWebContents(webContents.getFocusedWebContents()); const winURL = process.env.NODE_ENV === 'development' ? `http://localhost:9080/#/suspension` : `file://${__dirname}/index.html/#/suspension`; ipcMain.on('showSuspensionWindow', () => { if (win) { if (win.isVisible()) { createSuspensionWindow(); } else { win.showInactive(); } } else { createSuspensionWindow(); } }); ipcMain.on('createSuspensionMenu', (e) => { const rightM = Menu.buildFromTemplate([ {label: '開始所有任務', enabled: false}, {label: '暫停所有任務', enabled: false}, {label: '本次傳輸完自動關機'}, {type: 'separator'}, { label: '隱藏懸浮窗', click: () => { window.webContents.send('hideSuspension', false); win.hide() } }, {type: 'separator'}, { label: '加入qq羣', click: () => { shell.openExternal('tencent://groupwpa/?subcmd=all¶m=7B2267726F757055696E223A3831343237303636392C2274696D655374616D70223A313533393531303138387D0A'); } }, { label: 'GitHub地址', click: () => { shell.openExternal('https://github.com/lihaotian0607/auth'); } }, { label: '退出軟件', click: () => { app.quit(); } }, ]); rightM.popup({}); }); function createSuspensionWindow() { win = new BrowserWindow({ width: 107, //懸浮窗口的寬度 比實際DIV的寬度要多2px 由於有1px的邊框 height: 27, //懸浮窗口的高度 比實際DIV的高度要多2px 由於有1px的邊框 type: 'toolbar', //建立的窗口類型爲工具欄窗口 frame: false, //要建立無邊框窗口 resizable: false, //禁止窗口大小縮放 show: false, //先不讓窗口顯示 webPreferences: { devTools: false //關閉調試工具 }, transparent: true, //設置透明 alwaysOnTop: true, //窗口是否老是顯示在其餘窗口以前 }); const size = screen.getPrimaryDisplay().workAreaSize; //獲取顯示器的寬高 const winSize = win.getSize(); //獲取窗口寬高 //設置窗口的位置 注意x軸要桌面的寬度 - 窗口的寬度 win.setPosition(size.width - winSize[0], 100); win.loadURL(winURL); win.once('ready-to-show', () => { win.show() }); win.on('close', () => { win = null; }) } ipcMain.on('hideSuspensionWindow', () => { if (win) { win.hide(); } });
路徑: /src/renderer/store/modules/suspension.js
shell
import storejs from 'storejs' const state = { show: storejs.get('showSuspension') }; const actions = { showSuspension: function ({state, commit}) { let status = true; storejs.set('showSuspension', status); state.show = status; }, hideSuspension: function ({state, commit}) { let status = false; storejs.set('showSuspension', status); state.show = status; }, }; export default ({ state, actions });
裏面使用的百度的圖標以及UI做爲學習使用,請不要做爲商業用途!npm
在軟件關閉以後重啓會致使懸浮窗口的位置重置 也曾嘗試在主進程中使用store.js 可是不能用!
若是想解決這個問題 能夠在渲染進程中將拖動的最後座標保存到storejs中
在渲染進程給主進程發送異步消息的時候將座標攜帶進去 也可使用nedb在主進程中存儲座標!app
使用electron製做百度網盤客戶端: https://github.com/lihaotian0...
使用electron製做百度網盤懸浮窗: https://github.com/lihaotian0...異步
目前這個開源代碼中沒有懸浮窗 有時間了會加上去!!!