当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 投票结果的图片进度条显示

ASP.NET
ASP.NET下MVC设计模式的实现
ASP.NET中利用cookies保持客户端信息
有关TextBox中输入字符控制的一种解决办法
ASP.NET访问Oracle数据库的方法
追踪ASP.NET代码里的bug
在asp.net中为Web用户控件添加属性和事件
使用.NET实现断点续传
ASP.NET Whidbey中实现Provider
使用函数传递参数来执行数据库操作
ASP.NET中实现模版的动态加载
用Repeater控件显示数据
五种常见的ASP.NET安全缺陷
利用Treeview实现树形列表
将Asp.net页面输出为HTML
不走寻常路 设计ASP.NET应用程序的七大绝招
ASP.NET中的HTTP模块和处理程序
充分利用ASP.NET的三种缓存提高站点性能
在ASP.NET中使用Treeview控件和XML
ASP.NET+XML Web服务客户端创建Web服务
ASP.NET中不定级动态菜单的实现

ASP.NET 中的 投票结果的图片进度条显示


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 110 ::
收藏到网摘: n/a

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

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;
    ......