当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 使用 VC.net 轻松实现按钮控件自绘

VC++
如何有效地使用对话框
一个定制CFileDialog对话框的实例
XP风格复活节彩蛋的实现
程序界面多模式显示的实现
改变视图单调的背景
使窗体拥有透明效果的API
《电子尺》V1.02程序开发实例
美化你的应用程序的外观界面
个人考勤软件开发实例
使用VC6.0实现窗口的任意分割
如何让一个打开的文档成为活动文档
创建非矩形窗口的简单方法
轻松实现类VC界面
视图的缩放的完整论述
如何获得另一个应用程序窗口中的文本
如何发送命令到文档对象
动画窗口的实现-VC++实例一则
如何在其他程序的窗口上创建按钮并使之能响应
如何在基于对话框的程序中动态设置鼠标指针
扩展COleDropTarget类来支持任意窗口拖放 - 作者:王加宝

VC++ 中的 使用 VC.net 轻松实现按钮控件自绘


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

使用 VC.net 轻松实现按钮控件自绘

作者:caeser2

下载源代码

  在我的上一篇文章“VC.NET简单实现GIF动画”中大家已经看到 .net 框架的易用性了,这一回我想说说 .net 控件的自绘,同样比 MFC 的控件自绘要轻松许多,我们就拿最常用的 Button 控件下手吧。

1、启动 VS.net,创建项目,




添加Form1_Load消息




添加控件,响应消息




2、添加代码

  我们首先改变按钮的外观,把它变成圆的,然后利用鼠标消息改变按钮的状态。注意我这里偷了个懒,当按钮获得焦点时没有显示出选中框(就是大家选中一个东西时边缘上的那个虚线框),大家如果觉得那个虚线很必要,可以自己在按钮获得焦点时画个虚线上去,也可以将按钮的普通状态保存成位图,然后在该位图上画好虚线并另存一下;在按钮获得焦点时显示那个有虚线的图,失去焦点则换回原图即可,十分简便。

 private: System::Void Form1_Load(System::Object * sender, System::EventArgs * e) {//先创建路径,在路径中画个椭圆,然后用这个路径创建区域,最后把区域给按钮并设置按钮的范围 System::Drawing::Drawing2D::GraphicsPath *path=new System::Drawing::Drawing2D::GraphicsPath();//创建路径 path->AddEllipse(Rectangle(10,10,80,80));//在路径中画椭圆 System::Drawing::Region *reg=new System::Drawing::Region(path);//利用路径创建区域 button1->Bounds=System::Drawing::Rectangle(50,50,100,100);//设定按钮显示位置和最大响应范围,只能是矩形 button1->Region=reg;//设定按钮的实际控制区域,可以是任意形状 }	//下面的内容就简单了,设置按钮在不同状态下的不同样式,没有响应焦点状态,就当作留给读者的作业吧^_^	private: System::Void button1_MouseDown(System::Object * sender, System::Windows::Forms::MouseEventArgs * e) { button1->Image=Image::FromFile("bitmap.bmp"); }	private: System::Void button1_MouseUp(System::Object * sender, System::Windows::Forms::MouseEventArgs * e) { button1->BackColor=SystemColors::AppWorkspace; button1->Image=NULL; }	private: System::Void button1_MouseEnter(System::Object * sender, System::EventArgs * e) { button1->BackColor=SystemColors::AppWorkspace; button1->Image=NULL; }	private: System::Void button1_MouseLeave(System::Object * sender, System::EventArgs * e) { button1->BackColor=SystemColors::ActiveBorder; button1->Image=NULL; }

  好了,就这么简单,是不是比 MFC 的按钮自绘要容易的多呢?不过 MFC7.0 中提供的 CBitmapButton 使用起来也同样简单,大家感兴趣的可以试一下。可是其它的 MFC 控件就没那么幸运了:( 而 .net 控件的自绘则基本都如此篇所述。