- - Action.Do method call interval

From: [at]} <Wojtek>
Date: Tue, 19 Jul 2005 08:59:54 -0400 (EDT)

----boundary-LibPST-iamunique-1288617208_-_-
Content-type: text/plain

Hi:

  there was an active discussion of this topic not long ago.
Doug Danforth posted a subsystem that uses Windows multimedia.
Getting down to 1 ms is tough. BlackBox is called from the Windows
event loop that limits the speed to tens of ms. There is a constant
in HostMenus (if I recall correctly). When you edit this, you can get
down to about 10 ms. Getting below 10 ms requires the multimedia timer,
and that is not part of BB. Let's see what Doug says, or e-mail him
directly.

Meanwhile, look at XYplane. It has the procedure ReadKey that
just reads the key from the keyboard. You can call it inside the
computation. Furthermore, since XYplane source is now available
in BB 1.5 Beta, you can see how to do such things.

W.

On Mon, 11 Jul 2005, Necati Ecevit wrote:

> Hello Blackbox users,
>
>
> Action.Do method is normally called at about 50 ms intervals if its body
> is empty (measured by PrivTestAction module as shown below) in Blackbox
> 1.5. Is it possible to decrease this dead time 1-3 ms?. i.e., I would
> like it to be called in 1-3 ms intervals.
>
> Alternatively, I can use the following technique;
> I have a long computation in a FOR loop. When the loop starts the
> framework is locked until it is finished. If I would like to to stop
> computation by pressing a command or command button how this can be
> achieved.
> (In Delphi, there was an Application.ProcessMessages procedure, when
> this procedure is called in a loop I could use the buttons to exit from
> the loop, that increases the computation time also)
>
> Thanks for help,
>
> - Necati
>
> (******************)
> MODULE PrivTestAction;
>
>
> IMPORT Out, Services;
>
> TYPE
> Action = POINTER TO RECORD (Services.Action) END;
>
> VAR i: INTEGER;
>
> action: Action;
> actionalive: BOOLEAN;
> dt0, time: LONGINT;
>
> PROCEDURE (a: Action) Do;
> BEGIN
> IF actionalive THEN
> time := Services.Ticks() - dt0;
> Services.DoLater(action, Services.now);
> dt0 := Services.Ticks();
> END;
> END Do;
>
>
> PROCEDURE Start*;
> BEGIN
> actionalive := TRUE;
> Out.String('Started'); Out.Ln;
> Services.DoLater(action, Services.now);
> dt0 := 0;
> END Start;
>
> PROCEDURE Stop*;
> BEGIN
> actionalive := FALSE;
> Out.String('time (ms): '); Out.Int(time, 0); Out.Ln;
> END Stop;
>
> BEGIN
>
> NEW(action);
> actionalive := FALSE;
>
> END PrivTestAction.
>
> PrivTestAction.Start
>
> PrivTestAction.Stop
>
> (* time: 50 - 55 ms *)
>
> --- BlackBox
> --- send subject HELP or UNSUBSCRIBE to blackbox{([at]})nowhere.xy
>
>

--- BlackBox
--- send subject HELP or UNSUBSCRIBE to blackbox{([at]})nowhere.xy



----boundary-LibPST-iamunique-1288617208_-_-
Content-type: application/rtf
Content-transfer-encoding: base64
Content-Disposition: attachment; filename="rtf-body.rtf"

