近段时间为了工作的需要学习了一下写自定义控件,呵呵!以前没写过,近段时间才开始研究的,昨天写了一个WEB状态条控件,
可以设置进度条的百分比,也可以设置它的总数与当前的数量来自动计算百分比,可以设置颜色显示或图片显示(当没有设置图片
的时候就会自动用颜色来显示),状态条的宽度和高度可以自由设定,还是第一次写控件,希望大家多多指教.好了不多说了,还是把
代码贴出来供大家参考吧!有不同想法的希望大家能提出来交流一下!

先看看运行效果:
            

第一步:
新建一个类文件Guage.cs
代码如下:

using System;
using System.Drawing;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.ComponentModel;

namespace ZYT.Web.UI
{
/// <summary>
/// 进度条WEB控件

[DefaultProperty("Text"),
ToolboxData("<{0}:Guage runat=server></{0}:Guage>")]
public class Guage : System.Web.UI.WebControls.WebControl
{
#region 变量
/// <summary>
/// 列数(单元格)
/// </summary>
private int intCellCount = 20;

/// <summary>
/// 设置进度条百分比
/// </summary>
private int intPercentage = 0;

/// <summary>
/// 总数量
/// </summary>
private int intMaxNum = 0;
/// <summary>
/// 现在数量
/// </summary>
private int intCurNum = 0;

/// <summary>
/// 填充图片地址
/// </summary>
private string strFillImageUrl = "";
/// <summary>
/// 进度条图片地址
/// </summary>
private string strBarImageUrl = "";

#endregion

#region 属性
[Description("进度条百分比步长(必须被100整除)")]
public int PercentageStep
{
get { return 100 / intCellCount; }
set
{
if ((100 % value) != 0)
{
throw new ArgumentException("百分比步长必须被100整除");
}
intCellCount = 100 / value;
}
}

[Description("设置进度条百分比"), DefaultValue(0)]
public int Percentage
{
get { return intPercentage; }
set
{
// 确定百分比在指定的范围内
//
if (value > 100) // 超过100则显示100
{
intPercentage = 100;
}
else if (value < 0) // 小于0则显示0
{
intPercentage = 0;
}
else
{
intPercentage = value;
}
}
}

[Description("总数量")]
public int MaxNum
{
get { return intMaxNum; }
set
{
intMaxNum = value;
}
}

[Description("当前数量")]
public int CurNum
{
get { return intCurNum; }
set
{
intCurNum = value;
}
}

[Description("填充图片地址")]
public string FillImageUrl
{
get { return strFillImageUrl; }
set { strFillImageUrl = value; }
}

[Description("进度条图片地址")]
public string BarImageUrl
{
get { return strBarImageUrl; }
set { strBarImageUrl = value; }
}

#endregion

#region 构造函数
public Guage()
{
// 初始化进度条的背景颜色、字体颜色和边框颜色
BackColor = System.Drawing.Color.LightGray;
ForeColor = System.Drawing.Color.Blue;
BorderColor = Color.Empty;

//初始化进度条的宽度和高度
base.Width = Unit.Pixel(100);
base.Height = Unit.Pixel(16);

}
#endregion

#region 取得进度条百分比
/// <summary>
/// 取得进度条的百分比
/// </summary>
/// <param name="MaxNum">总数量</param>
/// <param name="curValue">当前数量</param>
/// <returns></returns>
private int GetPercentage(int maxNum, int curNum)
{
int intLvalue = 0;
int intFvalue = (curNum * 100) / maxNum;
int intMvalue = (curNum * 100) % maxNum;
if (intMvalue > 0)
{
string strLvalue = intMvalue.ToString().Substring(0, 1);
if (int.Parse(strLvalue) > 4)
{
intLvalue = int.Parse(strLvalue);
}
}
return intFvalue + intLvalue;
}

#endregion

/// <summary>
/// 进度条输出参数
/// </summary>
/// <param name="output"> 进度条 </param>
protected override void Render(HtmlTextWriter output)
{
if (Width.Type != UnitType.Pixel)
{
throw new ArgumentException("宽度必须为象素");
}

int intWidth = (int)Width.Value;//控件宽度

if (intPercentage == 0)
{
//进度条百分比
intPercentage = GetPercentage(intMaxNum, intCurNum);
}

if (BorderColor != Color.Empty)//进度条加边框
{
output.Write("<table border='0' cellspacing='0' cellpadding='1' bgColor='" +
ColorTranslator.ToHtml(BorderColor) + "'><tr><td>");
}
if (BarImageUrl == "")
{
output.Write("<table border='0' cellspacing='0' cellpadding='0' height='" + Height + "' bgColor='" + ColorTranslator.ToHtml(BackColor) + "'><tr>");
int intCellWidth = intWidth / intCellCount;
int intCurPercentage = 0;
int intPercentageStep = PercentageStep;
string strCellColor;
string strCellValue = "";

if (Page.Request.Browser.Browser.ToUpper() == "NETSCAPE")
{
if (FillImageUrl != "")
{
strCellValue = "<img src='" + FillImageUrl + "' border='0' width='" + intCellWidth + "'>";
}
else
{
strCellValue = " ";
}
}
for (int i = 0; i < intCellCount; i++, intCurPercentage += intPercentageStep)
{
if (intCurPercentage < intPercentage)
{
strCellColor = " bgColor='" + ColorTranslator.ToHtml(ForeColor) + "'";
}
else
{
strCellColor = "";
}

if (i == 0)
{
output.Write("<td height='" + Height + "' width='" + intCellWidth + "'" + strCellColor + ">" + strCellValue + "</td>");
}
else
{
output.Write("<td width='" + intCellWidth + "'" + strCellColor + ">" + strCellValue + "</td>");
}
}
output.Write("</tr></table>");
}
else
{
int intImageWidth = (int)((intPercentage / 100.0) * intWidth);

output.Write("<table border='0' cellpadding='0' cellSpacing='0' bgColor='" + ColorTranslator.ToHtml(BackColor) + "'><tr><td width='" + intWidth + "'>");
output.Write("<img src='" + BarImageUrl + "' width='" + intImageWidth + "' height='" + Height + "'>");
output.Write("</td></tr></table>");
}

if (BorderColor != Color.Empty)
{
output.Write("</td></tr></table>");
}
}

}
}

