区分 electron 全屏和最大化

一. 全屏

在 Electron 中,当窗口处于全屏状态时,通常不能直接使用 JavaScript 来改变窗口大小。这是出于安全和用户体验的考虑,以防止意外的窗口大小变化影响全屏体验。

1. 退出全屏后再调整大小

检测全屏状态,退出全屏并调整大小

javascript 复制代码
const { BrowserWindow } = require("electron");

const win = BrowserWindow.getFocusedWindow();

const isFullScreen = win.isFullScreen();



if (isFullScreen) {

  win.setFullScreen(false);

  win.setSize(800, 600); // 设置新的窗口大小

}

二. 最大化

在 Electron 中,当窗口处于最大化状态时,确实可能无法直接通过 JavaScript 来改变窗口大小。这是因为在最大化状态下,窗口的大小通常由操作系统管理。

1. 先取消最大化状态

在尝试改变窗口大小时,首先检查窗口是否处于最大化状态。如果是,可以使用 unmaximize() 方法来取消最大化状态。

javascript 复制代码
const { BrowserWindow } = require("electron");

let win = BrowserWindow.getFocusedWindow();

if (win.isMaximized()) {

  win.unmaximize();

  win.setSize(800, 600);

}
相关推荐
指尖跳动的光3 分钟前
将多次提交合并成一次提交
前端·javascript
程序员码歌9 分钟前
短思考第263天,每天复盘10分钟,胜过盲目努力一整年
android·前端·后端
oden13 分钟前
1 小时速通!手把手教你从零搭建 Astro 博客并上线
前端
若梦plus13 分钟前
JS之类型化数组
前端·javascript
若梦plus13 分钟前
Canvas 深入解析:从基础到实战
前端·javascript
若梦plus17 分钟前
Canvas渲染原理与浏览器图形管线
前端·javascript
C_心欲无痕42 分钟前
vue3 - 依赖注入(provide/inject)组件跨层级通信的优雅方案
前端·javascript·vue.js
幺零九零零1 小时前
全栈程序员-前端第二节- vite是什么?
前端
你脸上有BUG1 小时前
TreeSelect 组件 showCheckedStrategy 属性不生效问题
前端·vue