e1xydGYxXGFuc2lcYW5zaWNwZzEyNTJcZnJvbXRleHQgXGRlZmYwe1xmb250dGJsDQp7XGYwXGZz
d2lzcyBBcmlhbDt9DQp7XGYxXGZtb2Rlcm4gQ291cmllciBOZXc7fQ0Ke1xmMlxmbmlsXGZjaGFy
c2V0MiBTeW1ib2w7fQ0Ke1xmM1xmbW9kZXJuXGZjaGFyc2V0MCBDb3VyaWVyIE5ldzt9fQ0Ke1xj
b2xvcnRibFxyZWQwXGdyZWVuMFxibHVlMDtccmVkMFxncmVlbjBcYmx1ZTI1NTt9DQpcdWMxXHBh
cmRccGxhaW5cZGVmdGFiMzYwIFxmMFxmczIwIEhpOlxwYXINClxwYXINCiAgdGhlcmUgd2FzIGFu
IGFjdGl2ZSBkaXNjdXNzaW9uIG9mIHRoaXMgdG9waWMgbm90IGxvbmcgYWdvLlxwYXINCkRvdWcg
RGFuZm9ydGggcG9zdGVkIGEgc3Vic3lzdGVtIHRoYXQgdXNlcyBXaW5kb3dzIG11bHRpbWVkaWEu
XHBhcg0KR2V0dGluZyBkb3duIHRvIDEgbXMgaXMgdG91Z2guIEJsYWNrQm94IGlzIGNhbGxlZCBm
cm9tIHRoZSBXaW5kb3dzXHBhcg0KZXZlbnQgbG9vcCB0aGF0IGxpbWl0cyB0aGUgc3BlZWQgdG8g
dGVucyBvZiBtcy4gVGhlcmUgaXMgYSBjb25zdGFudFxwYXINCmluIEhvc3RNZW51cyAoaWYgSSBy
ZWNhbGwgY29ycmVjdGx5KS4gV2hlbiB5b3UgZWRpdCB0aGlzLCB5b3UgY2FuIGdldFxwYXINCmRv
d24gdG8gYWJvdXQgMTAgbXMuIEdldHRpbmcgYmVsb3cgMTAgbXMgcmVxdWlyZXMgdGhlIG11bHRp
bWVkaWEgdGltZXIsXHBhcg0KYW5kIHRoYXQgaXMgbm90IHBhcnQgb2YgQkIuIExldCdzIHNlZSB3
aGF0IERvdWcgc2F5cywgb3IgZS1tYWlsIGhpbVxwYXINCmRpcmVjdGx5LlxwYXINClxwYXINCk1l
YW53aGlsZSwgbG9vayBhdCBYWXBsYW5lLiBJdCBoYXMgdGhlIHByb2NlZHVyZSBSZWFkS2V5IHRo
YXRccGFyDQpqdXN0IHJlYWRzIHRoZSBrZXkgZnJvbSB0aGUga2V5Ym9hcmQuIFlvdSBjYW4gY2Fs
bCBpdCBpbnNpZGUgdGhlXHBhcg0KY29tcHV0YXRpb24uIEZ1cnRoZXJtb3JlLCBzaW5jZSBYWXBs
YW5lIHNvdXJjZSBpcyBub3cgYXZhaWxhYmxlXHBhcg0KaW4gQkIgMS41IEJldGEsIHlvdSBjYW4g
c2VlIGhvdyB0byBkbyBzdWNoIHRoaW5ncy5ccGFyDQpccGFyDQpXLlxwYXINClxwYXINCk9uIE1v
biwgMTEgSnVsIDIwMDUsIE5lY2F0aSBFY2V2aXQgd3JvdGU6XHBhcg0KXHBhcg0KPiBIZWxsbyBC
bGFja2JveCB1c2VycyxccGFyDQo+XHBhcg0KPlxwYXINCj4gQWN0aW9uLkRvIG1ldGhvZCBpcyBu
b3JtYWxseSBjYWxsZWQgYXQgYWJvdXQgNTAgbXMgaW50ZXJ2YWxzIGlmIGl0cyBib2R5XHBhcg0K
PiBpcyBlbXB0eSAobWVhc3VyZWQgYnkgUHJpdlRlc3RBY3Rpb24gbW9kdWxlIGFzIHNob3duIGJl
bG93KSBpbiBCbGFja2JveFxwYXINCj4gMS41LiBJcyBpdCBwb3NzaWJsZSB0byBkZWNyZWFzZSB0
aGlzIGRlYWQgdGltZSAxLTMgbXM/LiBpLmUuLCBJIHdvdWxkXHBhcg0KPiBsaWtlIGl0IHRvIGJl
IGNhbGxlZCBpbiAxLTMgbXMgaW50ZXJ2YWxzLlxwYXINCj5ccGFyDQo+IEFsdGVybmF0aXZlbHks
IEkgY2FuIHVzZSB0aGUgZm9sbG93aW5nIHRlY2huaXF1ZTtccGFyDQo+IEkgaGF2ZSBhIGxvbmcg
Y29tcHV0YXRpb24gaW4gYSBGT1IgbG9vcC4gV2hlbiB0aGUgbG9vcCBzdGFydHMgdGhlXHBhcg0K
PiBmcmFtZXdvcmsgaXMgbG9ja2VkIHVudGlsIGl0IGlzIGZpbmlzaGVkLiBJZiBJIHdvdWxkIGxp
a2UgdG8gdG8gc3RvcFxwYXINCj4gY29tcHV0YXRpb24gYnkgcHJlc3NpbmcgYSBjb21tYW5kIG9y
IGNvbW1hbmQgYnV0dG9uIGhvdyB0aGlzIGNhbiBiZVxwYXINCj4gYWNoaWV2ZWQuXHBhcg0KPiAo
SW4gRGVscGhpLCB0aGVyZSB3YXMgYW4gQXBwbGljYXRpb24uUHJvY2Vzc01lc3NhZ2VzIHByb2Nl
ZHVyZSwgd2hlblxwYXINCj4gdGhpcyBwcm9jZWR1cmUgaXMgY2FsbGVkIGluIGEgbG9vcCBJIGNv
dWxkIHVzZSB0aGUgYnV0dG9ucyB0byBleGl0IGZyb21ccGFyDQo+IHRoZSBsb29wLCB0aGF0IGlu
Y3JlYXNlcyB0aGUgY29tcHV0YXRpb24gdGltZSBhbHNvKVxwYXINCj5ccGFyDQo+IFRoYW5rcyBm
b3IgaGVscCxccGFyDQo+XHBhcg0KPiAtIE5lY2F0aVxwYXINCj5ccGFyDQo+ICgqKioqKioqKioq
KioqKioqKiopXHBhcg0KPiBNT0RVTEUgUHJpdlRlc3RBY3Rpb247XHBhcg0KPlxwYXINCj5ccGFy
DQo+IFx0YWIgSU1QT1JUIE91dCwgU2VydmljZXM7XHBhcg0KPlxwYXINCj4gXHRhYiBUWVBFXHBh
cg0KPiBcdGFiIFx0YWIgQWN0aW9uID0gUE9JTlRFUiBUTyBSRUNPUkQgKFNlcnZpY2VzLkFjdGlv
bikgRU5EO1xwYXINCj5ccGFyDQo+IFx0YWIgVkFSIGk6IElOVEVHRVI7XHBhcg0KPlxwYXINCj4g
XHRhYiBcdGFiIGFjdGlvbjogQWN0aW9uO1xwYXINCj4gXHRhYiBcdGFiIGFjdGlvbmFsaXZlOiBC
T09MRUFOO1xwYXINCj4gXHRhYiBcdGFiIGR0MCwgdGltZTogTE9OR0lOVDtccGFyDQo+XHBhcg0K
PiBcdGFiIFBST0NFRFVSRSAoYTogQWN0aW9uKSBEbztccGFyDQo+IFx0YWIgQkVHSU5ccGFyDQo+
IFx0YWIgXHRhYiBJRiBhY3Rpb25hbGl2ZSBUSEVOXHBhcg0KPiBcdGFiIFx0YWIgXHRhYiB0aW1l
IDo9IFNlcnZpY2VzLlRpY2tzKCkgLSBkdDA7XHBhcg0KPiBcdGFiIFx0YWIgXHRhYiBTZXJ2aWNl
cy5Eb0xhdGVyKGFjdGlvbiwgU2VydmljZXMubm93KTtccGFyDQo+IFx0YWIgXHRhYiBcdGFiIGR0
MCA6PSBTZXJ2aWNlcy5UaWNrcygpO1xwYXINCj4gXHRhYiBcdGFiIEVORDtccGFyDQo+IFx0YWIg
RU5EIERvO1xwYXINCj5ccGFyDQo+XHBhcg0KPiBcdGFiIFBST0NFRFVSRSBTdGFydCo7XHBhcg0K
PiBcdGFiIEJFR0lOXHBhcg0KPiBcdGFiIFx0YWIgYWN0aW9uYWxpdmUgOj0gVFJVRTtccGFyDQo+
IFx0YWIgXHRhYiBPdXQuU3RyaW5nKCdTdGFydGVkJyk7IE91dC5MbjtccGFyDQo+IFx0YWIgXHRh
YiBTZXJ2aWNlcy5Eb0xhdGVyKGFjdGlvbiwgU2VydmljZXMubm93KTtccGFyDQo+IFx0YWIgXHRh
YiBkdDAgOj0gMDtccGFyDQo+IFx0YWIgRU5EIFN0YXJ0O1xwYXINCj5ccGFyDQo+IFx0YWIgUFJP
Q0VEVVJFIFN0b3AqO1xwYXINCj4gXHRhYiBCRUdJTlxwYXINCj4gXHRhYiBcdGFiIGFjdGlvbmFs
aXZlIDo9IEZBTFNFO1xwYXINCj4gXHRhYiBcdGFiIE91dC5TdHJpbmcoJ3RpbWUgKG1zKTogJyk7
IE91dC5JbnQodGltZSwgMCk7IE91dC5MbjtccGFyDQo+IFx0YWIgRU5EIFN0b3A7XHBhcg0KPlxw
YXINCj4gQkVHSU5ccGFyDQo+XHBhcg0KPiBcdGFiIE5FVyhhY3Rpb24pO1xwYXINCj4gXHRhYiBh
Y3Rpb25hbGl2ZSA6PSBGQUxTRTtccGFyDQo+XHBhcg0KPiBFTkQgUHJpdlRlc3RBY3Rpb24uXHBh
cg0KPlxwYXINCj4gUHJpdlRlc3RBY3Rpb24uU3RhcnRccGFyDQo+XHBhcg0KPiBQcml2VGVzdEFj
dGlvbi5TdG9wXHBhcg0KPlxwYXINCj4gKCogdGltZTogNTAgLSA1NSBtcyAqKVxwYXINCj5ccGFy
DQo+IC0tLSBCbGFja0JveFxwYXINCj4gLS0tIHNlbmQgc3ViamVjdCBIRUxQIG9yIFVOU1VCU0NS
SUJFIHRvIGJsYWNrYm94QG9iZXJvbi5jaFxwYXINCj5ccGFyDQo+XHBhcg0KXHBhcg0KLS0tIEJs
YWNrQm94XHBhcg0KLS0tIHNlbmQgc3ViamVjdCBIRUxQIG9yIFVOU1VCU0NSSUJFIHRvIGJsYWNr
Ym94QG9iZXJvbi5jaFxwYXINCn19AGxpbmc=


----boundary-LibPST-iamunique-1288617208_-_---
Received on Tue Jul 19 2005 - 14:59:54 UTC

This archive was generated by hypermail 2.3.0 : Thu Sep 26 2013 - 06:28:12 UTC