C#进度轴控件分享

当执行长时间后台处理时,你是否希望软件给你一个反馈,让你了解程序执行进度。进度轴帮你忙,轻松掌握全局动态。你的进度你做主!进度轴分为横版和纵版总有一版适合你!

应用了事件机制假如有更好的方法欢迎交流,假如对您有用请顶一下。

载入时间轴控件

/// <summary>
   /// 载入时间轴控件
   /// 2015-04-16
   /// 吴海龙
   /// </summary>
   public void LoadTimeAxis()
   {
     SortedDictionary<string, string> sdict = new SortedDictionary<string, string>();
     sdict.Add("1", "读取配置");
     sdict.Add("2", "选择模板");
     sdict.Add("3", "确认数据");
     sdict.Add("4", "生成代码");
     uta = new uctlTimeAxis(sdict,1);
     uta.lc = new ToolFunction.uctlTimeAxis.TimeAxisClick(SayHello);
     CommonFunction.AddForm3(splitContainer4.Panel2, uta);
   }

panel容器中添加控件

/// <summary>
    /// 项panel容器中添加控件
    /// </summary>
    /// <param name="p">容器panel</param>
    /// <param name="uc">显示的usercontrol</param>
    public static void AddForm3(Panel p, UserControl uc)
    {
      p.Controls.Clear();
      p.Controls.Add(uc);
      uc.Dock = DockStyle.Fill;

    }

初始化纵版界面

/// <summary>
    /// 初始化垂直进度轴
    /// 2015-04-15
    /// 吴海龙
    /// </summary>
    public void InitVerticalTimeAxis()
    {
      try
      {
        int TempCenterOfThePieY = CenterOfTheCircleY;
        using (Graphics g = this.CreateGraphics())
        {
          g.SmoothingMode = SmoothingMode.HighQuality; //使绘图质量最高,即消除锯齿
          g.InterpolationMode = InterpolationMode.HighQualityBicubic;
          g.CompositingQuality = CompositingQuality.HighQuality;
          g.DrawString("正在执行:", f1, Brushes.Black, new PointF(CenterOfTheCircleX, 5));
          g.DrawLine(p3, new Point(LineStartX, TempCenterOfThePieY), new Point(LineStartX, (sdict.Keys.Count - 1) * CircleSpace + TempCenterOfThePieY));
          foreach (var item in sdict.Keys)
          {
            g.FillEllipse(Brushes.Gray, CenterOfTheCircleX - CircleRadius, TempCenterOfThePieY - CircleRadius, CircleRadius * 2, CircleRadius * 2);
            g.FillEllipse(Brushes.White, CenterOfTheCircleX - PieRadius2, TempCenterOfThePieY - PieRadius2, PieRadius2 * 2, PieRadius2 * 2);
            g.DrawString(sdict[item], f1, Brushes.DarkGray, new PointF(ItemStartX, TempCenterOfThePieY - ItemFixY));
            Label l = new Label();
            l.Name = item;
            l.Location = new Point(ItemStartX,TempCenterOfThePieY - ItemFixY);
            l.Text = sdict[item];
            l.Click +=new EventHandler(l_Click);

            //l.Click += new EventHandler(l_Click2);
            this.Controls.Add(l);
            TempCenterOfThePieY = TempCenterOfThePieY + CircleSpace;
          }
        }
      }
      catch (Exception exp)
      {
        CommonFunction.WriteLog(exp, "绘制失败");
      }
}

纵版进度轴步进方法

/// <summary>
    /// 垂直步进方法
    /// /// 2015-04-16
    /// 吴海龙
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    public void SetVerticalStep(object sender, KeyValueEventArgs e)
    {
      int TempCenterOfThePieY = CenterOfTheCircleY;
      if ("" == KeyValueEventArgs.Key)
      {
        return;
      }
      using (Graphics g = this.CreateGraphics())
      {
        g.SmoothingMode = SmoothingMode.HighQuality; //使绘图质量最高,即消除锯齿
        g.InterpolationMode = InterpolationMode.HighQualityBicubic;
        g.CompositingQuality = CompositingQuality.HighQuality;
        foreach (var item in sdict.Keys)
        {
          g.DrawString(sdict[item], f1, Brushes.Green, ItemStartX, TempCenterOfThePieY - ItemFixY);
          g.DrawEllipse(Pens.Green, CenterOfTheCircleX - CircleRadius, TempCenterOfThePieY - CircleRadius, CircleRadius * 2, CircleRadius * 2);
          g.DrawLine(p2, new Point(LineStartX, LineStartY), new Point(LineStartX, TempCenterOfThePieY));
          g.FillEllipse(Brushes.Green, CenterOfTheCircleX - PieRadius, TempCenterOfThePieY - PieRadius, PieRadius * 2, PieRadius * 2);
          if (item == KeyValueEventArgs.Key)
          {
            break;
          }
          TempCenterOfThePieY = TempCenterOfThePieY + CircleSpace;
        }
      }
}

