![]() |
Sinnvoller Aufbau größerer Projekte
Hallo,
weil ich momentan oft Probleme habe, meine Klassen, meine Form(en), etc. anständig zu organisieren, habe ich mich entschlossen, da mal die Profis zu fragen. Ich stehe dabei meißtens vor folgendem Problem: Soweit ich weiß, ist es üblich und auch sinnvoll, ein Hauptprogramm zu haben, das alle anderen Dinge, also Klassen, Formen, usw. verwaltet. Allerdings weiß ich nicht, wie ich das dann genau aufbauen kann. Das "normale" Hauptprogramm ist ja einfach die erste Form. Meine Frage wäre also, wie ich ein Hauptprogramm anlegen kann, das beim Programmstart zuerst ausgeführt wird, obwohl es nicht die FormUnit ist, mit der das Projekt angefangen wurde. Ich hoffe, ich konnte das einigermaßen erklären... Vielen Dank schonmal für eure Antworten! :dp: |
Re: Sinnvoller Aufbau größerer Projekte
Plane dein Projekt erst durch, bevor du mit der Codierung anfängst. Für dein "Hauptprogramm" (vielleicht meinst du damit sowas wie einen
![]() |
Re: Sinnvoller Aufbau größerer Projekte
Vllt ist meine Idee in Quellcode noch besser zu verstehen:
Delphi-Quellcode:
So könnte ich halt alles relativ einfach verwalten. "Hier laufen alle Fäden zusammen"...
unit mMainProgram;
interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, mMeineKlassen, mSonstwas, mForm1, mForm2; type TProgramm = class(TObject) //Das Programm soll natürlich keine Klasse sein, aber ich weiß grade nich, wie ich das besser ausdrücken sollte... private Form1: TForm1; Form2: TForm2; TMeineKlasse1; TMeineKLasse2; Array: Array[1..5,1..4] of irgendwas; procedure OnProgrammStart; [...] end; implementation {$R *.dfm} procedure OnProgrammStart; begin Form1:=TForm1.Create; Form1.show; end; procedure Form1.Button1OnClick; begin Array[1,4]:=irgendwas1; end; procedure Form2.Button1MouseMove; begin Form2.ShowMessage('Finger weg von der Maus!'); end; end. Meine Idee war halt, dass ich die Formen von da aus anzeige und die darauf gemachten eingaben im Hauptprogramm verarbeiten, ohne, dass die form da noch irgendwas mit zu tun hat. |
Re: Sinnvoller Aufbau größerer Projekte
Bei größeren Projekten muss man
![]() Am besten alles aufschreiben was benötigt wird und es sinnvol modelieren, dabei kann Dir ![]() Hier ist eine schöne Notationsübersicht von UML: ![]() Falls dein Projekt doch kleiner ausfällt, lohnt es sich aber auf jedenfall vorher zu überlegen, wie die Anforderungsdefinitionen sind und welche zusammenhänge zwischen Funktionen, Klassen, Modulen etc. herschen soll. Zu deiner anderen Frage: Du kannst doch die erste Form auch als Hauptprogramm machen... verstehe da nicht genau dein Problem... Du kannst ja später auch neue Forms öffnen mit z.b.:
Delphi-Quellcode:
form2.show;
|
Re: Sinnvoller Aufbau größerer Projekte
UML ist ne gute Möglichkeit sich einen Überblick zu verschaffen und eventuell kleine Denkfehler auszuradieren, bevor man anfängt, stimmt!
Zitat:
Wäre imho auch sehr übersichtlich. |
Re: Sinnvoller Aufbau größerer Projekte
Hi,
du hast doch dein Hauptprogramm wovon alle anderen Forms aufgerufen werden. Das ist die .dpr-Datei. In dieser kannst du ganz normalen Delphi-quellcode schreiben, welcher ALS ERSTES NACH DEM ÖFFNEN DER EXE ausgeführt wird. bei neuanlage sieht die so aus:
Delphi-Quellcode:
das kann man auch schön nutzen um startparameter abzufragen und was weis ich nit ;) dürfte abr genau das sein was du suchst
program Project1;
uses Forms, Unit1 in 'Unit1.pas' {Form1}; {$R *.res} begin Application.Initialize; Application.CreateForm(TForm1, Form1); Application.Run; end. beispiel:
Delphi-Quellcode:
program Project1;
uses Forms, Unit1 in 'Unit1.pas' {Form1}; {$R *.res} begin Application.Initialize; Application.CreateForm(TForm1, Form1); Application.CreateForm(TForm2, Form2); if Irgendetwasgesetzt then begin Form2.Showmodal; Form2.Release; end else begin Form1.Showmodal; Form1.Release; end end. |
Re: Sinnvoller Aufbau größerer Projekte
:roteyes: Ui, genau sowas meinte ich.
Aber das ganze benutzt ja die Formen nicht wie normale Klassen, sondern ruft sie einfach nur auf, oder kann ich da auch ganz normal Forms per Variablendefinition einsezen? |
Re: Sinnvoller Aufbau größerer Projekte
Klar geht das:
Delphi-Quellcode:
Allerdings solltest du dir die Grundlagen der OOP anschauen, das wird dir weiterhelfen...TMainForm = class(TForm) private FSubForm: TSubForm; public procedure ShowSubForm; end; ... procedure TMainForm.ShowSubForm; begin if not Assigned(FSubForm) then begin // Überprüft ob FSubForm geladen wurde Application.CreateForm(TSubForm, FSubForm); // Lädt FSubForm // alternative Application.CreateForm FSubForm := TSubForm.Create(Self); end; FSubForm.Show; end; Edit: Du kannst in Delphi auch ein DatenModul anlegen, darin kannst du Formen und Daten verwalten über die Projekt Optionen kannst du Einstellen, das nur das DatenModul geladen werden soll. mfg, Björn |
Re: Sinnvoller Aufbau größerer Projekte
hm, gerde da hatte ich mich ja gefragt, ob das in der .dpr geht...
Da wird nämlich kein Speicher für die Instanz der Klasse TForm1 reserviert, sie wird einfach aufgerufen...
Delphi-Quellcode:
Könnte ich das ganze dann in etwa so lösen...
program Project1;
uses Forms, Unit1 in 'Unit1.pas' {Form1}; {$R *.res} begin Application.Initialize; Application.CreateForm(TForm1, Form1); Application.Run; end.
Delphi-Quellcode:
+
program Project1;
uses //"Forms" werden hier nicht mehr gebraucht... Unit1 in 'Unit1.pas' {Form1}; {$R *.res} begin Application.Initialize; Application.CreateClass(TMeinHauptprogramm, Hauptprogramm); //...??? Application.Run; end.
Delphi-Quellcode:
type
TMeinHauptptogramm = class private Form1: TForm1; Form2punkt1, Form2punkt2: TForm2; //[...] public //[...] end; |
Re: Sinnvoller Aufbau größerer Projekte
müsste theoretisch auch gehen, aber dann musst du dich um das ganze erzeugen der form usw kümmern.. Objektorientiert ist shcön und gut und meiner meinung nach absolut wichtig, aber da wirds glaub ich etwas übertrieben ;)
probiere damit aber ruhig zu testzwecken einfach mal ein bissl rum, aber mehr übersicht bringt dir das, denke ich, nicht. Gruß |
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:42 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