博客
关于我
c#透明panel
阅读量:411 次
发布时间:2019-03-06

本文共 2112 字,大约阅读时间需要 7 分钟。

透明与半透明的显示效果

通过设置半透明图片,可以实现对父控件按钮的显示效果。透明的pane搭配半透明图片,确保背景内容清晰可见,同时突出重点内容。

C# 实现透明样式

在C#中,通过修改CreateParams的ExStyle属性,可以实现透明样式。这种方法避免了传统的覆盖方式,确保背景内容不受影响。

public partial class PanelEx : Panel          {              protected Graphics graphics;              protected override CreateParams CreateParams              {                  get                  {                      CreateParams cp = base.CreateParams;                      cp.ExStyle |= 0x00000020; // 实现透明样式                      return cp;                  }              }              public PanelEx()              {                  InitializeComponent();                  this.BackColor = Color.Transparent;                  this.ForeColor = Color.Transparent;              }              protected override void OnPaintBackground(PaintEventArgs pevent)              {              }              protected override void OnPaint(PaintEventArgs e)              {                  base.OnPaint(e);                  this.graphics = e.Graphics;                  this.graphics.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAlias;                  this.graphics.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBilinear;                  this.graphics.PixelOffsetMode = System.Drawing.Drawing2D.PixelOffsetMode.HighQuality;                  this.graphics.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;                  this.graphics.CompositingQuality = System.Drawing.Drawing2D.CompositingQuality.HighQuality;                  if (this.BackgroundImage != null)                  {                      int width = this.Width;                      int height = this.Height;                      Rectangle recModel = new Rectangle(0, 0, width, height);                      this.graphics.DrawImage(this.BackgroundImage, recModel);                  }                  else if (this.ForeColor != Color.Transparent)                  {                      this.graphics.Clear(this.ForeColor);                  }              }          }

该实现方式通过设置高质量的渲染参数,确保图像绘制效果最佳。背景图片绘制在前,前景绘制在后,从而实现半透明显示效果。

转载地址:http://tnvkz.baihongyu.com/

你可能感兴趣的文章
Node.js 切近实战(七) 之Excel在线(文件&文件组)
查看>>
node.js 初体验
查看>>
Node.js 历史
查看>>
Node.js 在个推的微服务实践:基于容器的一站式命令行工具链
查看>>
Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
查看>>
Node.js 异步模式浅析
查看>>
node.js 怎么新建一个站点端口
查看>>
Node.js 文件系统的各种用法和常见场景
查看>>
Node.js 模块系统的原理、使用方式和一些常见的应用场景
查看>>
Node.js 的事件循环(Event Loop)详解
查看>>
node.js 简易聊天室
查看>>
Node.js 线程你理解的可能是错的
查看>>
Node.js 调用微信公众号 API 添加自定义菜单报错的解决方法
查看>>
node.js 配置首页打开页面
查看>>
node.js+react写的一个登录注册 demo测试
查看>>
Node.js中环境变量process.env详解
查看>>
Node.js之async_hooks
查看>>
Node.js初体验
查看>>
Node.js升级工具n
查看>>
Node.js卸载超详细步骤(附图文讲解)
查看>>