8K分辨率下,使用WPF播放视频造成UI卡顿的问题

我们知道,WPF有两大特性:1、使用DirectX渲染;2、分辨率无关性:WPF使用与设备分辨率无关的单位来度量计算显示界面的像素点,相同大小的情况下,分辨率越高,像素点就会越多。因此在WPF中,使用矢量图(会根据WPF进行缩放,清晰度不变)比位图(固定像素点,缩放会出现锯齿,并且占用空间大)更合适。

在WPF问世之前,传统的Windows应用程序都依靠如下两部分来创建用户界面:

User32:该部分为许多元素(如窗口、按钮和文本框等)提供了熟悉的Windows外观。

GDI/GDI+:该部分为渲染简单形状、文本以及图像提供了绘图支持,但增加了复杂程度(而且通常性能较差)。

后针对User32和GDI/GDI+的限制发行了 DirectX 技术,起初用于开发游戏,注重速度,由显卡支持,可以实现复杂的纹理映射、特殊效果(如半透明)以及三位图形所需的硬件加速功能。

WPF应用程序在底层都是使用DirectX,因此具有两大优势:①可使用丰富的效果;②显卡硬件加速。

但是WPF默认是使用硬件加速的,所以如果在8K屏下,显卡的性能不如意,会出现WPF应用卡顿的问题:

1、例如在WPF应用在8K屏播放视频,不管是使用MediaElement(实际上是对MediaPlayer的封装,因为增加了重业务,所以相对于MediaPlayer,性能方面会差一些)还是MediaPlayer的方式,都会出现卡顿的效果。

  1)该问题尝试对视频的格式进行处理(包括帧率,码率,视频编码,关闭GPU加速等),仍然没办法解决卡顿的问题。

  2)通过对启动的exe->右键属性->兼容性->更改高的DPI设置->勾选替代高DPI缩放行为->选择应用程序(该造成的作用在于:避免应用程序在使用不同显示分辨率的监视器之间移动造成的影响),仍然没办法解决卡顿的问题。

2、如果显卡偶现异常情况,可能会造成视频的画面为黑色,音频仍然可以播放的情况。

针对上面的情况,目前找到比较好的办法是:禁用硬件加速

不要在app.xaml.cs的OnStartup中添加

应该在需要禁用的页面禁用,离开该页面再启用硬件加速,不然可能会出现一些高渲染的控件出现卡顿效果。

RenderOptions.ProcessRenderMode = System.Windows.Interop.RenderMode.SoftwareOnly;

禁用硬件加速后,MediaElement在Stop后不再卡顿,但是视频在播放的时候,仍然会存在卡顿的情况。

把AllowsTransparency设置为False,能起到一点卡顿优化的作用

如果设计到窗体圆角功能,AllowsTransparency设置为False之后圆角会出现一个黑色的尖角,可以使用WindowChrome去除,在Window窗体下添加

<WindowChrome.WindowChrome>
  <WindowChrome GlassFrameThickness="8"
          UseAeroCaptionButtons="False"
          NonClientFrameEdges="None"
          CornerRadius="8"
          ResizeBorderThickness="0">
  </WindowChrome>
</WindowChrome.WindowChrome>

 

posted @ 2022-07-25 13:41  log9527  阅读(1389)  评论(2编辑  收藏  举报