
Hallo, ich suche nach dem VBA-Code, um die Farbe einer Form in Excel mit VBA alle 5 Sekunden zu ändern, nachdem ich auf eine Schaltfläche geklickt habe. Der Name meiner Form ist „Rechteck 1“.
Antwort1
Weisen Sie Ihrer Taste das Ausführen zuStartTimer:
Public RunWhen As Double
Public Const cRunIntervalSeconds = 5
Public Const cRunWhat = "qwerty"
Sub StartTimer()
RunWhen = Now + TimeSerial(0, 0, cRunIntervalSeconds)
Application.OnTime earliesttime:=RunWhen, procedure:=cRunWhat, _
schedule:=True
End Sub
Sub StopTimer()
On Error Resume Next
Application.OnTime earliesttime:=RunWhen, _
procedure:=cRunWhat, schedule:=False
End Sub
Sub qwerty()
Dim s As Shape
Set s = ActiveSheet.Shapes("Rectangle 1")
s.Fill.ForeColor.SchemeColor = Application.WorksheetFunction.RandBetween(1, 20)
Call StartTimer
End Sub