欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Electron?自定義窗口桌面時鐘實現(xiàn)示例詳解

 更新時間:2023年03月09日 14:29:54   作者:喬珂力  
這篇文章主要為大家介紹了Electron?自定義窗口桌面時鐘實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jì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觸發(fā)onchange事件的方法說明

    js觸發(fā)onchange事件的方法說明

    怎么在js代碼模式通過代碼觸發(fā)textbox控件的onchange事件呢,經(jīng)過查閱資料,發(fā)現(xiàn)js提供了一個方法,可以觸發(fā)控件的應(yīng)該是所有事件
    2014-03-03
  • JS實現(xiàn)批量上傳文件并顯示進(jìn)度功能

    JS實現(xiàn)批量上傳文件并顯示進(jìn)度功能

    這篇文章主要介紹了JS實現(xiàn)批量上傳文件并顯示進(jìn)度功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-06-06
  • 如何用JS實現(xiàn)簡單的數(shù)據(jù)監(jiān)聽

    如何用JS實現(xiàn)簡單的數(shù)據(jù)監(jiān)聽

    這篇文章主要介紹了如何用JS實現(xiàn)簡單的數(shù)據(jù)監(jiān)聽,對數(shù)據(jù)監(jiān)聽感興趣的同學(xué),可以參考一下
    2021-05-05
  • javascript之bind使用介紹

    javascript之bind使用介紹

    首先apply和call是老生常談的東西,但是對于bind,我愣了下,因為這個詞是jquery中使用頻率很高的一個方法,用來給DOM元素綁定事件用的
    2011-10-10
  • JS復(fù)制對應(yīng)id的內(nèi)容到粘貼板(Ctrl+C效果)

    JS復(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)的實例

    下面小編就為大家分享一篇響應(yīng)式框架Bootstrap柵格系統(tǒng)的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • JavaScript中如何調(diào)用Java方法

    JavaScript中如何調(diào)用Java方法

    這篇文章主要介紹了JavaScript中如何調(diào)用Java方法,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下
    2020-09-09
  • js實現(xiàn)獲取焦點(diǎn)后光標(biāo)在字符串后

    js實現(xiàn)獲取焦點(diǎn)后光標(biāo)在字符串后

    這篇文章主要介紹了js實現(xiàn)獲取焦點(diǎn)后光標(biāo)在字符串后,原理就是獲得焦點(diǎn)后重新把自己復(fù)制粘帖一下,喜歡的朋友可以看看
    2014-09-09
  • 淺談JavaScript中的“!!”作用

    淺談JavaScript中的“!!”作用

    這篇文章主要介紹了淺談JavaScript中的“!!”作用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • JavaScript獲取數(shù)組最后一個元素的3種方法以及性能

    JavaScript獲取數(shù)組最后一個元素的3種方法以及性能

    在開發(fā)過程中,我們常常需要得到j(luò)s數(shù)組的最后一個數(shù)組元素,下面這篇文章主要給大家介紹了關(guān)于JavaScript獲取數(shù)組最后一個元素的3種方法以及性能,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06

最新評論