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

无论是使用 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 找到,我只是写博客的工具