画图属性字段

/// <summary>
   /// 蓝色宽2
   /// </summary>
   static Pen p1 = new Pen(Color.Blue, 2);
   /// <summary>
   /// 绿色宽3
   /// </summary>
   static Pen p2 = new Pen(Color.Green, 3);
   /// <summary>
   /// 灰色宽1
   /// </summary>
   static Pen p3 = new Pen(Color.Gray, 1);
   /// <summary>
   /// 微软雅黑
   /// </summary>
   static Font f1 = new Font("微软雅黑", 9, FontStyle.Regular);
   /// <summary>
   /// 圆心X坐标
   /// </summary>
   public static int CenterOfTheCircleX = 31;
   /// <summary>
   /// 圆心Y坐标
   /// </summary>
   public static int CenterOfTheCircleY = 46;
   /// <summary>
   /// 说明条目X坐标
   /// </summary>
   public static int ItemStartX = 45;
   /// <summary>
   /// 条目X修正量
   /// </summary>
   public static int ItemFixX = -20;
   /// <summary>
   /// 条目Y修正量
   /// </summary>
   public static int ItemFixY = 10;
   public static Point CenterOfThePie = new Point(CenterOfTheCircleX, CenterOfTheCircleY);
   /// <summary>
   /// 命中Pie半径
   /// </summary>
   public static int PieRadius = 6;
   /// <summary>
   /// 白点Pie半径
   /// </summary>
   public static int PieRadius2 = 8;
   /// <summary>
   /// 圆半径
   /// </summary>
   public static int CircleRadius = 9;
   /// <summary>
   /// 圆心距
   /// </summary>
   public static int CircleSpace = 80;
   /// <summary>
   /// 轴X起点
   /// </summary>
   public static int LineStartX = CenterOfTheCircleX;
   /// <summary>
   /// 轴Y起点
   /// </summary>
   public static int LineStartY = CenterOfTheCircleY;
   /// <summary>
   /// 内部Key定义
   /// </summary>
   public static string Key = "";
   /// <summary>
   /// 绘图事件
   /// </summary>
   public event EventHandler<KeyValueEventArgs> KeyValueChangeEventHandler;

   public delegate void LabelClickEventHandler(object sender, LabelClickEventArgs e);

   //public event LabelClickEventHandler<LabelClickEventArgs> ;

   public delegate void TimeAxisClick();

   public TimeAxisClick lc = null;

   public delegate void TimeAxisClick2(string labelName);

   public TimeAxisClick2 lc2 = null;
   /// <summary>
   /// 流程字典
   /// </summary>
   public static SortedDictionary<string, string> sdict = new SortedDictionary<string, string>();
   /// <summary>
   /// 水平标示
   /// </summary>
   private static readonly int HorizontalTimeAxis = 0;
   /// <summary>
   /// 垂直标志
   /// </summary>
   private static readonly int VerticalTimeAxis = 1;

   /// <summary>
   /// 绘制标志,0为水平;1为垂直。
   /// </summary>
   public static int TimeAxisModle = 0;

构造方法

#region 构造方法
    public uctlTimeAxis()
    {
      InitializeComponent();
    }

    public uctlTimeAxis(SortedDictionary<string, string> s)
    {
      InitializeComponent();
      if (sdict != null)
      {
        sdict = s;
      }
    }

    public uctlTimeAxis(SortedDictionary<string, string> s, int model)
    {
      InitializeComponent();
      if (sdict != null)
      {
        sdict = s;
        TimeAxisModle = model;
        if (HorizontalTimeAxis==TimeAxisModle)
        {
          KeyValueChangeEventHandler += new EventHandler<KeyValueEventArgs>(SetHorizontalStep);
        }
        else if (VerticalTimeAxis==TimeAxisModle)
        {
          KeyValueChangeEventHandler += new EventHandler<KeyValueEventArgs>(SetVerticalStep);
        }
      }
    }
#endregion

Key值转变

/// <summary>
   /// Key值转变
   /// </summary>
   public class KeyValueEventArgs : EventArgs
   {
     public static string Key = "";

     public KeyValueEventArgs(string s)
     {
       Key = s;
     }
   }

以上所述就是本文的全部内容了,希望大家能够喜欢。

(0)

