C#进度轴控件分享
更新时间:2015年06月04日 15:58:24 投稿:hebedich
这里给大家介绍的是使用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; } }
以上所述就是本文的全部内容了,希望大家能够喜欢。
您可能感兴趣的文章:
- C#中常使用进度条的代码
- asp.net(c#)开发中的文件上传组件uploadify的使用方法(带进度条)
- Android文件下载进度条的实现代码
- 6款新颖的jQuery和CSS3进度条插件推荐
- C#控制台输出进度和百分比的实例代码
- c#进度条 progressBar 使用方法的小例子
- C# cmd中修改显示(显示进度变化效果)的方法
- c#根据文件大小显示文件复制进度条实例
- android自定义进度条渐变色View的实例代码
- Jquery Uploadify上传带进度条的简单实例
- C# Winform下载文件并显示进度条的实现代码
- Android中实现Webview顶部带进度条的方法
- 基于jQuery实现网页进度显示插件
- php上传文件并显示上传进度的方法
- python下载文件时显示下载进度的方法
相关文章
C#实现给DevExpress中GridView表格指定列添加进度条
这篇文章主要为大家详细介绍了如何利用C#实现给DevExpress中GridView表格指定列添加进度条显示效果,感兴趣的小伙伴可以尝试一下2022-06-06
最新评论