如何用C#实现漂亮的动态图像按钮.docx_第1页
如何用C#实现漂亮的动态图像按钮.docx_第2页
如何用C#实现漂亮的动态图像按钮.docx_第3页
如何用C#实现漂亮的动态图像按钮.docx_第4页
如何用C#实现漂亮的动态图像按钮.docx_第5页
全文预览已结束

下载本文档

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

文档简介

前一阵子参与一个项目开发,好友总是抱怨工具栏按钮太简陋了:要是弄得炫一点该多好啊,看看人家Mac的桌面工具栏!事实也的确如此,现在越来越多的程序界面做的是相当的酷啊,无论是什么平台Mac、Windows还是Linux,其界面元素越来越丰富,一个小小的button背景都要在鼠标的不同事件激活下渐变来渐变去。但是,遍历VS IDE中默认的工具集合我们是无论如何也找不到如此复杂的控件的,所以,我们必须借助强大的.Net框架以及GDI+自己动手来制作类似的工具栏按钮控件。我们要创建的控件简单说就是一个动态渐变的图片按钮,示例程序界面如下:这个button控件依旧继承自UserControl,UserControl是制作自定义UI控件绝对的父类,这里不再细说。我们为这个button取名为DynamicImageButton。制作图像按钮当然离不开绘制,所以还得用到GDI+,我曾经写过多篇关于界面元素的文章,比如”利用.Net绘图技术制作水晶按钮控件”、” 利用C#实现任务栏通知窗口”、” 利用C#为数码照片添加拍照日期”、” C#实现运行时拖动控件并调整控件大小”等等,其中都会涉及到GDI+的诸多方面,可见GDI+在设计制作UI上是多么的重要啊!对于按钮图片透明度渐变的操作则比较有技巧,采取了个人认为比较另类却极其高效的方法。制作图片按钮肯定是要为这个button赋值一个图像文件的,我们需要公开一个属性,代码如下: public Bitmap Imageget return bmp0; setbmp0 = value;l bmp1 = returnAlpha(value, 60);bmp2 = returnAlpha(value, 120); ;bmp3 = returnAlpha(value, 180); ;draw(); 大家注意到,当给这个DynamicImageButton的image属性赋值一幅图片后,立即就会对这个原始图片经过4种不同的alpha过滤后分别存放到bmp位图数组下。bmp0保存原始图像,bmp3的图像则最透明。这就是本程序的特点所在,也就是在运行时是不进行图像透明度渐变计算的,在给image属性赋值时计算工作同时也已经完成了,这样可以省下鼠标移动事件的巨大计算量。returnAlpha方法就是将原始图像中的每一个像素按照相应的alpha值进行重新绘制后保存在bmp数组中,不同透明度的图像作为bmp数组的不同元素进行保存。代码如下: public static Bitmap returnAlpha(Bitmap bmp, int alpha)Color col;Bitmap bmp2 = new Bitmap(bmp);for (int i = 0; i bmp.Width; i+)for (int j = 0; j 0)bmp2.SetPixel(i, j, Color.FromArgb(min(col.A - alpha), col.R, col.G, col.B);return bmp2; 到这里大家可能就已经明白我的用意了,没错!从原始图像到最终图像的透明渐变我只设计了4帧!其实,这对于一个小小的button动画来说已经完全足够了。对于图像的绘制方法我们仍旧采用双缓冲区绘制,也就是内存复制,实际上就是双bitmap对象交替使用,这样可以更好的防止图像闪烁(参见我的另一篇文章”.NET框架下使用双缓冲技术绘图”)。相关代码如下: private void DynamicImageButton_Paint(object sender, System.EventArgs e)g2 = Graphics.FromImage(dblbuffer);g2.Clear(this.BackColor);curx = (int)(double)Width) / 6;cury = (int)(double)Height) / 6;curwidth = (int)(double)Width) / 3 * 2;curheight = (int)(double)Height) / 3 * 2;itvwidth = (Width - curwidth) / 2;g2.DrawImage(bmp3, curx, cury, curwidth, curheight);g.DrawImageUnscaled(dblbuffer, 0, 0); 然后就是对图像大小渐变的控制了,如下图所示:a、b、c和d四个矩形代表不同大小的4个帧,a帧是装载图像时的默认大小,就是bmp0的图像,也是4帧中最大的一帧,width=75和height=72是我们示例程序控件的大小,网友可以随意对长宽进行重新设定。这两个数值是基础,bmp0的图像会完全填充到这个区域内,在这个给定的长和宽的基础上我们计算出b、c和d三帧的图像大小和位置。然后创建一个计数器,当鼠标Enter或者Leave我们创建的这个DynamicImageButton时对图像的透明度和大小的渐变进行控制。相关代码如下:private void timer1_Tick(object sender, EventArgs e)if (mp = enumMousePosition.Enter)if (curx = 0) | (cury = itvwidth-2)g2.DrawImage(bmp3, curx - 1, cury - 1, curwidth + 2, curheight + 2);else if (curx= itvwidth / 3 * 2) & (curx = itvwidth / 3) & (curx = 0) & (curx = itvwidth / 3)g2.DrawImage(bmp0, curx - 1, cury - 1, curwidth + 2, curheight + 2);g.DrawImageUnscaled(dblbuffer, 0, 0);curx-;cury-;curwidth = curwidth + 2;curheight = curheight + 2;if (curx = 0) | (cury = (int)(double)Width) / 6) |(cury = (int)(double)Height) / 6) |(curwidth = itvwidth-2)g2.DrawImage(bmp3, curx - 1, cury - 1, curwidth + 2, curheight + 2);else if (curx = itvwidth / 3 * 2) & (curx = itvwidth / 3) & (curx = 0) & (curx = (int)(double)Width) / 6) |(cury = (int)(double)Height) / 6) |(curwidth = (int)(double)Width) / 3 * 2)

温馨提示

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

评论

0/150

提交评论