zoukankan      html  css  js  c++  java
  • 文本框控件不支持透明的背景色

    .NET环境下TextBox和RichTextBox是不支持透明背景色的。当我们在属性设计器中将它们的BackColor设置为Transparent时,会弹出一个警告窗口“属性值无效:控件不支持透明的背景色”。

    在网上一搜,有很多解决办法:

    (1)在代码中加入以下代码:textBox1.BackColor = System.Drawing.Color.Transparent;

    (2)通过继承TextBox进行简单设置样式ControlStyles.SupportsTransparentBackColor。

    public class MyTextBox : TextBox
    {
    public MyTextBox()
    {
    this.SetStyle(ControlStyles.SupportsTransparentBackColor, true);
    }
    }

    (3)如果不想自己做控件,提供一个比较丧心病狂的思路:

    1. 创建一个窗体,无边框,TrancsparencyKey设置为跟TextBox一样;
    2. 窗体上放一个TextBox,Dock属性设置为fill;
    3. 在主窗体上放置一个Label,设置成透明;
    4. 鼠标点击Label时,将自己做的窗体show出来,并且将label隐藏;
    5. 焦点离开TextBox时,将TextBox的内容复制给Label。关闭无框窗体,显示label;
    6. 其他细节就自己琢磨吧,比如鼠标外观啦,Tab键控制焦点移动啦之类。

    分析:

    方法(1):不可行。虽然编译能过,但会遇到运行时错误。因为WinForm不支持该控件的透明背景色。

    方法(2):不可行。虽然通过设置样式SupportsTransparentBackColor为真之后能够使文本框的背景色

    设置为Transparent,但是却达不到透明效果,背景色仍然不是透明的。

    方法(3):可行但却复杂。不是最佳方案,只能说是如果没有其他方案的情况下才使用该方法。

    总结

    由于.NET框架本身对文本框控件背景色的支持不太好,所以必须使用一些更底层的WIN32函数才能解决。下面是从The Code Project上找到的一些好的实现方式,基本上都是使用底层WIN32函数解决的,具体的代码剖析留到后面有时间再做,现在可以直接方便的使用就行。

    这有一篇专门讲怎么使文本框背景透明的文章:How to make a TextBox/RichTextBox transparent

    开源控件

    AlphaBlendTextBox - A transparent/translucent textbox for .NET

    Alpha Blended (Transparent Capable) TextBox and RichTextBox

    另外:

    C#中button透明,无边线框,但是点击透明部分能实现它的功能~~~· 谢谢

    最佳答案
    答:按钮的FlatStyle属性改成Flat.
    加一个button1.BackColor=Color.Transparent;
    (或者加this.button1.FlatStyle=FlatStyle.Flat;button1.BackColor=Color.Transparent;
    2010-12-23 11:57 dedtfo | 六级
    是Web的话就用ImageButton;是WinForm的话用pictureBox之后加onclick事件,我试过可以。用button的话,在无边框的状态下也能看的出一点点。当然用图片的话完全可以用透明的图片,你可以用PS导出,我试了完全可以。希望对您有一点点帮助。

  • 相关阅读:
    【UVA11324】 The Largest Clique (Tarjan+topsort/记忆化搜索)
    【洛谷2245】 星际导航 (最小瓶颈路)
    【UVA10816】Travel in Desert (最小瓶颈路+最短路)
    【洛谷 5002】专心OI
    炸金花【大模拟】
    【BZOJ1055】[HAOI2008]玩具取名(区间DP)
    【BZOJ1296】[SCOI2009]粉刷匠 (DP+背包)
    NOIP前的模板
    获取<考试>博文密码!o(*≧▽≦)ツ
    这是个萌新的萌新博客
  • 原文地址:https://www.cnblogs.com/blogpro/p/11462932.html
Copyright © 2011-2022 走看看