 |
Das deutsche QBasic- und FreeBASIC-Forum Für euch erreichbar unter qb-forum.de, fb-forum.de und freebasic-forum.de!
|
Vorheriges Thema anzeigen :: Nächstes Thema anzeigen |
Autor |
Nachricht |
Dusky_Joe

Anmeldungsdatum: 07.01.2005 Beiträge: 1007 Wohnort: Regensburg/Oberpfalz
|
Verfasst am: 21.08.2006, 13:19 Titel: Problem mit GETMOUSE bei Nutzung von SHELL o.ä. Befehlen |
|
|
Hallo Leute!
Bei einem meiner Projekte ist mir ein recht interessantes, in erster Linie aber unangenehmes Verhalten von GetMouse aufgefallen: Nach einem Shell-Aufruf im Textmodus wird GetMouse scheinbar ignoriert.
Beispielcode, mit dem ich getestet habe, ob es ein allg. Problem ist, oder an sonstigen Faktoren meines Projekts:
Code: | Width 80, 60 ' um die nähe zu meinem Programm zu wahren.
Locate 1, 1, 0 ' die beiden Zeilen haben aber keinen Einfluss auf das Getmouse-Prob.
Dim Shared As Integer x, y, b ' Das SHARED ist ebenso nur wegen der Situationsnähe.
Do
Sleep 1
GetMouse x, y, , b
Locate 1, 1
Print Using "##, ##, #"; x, y; b
Loop Until b
Shell "start Explorer " + Chr(34) + "C:\" + Chr(34)
Dim As Integer i
Do
Sleep 1
GetMouse x, y, , b
Locate 1, 1
Print Using "##, ##, #, ####"; x, y; b; i
i += 1
Loop Until b |
Wie man am fortlaufenden i erkennt, wird die zweite Do-Loop durchaus abgearbeitet, aber x, y und b werden nicht mehr aktualisiert. Die ändert sich auch nicht, wenn das Explorer-Fenster geschlossen wird.
Compiler: 0.17 testing @ WinXP Home.
* Lässt man diesen Test in einen beliebigen Gfx-Modus um, treten keine Probleme auf.
* Ruft man direkt nach dem Shell erneut Screen 0 auf, wird das Prog beendet. (Errorlevel 0)
* Eine Reihenfolge SHELL - SCREEN 1 - SCREEN 0 hat den selben Effekt.
* Es bleibt völlig egal, ob der Explorer gestartet wird, oder irgendein anderes Programm.
Sogar bei DIR weigert sich GetMouse, seien Arbeit zu tun.
* Ich hab das ganze auch mit EXEC getestet, es liegt also nicht direkt am SHELL.
Kennt irgendjemand einen anderen Walkaround, als das ganze Projekt (derzeit ca 100KB) auf Gfx umzuschreiben?
Alleine der Nostalgie wegen wollte ich zumindest im first Release dieses Progs im Txtmode bleiben...
Danke für eure Mühen
Have a nice day
Ciao
Dusky_Joe _________________ fully biological degradable
Once, the big wave arrives, you've got two ways, you can go:
Either, you ride it, or you don't do.
But, if you don't ride, you'll never know wether you'd have gone wet. |
|
Nach oben |
|
 |
volta
Anmeldungsdatum: 04.05.2005 Beiträge: 1876 Wohnort: D59192
|
Verfasst am: 21.08.2006, 17:44 Titel: |
|
|
Hi Dusky_Joe,
ich habe leider keine Lösung,
nur Beobachtungen deines Progs unter ME (FB0.16 stable):
Bei Aufruf der Shell wird das Konsolenfenster geschlossen und ein neues Konsolenfenster für 'Shell Prog' geöffnet.
Darin wird keine Anzeige (x,y,b,i) des alten Progs ausgegeben.
Mit exec ("C:\WIND\CALC.EXE" ,"" ) tritt etwas unvermutetes auf, wird Calc beendet arbeitet das Prog normal weiter.
Bleibt Calc ist das Prog wie eingefroren (die 2. DO .. LOOP wird nicht ausgeführt).
und der Hammer:
Code: | Screen 0
Dim Shared As Integer x, y, b, i
Do
Sleep 1
GetMouse x, y, , b
Locate 1, 1
Print Using "##, ##, #"; x, y; b
Loop while inkey=""
Shell "Dir " + Chr(34) + "C:\" + Chr(34)
'Screen 0
Do
Sleep 1
GetMouse x, y, , b
Locate 1, 1
Print Using "##, ##, #, ####"; x, y; b; i
i += 1
Loop while inkey="" | das Prog arbeitet ohne Tadel
Zeigt mir das Hauptverzeichnis im alten Konsolefenster an,
und getmouse in der 2. LOOP arbeitet auch richtig. ???
Unter XP SP2 mit FB0.16 stable kann ich deine Beobachtungen nur bestätigen.
Gruß Volta _________________ Warnung an Choleriker:
Dieser Beitrag kann Spuren von Ironie & Sarkasmus enthalten.
Zu Risiken & Nebenwirkungen fragen Sie Ihren Therapeuten oder Psychiater. |
|
Nach oben |
|
 |
Michael Frey

Anmeldungsdatum: 18.12.2004 Beiträge: 2577 Wohnort: Schweiz
|
|
Nach oben |
|
 |
|
|
Du kannst keine Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum nicht antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen.
|
|