ASP.NET实现用图片进度条显示投票结果
程序员文章站
2023-10-31 10:34:40
一个投票功能模块少不了查看投票结果,用进度条显示各个投票结果可以起到一目了然的效果。以下是我的方法,请大家不吝赐教: 1:做一张图片用于做进度条,只需要很小...
一个投票功能模块少不了查看投票结果,用进度条显示各个投票结果可以起到一目了然的效果。以下是我的方法,请大家不吝赐教:
1:做一张图片用于做进度条,只需要很小的一个图片就可以了,如高20px,宽1px。
2:在要显示进度条的单元格中插入image控件,其imageurl设置为已做好的图片的位置。
3:用一个datareader对象dr保存取出的各项票数,用一个int 型变量sum保存取出的总票数,各项分别再定义一个double型变量用来保存单项票数除以(/)总票数的结果(小数),再定义一个int型的变量来保存最终要显示的进度条的长度(用前面那个double型变量*用来显示进度条的单元格的长度,然后强制转换为int型),将长度赋值给图片的width 属性即可,以下为我的代码片段,显示四个进度条:
sqlcommand cmd=new sqlcommand("select * from tvotenum order by vid",con);//查出各项的投票结果的sql语句
sqldatareader dr=cmd.executereader();
......
sqlcommand cmd1=new sqlcommand("select sum(vnum) from tvotenum",con1);//查出总票数的sql语句
int sum=convert.toint32(cmd1.executescalar());
......
dr.read();//读datareader对象的第一条记录
this.label1.text=dr.getint32(1).tostring();//第一项的票数
double w1=(convert.todouble(this.label1.text)/sum);//此项票数占总票数的百分比
int wid1=(int)(w1*310);//转化为具体象素,310为要用来显示进度条的单元格长度
this.image1.width=wid1;//赋值给图片的宽度
dr.read();//读第二条记录
this.label2.text=dr.getint32(1).tostring();
double w2=(convert.todouble(this.label2.text)/sum);
int wid2=(int)(w2*310);
this.image2.width=wid2;
dr.read();//读第三条记录
this.label3.text=dr.getint32(1).tostring();
double w3=(convert.todouble(this.label3.text)/sum);
int wid3=(int)(w3*310);
this.image3.width=wid3;
dr.read();//读第四条记录
this.label4.text=dr.getint32(1).tostring();
double w4=(convert.todouble(this.label4.text)/sum);
int wid4=(int)(w4*310);
this.image4.width=wid4;
1:做一张图片用于做进度条,只需要很小的一个图片就可以了,如高20px,宽1px。
2:在要显示进度条的单元格中插入image控件,其imageurl设置为已做好的图片的位置。
3:用一个datareader对象dr保存取出的各项票数,用一个int 型变量sum保存取出的总票数,各项分别再定义一个double型变量用来保存单项票数除以(/)总票数的结果(小数),再定义一个int型的变量来保存最终要显示的进度条的长度(用前面那个double型变量*用来显示进度条的单元格的长度,然后强制转换为int型),将长度赋值给图片的width 属性即可,以下为我的代码片段,显示四个进度条:
sqlcommand cmd=new sqlcommand("select * from tvotenum order by vid",con);//查出各项的投票结果的sql语句
sqldatareader dr=cmd.executereader();
......
sqlcommand cmd1=new sqlcommand("select sum(vnum) from tvotenum",con1);//查出总票数的sql语句
int sum=convert.toint32(cmd1.executescalar());
......
dr.read();//读datareader对象的第一条记录
this.label1.text=dr.getint32(1).tostring();//第一项的票数
double w1=(convert.todouble(this.label1.text)/sum);//此项票数占总票数的百分比
int wid1=(int)(w1*310);//转化为具体象素,310为要用来显示进度条的单元格长度
this.image1.width=wid1;//赋值给图片的宽度
dr.read();//读第二条记录
this.label2.text=dr.getint32(1).tostring();
double w2=(convert.todouble(this.label2.text)/sum);
int wid2=(int)(w2*310);
this.image2.width=wid2;
dr.read();//读第三条记录
this.label3.text=dr.getint32(1).tostring();
double w3=(convert.todouble(this.label3.text)/sum);
int wid3=(int)(w3*310);
this.image3.width=wid3;
dr.read();//读第四条记录
this.label4.text=dr.getint32(1).tostring();
double w4=(convert.todouble(this.label4.text)/sum);
int wid4=(int)(w4*310);
this.image4.width=wid4;
上一篇: ASP.net基础知识之常见错误分析
下一篇: 宝宝发烧护理事项 半夜突发高烧退烧小偏方