第二步:在WEB项目下添加一个WEB文件:GuageDemo.aspx
代码如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="guageDemo.aspx.cs" Inherits="guageDemo" %>
<%@ Register Assembly="ZYT.Web.UI" Namespace="ZYT.Web.UI" TagPrefix="ZYTControl" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>无标题页</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<ZYTControl:Guage ID="guage1" runat="server" CurNum="34" MaxNum="1000" Height="25px" Width="300px" PercentageStep="2" BarImageUrl="Guage/Images/3.jpg" FillImageUrl="Guage/Images/1.jpg" ImageGeneratorUrl="" />
</div>
</form>
</body>
</html>

 

WEB进度条控件的更多相关文章

  1. Photoshop和WPF双剑配合,打造炫酷个性的进度条控件

    现在如果想打造一款专业的App,UI的设计和操作的简便性相当重要.UI设计可以借助Photoshop或者AI等设计工具,之前了解到WPF设计工具Expression Blend可以直接导入PSD文件或 ...

  2. [转载]ExtJs4 笔记(8) Ext.slider 滚轴控件、 Ext.ProgressBar 进度条控件、 Ext.Editor 编辑控件

    作者:李盼(Lipan)出处:[Lipan] (http://www.cnblogs.com/lipan/)版权声明:本文的版权归作者与博客园共有.转载时须注明本文的详细链接,否则作者将保留追究其法律 ...

  3. 用 CALayer 定制下载进度条控件

    // // RPProgressView.h // CALayer定制下载进度条控件 // // Created by RinpeChen on 16/1/2. // Copyright © 2016 ...

  4. ExtJs4 笔记(8) Ext.slider 滚轴控件、 Ext.ProgressBar 进度条控件、 Ext.Editor 编辑控件

    本篇要登场的有三个控件,分别是滚轴控件.进度条控件和编辑控件. 一.滚轴控件 Ext.slider 1.滚轴控件的定义 下面我们定义三个具有代表意义滚轴控件,分别展示滚轴横向.纵向,以及单值.多值选择 ...

  5. 【转】用emWin进度条控件做个表盘控件,效果不错

    @2018-08-09 用emWin进度条控件做个表盘控件,效果不错

  6. 为OLED屏添加GUI支持6:进度条控件

    为OLED屏添加GUI支持6:进度条控件 本文博客链接:http://blog.csdn.net/jdh99,作者:jdh,转载请注明. 环境: 主机:WIN10 开发环境:MDK5.13 MCU:S ...

  7. CProgressCtrl进度条控件实现进度滚动效果

    关于CProgressCtrl 控件的基本操作网上有很多资料,可我想实现进度条中进度滚动效果,即很多时候程序出现的等待或启动画面,如下图: 实现这个效果的函数为SetMarquee(_In_ BOOL ...

  8. HslControls组件库 工业控件库 曲线控件 时间控件 管道控件 温度计控件 阀门控件 传送带控件 进度条控件 电池控件 数码管控件等等

    本篇博客主要对 HslControls 组件做一个大概的总览介绍,更详细的内容可以参照页面里的子链接,还有github上的源代码,然后进行相关的学习,和使用. Prepare 先从nuget下载到组件 ...

  9. iOS:进度条控件的详细使用

    进度条控件:UIProcessView:UIView   功能:顾名思义,用来显示下载进度或者传输数据进度.   属性: @property(nonatomic) UIProgressViewStyl ...

随机推荐

  1. Weblogic部署项目过程中的一些问题

    weblogic启动,最后一段出现的警告: <Warning> <Log Management> <BEA-170011> <The LogBroadcast ...

  2. Python 中的枚举类型~转

    Python 中的枚举类型 摘要: 枚举类型可以看作是一种标签或是一系列常量的集合,通常用于表示某些特定的有限集合,例如星期.月份.状态等. 枚举类型可以看作是一种标签或是一系列常量的集合,通常用于表 ...

  3. hibernate学习(9)——日志,一对一,二级缓存

    1.Hibernate中的日志 1  slf4j 核心jar  : slf4j-api-1.6.1.jar .slf4j是日志框架,将其他优秀的日志第三方进行整合. 整合导入jar包 log4j 核心 ...

  4. System.Linq.Dynamic的使用

    项目中经常用到组合条件查询,根据用户配置的查询条件进行搜索,拼接SQL容易造成SQL注入,普通的LINQ可以用表达式树来完成,但也比较麻烦.有个System.Linq.Dynamic用起来比较方便. ...

  5. Alamofire 的使用

    最近,AFNetworking 的作者Mattt Thompson提交了一个新的类似于 AFNetworking 的网络 基础库,并且是专门使用最新的 Swift 语言来编写的,名为:Alamofir ...

  6. Ref 与 Out 的使用方法及区别

    C# 中我们有的时候会遇到这样的情况,一个方法需要返回多个参数的时候.怎么办呐? 我们可以给返回的参数加上 Out  或  Ref 类型标识  就可以实现返回多个参数了. 具体他们两个的用法有什么区别 ...

  7. [转载]ERP实施40问 60分钟外行变专家

    http://www.chinaodoo.net/thread-389-1-1.html 在多年的实践中,结合自身经验和多年的理论积累,总结出有关ERP实施的最关键的40个问题,以问答的形式,让您在最 ...

  8. (js) 输入框只能输入中文、英文、数字、@符号和.符号

    只能输入中文.英文.数字.@符号和.符号<input type="text" onkeyup="value=value.replace(/[^\a-\z\A-\Z0 ...

  9. Sublime Text 2 JS 格式化插件 JsFormat的配置使用

    (转自http://www.jb51.net/softjc/178401.html) 这里下载这插件包 https://github.com/jdc0589/JsFormat ,点油下角的zip就能下 ...

  10. JMeter学习-022-JMeter 分布式测试(性能测试大并发、远程启动解决方案)

    在使用 JMeter 进行性能测试时,难免遇到要求并发请求数比较的场景,此时单台测试机的配置(CPU.内存.带宽等)可能无法支持此性能测试场景.因而,此时 JMeter 提供的分布式测试功能就有了用武 ...