推荐阅读:listview 百分比进度条(delphi版)
对于已经有的组件,可以直接添加进来,添加后要先运行一下,然后会在工具箱内找到相应控件。
1、首先编写组件,然后将组件添加到工具箱内
编写代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
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、调用方法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
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 ,希望对大家有所帮助。