Swing Frage zu MVC

X

Xenya

Gast
Hallo,
um mich mit der Oberflächenprogrammierung vertraut zu machen, bastel ich Momentan an einem Übungsprojekt. Ich versuche mich dabei am MVC-Modell zu halten.

Ich habe also ein Model, für die Hauptlogik.
Einen Controller für die Kommunikation zwischen View und Model. Der Controller besitzt also eine Instanz des Models, an die er die Eingaben der View weitergibt.
Das Model bearbeitet die Anfragen, sollten Änderungen stattfinden, wird der Controller informiert. Den Controller bekommt er aber nicht über den Konstruktor, sondern es gibt eine addListener Methode, mit der beliebig viele Controller angmeldet werden dürfen.


Meine main erstellt erst das Model.
Anschließend den Controller, der über den Konstruktor das Model bekommt.

Wo ich mir nun nicht sicher bin, ist der Ort an dem die Listener hinzugefügt werden sollen.
Macht man dies im Konstruktor des Controllers, also addListener(this), damit man sich sonst niergends darum kümmern muss.
Oder macht man dies in der Main?
Also
Java:
m = new Model()
c = new Controller(m)
m.addListener(c)

Danke
 

bERt0r

Top Contributor
Normalerweise addest du nicht den Controller als ModelListener sondern die View. Wenn nämlich der Controller nämlich die Änderungen an die View weitergeben muss, ist die Trennung zwischen Controller und View nicht mehr gegeben: Dann braucht jede View genau einen Controller und ist von diesem abhängig.
Es sollte solaufen: Benutzer macht Aktion (View ruft Controller auf). -> Controller ändert Model. -> Model meldet Änderung an View.
 

hemeroc

Bekanntes Mitglied
Hi,
sry das ich mich einmische aber ich bin mit einem Teil davon nicht wirklich einverstanden:

"Model meldet Änderung an View."

Es sollte unter keinen Umständen passieren, dass das Model überhaupt Informationen über die View hat vielmehr sollte das Model die Rückmeldung an den Controller geben und der Controller dann der View sagen, dass sie Updaten soll.

Liebe Grüße
Hemeroc

Edit: Beispiel

User klickt im View auf eine neue Datenansicht und ruft eine entsprechende Funktion im Controller auf, der Controller sagt dem Model dass es die Daten laden soll, sobald die Daten da sind wird der Controller davon informiert und der Controller sagt dann der View das Sie die Daten anzeigen soll.
Im besten Fall ist es noch so, dass hier alles über Interfaces kommuniziert wird.
 
Zuletzt bearbeitet:
X

Xenya

Gast
Hallo bERt0r,
danke für deine Antwort.
Wie sieht das dann bei Swing aus?

Habe mal gelesen, dass bei den Swing-Objekte die Unterscheidung zwischen Model-und Controller nicht ganz eindeutig ist. Habe sie deshalb in meinen Controller gesteckt.

Hallo hemeroc,
dafür musst du dich nicht entschuldigen. Ich denke "richtig" gibt es bei MVC nicht und ich freue mich immer, wenn ich verschiedene Meinungen höre. Nur so kommt man weiter und lernt was.




Ich habe mich dazu entschlossen, ein kleines Beispiel zu machen, um mal meine Vorgehensweise zu zeigen. Ich habe auch reingeschrieben, wo meine Fragen sind (beziehungsweise wo die Stellen bei meinem Vorgehen sind, ob mein Vorgehen stimmt ist etwas anderes und ihr könnt mich gerne korrigieren).

Imports habe ich weggelassen, ist eh schon viel genug.
In meiner echten Anwendung sind natürlich die Models und Controller noch Interfaces.

Frage 1:
Die, die ich im Hauptpost gestellt habe. addListener in das Hauptprogramm oder in den Controller
Frage 2:
Wo werdem Entscheidungen gefällt, die eigentlich nur die View betreffen?
Zum Beispiel, wenn nach der Bearbeitung durch einen Klick auf dem Button ein Eingabefeld zurückgesetzt werden soll. Wird dies direkt im Controller gemacht?
Oder, weil es eine Logik ist, in das Modul und das Modul ruft ein resetInput im Controller auf? Nachteil daran: Das Model weiß also, dass es ein Eingabefeld gibt. Was, wenn es in einer "neuen" View irgend wann dieses Feld nichtmehr gibt und somit ein Aufruf der resetInput unnötig ist?

