国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

WPF仿三星手機充電界面實現代碼

2019-10-29 21:22:28
字體:
來源:轉載
供稿:網友

先上效果圖

WPF手機充電界面,WPF手機充電,WPF充電界面

這個效果來自于三星S5的充電界面,當然有些細節差別,主要看思路.本文目的是技術交流,不要將效果直接運用于商業產品和項目.

電池背景

因為電池內部有好幾個部分,所以本例用了一個Grid來做背景,用Clip屬性剪切出一個電池的輪廓,這樣不僅顯示出一個電池的輪廓,還可以避免水波和氣泡跑顯示Grid的外面.

Clip的內部,是一個Path形狀.具體畫法就不多說了,以前寫過.有興趣的同學看這里:http://www.cnblogs.com/tsliwei/p/5609035.html

WPF手機充電界面,WPF手機充電,WPF充電界面

表示電量的液體效果

整個液體分兩部分,上面是波浪,下面是矩形.進度值實際控制的是矩形的高度.兩個控件放到StackPanel中,讓下面的矩形往上頂.最后給波浪底部Margin值為-1,使其看起來沒有間隙.

WPF手機充電界面,WPF手機充電,WPF充電界面

波浪是用貝塞爾曲線實現的,首先介紹下貝塞爾曲線

WPF手機充電界面,WPF手機充電,WPF充電界面

貝塞爾曲線有4個點,起點終點和兩個控制點.(此括號里的可以不看:上圖畫的并不準確,因為控制點并不一定在曲線上).通過兩個控制點決定曲線的路徑.

顯然上圖這本身就是個波浪形.使用點動畫PointAnimation控制兩個點上下運動就有了波浪的動態效果.注意兩個動畫時間不要一樣,否則看起來動畫太假.兩個時間錯開一點點就好了.

WPF手機充電界面,WPF手機充電,WPF充電界面

波浪部分寬度是50,高度是5

WPF手機充電界面,WPF手機充電,WPF充電界面

氣泡效果

這里的氣泡效果就是個典型的粒子效果,而且是最簡單的那種,并不涉及到什么復雜的公式計算.

簡單介紹下原理:這里的氣泡可以看成是圓按照一定的速度不斷的上升(改變Y軸坐標).所以規定一個速率,規定一個距離,使用幀動畫CompositionTarget.Rendering,在每一幀都在Y軸上加這個速率在一幀移動的距離.然后判斷又沒達到規定的距離.如果達到,移除這個圓圈,否則繼續上升.

氣泡可以分成三個部分:

1.電池內部的氣泡.大小適中,移動速度最慢,移動距離最短.

2.屏幕底部的大氣泡,個頭比較大,移動速度較慢,移動距離較短.

3.屏幕底部的小氣泡,個頭最小,移動速度較快,移動距離較遠.

新建一個Class,用來表示氣泡信息

WPF手機充電界面,WPF手機充電,WPF充電界面

其中兩個重要屬性,一個是速率,一個是氣泡需要移動的距離.這兩個屬性決定了氣泡的運動軌跡.第三個屬性是用來判斷氣泡是不是完成了使命,第四個屬性是添加一個對氣泡的引用,這樣方便在后臺控制氣泡.

定義三個集合,用來存放三部分的氣泡信息.

在幀渲染事件內,遍歷三個集合.讓集合里的每個氣泡都向上移動(Canvas.SetTop),判斷氣泡是不是已經移動了指定的距離,是的話就在頁面移除氣泡,集合也移除該氣泡信息.判斷集合的Count是不是小于規定個個數,如果小于,就向頁面添加氣泡,集合添加氣泡信息.

畫氣泡

為了美觀,我自己畫了個氣泡的模型,用在了大氣泡上.小氣泡直接用的橢圓,因為即使用模型,因為太小,也看不出來.實際上大氣泡也不怎么看得出來.不過既然寫了,還是介紹下吧.畫的并不是很好看.還請見諒.

WPF手機充電界面,WPF手機充電,WPF充電界面

首先這個氣泡就是個ViewBox.方便縮放.

輪廓是個正圓,Fill給了個漸變畫刷,向外不斷加深,在最外圈0.85-1的部分是最深的.三個點的R都是20,B都是10,綠色部分G依次減小,分別是240,150,100.

WPF手機充電界面,WPF手機充電,WPF充電界面

右下邊的月牙是個Path,給了個半徑是10的模糊效果.Fill是半透明的白色.月牙的畫法就是兩個弧線,起點和終點相同,半徑不同.

WPF手機充電界面,WPF手機充電,WPF充電界面

左上角的亮點就是兩個橢圓,和月牙一樣.半徑是10的模糊效果.Fill是半透明的白色.

源碼下載:三星手機電池充電效果.rar

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 镶黄旗| 临高县| 建始县| 浙江省| 株洲县| 双鸭山市| 建瓯市| 民勤县| 焦作市| 团风县| 晴隆县| 阳泉市| 兰州市| 江北区| 紫金县| 蚌埠市| 乌海市| 八宿县| 诸暨市| 葵青区| 海盐县| 石柱| 静安区| 和平县| 天峻县| 七台河市| 新昌县| 常山县| 吉水县| 长顺县| 金塔县| 株洲县| 洮南市| 都兰县| 巴南区| 汽车| 荥经县| 萝北县| 廉江市| 稻城县| 澄迈县|