服务器之家

服务器之家 > 正文

ASP.NET显示渐变图片实现方法

时间:2019-12-24 12:39     来源/作者:lijiao

先给大家来个最终效果:

ASP.NET,渐变图片

实现效果,首先准备一张图片,高度为25pixel,宽度为1至3pixel渐变的图片。可以这里下载。

还要准备数据:

?
1
2
3
4
5
6
7
8
9
10
11
Dictionary<int, int> Datas
 {
 get
 {
  Dictionary<int, int> d = new Dictionary<int, int>();
  d.Add(1, 35);
  d.Add(2, 45);
  d.Add(3, 20);
  return d;
 }
 }

ok,数据准备完了,在aspx里放三个Label控件,当然你可以显示在其它控件或是标签中,有一点要注意的是Width="300",它是渐变图片在100%的宽度:

?
1
2
3
<asp:Label ID="Label1" runat="server" style="margin: 3px;" Text="" Width="300" BorderWidth="1"></asp:Label><br />
 <asp:Label ID="Label2" runat="server" style="margin: 3px;" Text="" Width="300" BorderWidth="1"></asp:Label><br />
 <asp:Label ID="Label3" runat="server" style="margin: 3px;" Text="" Width="300" BorderWidth="1"></asp:Label><br />

把数据显示于Label上:

?
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
protected void Page_Load(object sender, EventArgs e)
 {
 Data_Binding();
 }
 
 private void Data_Binding()
 {
 int totals = 100;
 foreach (KeyValuePair<int, int> kvp in Datas)
 {
  double rate = kvp.Value / (double)totals;
 
  double width = rate * 300;
  switch (kvp.Key)
  {
  case 1:
   this.Label1.Text = GradientImage(width, rate);
   break;
  case 2:
   this.Label2.Text = GradientImage(width, rate);
   break;
  case 3:
   this.Label3.Text = GradientImage(width, rate);
   break;
  }
 }
 }
 
 private string GradientImage(double width, double rate)
 {
 return "<IMG height='21' src='images/bar.gif' width='" + width + "' align='absMiddle'> " + rate.ToString("p");
 }

以上就是ASP.NET实现渐变图片的方法,希望对大家的学习有所帮助。

标签:

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
返回顶部