Da ich in letzter Zeit oft gefragt wurde, wie man denn die "Qt/Windows Open Source Edition" unter Dev-C++ installiert und ich beim Kompilieren von Projekten Probleme hatte und dafür keine richtige Beschreibung gefunden habe, die das gut zusammenfasst, kam ich auf die Idee, selber was zu schreiben. Also hoffe ich, dass dieser kurze Artikel den Lesern weiterhelfen kann ;-) .
2 Installieren
Zunächst sollten Sie erst einmal alles sauber installieren, denn dazu habe ich bisher die meisten Fragen bekommen. Was Sie am Anfang brauchen und ich nur der Vollständigkeit halber hier aufzähle, ist der Dev-C++ und die Qt-Library.
Das Installieren von Dev-C++ sollte keine Probleme darstellen. Deswegen überspringe ich das gleich und gehe zur Installation von Qt.
Sie haben jetzt die Wahl zwischen qt-win-opensource-4.4.x-mingw.exe und qt-win-opensource-src-4.4.x.zip. Wenn Sie MinGW bereits installiert haben, was sehr wahrscheinlich ist weil DevCpp MinGW installiert, können Sie die Source Version nehmen.
Die MinGW Version hat den Vorteil das der Installations-Assistent dabei ist und QT wird schon einmal Kompiliert. Nachdem Sie die ausführbare Datei heruntergeladen haben, können Sie sie ganz normal ausführen und dem Installationsassistenten folgen und damit die Qt-Dateien auf Ihre Festplatte kopieren. Wenn Sie die Source Version runtergeladen haben einfach in ein Verzeichnis ihrer Wahl entpacken. Wobei Sie ein Verzeichnis Pfad ohne Leerzeichen wählen sollten, da der MinGW Kompiler Probleme beim Auflösen von Leerezeichen in Verzeichnispfaden hat.
Nun müssen die Umgebungsvariablen gesetzt werden und das erledigen wir mit einem kleinem Skript, wobei Sie die Pfade in QTDIR, QMAKESPEC und PATH mit ihrem QT Pfad ändern müssen.
Code:
set QTDIR=C:\Qt\4.4.x
set PATH=C:\Qt\4.4.x\bin
set PATH=%PATH%;lokalerDevCppPfad\bin
set PATH=%PATH%;%SystemRoot%\System32
set QMAKESPEC=C:\Qt\4.4.x\mkspecs\win32-g++
Code:
set QTDIR=C:\Qt\4.4.x
set PATH=C:\Qt\4.4.x\bin
set PATH=%PATH%;lokalerDevCppPfad\bin
set PATH=%PATH%;%SystemRoot%\System32
set QMAKESPEC=C:\Qt\4.4.x\mkspecs\win32-g++
Code:
set QTDIR=C:\Qt\4.4.x
set PATH=C:\Qt\4.4.x\bin
set PATH=%PATH%;lokalerDevCppPfad\bin
set PATH=%PATH%;%SystemRoot%\System32
set QMAKESPEC=C:\Qt\4.4.x\mkspecs\win32-g++
Jetzt nicht vergessen, in den Qt-Ordner zu wechseln und die configure.exe auszuführen. Dann ist nur noch die Lizenz mit einem 'y' zu bestätigen.
Bild1
Das war bisher der einfache Teil, der auch immer bestens klappt, nur kommt dann oft die Frage: "Wie binde ich das jetzt unter Dev-C++ ein?". Da dem gutem evilissimo die Frage anscheinend auch zu oft gestellt wurde, hat er ein kleines Programm geschrieben, das hier sehr hilfreich ist und für Sie ein paar Arbeiten übernimmt. Ich verweise mal gleich darauf: http://www.evilissimo-softdev.de/downloads.html. Es ist der QT-Template-Installer.
Den kopieren Sie in Ihr Dev-C++-Verzeichnis und führen ihn aus. Jetzt sollte nur kurz ein Fenster aufpoppen und schnell wieder verschwinden. Wenn Sie nun Dev-C++ öffnen, sollte unter "Neue Projekte" im "Basic"-Reiter ein "QT 4.0 Application" auswählbar sein (siehe Bild 2).
Bild 2
Um fortzufahren, wählen Sie "QT 4.0 Application" aus und erstellen ein neues Projekt. Danach sehen Sie ein kleines Beispielprogramm, das ein Fenster erstellt, in dem ein Button mit der Beschriftung "Servus Welt" erscheint. Wenn Sie das Programm jetzt kompilieren können, können Sie den nächsten Teil überspringen.
So, jetzt müssen Sie das ganze auf Ihr System abstimmen. Dazu gehen Sie unter "Tools -> Compiler Options". Dort wählen Sie den Reiter "Directories" und sehen nach, ob die Qt-Include-Verzeichnisse richtig eingetragen sind. Wählen Sie den "C++ Includes"-Reiter aus und suchen nach den Qt-Verzeichnissen. Wenn dort keine sind, müssen Sie mit "Add" "QT\include" und alle Verzeichnisse in "QT\include" einzeln einfügen. So, dass es wie auf Bild 3 aussieht.
Bild3
Dasselbe müssen Sie noch mal unter "Project->Project Options" machen. Wenn das erledigt ist, müssen Sie den Reiter "Parameters" auswählen und dort unter Linker alle Verzeichnisse löschen, die sich auf Qt beziehen, und dann mit Hilfe von "Add Library or Object" in das Qt-Verzeichnis gehen und dort alle Dateien auswählen, die im lib-Ordner enthalten sind; auf "OK" klicken und nun sollten sie alle im Linkerfeld erscheinen. Dann klicken Sie auf "OK" und anschließend sollten Sie noch mal versuchen, das Programm zu kompilieren. Wenn es immer noch nicht funktioniert, sollten Sie erst einmal überprüfen, ob Sie irgendetwas übersprungen haben, oder im Forum posten.
3 qmake
Bevor es hier weiter geht, kommt ein bisschen Theorie. Was passiert eigentlich, nachdem auf "Kompilieren" gedrückt wurde?
Bild 4
Es geschehen folgende Schritte:
1. Es wird das make-Programm ausgeführt, dem das von Dev-C++ erstellte make-file als Parameter angeben wird. In dem make-file stehen die Abhängigkeiten Ihrer Projektdateien.
2. Jetzt werden die cpp-Dateien vom Compiler zu Objektdateien kompiliert. Der Kompiler wandelt also Ihre cpp-Dateien in eine Maschinensprache um.
3. Als Nächstes werden die Objektdateien mit den Bibliotheken gelinkt. Es werden Ihre Dateien mit der oder den Bibliotheken, die Sie benutzen, zu einem Binary File zusammengepackt. Unter Windows heißt das zu einer .EXE Datei.
Bild 5
Dasselbe passiert, wenn Sie ein Qt-Projekt kompilieren wollen, nur dass make-files plattform- und compilerabhängig sind. Das hat Trolltech durch eine Spracherweiterung mit Makros gelöst. Wozu und wie intressiert an dieser stelle nicht. Aber wer mehr darüber erfahren möchte, findet Sie hier mehr .
Im Enddefekt passiert dasselbe, nur dass ein Schritt dazu kommt. Es werden Ihre cpp-Dateien im MOC (Meta Object Compiler) in cpp-Dateien übersetzt. Diese gehen dann an den Compiler und es geht wie oben beschrieben weiter. Der MOC ist im Enddefekt dasselbe wie der Compiler, nur dass er keine Objektdateien generiert, sondern cpp-Dateien. Damit dies funktioniert, müssen Sie mittels qmake erst eine .pro-Datei und dann damit ein make-file generieren.
Öffnen Sie die Konsole und wechseln Sie in das Projektverzeichnis. Als Erstes müssen Sie die .pro-Datei erstellen. Das passiert, indem Sie
Code:
qmake -project
Code:
qmake -project
Code:
qmake -project
eingeben. Mit dem Befehl "qmake -project" wird eine .pro Datei erstellt die aus all den Dateien mit folgender Endungen bestehen *.c; *.ui; *.y; *.l; *.ts; *.xlf; *.qrc; *.h; *.hpp; *.hh; *.hxx; *.cpp; *.cc; *.cxx. Wenn Sie mehr Informationen über .pro Files wissen wollen finden Sie hier mehr.
Wenn jetzt eine leere Zeile und ein neuer Prompt kommt, dann läuft alles richtig.
Wenn nicht, sondern der Befehl oder die Datei nicht gefunden werden konnte, dann müssen Sie unter "Systemsteuerung->System" den Reiter "Erweitert" und dann den Button "Umgebungsvariablen" auswählen. In dem Dialog unter Systemvariablen suchen Sie nach der Variable "PATH", drücken den "Bearbeiten"-Button und fügen am Ende "DeinQtVerzeichnis\bin" ein. Drücken Sie "OK" und versuchen Sie die Eingabe von "qmake –project" erneut oder Starten Sie den Rechner neu manchmal brauch Windows einen Neustart um neue Systempfade einzupflegen.
Bild 6
Zur Kontrolle können Sie in Ihrem Projektordner nachsehen. Dort sollte es jetzt eine .pro-Datei und ein make-file geben. Danach geben Sie "qmake" ein und dann müssten zwei Dateien dazugekommen sein, ein "Makefile.Debug" und ein "Makefile.Release". Damit haben Sie das make-file erstellt und müssen das nun in die Dev-C++-Umgebung einbinden.
Bild 7
Dazu gehen Sie wieder zum Dev-C++ zurück und öffnen die "Projektoptionen". Wählen Sie diesmal den "Makefile"-Reiter. Dort klicken Sie die "Use custom make file (…)"-Checkbox aus, wählen den Ordner neben dem leeren Textfeld aus und benutzen jetzt eine der beiden zuletzt erstellten Dateien, was dann in etwa wie auf Bild 6 aussehen sollte.
Bild 8
Jetzt sollten Sie das Projekt einmal kompilieren und in dem Release- oder Debugordner nach der *.exe schauen, ob sie ordnungsgemäß erstellt wurde.
Zum Schluss wollen Sie wahrscheinlich, dass nach dem Kompilieren Dev-C++ die EXE auch ausführen kann. Dafür wählen Sie in dem "Project Options"-Dialog den "Build Options"-Reiter. Daraufhin klicken Sie den Button neben dem "Executable output directory"-Eingabefeld an und wählen dann dementsprechend den "Release"- oder "Debug"-Ordner aus. Schließlich geben Sie im untersten Textfeld den Namen der ausführbaren Datei ein. Jetzt sollte Ihr Programm kompiliert werden. Wenn Sie neue Dateien hinzufügt, müssen Sie auch eine neue .pro-Datei erstellen und den Rest wie oben beschrieben noch einmal durchführen. Wenn Ihnen das zu viel Arbeit ist, können Sie sich auch ein Script schreiben, das Sie anstatt des make-files einfügen und das jedes Mal die vorhin beschriebenen Schritte ausführt.
Ich hoffe, ich konnte weiterhelfen,
Gruß mosta
-----
_________________ “Computers are like bikinis. They save people a lot of guesswork.” (Sam Ewing)
The men who program in C++ are Real Men. The women who program in C++ are Real Men too
Zuletzt bearbeitet von Marc++us am 21:15:42 26.01.2009, insgesamt 7-mal bearbeitet
Ich habe ungelogen Tage damit verbracht und herumprobiert, dies zum Laufen zu bringen - doch wenn man nicht weiß, was wichtig ist und was nicht, kann man sich schnell mit unwichtigen Sachen herumschlagen, die letztendlich doch nicht zum Erfolg führen.
Mit dieser Anleitung habe ich's innerhalb von wenigen Minuten zum Laufen gebracht - sehr schön!
Mir erging es wie dem Vorredner, ich habe immer wieder versucht, es zu laufen zu bringen, aber ohne Erfolg, abgesehen von dem heutigen Tag mit dieser Anleitung. Eine Frage hätte ich aber doch noch:
Es ist im Dev-C++ äußerst mühsam, im Projekt->Projekt Optionen->Verzeichnis->Include-Verzeichnis alle QT Pfade zu korrigieren.
a) ist es überhaupt notwendig, wenn bereits mit qmake ein makefile erstellt wurde
b) kann das der Dev nicht allein, oder wenigstens als Standard speichern
Ich bin leider überfordert mit diesen Fragen... :-/
die Zeit, die Du mit dem Eintragen der Compiler-Einstellungen verbringst ist doch nicht zu vergleichen mit der Zeit, die Du vorher mit den vergeblichen Versuchen verbracht hast. Die Einstellungen musst Du nur ein einziges Mal zu Beginn des Projekts machen, dann nicht mehr ... wenn's hoch kommt verbringt ein schneller Tipper/Klicker vielleicht fünf bis zehn Minuten damit ...
erstmal vielen Dank an Mosta für die gute Anleitung.
Schritt eins und zwei funktionieren bei mir auch einwandfrei.
Solange ich kein Q_OBJECT mit einbinde lassen sich die Programme auch ohne Schritt drei problemlos compilieren.
Schritt drei habe ich nichtdestotrotz natürlich auch durchgeführt!
Ich hab hier ein kleines Programm und werde nicht richtig schlau aus den Fehlermeldungen!
Lässt sich problemlos ohne Q_OBJECT compilieren aber leider nicht mit!
Fehlermeldung
Zitat:
releasemain.o(.text+0x2a):main.cpp: undefined reference to `vtable for My_MainWindow'
releasemain.o(.text+0x31):main.cpp: undefined reference to `vtable for My_MainWindow'
releasemain.o(.text+0x6a):main.cpp: undefined reference to `vtable for My_MainWindow'
releasemain.o(.text+0x71):main.cpp: undefined reference to `vtable for My_MainWindow'
collect2: ld returned 1 exit status
make.exe: *** [release\test2.exe] Error 1
Ausführung beendet
Würde mich freuen, wenn ihr mir bei der Poblemlösung helfen könntet.
Nächstes Thema anzeigen Vorheriges Thema anzeigen
Sie können keine Beiträge in dieses Forum schreiben. Sie können auf Beiträge in diesem Forum antworten. Sie können Ihre Beiträge in diesem Forum nicht bearbeiten. Sie können Ihre Beiträge in diesem Forum nicht löschen. Sie können an Umfragen in diesem Forum nicht mitmachen.
c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums
für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de
Werbekostenerstattung verdient werden kann.
Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info, www.c-sar.de, www.c-plusplus.net und www.baeckmann.de
enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt
(vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in
privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden.
Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere
übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.