Visual Studio 2010 Hilfe
-
Einen guten Morgen euch allen!
Ich habe heute schon folgendes Problem, für das ich eure Hilfe benötige:
Seit kurzem bin ich von wxdevcpp zu Visual Studio 2010 Professional
umgestiegen. Ich erstelle ein neues Windows-Forms Projekt, was auch
problemlos möglich ist.
Ich habe nun meinen Frame vor mit, in den ich wie gewohnt via Drag and
Drop meine Steuerelemente (Buttons, Choicebox...usw..) hineinziehen kann.
Mache ich nun einen Doppelklick auf einen Button, so erzeuge ich wie
gewohnt eine Funktion (onclick..) die ausgeführt wird, wenn der Button
geklickt wird. Jetzt mein Problem: Warum steht diese Funktion in der
*.h -Datei und nicht in der .cpp ???? Ich kann doch in der *.h Datei
nicht programmieren, da stehen doch nur die einzelnen Methoden und Variablen.
Hoffe ihr versteht mich.
Mein zweites Problem besteht darin, dass ich sehr gerne eine onclick-Fkt
wieder entfernen würde. Ich finde aber einfach die Funktion nicht, wie
ich eine Solche Methode wieder entfernen kann. Könnt ihr mir helfen??
Ich würde mich freuen, wenn ihr mir antworten würdet.Liebe Grüße.
Melli
-
Dieser Thread wurde von Moderator/in Martin Richter aus dem Forum MFC (Visual C++) in das Forum C++/CLI mit .NET verschoben.
Im Zweifelsfall bitte auch folgende Hinweise beachten:
C/C++ Forum :: FAQ - Sonstiges :: Wohin mit meiner Frage?Dieses Posting wurde automatisch erzeugt.
-
Warum zweifelst du den Code an, den die IDE dir automatisch erzeugt? Das wird so schon ok sein. Fülle deinen Eventhandler einfach mit Leben, und gut is'.
Btw, du bist hier im falschen Unterforum gelandet. Du programmierst .Net mit C++/CLI, hier ist aber Visual C++ mit MFC.
-
Ich vertraue dem Comiler schon, aber meine Professorin bringt mich um, wenn ich in der *.h beginne Methoden zu implementieren. Das geht absolut gar nicht.
Kennt denn niemand eine Lösung für dieses Problem?
lg.
-
Sagt deine Professorin, dass du C++/CLI verwenden sollst? Nur zur Info: C++/CLI ist nicht C++ und für das erstellen von GUI Anwendungen eigentlich völlig ungeeignet. Wenn du .NET willst, verwend C#...
-
Hey,
erst einmal vielen Dank für deine Antwort.
Das C++ und Windows Forms sich nicht mögen, hab ich auch in den letzten 2 Stunden herausgefunden Ich kann leider nur C++. Meint ihr, dass es schwer ist, sich in MFC einzulesen? Es muss auf jeden Fall eine grafische Oberfläche besitzen und wenn möglich eben C++.
vlg.
Melli
-
Melanie_27 schrieb:
Ich kann leider nur C++. Meint ihr, dass es schwer ist, sich in MFC einzulesen?
Die MFC kann ich nicht empfehlen, dann würde ich wohl eher zu QT raten (selbst wenn ich es nicht so mag, aber das ist meine persönliche Meinung). Mit C++ wiederum kann man sich wiederum recht einfach in Java oder C# einarbeiten.
Melanie_27 schrieb:
Es muss auf jeden Fall eine grafische Oberfläche besitzen und wenn möglich eben C++.
Darf ich mal fragen was du gerade als Anforderungen mit welchen Hintergrund hast?
Melanie_27 schrieb:
ch vertraue dem Comiler schon, aber meine Professorin bringt mich um, wenn ich in der *.h beginne Methoden zu implementieren.
Ich verwende kein C++/CLI, aber hast du schon einmal versucht diese Methoden selbst in die cpp zu verlagern (und wenn ja: funktioniert dies?) und in der Header nur die Deklaration stehen zu lassen?
-
Hey,
danke für deine Antwort.
Ich möchte ein Programm erstellen, welches über TCP/IP in der Lage ist, Messwerte von einem anderen Rechner auszulesen.
Dem Benutzer soll eine grafische Oberfläche zur Verfügung stehen, bei der
er auswählen kann, welche Messwerte ausgelesen werden soll.
Selbstverständlich wird das Programm nicht nur aus einem Fenster bestehen.
Mit Windows Forms konnte ich ziemlich schnell eine brauchbare Oberfläche
erzeugen. Leider besteht hierbei das Problem mit der Trennung von *.h und
*.cpp. Ich habe bereits gelesen, wie es möglich ist, in der *.h nur noch
die Deklaration stehen zu lassen. Es kann aber nicht sein, dass ich jede
Funktion einzeln von Hand in die *.cpp kopieren muss und zudem noch
ein paar kleine Änderungen machen muss. Zudem scheint es Probleme beim
Zugriff auf globale Funktion zu geben. Bisher habe ich nur schlechtes
gelesen, wodurch ich nun eher zu MFC tendiere. Im Moment sitze ich
verzweifelt daran in MFC eine toolbar zu finden, mit der ich Elemente via
Drag and Drop einfügen kann. Sowas scheint es hier aber nicht zu geben :(((
lg.
Melli
-
Nimm C#. Wenn du C++ kannst und schon Ahnung von WinForms hast, sollte das für dich relativ einfach sein, dich da reinzufinden...
-
Melanie_27 schrieb:
..., wodurch ich nun eher zu MFC tendiere. Im Moment sitze
ich verzweifelt daran in MFC eine toolbar zu finden, mit der ich Elemente via
Drag and Drop einfügen kann. Sowas scheint es hier aber nicht zu geben :(((Wenn Du ein neues MFC-Projekt anlegst wird die Toolbar doch automatisch erzeugt?
Selbst bei "einfaches Dokument" im Projektstil "MFC-Standard" wird eine Toolbar
angelegt die man mit dem Resourcen-Editor ändern kann.//EDIT:
Leider ist der Resourcen-Editor speziell bei Toolbars etwas unflexibel; wenn
ausser Buttons noch andere Controls in die Toolbar sollen siehe hier:Walkthrough: Putting Controls On Toolbars
http://msdn.microsoft.com/en-us/library/bb983718.aspx
Deutlich einfacher wäre es diese Funktionalität in Dialoge zu verlagern - das wird direkt unterstützt.
-
asc schrieb:
Melanie_27 schrieb:
Ich kann leider nur C++. Meint ihr, dass es schwer ist, sich in MFC einzulesen?
Die MFC kann ich nicht empfehlen, dann würde ich wohl eher zu QT raten (selbst wenn ich es nicht so mag, aber das ist meine persönliche Meinung).
Die Empfehlung finde ich hier total deplatziert.
Einem Programmieranfänger der mal eben was für die Schule machen soll würde ich - wenn er denn schon mit Visual Studio arbeitet -- MFC *sehr* empfehlen.
Weil's schon dabei ist (d.h. er muss nicht erst 100 Stunden googeln bis er Qt installiert hat, die nötigen Linkeroptionen gemacht etc.), und vor allem weil der MFC Dialogeditor schön in Visual Studio integriert ist (wohingegen man mit Qt erst lernen muss Oberflächen "zu Fuss" zu programmieren oder wieder ein neues Tool suchen/lernen/einbinden muss).
-
hustbaer schrieb:
Einem Programmieranfänger der mal eben was für die Schule
machen soll würde ich - wenn er denn schon mit Visual Studio arbeitet -- MFC
*sehr* empfehlen. Weil's schon dabei ist ...Ob das "mal eben" geht würde ich anzweifeln ...
Für einen Programmieranfänger ist eine GUI wohl immer eine Herausforderung.
MFC würde ich empfehlen, wenn man nicht unbedingt mit der Expressversion von
VisualStudio auskommen muss und Windows die Zielplattform ist und man ausserdem
C++ verwenden möchte.
-
hustbaer schrieb:
Einem Programmieranfänger der mal eben was für die Schule machen soll würde ich - wenn er denn schon mit Visual Studio arbeitet -- MFC *sehr* empfehlen.
Ich würde wohl eher einfach C# empfehlen, da C++ für solche Sachen imo nicht wirklich gut geeignet ist, vor allem wenn man Anfänger ist. Von MFC würd ich einem Anfänger, der ja noch keinen gefestigten Programmierstil hat, schon alleine wegen des furchtbaren Vorbilds, das die MFC liefern würde, abraten...
-
hustbaer schrieb:
Einem Programmieranfänger der mal eben was für die Schule machen soll würde ich - wenn er denn schon mit Visual Studio arbeitet -- MFC *sehr* empfehlen.
Ich hatte die MFC im Studium, und sie hat bei den Großteil der Studenten Probleme bereitet. Vielleicht hat sich dies inzwischen geändert, aber empfehlen würde ich die MFC egal wie nicht. Gerade der Umgang mit dem Dialogeditor und den Ressourceneinträgen habe ich noch sehr negativ in Erinnerung.
Ich verstehe aber im Gegenzug auch nicht warum sich Dozenten an bestimmten Paradigmen fest beißen (Die Trennung Header/Source hat zwar Gründe, sollte aber dort aufgegeben werden können, wo es anders einfach nicht praktikabel ist).
-
Vielen Dank für eure vielen Antworten.
Ich würde es sehr gerne mit Visual Studio machen. Ein Windows Forms Projekt wäre perfekt. Leider schreibt mir die IDE aber alles in die header-Datei, was absolut unmöglich ist. MFC verstehe ich noch nicht wirklich. Vorallem das Entfernen von Objekten aus dem Ressourcenbereich macht mir Probleme. Einfach mal Entf geht leider nicht
Ich möchte eine grafische Oberfläche in C++, bei der ich die vielen Steuerelemente der Windows Forms verwenden kann (Choicebox, Buttons usw...), wo mir aber ein clickevent(..) nicht automatisch in die header geschrieben wird...
Liebe Grüße.
Melli
-
Vielen Dank für eure vielen Antworten. Ich würde es sehr gerne mit Visual Studio machen. Ein Windows Forms Projekt wäre perfekt. Leider schreibt mir die IDE aber alles in die header-Datei, was absolut unmöglich ist. MFC verstehe ich noch nicht wirklich. Vorallem das Entfernen von Objekten aus dem Ressourcenbereich macht mir Probleme. Einfach mal Entf geht leider nicht Ich möchte eine grafische Oberfläche in C++ , bei der ich die vielen Steuerelemente der Windows Forms verwenden kann (Choicebox, Button usw...) bei der mir aber ein onclickevent(....) nicht in die header geschrieben wird (nur der Funktionskopf). Ich bin wirklich ratlos.
Lg. Melli
-
Melanie_27 schrieb:
Ein Windows Forms Projekt wäre perfekt.
Du musst Dich entscheiden Wenn Du die Steuerelemente komfortabel mit C++
(ohne .NET und CLI) nutzen willst (Resourcen-Editor) bleibt ein MFC-Projekt
mit C++ fast alternativlos.Melanie_27 schrieb:
Ich möchte eine grafische Oberfläche in C++ , bei der ich die vielen Steuerelemente der Windows Forms verwenden kann (Choicebox, Button usw...) bei der mir aber ein onclickevent(....) nicht in die header geschrieben wird (nur der Funktionskopf). Ich bin wirklich ratlos.
Hast Du das vorgeschagene MFC-Projekt mit CFormView ausprobiert ?
Habe gerade mit VS2010 ein MFC-Projekt mit SDI und CFormView angelegt und
wie erwartet landet z.b. ::OnBnClickedButton1() in der zum View gehörenden
cpp-Datei. Im Header steht nur die Deklaration (auch wie erwartet ..)Möglicherweise hast Du da was anders gemacht ?
Hier die Einzelschritte zum nachvollziehen:
1. MFC-Anwendung (hier z.B. Name projektgui)
2. Einfaches Dokument, Projektstil: Windows Explorer, Unterstützung Dokument-/Ansichtarchitektur,
Stil + Farben: Windows 7, ohne Wechsel des visuellen Stils
3. Menü + Symbolleite verwenden, ohne Benutzerdef. Symbolleite und pers. Menüverhalten
4. Allgemeines Steuerelementemanifest, ohne ActiveX-Steuerelemente, ohne Neustartmanager
5. Den View bei den generierten Klassen auf CFormView ändern
(Den CLeftView kann man nicht ändern und wird ihn auch nicht los)
6. Fertig stellenWenn man den CLeftView nicht will kann man den natürlich löschen:
Die beiden Dateien LeftView.cpp und LeftView.h löschen (sowohl im Projekt alsauch die Dateien selbst.)
Vorher sollte man die Anweisung "class CprojektguiDoc;" aus LeftView.h in die projektguiView.h kopieren.
Da der Compiler nun alles mit LeftView nicht kennt muss die Anweisung
#include "LeftView.h" in projektgui.cpp gelöscht und in MainFrm.cpp durch
#include "projektguiView.h" ersetzt werden.Im Template in projektgui.cpp muss das 'CLeftView' wie folgt ersetzt werden:
RUNTIME_CLASS(CprojektguiDoc), RUNTIME_CLASS(CMainFrame), // Haupt-SDI-Rahmenfenster RUNTIME_CLASS(CprojektguiView));
In MainFrm.cpp muss dann nur noch die Erzeugung des Splitterfensters komplett
auskommentiert werden, da es bei nur einem View keinen Sinn macht. Am Besten
entfernt man das Überschreiben von OnCreateClient sowie die Membervariable des
Splitterfensters in MainFrm.h komplett.// CSplitterWnd m_wndSplitter; // virtual BOOL OnCreateClient(LPCREATESTRUCT lpcs, CCreateContext* pContext);
Melanie_27 schrieb:
Vorallem das Entfernen von Objekten aus dem Ressourcenbereich macht mir Probleme.
Notfalls die .rc Datei mit einem Texteditor bearbeiten