Model:
Java:
public class TestModel
{
	Set<TestController> controllers = new HashSet<TestController>();
	
	private StringBuilder word = new StringBuilder();
	
	public void addListener(TestController controller)
	{
		controllers.add(controller);
	}
	
	//Getter und Setter
	public String getWord()
	{
		return word.toString();
	}
	
	//Listener-Methoden die vom Controller aufgerufen werden
	public void addStrings(String newPart)
	{
		word.append(newPart);
		
		for(TestController controller: controllers)
			controller.outputTextChanged();
	}
}

Controller:
Java:
public class TestController
{
	private final TestModel model;

	private JFrame frame;
	private JTextField input;
	private JLabel output;

	public TestController(TestModel model)
	{
		this.model = model;
		
		initialize();
		frame.setVisible(true);
		
		//zu Frage 1
		//oder hier?
		model.addListener(this);
	}

	private void initialize()
	{
		frame = new JFrame();
		frame.setBounds(100, 100, 450, 300);
		frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		frame.getContentPane().setLayout(new FlowLayout(FlowLayout.CENTER, 5, 5));
		
		input = new JTextField();
		frame.getContentPane().add(input);
		input.setColumns(10);
		
		JButton buttonAdd = new JButton("add Word");
		buttonAdd.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent arg0) {
				clickedAddButton();
			}
		});
		frame.getContentPane().add(buttonAdd);
		
		output = new JLabel();
		frame.getContentPane().add(output);
	}
	
	//Listener die von der View aufgerufen werden, könnte auch direkt oben stehen
	protected void clickedAddButton()
	{
		model.addStrings(input.getText());
		
		//zu Frage 2
		input.setText("");
	}
	
	//Listener die vom Model aufgerufen werden
	public void outputTextChanged()
	{
		output.setText(model.getWord());
	}
}

Die Main, die alles zusammenfügt:
Java:
public class TestMain
{
	public static void main(String[] args)
	{
		TestModel model = new TestModel();
		TestController controller = new TestController(model);
		
		//zu Frage 1:
		//an dieser Stelle?
		model.addListener(controller);
	}
}
 

Wildcard

Top Contributor
IMO wurde diese ganze MVC Geschichte mittlerweile totgekaut und ist stark überschätzt. Das wichtige ist das Model, das ist der Kern von allem.
Das Verbindung zwischen View und Model schafft man am elegantesten mit Databinding und dann muss man sich auch nicht mehr darüber streiten was nun in welche Schicht gehört.
Und nicht vergessen, nichtmal Swing ist MVC. Swing ist mehr DMSMJCVC (Domain Model -> Swing Model -> JComponent -> View -> Controler).
Vielleicht bin ich auch nur SWT/JFace verwöhnt...
 

bERt0r

Top Contributor
Überleg doch mal, es macht doch gar keinen Sinn wenn das Model den Controller benachrichtigt:
Wenn der Contorller was am Model ändert weis er das doch, wieso wird er dann nochmal benachrichtigt? Da ist doch eine direkte Kommunikation mit der View schneller und auch logischer.

Sämtliche Komponenten in Swing sind so aufgebaut, Beispiel Table:
Im TableModel gibt es die Methode addTableModelListener. Und wer implementiert TableModelListener? JTable, also die View. Jedes mal wenn im TableModel was geändert wird, werden sämtliche TableModelListener abgeklappert und ihnen ein TableModelEvent geschickt.

Wenn du vom Controller aus die View steuern willst, kannst du das ja gleich so machen:
Java:
public void benutzerAktion(){
model.changeStuff();
view.updateView();
}
Nur ist mit so einer Konstruktion die Unabhängigkeit von View und Controller nicht mehr gegeben. Du bist auf auf eine View beschränkt Eine Konstruktion wie 1 Model mit 5 Views kannst du so nicht realisieren.

Du kannst dir gerne das beispiel von GUIProgrammierer ansehen, was ich in diese Richtung überarbeitet habe, da wird das ganze anschaulich demonstriert: MVC Beispiel
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5
H Frage zu java.weka.core.Instances Allgemeine Java-Themen 3
S Frage zu Format Modifiers in Log4j Allgemeine Java-Themen 11
H Frage zu clone() Allgemeine Java-Themen 5
4 Simple(?) Frage zu Threads Allgemeine Java-Themen 14
H2SO3- SCJP Chapter 3 Frage 10. Falsche Antwort? Allgemeine Java-Themen 15
H Frage sinnvolle Datenspeicherung und -verarbeitung Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben