我使用Windows窗体在C#中,我需要做一个文本框的背景颜色是透明的。 我有一个跟踪条,从0到255应该控制它,但我遇到了一些麻烦。 我创建了一个问题,今天早些时候,询问同样的事情,但没有成功。
这是我目前拥有的代码:
private void trackAlpha_ValueChanged(object sender, EventArgs e)
{
newColor = Color.FromArgb(trackAlpha.Value, colorDialog.Color.R, colorDialog.Color.G, colorDialog.Color.B);
colorDialog.Color = newColor; // The Windows dialog used to pick the colors
colorPreview.BackColor = newColor; // Textbox that I'm setting the background color
}
问题是,绝对没有任何反应。 为什么任何想法是不工作?
对前一个问题,这个好人说什么SetStyle(ControlStyles.SupportsTransparentBackColor, true);
,但我在哪里,我应该把这个不知道。
你需要尝试了这样的事情。
添加一个新的用户控件,说CustomTextBox和变化
public partial class CustomTextBox : UserControl
至
public partial class CustomTextBox : TextBox
然后,您会收到以下错误说,“AutoScaleMode”没有定义。 删除Designer.cs类以下行。
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
更改新添加如下控制的构造。
public partial class CustomTextBox : TextBox
{
public CustomTextBox()
{
InitializeComponent();
SetStyle(ControlStyles.SupportsTransparentBackColor |
ControlStyles.OptimizedDoubleBuffer |
ControlStyles.AllPaintingInWmPaint |
ControlStyles.ResizeRedraw |
ControlStyles.UserPaint, true);
BackColor = Color.Transparent;
}
}
建立,如果打开关闭自定义控制设计,你将能够使用任何其他控件或窗体此控件。
从工具箱拖放如下所示
创建一个新的控制从TextBox继承,设置样式为允许在构造函数中tranparency。 然后使用新的控制,而不是文本框的
在构造函数中执行此操作:
this.SetStyle(ControlStyles.SupportsTransparentBackColor, true);
这将使你的新的控制有一个透明的背景色。
您可以在此处详细了解控制方式; MSDN:控制风格 ,这可以很好的帮助; 从Windows继承窗体控件使用Visual C#
我从来不喜欢有让我自己继承的控制这一点。 所以我做了一个包装函数私有的SetStyle功能。
尝试使用它,而不是创建自己的类?
public static bool SetStyle(Control c, ControlStyles Style, bool value)
{
bool retval = false;
Type typeTB = typeof(Control);
System.Reflection.MethodInfo misSetStyle = typeTB.GetMethod("SetStyle", System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance);
if (misSetStyle != null && c != null) { misSetStyle.Invoke(c, new object[] { Style, value }); retval = true; }
return retval;
}
bool itWorked = SetStyle(myControl, ControlStyles.SupportsTransparentBackColor, true);
对不起,揭露旧文章,但一直在寻找,现在几天就找到了解决没有透明度,文本框,这个可怕的问题! (令人惊讶的是MSACCESS有检查状态显示透明!)
不管怎么说,我建立了一个VB的解决办法,但是,它是非常粗糙,同时可以帮助很多人也想从更硬core'rs有任何见解任何输入...
它基本上是采用文本框,然后确定其大小,距离与标签取代(因此现在代表一个透明的“出现”文本框。此外一些其他的事情一样,如果停止按单行文本框中输入的蜂鸣声。
使用 - 创建一个新的类,并粘贴在上面这个应该创建两个自定义对象(CTextBox和CLabel)所有的代码 - 你只需要在你的表单设计使用CTEXTBOX。
很容易转换成C,如果这是你的语言,但请让我知道如果有什么建议?
Imports System.ComponentModel
Public Class CTextBox
Inherits TextBox
Dim _zUseEnterAsTab As Boolean = True
Dim _zUseTransparent As Boolean = False
Dim _zUseTransparentColor As Color = Color.Transparent
Dim _zUseTransparentBorderColor As Color = Color.Gray
<Description("Use the Enter Key as Tab (Stops Beeps) only for Single line TextBox"), Category("CTextBox")> _
Public Property zUseEnterAsTab() As Boolean
Get
Return _zUseEnterAsTab
End Get
Set(value As Boolean)
_zUseEnterAsTab = value
Me.Invalidate()
End Set
End Property
<Description("Use Transparent TextBox"), Category("CTextBox")> _
Public Property zUseTransparent() As Boolean
Get
Return _zUseTransparent
End Get
Set(value As Boolean)
_zUseTransparent = value
Me.Invalidate()
End Set
End Property
<Description("Change the transparency to ANY color or shade or Alpha"), Category("CTextBox")> _
Public Property zUseTransparentColor() As Color
Get
Return _zUseTransparentColor
End Get
Set(value As Color)
_zUseTransparentColor = value
Me.Invalidate()
End Set
End Property
<Description("Border color of the texbox when transparency used"), Category("CTextBox")> _
Public Property zUseTransparentBorderColor() As Color
Get
Return _zUseTransparentBorderColor
End Get
Set(value As Color)
_zUseTransparentBorderColor = value
Me.Invalidate()
End Set
End Property
Protected Overrides Sub OnCreateControl()
'Again for my benifit - there may be other ways to force the transparency
'code at form / event startup, but this is the way i chose, any advice
'or alternatives would be great!! :)
If Not DesignMode Then
'Basically don't do in design mode!
If _zUseTransparent Then
'Added to handle the event of textbox dissabled
If Me.Enabled Then
CreateMyLabel(Me)
MakeLabelVisible(foundLabel, Me)
End If
End If
End If
MyBase.OnCreateControl()
End Sub
Protected Overrides Sub OnKeyPress(e As KeyPressEventArgs)
If MyBase.Multiline = True Then
MyBase.OnKeyPress(e)
Else
If e.KeyChar = Chr(Keys.Enter) Then
e.Handled = True
If zUseEnterAsTab = True Then SendKeys.Send("{tab}")
MyBase.OnKeyPress(e)
End If
End If
End Sub
Protected Overrides Sub OnLeave(e As EventArgs)
If _zUseTransparent Then
CreateMyLabel(Me)
MakeLabelVisible(foundLabel, Me)
End If
MyBase.OnLeave(e)
End Sub
Protected Overrides Sub OnEnter(e As EventArgs)
If _zUseTransparent Then
CreateMyLabel(Me)
MakeTextBoxVisible(foundLabel, Me)
End If
MyBase.OnEnter(e)
End Sub
Dim foundLabel As CLabel = Nothing
Sub CreateMyLabel(_TxtBox As CTextBox)
foundLabel = Nothing
Dim l As CLabel
If GetMyLabel("L_" & Me.Name, Me) Then
l = foundLabel
If Not l.Name = "L_" & Me.Name Then
MsgBox("L_" & Me.Name)
End If
l.Font = _TxtBox.Font
l.Text = _TxtBox.Text
l.BorderColor = _zUseTransparentBorderColor
l.BackColor = _zUseTransparentColor
l.BorderStyle = Windows.Forms.BorderStyle.None 'Handled by paint event
Else
l = New CLabel
l.Name = "L_" & _TxtBox.Name
l.BorderColor = _zUseTransparentBorderColor
l.BackColor = _zUseTransparentColor
l.Size = _TxtBox.Size
l.BorderStyle = Windows.Forms.BorderStyle.None 'Handled by paint event
l.AutoSize = False
l.Font = _TxtBox.Font
l.Location = _TxtBox.Location
l.Text = _TxtBox.Text
l.Anchor = _TxtBox.Anchor
_TxtBox.Parent.Controls.Add(l)
foundLabel = l
End If
End Sub
Function GetMyLabel(_LabelName As String, _TxtBox As CTextBox) As Boolean
For Each ctl As Control In _TxtBox.Parent.Controls
If ctl.Name = _LabelName Then
foundLabel = ctl
Return True
End If
Next
Return False
End Function
Private Sub MakeLabelVisible(_Label As CLabel, _TxtBox As CTextBox)
_Label.Location = _TxtBox.Location
_Label.Anchor = _TxtBox.Anchor
_Label.Size = _TxtBox.Size
_TxtBox.Size = New Size(0, 0)
_TxtBox.Anchor = AnchorStyles.None
End Sub
Private Sub MakeTextBoxVisible(_Label As CLabel, _TxtBox As CTextBox)
_TxtBox.Location = _Label.Location
_TxtBox.Anchor = _Label.Anchor
_TxtBox.Size = _Label.Size
_Label.Size = New Size(0, 0)
_Label.Anchor = AnchorStyles.None
End Sub
End Class
Public Class CLabel
Inherits Label
Public BorderColor As Color = Color.Gray
Sub New()
MyBase.FlatStyle = Windows.Forms.FlatStyle.Standard
'Added padding as labels shifted text upwards
'NOT tested on all fonts etc, purely for my sources
MyBase.Padding = New Padding(0, 3, 0, 0)
End Sub
Protected Overrides Sub OnMouseDown(e As MouseEventArgs)
Dim _TxtBox As CTextBox = Nothing
Dim _TxtBoxName As String = Microsoft.VisualBasic.Right(Me.Name, Len(Me.Name) - 2)
For Each elem As Control In Me.Parent.Controls
If elem.Name = _TxtBoxName Then
_TxtBox = elem
Exit For
End If
Next
_TxtBox.Select()
MyBase.OnMouseDown(e)
End Sub
Protected Overrides Sub OnMouseEnter(e As EventArgs)
Cursor = Cursors.IBeam
MyBase.OnMouseEnter(e)
End Sub
Protected Overrides Sub OnMouseLeave(e As EventArgs)
Cursor = Cursors.Default
MyBase.OnMouseLeave(e)
End Sub
Protected Overrides Sub OnPaint(e As PaintEventArgs)
MyBase.OnPaint(e)
ControlPaint.DrawBorder(e.Graphics, Me.DisplayRectangle, Color.Gray, ButtonBorderStyle.Solid)
End Sub
Private Sub MakeLabelVisible(_Label As CLabel, _TxtBox As CTextBox)
_Label.Size = _TxtBox.Size
_TxtBox.Size = New Size(0, 0)
_Label.Anchor = _TxtBox.Anchor
_TxtBox.Anchor = AnchorStyles.None
End Sub
Private Sub MakeTextBoxVisible(_Label As CLabel, _TxtBox As CTextBox)
_TxtBox.Size = _Label.Size
_Label.Size = New Size(0, 0)
_TxtBox.Anchor = _Label.Anchor
_TxtBox.Anchor = AnchorStyles.None
End Sub
End Class
this.SetStyle(ControlStyles.SupportsTransparentBackColor, true);