颜色渐变的窗体

2024-05-23 21:04:28 (46分钟前 更新) 538 2629
窗体颜色改变为另一种渐变颜色设计一VB程序,当单击窗体时,窗体颜色渐变

最新回答

再上来了联系,已经给你做好了窗体颜色的程序。可以指定渐变颜色的。
再上来了联系,已经给你做好了窗体颜色的程序。可以指定渐变颜色的。
杰克贝老师 2024-05-23
BackColor = &HE6E6FA
K = K + 1
Case 3
Me.BackColor = &HFF
K = K + 1
Case 4
MeDim K As Integer
Private Sub Form_Click()
Select Case K
Case 1
Me.BackColor = &HFF0000
K = K + 1
Case 2
Me
BackColor = &HE6E6FA
K = K + 1
Case 3
Me.BackColor = &HFF
K = K + 1
Case 4
MeDim K As Integer
Private Sub Form_Click()
Select Case K
Case 1
Me.BackColor = &HFF0000
K = K + 1
Case 2
Me
Mikewen126 2024-05-20
加上一个循环即可,例如
Private Sub Form_Click()
For a = 1 To 255 Step 1 / 6000
Me.BackColor = RGB(a, 0, 255 - a)
Next
End Sub
加上一个循环即可,例如
Private Sub Form_Click()
For a = 1 To 255 Step 1 / 6000
Me.BackColor = RGB(a, 0, 255 - a)
Next
End Sub
雪莉小姐的 2024-05-06
'没理解错的话,是窗体呈现静态渐变色的意思吧,而不是随着时间的改变,背景色发生动态渐变吧?如果是静态渐变色的话,考虑以下的代码(背景色随着时间改变的代码,也写了,在后面):
Dim flag As Integer
Private Sub Dither()
Dim i As Integer
For i = 0 To 255
Select Case flag Mod 7
Case 0
vcolor = RGB(0, 0, 255 - i)
Case 1
vcolor = RGB(0, 255 - i, 0)
Case 2
vcolor = RGB(255 - i, 0, 0)
Case 3
vcolor = RGB(0, 255 - i, 255 - i)
Case 4
vcolor = RGB(255 - i, 0, 255 - i)
Case 5
vcolor = RGB(255 - i, 255 - i, 0)
Case 6
vcolor = RGB(255 - i, 255 - i, 255 - i)
End Select
Me.Line (0, i)-(Screen.Width, i - 1), vcolor, B
Next
End Sub
Private Sub Form_Activate()
Me.DrawStyle = vbInsideSolid
Me.DrawMode = vbCopyPen
Me.ScaleMode = vbPixels
Me.DrawWidth = 2
Me.ScaleHeight = 256
Me.AutoRedraw = True
flag = 0
Dither
End Sub
Private Sub Form_Click()
flag = flag + 1
If flag > 6 Then flag = 0
Dither
End Sub
Private Sub Form_Resize()
Me.ScaleHeight = 256
Dither
End Sub
'背景色随着时间改变的代码,需要添加一个Timer1控件:
Dim flag As Integer
Private Sub Form_Activate()
Timer1.Enabled = True
Timer1.Interval = 1
End Sub
Private Sub Form_Click()
flag = flag + 1
If flag > 6 Then flag = 0
End Sub
Private Sub Timer1_Timer()
Static i As Integer
Select Case flag Mod 7
Case 0
vcolor = RGB(0, 0, 255 - i)
Case 1
vcolor = RGB(0, 255 - i, 0)
Case 2
vcolor = RGB(255 - i, 0, 0)
Case 3
vcolor = RGB(0, 255 - i, 255 - i)
Case 4
vcolor = RGB(255 - i, 0, 255 - i)
Case 5
vcolor = RGB(255 - i, 255 - i, 0)
Case 6
vcolor = RGB(255 - i, 255 - i, 255 - i)
End Select
i = i + 1
If i > 255 Then i = 0
Me.BackColor = vcolor
End Sub
'没理解错的话,是窗体呈现静态渐变色的意思吧,而不是随着时间的改变,背景色发生动态渐变吧?如果是静态渐变色的话,考虑以下的代码(背景色随着时间改变的代码,也写了,在后面):
Dim flag As Integer
Private Sub Dither()
Dim i As Integer
For i = 0 To 255
Select Case flag Mod 7
Case 0
vcolor = RGB(0, 0, 255 - i)
Case 1
vcolor = RGB(0, 255 - i, 0)
Case 2
vcolor = RGB(255 - i, 0, 0)
Case 3
vcolor = RGB(0, 255 - i, 255 - i)
Case 4
vcolor = RGB(255 - i, 0, 255 - i)
Case 5
vcolor = RGB(255 - i, 255 - i, 0)
Case 6
vcolor = RGB(255 - i, 255 - i, 255 - i)
End Select
Me.Line (0, i)-(Screen.Width, i - 1), vcolor, B
Next
End Sub
Private Sub Form_Activate()
Me.DrawStyle = vbInsideSolid
Me.DrawMode = vbCopyPen
Me.ScaleMode = vbPixels
Me.DrawWidth = 2
Me.ScaleHeight = 256
Me.AutoRedraw = True
flag = 0
Dither
End Sub
Private Sub Form_Click()
flag = flag + 1
If flag > 6 Then flag = 0
Dither
End Sub
Private Sub Form_Resize()
Me.ScaleHeight = 256
Dither
End Sub
'背景色随着时间改变的代码,需要添加一个Timer1控件:
Dim flag As Integer
Private Sub Form_Activate()
Timer1.Enabled = True
Timer1.Interval = 1
End Sub
Private Sub Form_Click()
flag = flag + 1
If flag > 6 Then flag = 0
End Sub
Private Sub Timer1_Timer()
Static i As Integer
Select Case flag Mod 7
Case 0
vcolor = RGB(0, 0, 255 - i)
Case 1
vcolor = RGB(0, 255 - i, 0)
Case 2
vcolor = RGB(255 - i, 0, 0)
Case 3
vcolor = RGB(0, 255 - i, 255 - i)
Case 4
vcolor = RGB(255 - i, 0, 255 - i)
Case 5
vcolor = RGB(255 - i, 255 - i, 0)
Case 6
vcolor = RGB(255 - i, 255 - i, 255 - i)
End Select
i = i + 1
If i > 255 Then i = 0
Me.BackColor = vcolor
End Sub
伊月寒水20 2024-04-27

扩展回答

热门问答

装修专题

其他人还看了

页面运行时间: 0.44977903366089 秒