WPF實現三星手機充電界面

来源:http://www.cnblogs.com/tsliwei/archive/2016/08/14/5770546.html
-Advertisement-
Play Games

先上效果圖 這個效果來自於三星S5的充電界面,當然有些細節差別,主要看思路.本文目的是技術交流,不要將效果直接運用於商業產品和項目. 電池背景 因為電池內部有好幾個部分,所以本例用了一個Grid來做背景,用Clip屬性剪切出一個電池的輪廓,這樣不僅顯示出一個電池的輪廓,還可以避免水波和氣泡跑顯示Gr ...


先上效果圖

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

 

電池背景

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

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

 

 

表示電量的液體效果

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

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

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

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

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

 

氣泡效果

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

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

氣泡可以分成三個部分:

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

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

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

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

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

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

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

 

畫氣泡

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

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

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

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

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

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

碼字不易,歡迎轉載,但請註明本文鏈接

推薦一個不錯的Blend,Wpf,sl交流群

群號碼:152049269

歡迎大神,萌新踴躍加入,交流探討,共同進步!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 源代碼如下: typedef struct _IMAGE_NT_HEADERS { +00h DWORD Signature; // 固定為 0x00004550 根據小端存儲為:"PE.." +04h IMAGE_FILE_HEADER FileHeader; +18h IMAGE_OPTIONA... ...
  • ...
  • 我們可以為自己訂製個性化的命令行提示符,Linux系統提示符是用系統變數PS1來定義的,只要按規則修改PS1系統變數的值隨意修改命令行提示符。 ...
  • 編程語言,作為人與電腦溝通的橋梁,有著重要和深遠的意義。有過電腦編程經驗的人,多少學習或掌握過一到多種編程語言。電腦專業領域的編程語言成百上千種,主流的編程語言也有數十種之多。每種編程語言面向的領域和特性都不盡相同,不過歸根結底是為瞭解決人與電腦之間溝通的效率問題,提高電腦的生產力。想必有 ...
  • ************************************************************************************************************ 本文是一個學習日記,如果大家有參考發現其中問題的可以與我聯繫。我們一起學習。希望... ...
  • 遍歷文件夾的子文件夾下的所有文件,將上個月的文件集中到一起,然互壓縮,並copy到伺服器的映射磁碟。 static void Main(string[] args) { //原始文件存放的位置 DirectoryInfo theFolder = new DirectoryInfo(@"E:\Test ...
  • 關於測試的必要性什麼的已經在 重構與測試 里扯過了。倒也沒必要說,寫的代碼多了自然就明白這個東西重要性。 當時說了坐等被推動去學習單元測試來著,然而等著被人推動的結果就是根本就沒人來推你。o(∩_∩)o 所以還是自己主動來學,主動來總結了。 可測試性設計基礎理論知識 可測試性設計(Design fo ...
  • 網站配置一般用來保存網站的一些設置,寫在配置文件中比寫在資料庫中要合適一下,因為配置文件本身帶有緩存,隨網站啟動讀入緩存中,速度更快,而保存在資料庫中要單獨為一條記錄創建一個表,結構不夠清晰,而且讀寫也沒有配置文件容易實現。這次要做的是網站的基本信息,數據保存在SiteConfig.config。 ... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...