主頁 > .NET開發 > 【WPF學習】第五十二章 影片性能

【WPF學習】第五十二章 影片性能

2020-09-10 18:02:33 .NET開發

  通常,為用戶界面應用影片只不過是創建并配置正確的影片和故事板物件,但在其他情況下,特別是同時發生多個影片時,可能需要更加關注性能,特定的效果更可能導致這些問題——例如,那些涉及視頻、大位圖以及多層透明等的效果通常需要占用更多CPU開銷,如果不謹慎實作這類效果,運行它們使可能造成明顯抖動,或者會從其他同時運行的應用程式搶占CPU時間,

  幸運的是,WPF提供了幾個可提供幫助的技巧,接下來的幾節將學習降低最大幀率以及快取計算機顯卡中的位圖,這兩種技術可以減輕CPU的負擔,

一、期望的幀率

  正如前面所學習的,WPF試圖保持以60幀/秒的速度運動影片,這樣可確保從開始到結束得到平滑流暢的影片,當然,WPF可能達不到這個目標,如果同時運行多個復雜的影片,并且CPU或顯卡不能承受的話,整個幀率可能會下降(最好的情形),甚至可能會跳躍以進行補償(最壞的情形),

  盡管很少提高幀率,但可能會選擇降低幀率,這可能是因為以下兩個原因之一:

  •   影片使用更低的幀率看起來也很好,所以不希望浪費額外的CPU周期,
  •   應用程式運行在性能較差的CPU或顯卡上,并知道使用高的幀率時整個影片的渲染效果還不如使用更低的幀率的渲染效果好,

  調整幀率很容易,只需要為包含影片的故事板使用Timeline.DesiredFrameRate附加屬性,下面的示例將幀率減半:

<Storyboard Timeline.DesiredFrameRate="30">

  下圖顯示了一個簡單的測驗程式,該程式為一個小球應用影片,使其在Canvas控制元件上沿一條曲線運動,

  這個應用程式開始在Canvas上繪制Ellipse物件,Canvas.ClipToBounds屬性被設定為true,所以圓的邊緣不會超出Canvas控制元件的邊緣而進入視窗的其他部分,

<Canvas ClipToBounds="True">
     <Ellipse Name="ellipse" Fill="Red" Width="10" Height="10"></Ellipse>
</Canvas>

  為在Canvas控制元件上移動圓,需要同時進行兩個影片——一個影片用于更新Canva.Left屬性(從左向右移動圓),另一個影片用于改變Canvas.Top屬性(使圓上升,然后下降),Canvas.Top影片是可反轉的——一旦圓達到最高點,就會下降,Canvas.Left影片不是可反轉的,但持續時間是Canvas.Top影片的兩倍,從而使得這兩個影片可以同時移動圓,最后的技巧是為Canvas.Top影片使用DeceleartionRatio屬性,這樣,當圓達到最高點是上升的速度會更慢,這會創建更逼真的效果,

  下面是影片的完整標記:

<Window.Resources>
        <BeginStoryboard x:Key="beginStoryboard">
            <Storyboard Timeline.DesiredFrameRate="{Binding ElementName=txtFrameRate,Path=Text}">
                <DoubleAnimation Storyboard.TargetName="ellipse" Storyboard.TargetProperty="(Canvas.Left)"
                         From="0" To="300" Duration="0:0:5">
                </DoubleAnimation>
                <DoubleAnimation Storyboard.TargetName="ellipse" Storyboard.TargetProperty="(Canvas.Top)"
                         From="300" To="0" AutoReverse="True" Duration="0:0:2.5"
                         DecelerationRatio="1">
                </DoubleAnimation>
            </Storyboard>
        </BeginStoryboard>
    </Window.Resources>

 這個示例的真正目的是嘗試不同的幀率,為查看某個特定幀率的效果,只需要在文本框中輸入合適的數值,然后單擊Repeat按鈕即可,然后影片就會使用新的幀率(通過資料系結運算式獲取新的幀率)觸發,從而可以觀察影片的效果,在更低的幀率下,橢圓不會均勻移動——而會在Cavans控制元件中的跳躍,

  也可使用代碼調整Timeline.DesiredFrame屬性,例如,可能希望讀取靜態屬性RenderCapability.Tier以確定顯卡支持的渲染級別,

