Electron实现自定义最大化最小化关闭窗口功能

如何在渲染进程中调用主进程的最大化窗口、最小化窗口、关闭窗口的方法

创建窗口时设置frame属性为false,即创建一个无边框的窗口,不使用Electron自带的框架,那么如何在渲染进程中通知主进程进行窗口的操作?详见代码如下。

主进程代码

const { app, BrowserWindow, Tray, Menu, ipcMain, } = require('electron');
const path = require('path');
//入口文件
let indexHtml = 'http://localhost:' + 8080 + '/xiongxin/';
//熊信图标路径
const iconPath = path.join(__dirname,`../src/assets/logo/icon.png`);

//所有窗体
let windows = {
	mainWindow: null, //主窗口
}

//创建主窗口
const createMainWindow = () => {
    //创建并控制浏览器窗口。
    windows.mainWindow = new BrowserWindow({
        width: 1200,
        height: 900,
        minWidth: 900,
        minHeight: 600,
        frame: false, // 无边框
        icon: iconPath,// 窗口图标
        webPreferences: {//网页功能设置。
            preload: path.join(__dirname, 'preload.js'),//在页面运行其他脚本之前预先加载指定的脚本 无论页面是否集成Node, 此脚本都可以访问所有Node API 脚本路径为文件的绝对路径。
            webSecurity: false,//禁用同源策略
            nodeIntegration: true,
            nodeIntegrationInWorker: true
        }
    });
    //加载路径
    windows.mainWindow.loadURL(indexHtml);
};

//当Electron 初始化完成时触发
app.whenReady().then(() => {
    createMainWindow();//创建主窗口
    app.on('activate', () => { // macOS 应用通常即使在没有打开任何窗口的情况下也继续运行,并且在没有窗口可用的情况下激活应用时会打开新的窗口。
        if (BrowserWindow.getAllWindows().length === 0) createMainWindow();
    });
});

//关闭所有窗口时退出应用 ,监听 app 模块的 'window-all-closed' 事件。如果用户不是在 macOS(darwin) 上运行程序,则调用 app.quit()。
app.on('window-all-closed', () => {
    if (process.platform !== 'darwin') app.quit();
});

/** 接收渲染进程 操作窗口 的通知
 * @param {Object} event
 * @param {String} windowName 需要操作的窗口名称
 * @param {String} operationType 操作类型
 */
ipcMain.on('operation-window', function(event, windowName, operationType) {
    const currOperationWindow = windows[windowName];//当前操作的窗口实例
    if (!currOperationWindow) return;
    switch (operationType) {
        case 'max'://窗口 最大化
            currOperationWindow.maximize();
            break;
        case 'restoreDown'://窗口 向下还原
            currOperationWindow.unmaximize();
            break;
        case 'min'://窗口 最小化
            currOperationWindow.minimize();
            break;
        case 'close'://窗口 关闭
            currOperationWindow.close();
            break;
    }
});

预加载脚本代码

//向渲染器进程暴露一个全局的 window.electronAPI 变量。
const { contextBridge, ipcRenderer, app } = require('electron');
contextBridge.exposeInMainWorld('electronAPI', {
	operationWindow: (windowName,actionType) => ipcRenderer.send('operation-window', windowName,actionType),
})

渲染进程代码

<template>
	<div  class="min" @click="onElectronOperationWindow('min')">最小化</div>
	<div  class="max" @click="onElectronOperationWindow('max')">最大化</div>
	<div  class="restoreDown" @click="onElectronOperationWindow('restoreDown')">向下还原</div>
	<div  class="close" @click="onElectronOperationWindow('close')">关闭</div>
</template>
<script lang="ts" setup>
	function onElectronOperationWindow(operationType){
			if(window.electronAPI && window.electronAPI.operationWindow) {
				window.electronAPI.operationWindow('mainWindow ',operationType)
			}
	}
</script>
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值