Ik heb een Thread gemaakt. Binnen deze thread wil ik een timer maklen die om de 5 seconde een actie uitvoert. Het aanmaken van de Timer gaat goed.
Met g_ThreadBinder.Log('beep',LogMessage); schrijf ik het weg naar een bestand/
De eerste beep komt er wel in, maar die in de functie TimerOnTimer niet.
Weet iemand hoe dit komt?
Gestripte versie van de code.
Met g_ThreadBinder.Log('beep',LogMessage); schrijf ik het weg naar een bestand/
De eerste beep komt er wel in, maar die in de functie TimerOnTimer niet.
Weet iemand hoe dit komt?
Gestripte versie van de code.
Delphi:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
| unit ReadAeroScout; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, SerialNG,StdCtrls,Grids,SyncObjs,Constants,ComObj,ReadThread, IdTCPClient,ScktComp,QExtCtrls,XMLDoc,xmldom,XMLIntf, msxmldom; type TReadAeroScout = class(TReadThread) private HeartBeatTimer : TTimer; procedure TimerOnTimer(Sender: TObject); procedure SetName; protected procedure Execute; override; end; var ReadThread : TReadAeroScout; implementation uses ThreadBinder; {------------------------------- TReadThread -----------------------------------} procedure TReadAeroScout.SetName; var ThreadNameInfo : TThreadNameInfo; begin ThreadNameInfo.FType := $100; ThreadNameInfo.FName := 'ReadThread'; ThreadNameInfo.FThreadID := $AAAAAAAA; ThreadNameInfo.FFlags := 0; try RaiseException( $406D1388, 0, sizeof(ThreadNameInfo) div sizeof(LongWord),@ThreadNameInfo); except end; end; procedure TReadAeroScout.Execute; begin SetName; g_ThreadBinder.Log('beep',LogMessage); HeartBeatTimer := TTimer.Create(nil); HeartBeatTimer.OnTimer:=TimerOnTimer; HeartBeatTimer.Interval := 1000; HeartBeatTimer.Enabled := true; end; procedure TReadAeroScout.TimerOnTimer(Sender: TObject); begin g_ThreadBinder.Log('beep',LogMessage); end; end. |