Electron?自定義窗口桌面時鐘實現(xiàn)示例詳解
正文
本節(jié)主要講解如何使用 Electron 創(chuàng)建自定義窗口,并帶領(lǐng)大家開發(fā)一款漂亮的桌面時鐘
效果如下
實例化 BrowserWindow 類創(chuàng)建窗口
眾所周知,在 Electron 里面,窗口都是通過實例化 BrowserWindow
類創(chuàng)建出來的
一個最簡單的創(chuàng)建窗口的代碼如下:
const win = new BrowserWindow({ width: 800, height: 600 })
這樣就會創(chuàng)建出一個寬 800 像素,高 600 像素的窗口出來。BrowserWindow 類是 Electron 提供的窗口管理的類,繼承自 EventEmitter:
class BrowserWindow extends NodeEventEmitter { // 省略... }
窗口創(chuàng)建之后,默認(rèn)是空的,如果想要界面上顯示內(nèi)容,Electron 提供了兩個方法:
loadURL
:加載指定網(wǎng)站loadFile
:加載本地文件
加載本地 clock.html 文件
const win = new BrowserWindow({ width: 800, height: 600 }) win.loadFile(path.join(__dirname, '../renderer/clock.html'))
默認(rèn)的窗口是帶標(biāo)題欄的,但系統(tǒng)自帶的標(biāo)題欄定制功能很弱,往往無法滿足個性化需求,于是 Electron 提供了 titleBarStyle
選項來隱藏標(biāo)題欄:
win = new BrowserWindow({ width: 600, height: 500, titleBarStyle: 'hiddenInset', // 隱藏標(biāo)題欄 })
這個時候的效果看起來舒服多了:
除此之外,還可以設(shè)置 transparent: true
來創(chuàng)建一個透明窗口:
可以看到,整個矩形窗體的非內(nèi)容區(qū)都變成了透明狀態(tài),但還能看到邊框,此時可以用 frame: false
創(chuàng)建一個無邊框窗口,僅顯示時鐘圓形區(qū)域:
win = new BrowserWindow({ width: 600, height: 500, resizable: false, frame: false, transparent: true, webPreferences: { preload: path.join(__dirname, '../preload/index.js'), }, })
這樣就實現(xiàn)文章開頭的效果了:
不過雖然窗口變透明了,但本質(zhì)上窗口還是矩形的,如果用戶點(diǎn)擊時鐘外側(cè)、矩形內(nèi)側(cè)的區(qū)域,還是能夠選中時鐘窗口:
但我們要實現(xiàn)的是鼠標(biāo)穿透效果,即:點(diǎn)擊透明區(qū)域能夠選中下層的元素。BrowserWindow 提供了一個方法:
win.setIgnoreMouseEvents(true)
但這會帶來新的問題:點(diǎn)擊時鐘里面也會造成鼠標(biāo)穿透!也就是說,時鐘變成了一個永遠(yuǎn)無法選中、無法拖動的窗口了。要想解決這個問題,只能通過渲染進(jìn)程向主進(jìn)程發(fā)送消息,動態(tài)的設(shè)置鼠標(biāo)穿透效果,
主進(jìn)程代碼
ipcMain.on('set-ignore-mouse-events', (event, ...args) => { console.log('set-ignore-mouse-events', args) BrowserWindow.fromWebContents(event.sender).setIgnoreMouseEvents(...args) })
在 preload.js 中監(jiān)聽鼠標(biāo)事件,當(dāng)進(jìn)入時鐘圓形內(nèi)部的時候,不設(shè)置鼠標(biāo)穿透,離開時鐘再設(shè)置穿透效果:
const { ipcRenderer } = require('electron') document.addEventListener('DOMContentLoaded', () => { const clock = document.getElementById('clock') clock.addEventListener('mouseenter', () => { ipcRenderer.send('set-ignore-mouse-events', false) }) clock.addEventListener('mouseleave', () => { ipcRenderer.send('set-ignore-mouse-events', true, { forward: true }) }) })
這樣就完美實現(xiàn)了可拖拽、可移動的時鐘啦!
以上就是Electron 自定義窗口桌面時鐘實現(xiàn)示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Electron 窗口時鐘的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
如何用JS實現(xiàn)簡單的數(shù)據(jù)監(jiān)聽
這篇文章主要介紹了如何用JS實現(xiàn)簡單的數(shù)據(jù)監(jiān)聽,對數(shù)據(jù)監(jiān)聽感興趣的同學(xué),可以參考一下2021-05-05JS復(fù)制對應(yīng)id的內(nèi)容到粘貼板(Ctrl+C效果)
這篇文章主要給大家介紹了利用JS實現(xiàn)復(fù)制指定對應(yīng)id的內(nèi)容到粘貼板(Ctrl+C效果),文中給出了詳細(xì)的介紹和示例代碼,有需要的朋友可以參考借鑒,下面來一起看看吧。2017-01-01響應(yīng)式框架Bootstrap柵格系統(tǒng)的實例
下面小編就為大家分享一篇響應(yīng)式框架Bootstrap柵格系統(tǒng)的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12js實現(xiàn)獲取焦點(diǎn)后光標(biāo)在字符串后
這篇文章主要介紹了js實現(xiàn)獲取焦點(diǎn)后光標(biāo)在字符串后,原理就是獲得焦點(diǎn)后重新把自己復(fù)制粘帖一下,喜歡的朋友可以看看2014-09-09JavaScript獲取數(shù)組最后一個元素的3種方法以及性能
在開發(fā)過程中,我們常常需要得到j(luò)s數(shù)組的最后一個數(shù)組元素,下面這篇文章主要給大家介紹了關(guān)于JavaScript獲取數(shù)組最后一個元素的3種方法以及性能,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06