二、位圖快取

  位圖快取通知WPF獲取內容的當前位圖影像,并將其復制到顯卡的記憶體中,這時,顯卡可以控制位圖的操作和顯示的重繪,這個處理程序比讓WPF完成所有作業要快很多,并且和顯卡不斷通信,

  如果運用得當,位圖快取可以改善應用程式的繪圖性能,但如果運用不當,就會浪費顯存并且實際上會降低性能,所以,在使用位圖快取之前,需要確保真正合適,下面列出一些指導原則:

  •   如果正在繪制的內容需要頻繁地重新繪制,使用位圖快取可能是合理的,因為每次后續的重新繪制將更快,一個例子是當其他一些具有影片的物件浮動在形狀表面上時,使用BitmapCacheBrush畫刷繪制形狀的表面,盡管形狀沒有變化,但是形狀的不同部分被遮擋住或顯露出來,從而需要重新繪制,
  •   如果元素的內容經常變化,使用位圖快取可能不合理,因為可視化內容每次改變時,WPF需要重新渲染位圖將其發送到顯卡快取,而這需要耗費時間,該規則有些晦澀,因為某些改變不會導致快取無效,安全操作的例子包括使用變換旋轉以及重新縮放元素、剪裁元素、改變元素的透明度以及應用效果,另一方面,改變元素的內容、布局以及各式將強制重新渲染位圖,
  •   盡量少快取內容,位圖越大,WPF存盤快取副本所需的時間越長,需要的顯存越多,一旦耗盡顯存,WPF將被迫使用更慢的軟體渲染,

  為更好地理解位圖快取,使用一個簡單示例是有幫助的,下圖例舉一個示例,一個影片推動一個簡單的影像——正方形——在Canvas面板上移動,Canvas面板包含一條具有復雜集合圖形的路徑,但正方形在Canvas面板表面上移動時,強制WPF重新計算路徑并填充丟失的部分,這會帶來極大的CPU負擔,并且影片甚至可能開始變得斷斷續續,

 

   可采用幾種方法解決該問題,一種選擇是使用一幅位圖替換背景,WPF能夠更高效地管理位圖,更靈活的選擇是使用位圖快取,這種方法可繼續將存活的、可互動的元素作為背景,

  為啟用位圖快取功能,將相應元素的CacheMode屬性設定為BitmapCache,每個元素都提供了CacheMode屬性,這意味著可以精確選擇為哪個元素使用這一特征,

<Path CacheMode="BitmapCache" ...></Path>

  通過這個簡單修改,可立即看到區別,首先,視窗顯示的事件要稍長一些,但影片的運行將更平滑,并且CPU的負擔將顯著降低,可通過Windows任務管理器進行檢查——經常可以看到CPU的負擔從接近100%減少到20%一下,

  通常,當啟用位圖快取時,WPF采用元素當前尺寸的快照并將其位圖復制到顯卡中,如果之后使用ScaleTransform放大元素,這會變成一個問題,在這種情況下,將放大快取的位圖,而不是實際的元素,當放大元素時這會導致模糊放大以及色塊,

  例如,設想一個修訂過的示例,在這個示例中,第二個同步影片擴展Path使其為原始尺寸的10倍,然后碩訓原始尺寸,為確保具有良好的顯示質量,可使用5倍于Path原始尺寸的尺寸快取其位圖:

<Path ...>
    <Path.CacheMode>
        <BitmapCache RenderAtScale="5"></BitmapCache>
    </Path.CacheMode>
</Path>

  這樣可解決像素化問題,雖然快取的位圖仍比Path的最大影片尺寸(最大尺寸達10倍于其原始尺寸)小,但顯卡能使位圖的尺寸加倍,從5倍到10倍,而不會有任何明顯的縮放問題,更重要的是,這可使應用避免過多地使用顯存,

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/2973.html

標籤:WPF

上一篇:【WPF學習】第五十一章 影片緩動

下一篇:【WPF學習】第五十三章 影片型別回顧

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • C#多執行緒學習(二) 如何操縱一個執行緒

    <a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...

    uj5u.com 2023-04-19 09:17:20 more
  • C#多執行緒學習(二) 如何操縱一個執行緒

    C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......

    uj5u.com 2023-04-19 09:16:49 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    <a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...

    uj5u.com 2023-04-18 08:39:04 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......

    uj5u.com 2023-04-18 08:33:10 more
  • SignalR, No Connection with that ID,IIS

    <a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...

    uj5u.com 2023-03-30 17:21:52 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:15:33 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:13:31 more
  • C#遍歷指定檔案夾中所有檔案的3種方法

    <a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...

    uj5u.com 2023-03-27 14:46:55 more
  • C#/VB.NET:如何將PDF轉為PDF/A

    <a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...

    uj5u.com 2023-03-27 14:46:35 more
  • 武裝你的WEBAPI-OData聚合查詢

    <a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...

    uj5u.com 2023-03-27 14:46:16 more