X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=net.mograsim.logic.model%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fmodel%2Fmodel%2FViewModel.java;fp=net.mograsim.logic.model%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fmodel%2Fmodel%2FViewModel.java;h=c60de3ed3f6facc69cb9477ad7977efb59479420;hb=e8e95e2e345f4d9c5927aa78f5c0fb607d352a97;hp=68cc489f06accd934d3f8883be94f3fde4f46d21;hpb=a36b5eded424a8c480140e9ce853145c2bcc9d7e;p=Mograsim.git diff --git a/net.mograsim.logic.model/src/net/mograsim/logic/model/model/ViewModel.java b/net.mograsim.logic.model/src/net/mograsim/logic/model/model/ViewModel.java index 68cc489f..c60de3ed 100644 --- a/net.mograsim.logic.model/src/net/mograsim/logic/model/model/ViewModel.java +++ b/net.mograsim.logic.model/src/net/mograsim/logic/model/model/ViewModel.java @@ -21,9 +21,8 @@ public class ViewModel private final List> componentRemovedListeners; private final List> wireAddedListeners; private final List> wireRemovedListeners; - private final List redrawListeners; - private final Runnable redrawListenerForSubcomponents; + private Runnable redrawHandler; protected ViewModel() { @@ -36,9 +35,6 @@ public class ViewModel componentRemovedListeners = new ArrayList<>(); wireAddedListeners = new ArrayList<>(); wireRemovedListeners = new ArrayList<>(); - redrawListeners = new ArrayList<>(); - - redrawListenerForSubcomponents = this::callRedrawListeners; } /** @@ -51,8 +47,7 @@ public class ViewModel throw new IllegalStateException("Don't add the same component twice!"); components.put(component.name, component); callComponentAddedListeners(component); - component.addRedrawListener(redrawListenerForSubcomponents); - callRedrawListeners(); + requestRedraw(); } /** @@ -65,8 +60,7 @@ public class ViewModel throw new IllegalStateException("Don't remove the same component twice!"); components.remove(component.name); callComponentRemovedListeners(component); - component.removeRedrawListener(redrawListenerForSubcomponents); - callRedrawListeners(); + requestRedraw(); } /** @@ -79,8 +73,7 @@ public class ViewModel throw new IllegalStateException("Don't add the same wire twice!"); wires.put(wire.name, wire); callWireAddedListeners(wire); - wire.addRedrawListener(redrawListenerForSubcomponents); - callRedrawListeners(); + requestRedraw(); } /** @@ -93,8 +86,7 @@ public class ViewModel throw new IllegalStateException("Don't remove the same wire twice!"); wires.remove(wire.name); callWireRemovedListeners(wire); - wire.removeRedrawListener(redrawListenerForSubcomponents); - callRedrawListeners(); + requestRedraw(); } public Map getComponentsByName() @@ -112,18 +104,31 @@ public class ViewModel public void addComponentRemovedListener (Consumer listener) {componentRemovedListeners.add (listener);} public void addWireAddedListener (Consumer listener) {wireAddedListeners .add (listener);} public void addWireRemovedListener (Consumer listener) {wireRemovedListeners .add (listener);} - public void addRedrawListener (Runnable listener) {redrawListeners .add (listener);} public void removeComponentAddedListener (Consumer listener) {componentAddedListeners .remove(listener);} public void removeComponentRemovedListener(Consumer listener) {componentRemovedListeners.remove(listener);} public void removeWireAddedListener (Consumer listener) {wireAddedListeners .remove(listener);} public void removeWireRemovedListener (Consumer listener) {wireRemovedListeners .remove(listener);} - public void removeRedrawListener (Runnable listener) {redrawListeners .remove(listener);} private void callComponentAddedListeners (GUIComponent c) {componentAddedListeners .forEach(l -> l.accept(c));} private void callComponentRemovedListeners(GUIComponent c) {componentRemovedListeners.forEach(l -> l.accept(c));} private void callWireAddedListeners (GUIWire w ) {wireAddedListeners .forEach(l -> l.accept(w));} private void callWireRemovedListeners (GUIWire w ) {wireRemovedListeners .forEach(l -> l.accept(w));} - private void callRedrawListeners ( ) {redrawListeners .forEach(l -> l.run( ));} // @formatter:on + + public void setRedrawHandler(Runnable handler) + { + this.redrawHandler = handler; + } + + public Runnable getRedrawHandler() + { + return redrawHandler; + } + + public void requestRedraw() + { + if (redrawHandler != null) + redrawHandler.run(); + } } \ No newline at end of file