![]() |
Mein guter Freund Mr. ShellExecute
Hallo zusammen,
Ich häng seit ca ner halben stunde im Internet rum und such danach wie ich mithilfe von ShellExecute eine Datei in einem bestimmten Programm öffne. Geht hierbei um ne PDF, die nicht im standardprogramm alias Acrobat sondern im PDF Xchange-Viewer geöffnet werden soll. das ganze hab ich so begonnen:
Delphi-Quellcode:
_installpath wird aus der registery rausgezogen und die dateinamen werden halt noch angehangen, wie bring ich den jetz dazu, dass der mir meinen Report.pdf mit PDFXCview.exe startet?
ShellExecute(Application.Handle, 'open', PWideChar(_installpath+'PDFXCview.exe'),PWideChar(_installpath+'Report.pdf') , nil, SW_NORMAL);
Gruß alphanum |
Re: Mein guter Freund Mr. ShellExecute
Eigentlich sieht der Aufruf in Ordnung aus. Was passiert denn? Gar nichts oder wird die PDF doch mit Adobe gestartet?
|
Re: Mein guter Freund Mr. ShellExecute
Liegt die PDFXCview.exe und Report.pdf wirklich im _installpath?
|
Re: Mein guter Freund Mr. ShellExecute
Der Xchange viewer startet, allerdings ohne die datei
Jo die Dateien liegen beide wirklich drin. wie gesagt, programm startet, aber report wird ned gestartet. |
Re: Mein guter Freund Mr. ShellExecute
Vielleicht erwartet der Xchange viewer den Parameter in einem bestimmten Format. Klappt es, wenn Du den Befehl über Start-Ausführen absetzt?
[edit] Oder wenn Du den gesamten Parameter einmal in Anführungszeichen einschließt, falls Deine Variable Leerzeichen enthält? [/edit] |
Re: Mein guter Freund Mr. ShellExecute
oder falls Leerzeichen im Pfad sind empfehle ich:
Delphi-Quellcode:
Roter Kaste aka DeddyH: :twisted:
ShellExecute(Application.Handle, 'open', PWideChar(_installpath+'PDFXCview.exe'),PWideChar('"'+_installpath+'Report.pdf"') , nil, SW_NORMAL);
|
Re: Mein guter Freund Mr. ShellExecute
:tongue: :lol:
|
Re: Mein guter Freund Mr. ShellExecute
die leerzeichen warens, nun funktioniert es, vielen dank! :)
|
Re: Mein guter Freund Mr. ShellExecute
ShellExecute + PWideChar :?:
Laß diesen Code mal durch einen "älteren" (nicht Unicode) Compiler laufen! entweder ShellExecuteW + PWideChar ShellExecuteA + PAnsiChar oder ShellExecute + PChar Genau durch solche "Schlampereien" hat man bei späteren Umstellungen, innerhalb des Compilers, enorme Probleme. |
Re: Mein guter Freund Mr. ShellExecute
ich hab die kisten so umgewandelt weil der mir in den parametern nen pwidechar verlangt hat - geht das dann auch als pchar? wenn ja, werd ich das morgen auf arbeit gleich korrigieren, danke :)
|
Re: Mein guter Freund Mr. ShellExecute
Klar will ShellExecute bei DIR einen PWideChar, da
Delphi 2009/2010: ShellExecute = ShellExecuteW und das will PWideChar | PChar = PWideChar "älteres" Delphi: ShellExecute = ShellExecuteA und das will PAnsiChar | PChar = PAnsiChar Wenn man jetzt das veränderliche ShellExecute mit dem festen PWideChar mischt, dann kann es zu Problemen kommen. z.B. in Delphi 2007 und älter will ShellExecute einen PChar aka PAnsiChar, wärend in deinem Code PWideChar fest vorgegeben ist. Und irgendwann kommt UCS4, wo dann ShellExecute das 4-Byte-Unicode will, wärend PWideChar nur ein 2-Byte-Unicode liefert Also NIEMALS derartige Sachen mischen
Code:
Einzig und alleine bei Char und String wäre eine Vermischung möglich, da Delphis CompilerMagic dort eine automatische Typumwandlung implementiert hat, aber auch da "meckert" der Compiler und warnt vor eventuellen Datenverlusten, Aufgrund "unkontrollierter" Umwandlungen.
[color=silver]Api[/color] - Char - String - CharArray - PChar
[color=silver]Api[/color]A - AnsiChar - AnsiString - AnsiCharArray - PAnsiChar [color=silver]Api[/color]W - WideChar - WideString/UnicodeString - WideCharArray - PWideChar Wenn Daten nicht Bytegenau und Typsicher gespeichert oder übertagen werden sollen, dann einfach die 1. Variante (mit String und Co.) verwenden, da sie sich an den genutzen Compiler und seine Standardfunktionen anpaßt. Ansonsten sollte man es genau definieren, damit z.B. bei Compiler/IDE-Upgrade sich nichts verändert. > Char String PChar Integer Cardinal Pointer und die APIs ohne A/W sind dieser Veränderlichen |
Re: Mein guter Freund Mr. ShellExecute
Das hat Microsoft besser gelöst. Wenn ich dort in einem Programm ShellExecute benutze, wird je nach Kompilereinstellungen ShellExecuteA oder ShellExecuteW benutzt. Wenn ich dann noch das Makro _T (oder so) benutze, dann werden auch die zeichenketten passend konvertiert.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:41 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz