WPF 全屏窗口将让 Chrome 97 视频停止播放

无论是使用 WPF 全屏窗口,还是高性能全屏透明窗口,都会在 Chrome 97 以及使用 chromium 对应版本内核的应用的视频停止播放。这是 chromium 的一个优化,因为 chromium 认为,如果有全屏窗口盖在上面,自然此时停止播放视频可以节省资源。然而 chromium 却没有考虑到,有很多会议的应用,虽然是全屏的,但也是透明的,于是此时停止播放视频将是非预期的

敲黑板,这次 WPF 是背锅的,这完全是 Chrome 97 自己的优化问题

这是 Chrome 97 的功能,是功能,不是 bug 哦

除了 WPF 的全屏窗口进入前台时,会让 Chrome 97 的应用的视频停止播放。其他任何的 Win32 应用,也能让 Chrome 97 的应用的视频停止播放。因为这是 Chrome 97 在内核里的优化判断,只要有窗口满足 Windows Native Window Occlusion Detection 文档所描述的条件,将会自动停止视频的播放

此问题已算报告给 chromium 官方,细节请看 Chrome Occlusion Problem is Back, Help Please? : incremental_games

最佳修复方法为禁用 Chrome 此功能,进入 chrome://flags 禁用 #calculate-native-win-occlusion 即可

另外一个应该是有坑的方法是更改自己的 WPF 应用,如给应用的窗口设置 Win32 的窗口样式,设置 WM_Popup 样式,也能解决此问题,因为绕过了 Windows Native Window Occlusion Detection 文档描述的方法。但是加上 WM_Popup 样式,一个已知问题是会在 .NET Framework 4.7.1 以下的运行时,敲黑板,不是 SDK 版本,是用户端安装的运行时版本,也许会存在触摸失效问题,详细请看 dotnet/479874-WPF Touch Stops Working After Prolonged Use of Popups.md at master · Microsoft/dotnet

详细解决方法请参阅 How to force rendering of video tag content while chrome/electron window is not active for screen sharing? - Stack Overflow

关于 WPF 高性能全屏透明窗口请看 WPF 制作高性能的透明背景异形窗口(使用 WindowChrome 而不要使用 AllowsTransparency=True) - walterlvWPF 制作支持点击穿透的高性能的透明背景异形窗口

此问题由 lsj 找到,我只是写博客的工具

posted @ 2022-09-15 19:52  lindexi  阅读(121)  评论(0编辑  收藏  举报