Einstieg in Model-View-Konzept
-
wrote on 6 Jan 2011, 13:51 last edited by
Evtl. kann man auch ein model n views mit einbauen, so zum zeigen (z.B. Liste und Tabelle).
Oder z.B. gegen ende ein hauptmodell (tree) das als Tree angezeigt wird.
Eine ListView die die erste Ebene anzeigt und auswählt, welche childs in einer tabelle angezeigt werden sollen... -
wrote on 6 Jan 2011, 14:16 last edited by
Ich möchte euch nicht stoppen, aber...
...ich hätte gern einen bedarfsgetriebenen Ansatz.Damit will ich sagen, dass wenn der Bedarf nicht erkannt wird, auch die Technik zu seiner Befriedigung langweilig bleiben wird. Ihr wart doch auch in der Schule oder? Wie wurde da gelehrt? Haben die Schüler auch gestöhnt: Wozu brauchen wir das denn später mal?
Merkt ihr worauf ich hinaus will?
-
wrote on 6 Jan 2011, 14:31 last edited by
Ich habe bisher alles davon in meinem Projekt benötigt :-) :-)
Die Frage ist was ist der Bedarf für ein eigenes Model, d.h. warum schreibt man ein komplett eigenes Model und passt nicht ein bestehendes an?
-
wrote on 6 Jan 2011, 15:25 last edited by
Ja, klar. Aber das weiß ein Neueinsteiger ja noch nicht, und er fragt sich ggf. wozu diese "neuen" Konzepte. Und wir sollten das für ihn erfahrbar machen - meine ich.
-
wrote on 6 Jan 2011, 15:40 last edited by
Ein existierendes anpassen hats nur, wenn in dem projekt schon welche da sind.
Aber dann sollten wir erst mal überlegen, was der grund für QTableView & model im gegensatz zu QTableWidget ist.
1.) Daten können in eigenen strukturen gehalten werden --> wieder verwendung der Daten schicht (wenn's sowas gibt)
2.) Zugriff auf die Daten ist einfacher (nicht immer TableWidget--> find --> get --> etc.)
3.) Erweiterbarkeit (neue features, neue zeilen/spalten, ...)
... (spontan fällt mir gerade nix ein) -
wrote on 6 Jan 2011, 17:12 last edited by
Für mich persönlich fallen die QxxxWidgets nicht unter den Punkt Model-View-Controller, das sind bequeme Klassen, die alles in einer Black-Box kapseln. Das ist prima für bestimmte Anwendungsfälle, hat aber wie gesagt für mich nichts mit MVC zu tun (wie's intern implementiert ist, tut da ja nichts zur Sache) - man hat (bis auf den Delegate) keinen Einfluss auf das Model und die View.
Wenn wir über Model-View-Controller reden, fängt das bei mir mit einem eigenen Model an. Ggf. erweitert man eine View (habe ich auch schon gemacht, weil die Default-Implementierung für uns nicht passt). Je nach Anwendungsfall hat man noch 'nen Delegate für's optische.
Die Frage ist auch, wo legt man das Einstiegslevel fest. Soll die Zielgruppe schon wissen, was MVC ist und wir vermitteln nur, wie man es mit Qt macht, oder müssen wir noch eine allgemeine Einführung dazu geben?
Vor einer klaren Abgrenzung wann man QxxView + eigenes Model verwenden soll und wann QxxWidget würde ich abraten. In der IT hängt da zu vieles vom "kommt darauf an" ab. Man kann natürlich Vor- und Nachteile angeben, Anwendungsbeispiele, etc. Die Entscheidung kann einem aber niemand abnehmen. In unserer Anwendung verwenden wir beides, je nachdem was gerade gemacht werden muss, und wie es einfacher zu lösen ist.
In diesem Zusammenhang wäre dann vielleicht ein eigenes Tutorial "Die QtxxWidget-Klassen erweitern" angebracht?
-
wrote on 6 Jan 2011, 17:59 last edited by
Das wäre ja schon fast ein kapitel für ein buch inzwischen :-)
-
wrote on 6 Jan 2011, 18:35 last edited by
Zum Einstiegslevel: Nicht bei Adam und Eva anfangen. MVC kann man ja mal mit drei Sätzen anreißen, aber Zielgruppe sollten Programmierer sein, nicht die Berufsschulklasse im 1. Lehrjahr.
-
wrote on 6 Jan 2011, 18:35 last edited by
Evtl kann man mal das design pattern dahinter erläutern, wäre ein einstieg, oder?
-
wrote on 6 Jan 2011, 21:05 last edited by
Ich will mal ganz und gar ehrlich sein. Das Pattern-Buch habe ich gelesen, das ist lang her. Als Katalog nützt es nicht wirklich zum Verständnis von Patterns im Allgemeinen. Später habe ich ein HeadFirst-Buch in die Hand bekommen, das Patterns (hauptsächlich mit Java-Bezug) erklärt. Mit dem bin ich zwar nicht durch (und zugegeben: es ist etwas flacher), aber durch diese Lektüre habe ich viel mehr behalten. Wirklich ein Lich ist mir dann mit dem "Büchlein von Helmut Leitner":http://www.mustertheorie.de/ aufgegangen, allerdings ist dieses dann wieder grundlegender.
Was MVC betrifft, bin ich - praktisch gesehen - wohl eher ein Neuling oder vielleicht ein unbewusster Anwender (ja ihr könnt mich gern jetzt auspfeifen). Aber ich habe es ehrlich mehrmals versucht, den Stoff zu raffen. Ist dann ein bisschen wie höhere Mathematik für mich: hochtrabende bis verstiegene Terminologie und kaum eine helfende Hand die einem daraus entgegenragt...
Deshalb würde ich auch einen Weg durch - simulierte - Erfahrung bevorzugen und von MVC überhaupt nur soviel hinein nehmen, dass es zum richtigen Anwenden von MV(D) mit Qt genügt. Theoretisch vollständig durchdringen kann man es ja später immer noch (und wird es bei ernsthafter Beschäftigung damit schließlich auch wollen).
O, nun ist es doch wieder eine ganz lange Antwort geworden - und bevor ich mich nun an ein Thema heranwage, in dem ich sicherlich ganz schön ins Schwitzen (und Schwimmen) kommen werde, mach ich jetzt besser mal was anderes (das ich auch schon in Aussicht gestellt habe und noch schuldig bin: die "Vorzüge der Ausnahmebehandlung":http://developer.qt.nokia.com/groups/qt_german/wiki/Wo_Ausnahmebehandlung_echt_hilft erklären, zumindest eine Notiz hinterlassen)
[edit] sehe gerade: MV-Stoffsammlung ist auch schon dort, gut! :)
-
wrote on 6 Jan 2011, 21:09 last edited by
[quote author="Panke" date="1294338902"]Zum Einstiegslevel: Nicht bei Adam und Eva anfangen. MVC kann man ja mal mit drei Sätzen anreißen, aber Zielgruppe sollten Programmierer sein, nicht die Berufsschulklasse im 1. Lehrjahr.[/quote] Dann versuch du mir mal diese Adam-und-Eva-Sache kurz und bündig zu verklickern. Eigentlich sah ich mich bislang nicht beratungsresistent ;) - nein wirklich, ganz ernthaft...
-
wrote on 6 Jan 2011, 21:50 last edited by
[quote author="Wolf P." date="1294348164"][quote author="Panke" date="1294338902"]Zum Einstiegslevel: Nicht bei Adam und Eva anfangen. MVC kann man ja mal mit drei Sätzen anreißen, aber Zielgruppe sollten Programmierer sein, nicht die Berufsschulklasse im 1. Lehrjahr.[/quote] Dann versuch du mir mal diese Adam-und-Eva-Sache kurz und bündig zu verklickern. Eigentlich sah ich mich bislang nicht beratungsresistent ;) - nein wirklich, ganz ernthaft...
[/quote]
Den Eindruck habe ich auch gar nicht. Mein Beitrag bezog sich auf Volkers Frage.
bq. Die Frage ist auch, wo legt man das Einstiegslevel fest. Soll die Zielgruppe schon wissen, was MVC ist und wir vermitteln nur, wie man es mit Qt macht, oder müssen wir noch eine allgemeine Einführung dazu geben?
Natürlich muss man einleitend ein paar Worte über MVC geben, wenn man ein Model-View-Framework beschreibt. Aber die Details, Diskussion der Vor- und Nachteile, Alternativen etc. sprengen meiner Meinung nach den Rahmen.
Das heißt natürlich nicht, dass man eine schlechtere Alternative (QxxWidget) zuerst präsentieren kann, um das Problem zu veranschaulichen, dass das Framework lösen soll.
-
wrote on 6 Jan 2011, 22:14 last edited by
[quote author="Panke" date="1294350629"] Das heißt natürlich nicht, dass man eine schlechtere Alternative (QxxWidget) zuerst präsentieren kann, um das Problem zu veranschaulichen, dass das Framework lösen soll. [/quote] Genau darauf wollte ich hinaus!
Ich glaube, dass ein An-die-Grenze-des-Machbaren-Stoßen wirklich stark motivieren kann. -
wrote on 6 Jan 2011, 22:54 last edited by
Das Problem ist, wenn ich es will, kann ich mit QXxxWidget verdammt weit kommen, nur wird es irgendwann immer schwerer. Wenn ich aber leicht anfange damit, kann ich immer wa shinzubauen. Iregndwann komme ich aber an die Grenze, wo es mit dem MV(D) Ansatz (von Anfang an benutzt) deutlich eleganter und günstiger wird.
Ich würde die Widgets gfleich weglassen in dem Tutorial. Ein Model ist im prinzip ganz einfach (ReadOnly, tabelle), wenn die Daten einmal gelesen werden und dann nur präsentiert.
-
wrote on 7 Jan 2011, 09:51 last edited by
Dann wäre es wohl gut, wir gingen dazu über, das von nun an als zwei Dinge zu betrachten.
Was meint ihr?Das MV(D) sollte dann vielleicht besser ein anderer vorantreiben, bei mir käme es ins stocken, wobei ich es definitiv begleiten werde, Review, Diskussion, Verbesserungen usw.
Das andere - das "Kaputt-Verbessern":http://de.wikipedia.org/wiki/Kaputt einer Widget-Lösung - würde ich dann übernehmen.
-
wrote on 7 Jan 2011, 10:30 last edited by
Ich kann mal sehen, ob ich dazu komme, aber das wird was größeres... also auch etwas dauern....
By the way, hier ein sehr "nettes pattern":http://sourceknights.blogspot.com/2010/12/normal-0-false-false-false.html :-)
-
wrote on 7 Jan 2011, 10:34 last edited by
[quote author="Gerolf" date="1294396200"]By the way, hier ein sehr "nettes pattern":http://sourceknights.blogspot.com/2010/12/normal-0-false-false-false.html :-)[/quote] :D Herrlich!
-
wrote on 7 Jan 2011, 10:37 last edited by
Und, schonmal verwendet :-)))?
-
wrote on 7 Jan 2011, 10:50 last edited by
...muss ich erst mit meiner QA absprechen. :)
-
wrote on 7 Jan 2011, 11:29 last edited by
[quote author="Gerolf" date="1294396200"]By the way, hier ein sehr "nettes pattern":http://sourceknights.blogspot.com/2010/12/normal-0-false-false-false.html :-)[/quote]
Haha, super! Wusste ich doch, dass ich ständig Patterns verwende, ohne es zu wissen :-)
35/109