网站首页 语言 会计 电脑 医学 资格证 职场 文艺体育 范文

ASP.NET新型的投票结果显示方法

栏目: 网页设计 / 发布于: / 人气:3.05W

一个投票功能模块少不了查看投票结果,用进度条显示各个投票结果可以起到一目了然的效果。以下是我的方法,请大家不吝赐教:

ASP.NET新型的投票结果显示方法

1:做一张图片用于做进度条,只需要很小的一个图片就可以了,如高20px,宽1px。

2:在要显示进度条的单元格中插入image控件,其imageUrl设置为已做好的图片的位置。

3:用一个dataReader对象dr保存取出的.各项票数,用一个int型变量sum保存取出的总票数,各项分别再定义一个double型变量用来保存单项票数除以(/)总票数的结果(小数),再定义一个int型的变量来保存最终要显示的进度条的长度(用前面那个double型变量*用来显示进度条的单元格的长度,然后强制转换为int型),将长度赋值给图片的width属性即可,以下为我的代码片段,显示四个进度条:

SqlCommandcmd=newSqlCommand("select*fromTvoteNumorderbyVid",con);//查出各项的投票结果的sql语句

SqlDataReaderdr=uteReader();

......

SqlCommandcmd1=newSqlCommand("selectsum(Vnum)fromTvoteNum",con1);//查出总票数的sql语句

intsum=t32(uteScalar());

......

();//读datareader对象的第一条记录

=nt32(1)ring();//第一项的票数

doublew1=(uble()/sum);//此项票数占总票数的百分比

intwid1=(int)(w1*310);//转化为具体象素,310为要用来显示进度条的单元格长度

h=wid1;//赋值给图片的宽度

();//读第二条记录

=nt32(1)ring();

doublew2=(uble()/sum);

intwid2=(int)(w2*310);

h=wid2;

();//读第三条记录

=nt32(1)ring();

doublew3=(uble()/sum);

intwid3=(int)(w3*310);

h=wid3;

();//读第四条记录

=nt32(1)ring();

doublew4=(uble()/sum);

intwid4=(int)(w4*310);

h=wid4;