| |
|
|
E.T. | Moin, sieht jemand eine Möglichkeit, die Ausgaben eines Konsolen-Programmes (welche ja im cmd-Fenster sind), im eigenen Programm-Fenster einzubinden ?? Meine jetzige Umsetzung, das cmd-Fenster einzufangen, die Größe anzupassen und dieses dann unterhalb meines Programm-Fensters anzudocken gefällt mir überhaupt nicht: Ich muß immer das Fremdfenster mit überwachen (Größenänderung, verschieben, minimieren, wiederherstellen etc.), und da das Konsolen-Programm recht Hardware- und Speicher-Lastig ist, kommt irgendwie alles nicht so recht hinterher . Und die cmd-Fenster sind auch in jeder Win-Version noch unterschiedlich groß...
Also irgendwie das cmd-Fenster in mein Programm-Fenster integrieren, geht sowas ??? Hab bis jetzt keine zündende Idee...
Das Konsolen-Proggi macht auch keine Ausgaben in eine .log-Datei oder so, welche ich anzapfen könnte (Das Prog ist nicht von mir, ich will nur ne Oberfläche dazu, da die Bedienung komplett per Start-Parameter funzt und das Ansprechen der Laufwerke wie bei SCSI (1:0:0, 0:1:0 etc.) doch arg an die Nerven geht, bis man das richtige LW hat...). |
|
|
| Grüße aus Sachsen... Mario WinXP, Win7 (64 Bit),Win8(.1),Win10, Win 11, Profan 6 - X4, XPSE, und 'nen schwarzes, blinkendes Dingens, wo ich das alles reinschütte... | 11.04.2009 ▲ |
|
|
|
|
Andreas Miethe
| So etwas ? KompilierenMarkierenSeparieren $H Windows.ph
$H Structs.ph
Struct PROCESS_INFORMATION = ~PROCESS_INFORMATION
Struct SECURITY_ATTRIBUTES = ~SECURITY_ATTRIBUTES
Struct STARTUPINFO = ~STARTUPINFO
DEF &NORMAL_PRIORITY_CLASS $20
DEF &STARTF_USESTDHANDLES $100
DEF &STARTF_USESHOWWINDOW $1
CLS ~GetSysColor(~COLOR_BTNFACE)
SetDialogFont ~GetStockObject(~ANSI_VAR_FONT)
Var Ende& = 0
Var Multi& = Create(MultiEdit,%hwnd,,1,10,500,400)
Var Button& = Create(Button,%hwnd,Start,540,10,80,24)
Var Button1& = Create(Button,%hwnd,Ende,540,40,80,24)
Whilenot Ende&
Waitinput
If Clicked(Button1&)
Ende& = 1
ElseIf Clicked(Button&)
SetText Multi&,
Beispiel mit Ping
DirektDosOutputToMultiedit(, ping localhost,255,Multi&)
Endif
EndWhile
End
Proc DirektDosOutputToMultiedit
Parameters Progname$,Command$,MemBuffer&,Multiedit&
Declare hRPipe&,hWPipe&,pRBytes&,Result&
Declare PI#,SI#,SA#
Dim PI#,PROCESS_INFORMATION
Dim SI#,STARTUPINFO
Dim SA#,SECURITY_ATTRIBUTES
Declare StringBuffer$
StringBuffer$ = Space$(MemBuffer&)
SA#.nLength& =SizeOf(SA#)
SA#.bInheritHandle& = 1
SA#.lpSecurityDescriptor& = 0
Result& = ~CreatePipe(Addr(hRPipe&), Addr(hWPipe&), SA#, 0)
If Result& = 0
MessageBox(Pipe konnte nicht gestartet werden,,0)
End
Endif
If Progname$ <>
Command$ = + Command$
Endif
SI#.cb& = SizeOf(SI#)
SI#.dwFlags& = &STARTF_USESHOWWINDOW | &STARTF_USESTDHANDLES
SI#.hStdOutput& = hWPipe&
SI#.hStdError& = hWPipe&
If Progname$ =
Result& = ~CreateProcess(0, Addr(Command$), SA#, SA#, 1, &NORMAL_PRIORITY_CLASS, 0, 0, SI#,PI#)
Else
Result& = ~CreateProcess(Addr(Progname$), Addr(Command$),SA#,SA#,1,&NORMAL_PRIORITY_CLASS, 0, 0,SI#,PI#)
Endif
If Result& <> 1
MessageBox(Datei nicht gefunden,,0)
End
Else
Endif
Result& = ~CloseHandle(hWPipe&)
Var out$ =
While Result& <> 0
Result& = ~ReadFile(hRPipe&,Addr(StringBuffer$),MemBuffer&,Addr(pRBytes&), 0)
If pRBytes& > 0
Out$ = Left$(StringBuffer$,pRBytes&)
~OemToChar(Addr(Out$),Addr(Out$))
Settext Multiedit&,GetText$(Multiedit&)+Out$
If Instr(RUNNING,Out$)
Messagebox(läuft,läuft,0)
endif
Endif
Endwhile
~CloseHandle(PI#.hProcess&)
~CloseHandle(PI#.hThread&)
~CloseHandle(hRPipe&)
Dispose PI#,SI#,SA#
EndProc
|
|
|
| Gruss Andreas ________ ________ ________ ________ _ Profan 3.3 - XProfanX2 Win 95,98,ME,2000,XP,Vista - Win 7 32 / 64 Bit ASUS X93S - Intel Core I7-NVIDIA GForce 540M 8GB Arbeitsspeicher Homepage : [...] | 11.04.2009 ▲ |
|
|
|
|
Paul Glatz | @E.T. Zeig mal wie du es jetzt machst. |
|
|
| |
|
|
|
Paul Glatz | @E.T. Wenn es reicht nach dem beenden des Programmes die ausgabe zu haben kannst du KompilierenMarkierenSeparieren Helfen. Die ausgabe liegt in der Angegebenen Textdatei! |
|
|
| |
|
|