【electron】解决CS里的全屏问题

目录

解决方法及原理

效果

用原生的html即可全屏

[原生的electron api](#原生的electron api)

[wvp工程还是用它的h5 不变](#wvp工程还是用它的h5 不变)


解决方法及原理

1. 在主进程中启用全屏权限

main.js(file:///d:/java/test/cs/main.js)中增加了对全屏权限的支持:

  • webPreferences(file:///d:/java/test/cs/main.js#L12-L12)中添加了`fullscreenable: true`

  • 在权限处理函数中允许fullscreen(file://d:\java\test\cs\main.js#L50-L50)权限请求

  • 添加了专门用于全屏控制的IPC处理程序

2. 在预加载脚本中暴露Electron原生全屏API

preload.js(file:///d:/java/test/cs/preload.js)中通过IPC暴露了以下方法:

  • `window.electron.enterFullscreen()` - 进入全屏

  • `window.electron.exitFullscreen()` - 退出全屏

  • `window.electron.isFullscreen()` - 检查是否全屏状态

3. 在2.html中增加了两种全屏方法的支持

2.html(file:///d:/web-video-platform/wvp/static/2.html)中实现了:

  • HTML5原生全屏API(适用于普通浏览器)

  • Electron原生全屏API(适用于Electron环境)

  • 用户可以选择使用哪种方法进行全屏操作

使用说明:

  1. 在Electron应用中打开2.html(file:///d:/web-video-platform/wvp/static/2.html)

  2. 选择"Electron原生全屏"选项

  3. 点击"切换全屏"按钮即可正常使用全屏功能

  4. 按ESC键或再次点击按钮可退出全屏

这样修改后,在Electron环境中就可以正常使用全屏功能了。Electron原生全屏方法比HTML5 API在Electron环境中更加稳定可靠。

效果

用原生的html即可全屏

原生的electron api

wvp工程还是用它的h5 不变

即我们只是需要cs:里的 main.js里开放权限即可。

相关推荐
kyriewen1 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒1 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马2 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮2 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦2 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer2 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队2 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY2 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_3 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏3 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端