![]() |
Re: aus dll code in hauptanwendung ausführen
Zitat:
ich weiß nicht ;-) was genau meinst du?? naja ansonnsten wollte ich es auch eigentlich nicht mehr ändern, das ist schon aus früheren programmierzeiten.. edit: achja, den aufruf für die dll und so hab ich schon, wie gesagt die läuft schon, nur will ich halt jetzt einen opendialog aus der dll starten.. |
Re: aus dll code in hauptanwendung ausführen
Zitat:
mit funktionspointern zu arbeiten macht nicht immer sinn. will man einfache funktionen auslagern bzw. will man sein programm durch ersetzen der dll aktualisieren, ist es sicher sinnvoller wenn man seine dll statisch benutzt. funktionen die vom programm unbedingt gebraucht werden, sollten auch verfuegbar sein. ist die dll nicht verfuegbar, startet das programm erst garnicht. wird die addresse zur funktion zur laufzeit ausgelesen, muesste man manuelles exception handling betreiben (á al 'das programm benoetigt die dll 'miep.dll') => mehr aufwand als es wert ist ein funktionspointer macht sinn, wenn man sein programm durch eine dll erweitern moechte (wie im obigen bsp. if Assigned() then ..). will man eine unbestimmte anzahl von dll's benutzen, kann man das nur dynamisch (macht ja auch sinn. man kann ja nicht wissen, wieviele dll's noch hinzu kommen werden). dynamisches benutzen von dll's recht & gut, die benutzung muss aber auch gerechtfertigt sein. imho sind die ganzen winapi funktionen auch nicht dynamisch, sondern statisch niedergeschrieben. [/ot] Zitat:
eine dll sieht im grunde genau so aus wie ein normales programm. du erstellst einfach dein hilfe fensterchen (als waere es ein anderes programm), speicherst es und oeffnest die *.dpr datei (in einem editor!). gleich in der ersten zeile aenderst du das 'program' in ein 'library'. fertig. benutzen kannst du das ding mit einem einfachen Loadlibrary() call. du mappst einfach die dll in den speicher und dein form fenster wird erstellt. idr. sollte das ding wieder freigegeben werden, sobald das fenster (welches aus der dll gestartet wurde) beendet wird. sollte man versuchen. ansonsten einfach mit FreeLibrary() freigeben :o) |
Re: aus dll code in hauptanwendung ausführen
@1234588:
Wenn er dem programm aus der DLL heraus ein onClick ereignis zur verfügung stellen will geht es nur über eien CallBack Prozedur. Und er hat ja gesagt er will im Programm auf eben ein OnClick auf einen Button reagieren. Dann muss er wohl das Ereignis per Funktionspointer zuweisen können also die Adresse des Ereignisses der DLL bekannt geben. Das ist die Lösung für das von ihm im ersten Post gestellte Problem. Wie er die DLL im Program verfügbar macht hat mit dem Problem nichts zu tun und ist eine philosophische Frage. Ich persönlich würde wenn ich davon ausgehen kann das ich der einzige bin der an dem Programm entwickelt eine BPL nehmen. Da kann ich die Classen und Objekte direkt benutzen. Aber wenn er halt ne DLL gemacht hat... @IBCCalleb: hast du im dll eine "exports" Klausel die eine Methode zum starten des Dialogs exportiert? |
Re: aus dll code in hauptanwendung ausführen
Zitat:
hab jetzt aber noch was im internet gefunden unter: ![]() und noch was in der dp: ![]() ich hoffe mal es hilft mir weiter hab nur gerade keine zeit dafür mach ich montag weiter mit.... aber für tipps, währe ich trotzdem noch offen, wie ich das ereignis auf dem simplen button click in meiner hauptanwendung reagieren kann... |
Re: aus dll code in hauptanwendung ausführen
Zitat:
function SendMessage(hWnd:HWND; Msg:UINT; wParam:WPARAM; lParam:LPARAM):LRESULT; external 'user32' name 'SendMessageA'; okay, was ist dann das?
Delphi-Quellcode:
die addresse ist also sehr wohl bekannt :o)
uses windows;
begin writeln('0x', longint(@SendMessage)); readln; end. es ist moeglich, die OnClick property zu ueberschreiben. mit was man diese procedure ueberschreibt kann dem compiler egal sein (solange die aufrufkonvektion & groeße der argumente stimmt). was spricht also dagegen, das man das mit einer statisch eingebunden funktion/prozedur aus einer dll macht? wers mag kann ja auch die prozedur aus der dll in der OnClick prozedur aufrufen. jetzt sagst du mir bitte, was daran nicht machbar ist? Zitat:
uebrigens kann man auch objekte ueber dll's benutzen. man muss nur auf beiden seiten die klassen deklaration haben ;) Zitat:
Delphi-Quellcode:
ich weiß nicht, wie die prozedur in der dll aussieht, deshalb muesstest du evtl. zeile 3 (proc: procedure) anpassen. des weitern musst du noch den namen deiner dll in zeile 6 aendern und den namen der prozedur in zeile 9 eintragen.
procedure start;
var proc: procedure; lib: LongWord; begin lib := LoadLibrary('deine dll'); if lib <> 0 then begin proc := GetProcAddress(lib, 'dein_proceduren_name'); if Assigned(proc) then proc; end; end; außerdem kannst du bei bedarf die moeglichen fehler behandeln (wenn lib = 0 oder wenn Assigned() = false waere). problem ist, das du die hilfe-schaltflaeche dann immer sichtbar bzw. dueckbar haben musst. das laesst sich aber auch eleganter loesen. pruefe einfach im form create ob die dll vorhanden ist, oder noch besser ob die funktion die du importieren moechtest, vorhanden ist (siehe bsp. -> wenn Loadlibrary() 0 zurueck gibt, ist die dll entweder nicht vorhanden oder fehlerhaft. mit Assigned() pruefst du dann, ob die prozedur vorhanden ist). je nach dem kannst du dann die hilfe schaltflaeche anzeigen, drueckbar machen, oder was auch immer. ich hoffe, ich hab das einigermaßen verstaendlich rueber gebracht, hatte gerade feierabend =) |
Re: aus dll code in hauptanwendung ausführen
Hallo, du hast ihm erklärt wie man eine Procedure aus einer DLL einbindet. Das ist ganz normaler standard.
Jetzt kann er immer noch keine Anwedungsmethode der DLL als Ereigniss zuweisen. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:54 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