<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        仿vs實現WPF好看的進度條

        來源:懂視網 責編:小采 時間:2020-11-27 22:38:30
        文檔

        仿vs實現WPF好看的進度條

        仿vs實現WPF好看的進度條:為了界面友好,一般的操作時間較長時,都需要增加進度條提示。由于WPF自帶的進度條其實不怎么好看,而且沒啥視覺效果。后來,裝VS2012時,發現安裝過程中進度條效果不錯,于是上網查了資料。學習了ModernUI(開源的),地址:https://github.com/
        推薦度:
        導讀仿vs實現WPF好看的進度條:為了界面友好,一般的操作時間較長時,都需要增加進度條提示。由于WPF自帶的進度條其實不怎么好看,而且沒啥視覺效果。后來,裝VS2012時,發現安裝過程中進度條效果不錯,于是上網查了資料。學習了ModernUI(開源的),地址:https://github.com/

        為了界面友好,一般的操作時間較長時,都需要增加進度條提示。由于WPF自帶的進度條其實不怎么好看,而且沒啥視覺效果。后來,裝VS2012時,發現安裝過程中進度條效果不錯,于是上網查了資料。學習了ModernUI(開源的),地址:https://github.com/firstfloorsoftware/mui。

          后來,做了嘗試寫了個Demo,效果不錯。另外,專門錄制了tif文件,方便大家看到效果。廢話不多說,先展示效果:

        一、效果展示

          A、VS2012安裝界面圖;

          B、個人嘗試Demo效果圖: 

        二、實現說明

          1、下載MUI相關代碼或者dll文件;

          2、工程中引入該dll,并引入其資源文件;

        代碼如下:
        <Application.Resources>
                <ResourceDictionary>
                    <ResourceDictionary.MergedDictionaries>
                        <ResourceDictionary Source="/FirstFloor.ModernUI;component/Assets/ModernUI.xaml" />
                        <ResourceDictionary Source="/FirstFloor.ModernUI;component/Assets/ModernUI.Light.xaml"/>
                    </ResourceDictionary.MergedDictionaries>
                </ResourceDictionary>
            </Application.Resources>

          3、在需要顯示進度條的頁面,加入控件(其實還是WPF控件,只是MUI擴展了其樣式而已);

        代碼如下:
        <Label Margin="280,169,0,0" Style="{StaticResource BackGroundContentText}" x:Name="lblMainState" HorizontalAlignment="Left" VerticalAlignment="Top">正在啟動:</Label>
                <ProgressBar Margin="280,200,0,0" HorizontalAlignment="Left" VerticalAlignment="Top" Width="500" Minimum="0" x:Name="ProgressControlRealValue" Maximum="1"  Value="0.1" Height="16" IsIndeterminate="False"/>
                <Label Margin="280,212,0,0" Style="{StaticResource BackGroundContentText}" x:Name="lblProcess" HorizontalAlignment="Left" VerticalAlignment="Top">正在加載地圖數據...</Label>
                <ProgressBar Margin="280,250,0,0" HorizontalAlignment="Left" VerticalAlignment="Top"  Minimum="0" x:Name="ProgressControl"  Width="500" Maximum="2" Height="16" IsIndeterminate="True" />

          4、后臺實現,由于要根據情況更新進度文字及進度條的值。所以,這里用到了異步BackgroundWorker(具體可以網上查查相關資料);

        using System;
        using System.Collections.Generic;
        using System.Linq;
        using System.Text;
        using System.ComponentModel;
        
        namespace Monitor.Class
        {
         /// <summary>
         /// 異步操作
         /// </summary>
         public class CWorker
         {
         /// <summary>
         /// 對象
         /// </summary>
         private BackgroundWorker backgroundWorker;
        
         /// <summary>
         /// 后臺執行的操作
         /// </summary>
         public Action BackgroundWork { get; set; }
        
         /// <summary>
         /// 后臺任務執行完畢后事件
         /// </summary>
         public event EventHandler<BackgroundWorkerEventArgs> BackgroundWorkerCompleted;
        
         private BackgroundWorkerEventArgs _eventArgs;//異常參數
        
         /// <summary>
         /// 構造
         /// </summary>
         public CWorker()
         {
         _eventArgs = new BackgroundWorkerEventArgs();
         backgroundWorker = new BackgroundWorker();
         backgroundWorker.WorkerReportsProgress = true;
         backgroundWorker.WorkerSupportsCancellation = true;
         backgroundWorker.DoWork += new DoWorkEventHandler(backgroundWorker1_DoWork);
         backgroundWorker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(backgroundWorker1_RunWorkerCompleted);
         }
        
         /// <summary>
         /// 開始工作
         /// </summary>
         public void BegionWork()
         {
         if (backgroundWorker.IsBusy)
         return;
         backgroundWorker.RunWorkerAsync();
         }
        
         /// <summary>
         /// 工作
         /// </summary>
         /// <param name="sender"></param>
         /// <param name="e"></param>
         private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
         {
         if (BackgroundWork != null)
         {
         try
         {
         BackgroundWork();
         }
         catch (Exception ex)
         {
         _eventArgs.BackGroundException = ex;
         }
         }
         }
        
         /// <summary>
         /// 完成
         /// </summary>
         /// <param name="sender"></param>
         /// <param name="e"></param>
         private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
         {
         if (this.BackgroundWorkerCompleted != null)
         {
         this.BackgroundWorkerCompleted(null, _eventArgs);
         }
         }
         }
        
         /// <summary>
         /// 事件
         /// </summary>
         public class BackgroundWorkerEventArgs : EventArgs
         {
         /// <summary>
         /// 后臺程序運行時拋出的異常
         /// </summary>
         public Exception BackGroundException { get; set; }
         }
        }
        
        
        namespace Monitor
        {
         /// <summary>
         /// Splash.xaml 的交互邏輯
         /// </summary>
         public partial class Splash : Window
         {
         MainWindow m_MainWindow = null;//主窗口
         CWorker m_Work = null;//任務
        
         public Splash()
         {
         InitializeComponent();
         m_MainWindow = new MainWindow();//創建主窗口對象
         m_Work = new CWorker();
         m_Work.BackgroundWork = this.ProcessDo;
         m_Work.BackgroundWorkerCompleted += new EventHandler<BackgroundWorkerEventArgs>(m_Work_BackgroundWorkerCompleted);
         }
        
         /// <summary>
         /// 進度提示
         /// </summary>
         public void ProcessDo()
         {
         m_MainWindow.InitData(this);
         }
        
         /// <summary>
         /// 移動
         /// </summary>
         /// <param name="sender"></param>
         /// <param name="e"></param>
         private void Grid_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
         {
         this.DragMove();
         }
        
         /// <summary>
         /// 窗口加載
         /// </summary>
         /// <param name="sender"></param>
         /// <param name="e"></param>
         private void Window_Loaded(object sender, RoutedEventArgs e)
         {
         m_Work.BegionWork();
         }
        
         /// <summary>
         /// 執行完成
         /// </summary>
         /// <param name="sender"></param>
         /// <param name="e"></param>
         void m_Work_BackgroundWorkerCompleted(object sender, BackgroundWorkerEventArgs e)
         {
         m_MainWindow.Show();
         this.Close();
         }
        
         /// <summary>
         /// 賦值
         /// </summary>
         /// <param name="text"></param>
         private delegate void SetProcessLabelDelegate(string text, double processValue);
         public void SetProcessValue(string text, double processValue)
         {
         if (!Dispatcher.CheckAccess())
         {
         Dispatcher.Invoke(DispatcherPriority.Send, new SetProcessLabelDelegate(SetProcessValue), text, processValue);
         return;
         }
         this.lblProcess.Content = text;
         this.ProgressControlRealValue.Value = processValue;
         }
         }
        }
        

        以上所述就是本文的全部內容了,希望大家能夠喜歡。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        仿vs實現WPF好看的進度條

        仿vs實現WPF好看的進度條:為了界面友好,一般的操作時間較長時,都需要增加進度條提示。由于WPF自帶的進度條其實不怎么好看,而且沒啥視覺效果。后來,裝VS2012時,發現安裝過程中進度條效果不錯,于是上網查了資料。學習了ModernUI(開源的),地址:https://github.com/
        推薦度:
        標簽: vs WPF 的進度條
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 日韩成人免费aa在线看| 吃奶摸下高潮60分钟免费视频| 222www在线观看免费| 青草草在线视频永久免费| 伊人久久大香线蕉亚洲五月天| 亚洲国产成人va在线观看网址| 日韩久久无码免费毛片软件| av大片在线无码免费| 亚洲人成网亚洲欧洲无码久久 | 免费中文字幕在线观看| 国产综合成人亚洲区| 国产精品视频免费观看| 亚洲理论精品午夜电影| 久久免费美女视频| 日韩精品电影一区亚洲| 亚洲成人黄色网址| 日韩精品免费视频| 亚洲精品久久久www| 亚洲AV噜噜一区二区三区| 69天堂人成无码麻豆免费视频| 亚洲午夜精品国产电影在线观看| 18禁成年无码免费网站无遮挡| 精品日韩亚洲AV无码 | 亚洲AV人无码综合在线观看| 黄网站色成年片大免费高清| 成年大片免费视频| 91亚洲自偷在线观看国产馆| 黄网址在线永久免费观看| 一区二区视频免费观看| 国产老女人精品免费视频| 亚洲天堂男人影院| 美女裸身网站免费看免费网站| 久久久久亚洲av无码专区| 999国内精品永久免费视频| 精品无码专区亚洲| 国产成人啪精品视频免费网| 中文字幕视频在线免费观看| 久久亚洲AV无码西西人体| 一级女性全黄生活片免费看| 亚洲天天在线日亚洲洲精| 久久一本岛在免费线观看2020|