C#实现带进度条的ListView

 更新时间:2020年6月25日 11:25  点击:3011

推荐阅读:ListView 百分比进度条(delphi版)

对于已经有的组件,可以直接添加进来,添加后要先运行一下,然后会在工具箱内找到相应控件。

1、首先编写组件,然后将组件添加到工具箱内


编写代码如下:

public partial class ListViewEx : System.Windows.Forms.ListView
{
public ListViewEx()
{
InitializeComponent();
}
//C# listview进度条显示
private Color mProgressColor = Color.Red;
public Color ProgressColor
{
get
{
return this.mProgressColor;
}
set
{
this.mProgressColor = value;
}
}
private Color mProgressTextColor = Color.Black;
public Color ProgressTextColor
{
get
{
return mProgressTextColor;
}
set
{
mProgressTextColor = value;
}
}
public int ProgressColumIndex
{
set
{
progressIndex = value;
}
get
{
return progressIndex;
}
}
int progressIndex = -1;
const string numberstring = "0123456789.";
private bool CheckIsFloat(String s)
{
//C# listview进度条显示
foreach (char c in s)
{
if (numberstring.IndexOf(c) > -1)
{ continue; }
else return false;
}
return true;
}
protected override void Dispose(bool disposing)
{
base.Dispose(disposing);
}
//C# listview进度条显示
private void InitializeComponent()
{
this.OwnerDraw = true;
this.View = View.Details;
}
protected override void OnDrawColumnHeader(DrawListViewColumnHeaderEventArgs e)
{
e.DrawDefault = true;
base.OnDrawColumnHeader(e);
}
protected override void OnDrawSubItem(DrawListViewSubItemEventArgs e)
{
if (e.ColumnIndex != this.progressIndex)
{
e.DrawDefault = true; base.OnDrawSubItem(e);
}
else
{
if (CheckIsFloat(e.Item.SubItems[e.ColumnIndex].Text))
//判断当前subitem文本是否可以转为浮点数
{
float per = float.Parse(e.Item.SubItems[e.ColumnIndex].Text);
if (per >= 1.0f) { per = per / 100.0f; }
Rectangle rect = new Rectangle(e.Bounds.X, e.Bounds.Y, e.Bounds.Width, e.Bounds.Height);
DrawProgress(rect, per, e.Graphics);
}
}
}
//C# listview进度条显示 ///绘制进度条列的subitem 
private void DrawProgress(Rectangle rect, float percent, Graphics g)
{
if (rect.Height > 2 && rect.Width > 2)
{
if ((rect.Top > 0 && rect.Top < this.Height) && (rect.Left > this.Left && rect.Left < this.Width))
{
//绘制进度 
int width = (int)(rect.Width * percent);
Rectangle newRect = new Rectangle(rect.Left + 1, rect.Top + 1, width - 2, rect.Height - 2);
using (Brush tmpb = new SolidBrush(this.mProgressColor))
{ g.FillRectangle(tmpb, newRect); }
newRect = new Rectangle(rect.Left + 1, rect.Top + 1, rect.Width - 2, rect.Height - 2);
g.DrawRectangle(Pens.RoyalBlue, newRect);
StringFormat sf = new StringFormat();
sf.Alignment = StringAlignment.Center;
sf.LineAlignment = StringAlignment.Center;
sf.Trimming = StringTrimming.EllipsisCharacter;
newRect = new Rectangle(rect.Left + 1, rect.Top + 1, rect.Width - 2, rect.Height - 2);
using (Brush b = new SolidBrush(mProgressTextColor))
{
g.DrawString(percent.ToString("p1"), this.Font, b, newRect, sf);
}
}
}
//C# listview进度条显示
else
{
return;
}
} 
}

2、调用方法:

private void Form1_Load(object sender, EventArgs e)
{
ListViewItem lviUserName = new ListViewItem();
ListViewItem.ListViewSubItem lvsinc = new ListViewItem.ListViewSubItem();
ListViewItem.ListViewSubItem lvsihostname = new ListViewItem.ListViewSubItem();
ListViewItem.ListViewSubItem lvsiip = new ListViewItem.ListViewSubItem();
lviUserName.Text = "5";
lvsinc.Text = "4";
lvsihostname.Text = "3";
lvsiip.Text = "100";
lviUserName.SubItems.Add(lvsinc);
lviUserName.SubItems.Add(lvsihostname);
lviUserName.SubItems.Add(lvsiip);
this.listView1.Items.Add(lviUserName);
this.listView1.ProgressTextColor = Color.Red;
this.listView1.ProgressColor = Color.YellowGreen;
}
private void listView1_DrawSubItem(object sender, DrawListViewSubItemEventArgs e)
{
//设置进度条的ColunIndex
this.listView1.ProgressColumIndex = 1;
}
private void timer1_Tick(object sender, EventArgs e)
{
if (Convert.ToInt32(listView1.Items[0].SubItems[1].Text.ToString()) <= 100)
{
//进度条数字更新
listView1.Items[0].SubItems[1].Text = (Convert.ToInt32(listView1.Items[0].SubItems[1].Text.ToString()) + 1).ToString();
}
}

3、注意要添加Timer控件

相应属性设置如下:


4、运行结果如下所示


以上所述是基于C#实现带进度条的ListView ,希望对大家有所帮助。

[!--infotagslink--]

相关文章