相关推荐

  • Jquery Uploadify上传带进度条的简单实例

    复制代码 代码如下: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="UpLoad.aspx.cs" Inherits="UploadifyDemo_UpLoad" %> <html xmlns="http://www.w3.org/1999/xhtml"><head id="Head1" ru

  • C# cmd中修改显示(显示进度变化效果)的方法

    复制代码 代码如下: public void PrintPercentage(int FinishedCount, int TotalCount)  {         decimal finishedPercentage = Convert.ToDecimal(FinishedCount) / Convert.ToDecimal(TotalCount);         Console.SetCursorPosition(0, Console.CursorTop - 1);         C

  • C#控制台输出进度和百分比的实例代码

    复制代码 代码如下: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ConsoleApplication1 {     class Program     {         static void Main(string[] args)         {             bool isBreak = false;             C

  • Android文件下载进度条的实现代码

    main.xml: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:orientation="vertical"    android:layout_width="fill_paren

  • C#中常使用进度条的代码

    复制代码 代码如下: using System; using System.Drawing; using System.Collections; using System.ComponentModel; using System.Windows.Forms; using System.Data; using System.Diagnostics; using System.Threading; namespace WindowsApplication2 { /// <summary> /// 

  • c#根据文件大小显示文件复制进度条实例

    初学者,照着书上的抄袭制作,但已经理解了里面的意思和应用,并且进行了稍微改善和异常捕捉.这里记录下,以防以后用到这方面的知识点. 窗体设计: code: 复制代码 代码如下: using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.

  • android自定义进度条渐变色View的实例代码

    最近在公司,项目不是很忙了,偶尔看见一个兄台在CSDN求助,帮忙要一个自定义的渐变色进度条,我当时看了一下进度条,感觉挺漂亮的,就尝试的去自定义view实现了一个,废话不说,先上图吧! 这个自定义的view,完全脱离了android自带的ProgressView,并且没使用一张图片,这样就能更好的降低程序代码上的耦合性! 下面我贴出代码  ,大概讲解一下实现思路吧! 复制代码 代码如下: package com.spring.progressview; import android.conten

  • Android中实现Webview顶部带进度条的方法

    写这篇文章,做份备忘,简单滴展示一个带进度条的Webview示例,进度条位于Webview上面. 示例图如下: 主Activity代码: 复制代码 代码如下: package com.droidyue.demo.webviewprogressbar; import android.app.Activity; import android.os.Bundle; import android.view.Menu; import android.view.View; import android.vi

  • python下载文件时显示下载进度的方法

    本文实例讲述了python下载文件时显示下载进度的方法.分享给大家供大家参考.具体分析如下: 将这段代码放入你的脚本中,类似:urllib.urlretrieve(getFile, saveFile, reporthook=report) 第三个参数如下面的函数定义report,urlretrieve下载文件时会实时回调report函数,显示下载进度 def report(count, blockSize, totalSize): percent = int(count*blockSize*10

  • asp.net(c#)开发中的文件上传组件uploadify的使用方法(带进度条)

    在Web开发中,有很多可以上传的组件模块,利用HTML的File控件的上传也是一种办法,不过这种方式,需要处理的细节比较多,而且只能支持单文件的操作.在目前Web开发中用的比较多的,可能uploadify(参考http://www.uploadify.com/)也算一个吧,不过这个版本一直在变化,他们的脚本调用也有很大的不同,甚至调用及参数都一直在变化,很早的时候,那个Flash的按钮文字还没法变化,本篇随笔主要根据项目实际,介绍一下3.1版本的uploadify的控件使用,这版本目前还是最新的

  • C# Winform下载文件并显示进度条的实现代码

    方法一: 效果如下图所示: 代码如下: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace WinShowDown { public partial class F

  • 基于jQuery实现网页进度显示插件

    相信大家都见过类似的网站功能,这种形式的进度显示可以很方便的让用户去理解和操作, 以下是插件的测试截图 ,提供了两个皮肤 使用js编写 可以灵活的生成进度条 方便进对一些工作进度进行图形显示 1.简单的调用 //所有步骤的数据 var stepListJson=[{StepNum:1,StepText:"第一步"}, {StepNum:2,StepText:"第二步"}, {StepNum:3,StepText:"第三步"}, {StepNum:

  • 6款新颖的jQuery和CSS3进度条插件推荐

    现在的网页功能越来越多,尤其是AJAX的广泛应用,进度条和Loading加载动画显得越来越重要了.下面给大家介绍几款比较新颖的jQuery和CSS3进度条Loading加载动画插件,希望对大家有帮助. 1.不同进度显示不同颜色的进度条 这款CSS3进度条和别的有所不同,他的主要特点是随着进度的变化,进度条的颜色会有所改变,这个和游戏中人物的生命值很相似. 2.纯CSS3实现的彩色进度条 该进度条利用了CSS3的颜色渐变属性,让进度条的色彩显得非常具有立体感. 3.jQuery Progress

  • php上传文件并显示上传进度的方法

    本文实例讲述了php上传文件并显示上传进度的方法.分享给大家供大家参考.具体如下: 记得上传文件的时候要大点,不然还没看出来就上传完了,并且上传的文件不要太大,上G的就算了,2G的我试了,PHP受不了,我测试的是300多M的,记得要调整小php.ini参数啊 "选文件=>提交=>获取信息"要一气呵成哦^ ^ <?php $prefix = ini_get('session.upload_progress.prefix'); $name = ini_get('sessi

  • c#进度条 progressBar 使用方法的小例子

    复制代码 代码如下: using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Text;using System.Windows.Forms;using Mes.Core; namespace HCMDoImport{    public partial class ProcessBarForm : B

随机推荐