Electron 自定义窗口桌面时钟实现示例详解

 更新时间:2023年03月09日 14:29:54   作者:乔珂力  
这篇文章主要为大家介绍了Electron 自定义窗口桌面时钟实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

正文

本节主要讲解如何使用 Electron 创建自定义窗口,并带领大家开发一款漂亮的桌面时钟

效果如下

实例化 BrowserWindow 类创建窗口

众所周知,在 Electron 里面,窗口都是通过实例化 BrowserWindow 类创建出来的

一个最简单的创建窗口的代码如下:

const win = new BrowserWindow({ width: 800, height: 600 })

这样就会创建出一个宽 800 像素,高 600 像素的窗口出来。BrowserWindow 类是 Electron 提供的窗口管理的类,继承自 EventEmitter:

class BrowserWindow extends NodeEventEmitter {
	// 省略...
}

窗口创建之后,默认是空的,如果想要界面上显示内容,Electron 提供了两个方法:

  • loadURL:加载指定网站
  • loadFile:加载本地文件

加载本地 clock.html 文件

const win = new BrowserWindow({ width: 800, height: 600 })
win.loadFile(path.join(__dirname, '../renderer/clock.html'))

默认的窗口是带标题栏的,但系统自带的标题栏定制功能很弱,往往无法满足个性化需求,于是 Electron 提供了 titleBarStyle 选项来隐藏标题栏:

win = new BrowserWindow({
  width: 600,
  height: 500,
  titleBarStyle: 'hiddenInset', // 隐藏标题栏
})

这个时候的效果看起来舒服多了:

除此之外,还可以设置 transparent: true 来创建一个透明窗口:

可以看到,整个矩形窗体的非内容区都变成了透明状态,但还能看到边框,此时可以用 frame: false 创建一个无边框窗口,仅显示时钟圆形区域:

win = new BrowserWindow({
  width: 600,
  height: 500,
  resizable: false,
  frame: false,
  transparent: true,
  webPreferences: {
    preload: path.join(__dirname, '../preload/index.js'),
  },
})

这样就实现文章开头的效果了:

不过虽然窗口变透明了,但本质上窗口还是矩形的,如果用户点击时钟外侧、矩形内侧的区域,还是能够选中时钟窗口:

但我们要实现的是鼠标穿透效果,即:点击透明区域能够选中下层的元素。BrowserWindow 提供了一个方法:

win.setIgnoreMouseEvents(true)

但这会带来新的问题:点击时钟里面也会造成鼠标穿透!也就是说,时钟变成了一个永远无法选中、无法拖动的窗口了。要想解决这个问题,只能通过渲染进程向主进程发送消息,动态的设置鼠标穿透效果,

主进程代码

ipcMain.on('set-ignore-mouse-events', (event, ...args) => {
  console.log('set-ignore-mouse-events', args)
  BrowserWindow.fromWebContents(event.sender).setIgnoreMouseEvents(...args)
})

在 preload.js 中监听鼠标事件,当进入时钟圆形内部的时候,不设置鼠标穿透,离开时钟再设置穿透效果:

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 })
  })
})

这样就完美实现了可拖拽、可移动的时钟啦!

以上就是Electron 自定义窗口桌面时钟实现示例详解的详细内容,更多关于Electron 窗口时钟的资料请关注脚本之家其它相关文章!

相关文章

  • js触发onchange事件的方法说明

    js触发onchange事件的方法说明

    怎么在js代码模式通过代码触发textbox控件的onchange事件呢,经过查阅资料,发现js提供了一个方法,可以触发控件的应该是所有事件
    2014-03-03
  • JS实现批量上传文件并显示进度功能

    JS实现批量上传文件并显示进度功能

    这篇文章主要介绍了JS实现批量上传文件并显示进度功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-06-06
  • 如何用JS实现简单的数据监听

    如何用JS实现简单的数据监听

    这篇文章主要介绍了如何用JS实现简单的数据监听,对数据监听感兴趣的同学,可以参考一下
    2021-05-05
  • javascript之bind使用介绍

    javascript之bind使用介绍

    首先apply和call是老生常谈的东西,但是对于bind,我愣了下,因为这个词是jquery中使用频率很高的一个方法,用来给DOM元素绑定事件用的
    2011-10-10
  • JS复制对应id的内容到粘贴板(Ctrl+C效果)

    JS复制对应id的内容到粘贴板(Ctrl+C效果)

    这篇文章主要给大家介绍了利用JS实现复制指定对应id的内容到粘贴板(Ctrl+C效果),文中给出了详细的介绍和示例代码,有需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-01-01
  • 响应式框架Bootstrap栅格系统的实例

    响应式框架Bootstrap栅格系统的实例

    下面小编就为大家分享一篇响应式框架Bootstrap栅格系统的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • JavaScript中如何调用Java方法

    JavaScript中如何调用Java方法

    这篇文章主要介绍了JavaScript中如何调用Java方法,帮助大家更好的理解和使用JavaScript,感兴趣的朋友可以了解下
    2020-09-09
  • js实现获取焦点后光标在字符串后

    js实现获取焦点后光标在字符串后

    这篇文章主要介绍了js实现获取焦点后光标在字符串后,原理就是获得焦点后重新把自己复制粘帖一下,喜欢的朋友可以看看
    2014-09-09
  • 浅谈JavaScript中的“!!”作用

    浅谈JavaScript中的“!!”作用

    这篇文章主要介绍了浅谈JavaScript中的“!!”作用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • JavaScript获取数组最后一个元素的3种方法以及性能

    JavaScript获取数组最后一个元素的3种方法以及性能

    在开发过程中,我们常常需要得到js数组的最后一个数组元素,下面这篇文章主要给大家介绍了关于JavaScript获取数组最后一个元素的3种方法以及性能,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-06-06

最新评论