到目前為止,看到的所有動畫都使用線性插值從起點到終點。但如果需要創(chuàng)建具有多個分段的動畫和不規(guī)則移動的動畫。例如,可能希望創(chuàng)建一個動畫,快速地將一個元素滑入到視圖中,然后慢慢地將它移到正確位置??赏ㄟ^創(chuàng)建兩個連續(xù)的動畫,并使用BeginTime屬性在第一個動畫之后開始第二個動畫來實現(xiàn)這種效果。然而,還有更簡單的方法——可使用關鍵幀動畫。
為東麗等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及東麗網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為成都網(wǎng)站建設、網(wǎng)站制作、東麗網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!關鍵幀動畫是由許多較短的段構成的動畫。每段表示動畫中的初始值,最終值或中間值當運行動畫時,它平滑地從一個值移到另一個值。
例如,分析下面的將RadialGradientBrush畫刷的中心點從一個位置移到另一個位置的Point動畫:
<PointAnimation Storyboard.TargetName="ellipse" Storyboard.TargetProperty="Fill.GradientOrigin"
From="0.7,0.3" To="0.3,0.7" Duration="0:0:10" AutoReverse="True" RepeatBehavior="Forever">
</PointAnimation>
可使用一個效果相同的PointAnimationUsingKeyFrames對象代替這個PointAnimation對象,如下所示:
復制代碼
<PointAnimationUsingKeyFrames Storyboard.TargetName="ellipse" Storyboard.TargetProperty="Fill.GradientOrigin" AutoReverse="True" RepeatBehavior="Forever">
<LinearPointKeyFrame Value="0.7,0.3" KeyTime="0:0:0"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.3,0.7" KeyTime="0:0:10"></LinearPointKeyFrame>
</PointAnimationUsingKeyFrames>
復制代碼
這個動畫包含兩個關鍵幀。當動畫首次啟動時第一個關鍵幀設置Point值(如果希望使用在RadialGradientBrush畫刷中設置的當前值,可省略這個關鍵幀)。第二個關鍵幀定義結束值,這是10秒之后達到的數(shù)值。PointAnimationUsingKeyFrames對象執(zhí)行線性插值。從第一個關鍵幀平滑移到第二個關鍵幀,就像PointAnimation對象對From和To值執(zhí)行的操作一樣。
可使用一系列關鍵幀創(chuàng)建更有趣的示例。下面的動畫通過在不同的時刻到達的一系列位置經(jīng)歷中心點。中心點的移動速度根據(jù)關鍵幀之間的持續(xù)時間以及需要移動的距離而改變。
復制代碼
<PointAnimationUsingKeyFrames Storyboard.TargetName="ellipse" Storyboard.TargetProperty="Fill.GradientOrigin"
RepeatBehavior="Forever">
<LinearPointKeyFrame Value="0.7,0.3" KeyTime="0:0:0"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.3,0.7" KeyTime="0:0:5"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.5,0.9" KeyTime="0:0:8"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.9,0.6" KeyTime="0:0:10"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.8,0.2" KeyTime="0:0:12"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.7,0.3" KeyTime="0:0:14"></LinearPointKeyFrame>
</PointAnimationUsingKeyFrames>
復制代碼
這個動畫不是可反轉的,但可以重復。為確保在一次迭代的最后數(shù)據(jù)和下一次迭代的開始數(shù)值之間不會出現(xiàn)跳躍,應使動畫的結束點和開始點位于相同的中心點。
一、離散的關鍵幀動畫
上面示例中的關鍵幀動畫使用線性關鍵幀。所以,它在關鍵幀值之間平滑地過渡,另一種選擇是使用離散的關鍵幀。對于這種情況,不進行插值。當?shù)竭_關鍵時間時,屬性突然改變?yōu)樾轮怠?/p>
線性關鍵幀類使用“Linear+數(shù)據(jù)類型+KeyFrame”的形式進行命名。離散關鍵幀類使用“Discrete+數(shù)據(jù)類型+KeyFrame”的形式命名。下面是RadialGradientBrush畫刷示例的修改版本,在該修改版本中使用的是離散關鍵幀:
復制代碼
<PointAnimationUsingKeyFrames Storyboard.TargetName="ellipse" Storyboard.TargetProperty="Fill.GradientOrigin"
RepeatBehavior="Forever">
<DiscretePointKeyFrame Value="0.7,0.3" KeyTime="0:0:0"></DiscretePointKeyFrame>
<DiscretePointKeyFrame Value="0.3,0.7" KeyTime="0:0:5"></DiscretePointKeyFrame>
<DiscretePointKeyFrame Value="0.5,0.9" KeyTime="0:0:8"></DiscretePointKeyFrame>
<DiscretePointKeyFrame Value="0.9,0.6" KeyTime="0:0:10"></DiscretePointKeyFrame>
<DiscretePointKeyFrame Value="0.8,0.2" KeyTime="0:0:12"></DiscretePointKeyFrame>
<DiscretePointKeyFrame Value="0.7,0.3" KeyTime="0:0:14"></DiscretePointKeyFrame>
</PointAnimationUsingKeyFrames>
復制代碼
當運行這個動畫時,中心點在適當?shù)臅r間從一個位置跳到下一個位置。這是戲劇性的(但是不平穩(wěn)的)效果。
所有關鍵幀動畫類都支持離散關鍵幀,但只有一部分關鍵幀動畫類支持線性關鍵幀。這完全取決于數(shù)據(jù)類型。支持線性關鍵幀的數(shù)據(jù)類型也支持線性插值,并提供了相應的DataTypeAnimation類,如Point、Color以及double。不支持線性插值的數(shù)據(jù)類型包括字符串和對象。
二、緩動關鍵幀
通過“【W(wǎng)PF學習】第五十一章 動畫緩動 ”的學習,看到了如何使用緩動函數(shù)改進普通動畫。盡管關鍵幀動畫被分割成多段,但每段仍使用普遍的、令人厭煩的線性插值。
如果這不是希望的結果,可使用緩動函數(shù)為每個關鍵幀添加加速和減速的效果。然而,普通的線性插值關鍵幀類和離散關鍵幀類不支持該特征。相反,需要使用緩動關鍵幀,如EasingDoubleKeyFrame、EasingColorKeyFrame或EasingPointKeyFrame。每個緩動關鍵幀類和對應的線性插值關鍵幀類的工作方式相同,但是額外提供了EasingFunction屬性。
下面的示例使用動畫緩動為前5秒得關鍵幀動畫應用加速效果:
復制代碼
<PointAnimationUsingKeyFrames Storyboard.TargetName="ellipse" Storyboard.TargetProperty="Fill.GradientOrigin"
RepeatBehavior="Forever">
<LinearPointKeyFrame Value="0.7,0.3" KeyTime="0:0:0"></LinearPointKeyFrame>
<EasingPointKeyFrame Value="0.3,0.7" KeyTime="0:0:5">
<EasingPointKeyFrame.EasingFunction>
<CircleEase></CircleEase>
</EasingPointKeyFrame.EasingFunction>
</EasingPointKeyFrame>
<LinearPointKeyFrame Value="0.5,0.9" KeyTime="0:0:8"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.9,0.6" KeyTime="0:0:10"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.8,0.2" KeyTime="0:0:12"></LinearPointKeyFrame>
<LinearPointKeyFrame Value="0.7,0.3" KeyTime="0:0:14"></LinearPointKeyFrame>
</PointAnimationUsingKeyFrames>
復制代碼
結合使用關鍵幀和動畫緩動是構建復雜動畫模型的簡便方式,但仍可能無法提供所需的控制。不使用動畫緩動,可創(chuàng)建數(shù)學公式指示動畫的進度。
三、樣條關鍵幀動畫
還有一種關鍵幀類型:樣條關鍵幀。每個支持線性關鍵幀的類也支持樣條關鍵幀,它們使用“Spline+數(shù)據(jù)類型+KeyFrame”的形式進行命名。
與線性關鍵幀一樣,樣條關鍵幀使用插值從一個鍵值平滑地移到另一個鍵值。區(qū)別是每個樣條關鍵幀都是KeySpline屬性??墒褂迷搶傩远x能影響插值方式的三次貝塞爾曲線。盡管為了得到希望的效果這樣做有些繁瑣,但這種技術能創(chuàng)建更加連貫的加速和減速以及更逼真的動畫效果。
在前面章節(jié)學習過,貝塞爾曲線由起點、終點以及兩個控制點定義。對于關鍵樣條,起點總是(0,0),終點總是(1,1)。用戶只需要提供兩個控制點。創(chuàng)建的曲線描述了時間(X軸)和動畫值(Y值)之間的關系。
下面的示例通過對比Canvas面板上兩個橢圓的移動,演示了一個關鍵幀樣條動畫。第一個橢圓使用DoubleAnimation動畫緩慢勻速地再窗口上移動。第二個橢圓使用具有兩個SplineDoubleKeyFrame對象的DoubleAnimationUsingKeyFrames動畫。兩個橢圓同時到達目的位置(10秒后),但第二個橢圓在運動過程中會有明顯的加速和減速,減速時會超過第一個橢圓而減速時又會落后于第一個橢圓。
復制代碼
<DoubleAnimationUsingKeyFrames
Storyboard.TargetName="ellipse2" Storyboard.TargetProperty="(Canvas.Left)" >
<SplineDoubleKeyFrame KeyTime="0:0:5" Value="250" KeySpline="0.25,0 0.5,0.7"></SplineDoubleKeyFrame>
<SplineDoubleKeyFrame KeyTime="0:0:10" Value="500" KeySpline="0.25,0.8 0.2,0.4"></SplineDoubleKeyFrame>
</DoubleAnimationUsingKeyFrames>
<DoubleAnimation
Storyboard.TargetName="ellipse1" Storyboard.TargetProperty="(Canvas.Left)"
To="500" Duration="0:0:10">
</DoubleAnimation>
復制代碼
最快的加速發(fā)生在5秒后不久,也就是當進入第二個SplineDoubleKeyFrame關鍵幀時。貝塞爾曲線的第一個控制點將較大的表示動畫進度(0.8)的Y軸值與較小的表示時間的X軸值相匹配。所以,在再次減慢速度前,橢圓在一小段距離內(nèi)會增加速度。
下圖以圖形方式顯示了兩條控制橢圓運動的曲線。為理解這些曲線,請記住它們從頂部到底部描述了動畫過程。觀察第一條曲線可以發(fā)現(xiàn),它相對均勻地下降,在開始處有較短的暫停,在末尾處平緩下降。然而第二條曲線快速下降,運動了一個大段距離,然后對于剩余的動畫部分,曲線緩緩下降。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
本文名稱:關鍵幀動畫的三種類型-創(chuàng)新互聯(lián)
鏈接URL:http://www.rwnh.cn/article42/copehc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、網(wǎng)站改版、建站公司、自適應網(wǎng)站、軟件開發(fā)、Google
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容