手把手教你开发圆盘仪表控件_第1页
手把手教你开发圆盘仪表控件_第2页
手把手教你开发圆盘仪表控件_第3页
手把手教你开发圆盘仪表控件_第4页
手把手教你开发圆盘仪表控件_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

创建项目自定义控件库其实本质上就是一个类库,所以我们在创建项目时直接创建类库项目。在创建好的类库项目中添加“用户控件”。实现思路整个控件其实是由四个部分组成的。第一个部分为一个固定颜色的底圆,第二部分是一个渐变色的扇形,第三部分是一个颜色与窗体背景色相同的上圆,第四部分是显示百分比的文字。最后将这四个部分叠加起来就得到了我们最终想要得到的控件。实现过程1.绘制准备在用户控件中添加代码,我们使用OnPaint事件来绘制控件,通过参数e来获取画布。并给画布设置一些属性。protectedoverridevoidOnPaint(PaintEventArgse)

{

base.OnPaint(e);

//

获取画布

Graphicsgraphics

=

e.Graphics;

//消除锯齿

graphics.SmoothingMode

=

SmoothingMode.AntiAlias;

//文字显示效果

graphics.TextRenderingHint

=

System.Drawing.Text.TextRenderingHint.ClearTypeGridFit;

//插补模式

graphics.InterpolationMode

=

InterpolationMode.HighQualityBicubic;

//图片呈现质量

graphics.CompositingQuality

=

CompositingQuality.HighQuality;

}2.绘制底圆我们在事件中继续添加一些代码,使用画布的FillEllipse()方法绘制一个底圆,底圆的大小依照整个控件的大小创建。//

绘制底圆

SolidBrushbrush1

=

newSolidBrush(Color.FromArgb(93,

107,

153));

Rectanglerectangle1

=

newRectangle(1,

1,

this.Width

-

2,

this.Height

-

2);

graphics.FillEllipse(brush1,

rectangle1);测试效果如下:3.绘制扇形首先创建属性与字段,以便使用属性来控制扇形的区域,使得扇形的区域是可变的。//最大值

private

float

maxValue

=

100;

public

float

MaxValue

{

get

{

return

maxValue;

}

set

{

maxValue

=

value;

this.Invalidate();

}

}

//实际值

private

float

actureValue

=

60;

public

float

ActureValue

{

get

{

return

actureValue;

}

set

{

actureValue

=

value;

this.Invalidate();

}

}

//文字显示值

private

float

PercentVal

=

0;绘制扇形的大小与底圆的大小相一致,颜色采用渐变色。//绘制扇形

Rectanglerectangle2

=

newRectangle(1,

1,

this.Width

-

2,

this.Height

-

2);

LinearGradientBrushbrush2

=

newLinearGradientBrush(rectangle2,

Color.Blue,

Color.Red,

150.0f,

true);

this.PercentVal

=

(ActureValue

/

MaxValue)

*

100;

graphics.FillPie(brush2,

rectangle2,

-90,

(ActureValue

/

MaxValue)

*

360f);测试效果如下:4.绘制上圆绘制上圆比较简单,大小比底圆稍小,位置在整个控件中心,颜色与控件颜色相同。//绘制上圆

SolidBrushsolidBrushElipse

=

newSolidBrush(this.BackColor);

Rectanglerectangle3

=

newRectangle(15,

15,

this.Width

-

30,

this.Height

-

30);

graphics.FillEllipse(solidBrushElipse,

rectangle3);测试效果如下:5.绘制文字最后在控件的中心位置绘制文字//绘制文字

Fontfont

=

newFont("华为宋体",

14);

PointFpoint

=

newPointF(((float)this.Width)

/

2.0f

-

27,

((float)this.Height)

/

2.0f

-

10);

graphics.DrawString(this.PercentVal.

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论