VB中程序中引用timer,timer无法循环

2024-12-29 16:20:58
推荐回答(1个)
回答1:

可以考虑VB多线程编程吧,一样的类似创建一个timer一样的一个线程,和你现在的应用程序不相互影响
下面的程序是个例子,控件自己添加,还要添加一个模块(菜单里的工程---添加模块)
3个text控件,1个command控件
你可以循环读取每个线程函数的返回值然后告诉主程序
模块代码:
Public Declare Function SetTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long) As Long
Public Declare Function KillTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long) As Long
Public Const TimeId As Long = 1 '线程ID
Public n1 As Long
Public Sub myProc()
'这里填写自己的过程或调用的函数
Form1.Text1.Text = myFun(n1)
n1 = n1 + 1
End Sub
Public Sub myProc1()
'这里填写自己的过程或调用的函数
Form1.Text2.Text = Form1.Text2.Text - 1
End Sub
Private Function myFun(n As Long) As Long
'调用函数

myFun = n
End Function

窗体代码:
Dim TimeInterval As Long '时间间隔,毫秒
Private Sub Command1_Click()
'创建线程
SetTimer Me.hwnd, TimeId, TimeInterval, AddressOf myProc
SetTimer Me.hwnd, 2, TimeInterval, AddressOf myProc1
End Sub
Private Sub Form_Load()
n1 = 0
Text1.Text = ""
Text2.Text = 1000
TimeInterval = 1000
End Sub
Private Sub Form_Unload(Cancel As Integer)
'结束线程
KillTimer Me.hwnd, TimeId
KillTimer Me.hwnd, 2
End Sub
Private Sub Text1_Change()
Text3.Text = "线程1执行结果" & n1
End Sub