diff options
-rw-r--r-- | grc/src/gui/ActionHandler.py | 7 | ||||
-rw-r--r-- | grc/src/gui/DrawingArea.py | 20 | ||||
-rw-r--r-- | grc/src/platforms/gui/FlowGraph.py | 25 |
3 files changed, 28 insertions, 24 deletions
diff --git a/grc/src/gui/ActionHandler.py b/grc/src/gui/ActionHandler.py index 27f19cbf9..f5f349d4a 100644 --- a/grc/src/gui/ActionHandler.py +++ b/grc/src/gui/ActionHandler.py @@ -345,8 +345,13 @@ class ActionHandler: #saved status Actions.get_action_from_name(Actions.FLOW_GRAPH_SAVE).set_sensitive(not self.get_page().get_saved()) self.main_window.update() + try: #set the size of the flow graph area (if changed) + new_size = self.get_flow_graph().get_option('window_size') + if self.get_flow_graph().get_size() != tuple(new_size): + self.get_flow_graph().set_size(*new_size) + except: pass #draw the flow graph - self.get_flow_graph().update_highlighting() + self.get_flow_graph().update_selected() self.get_flow_graph().queue_draw() def update_exec_stop(self): diff --git a/grc/src/gui/DrawingArea.py b/grc/src/gui/DrawingArea.py index 5258979d8..feb401978 100644 --- a/grc/src/gui/DrawingArea.py +++ b/grc/src/gui/DrawingArea.py @@ -40,11 +40,12 @@ class DrawingArea(gtk.DrawingArea): self._main_window.drawing_area = self gtk.DrawingArea.__init__(self) self.set_size_request(MIN_WINDOW_WIDTH, MIN_WINDOW_HEIGHT) + self.connect('configure-event', self._handle_window_configure) self.connect('expose-event', self._handle_window_expose) self.connect('motion-notify-event', self._handle_mouse_motion) self.connect('button-press-event', self._handle_mouse_button_press) self.connect('button-release-event', self._handle_mouse_button_release) - self.set_events( + self.add_events( gtk.gdk.BUTTON_PRESS_MASK | \ gtk.gdk.POINTER_MOTION_MASK | \ gtk.gdk.BUTTON_RELEASE_MASK | \ @@ -59,8 +60,6 @@ class DrawingArea(gtk.DrawingArea): self.get_focus_flag = lambda: self._focus_flag self.connect('leave-notify-event', self._handle_focus_event, False) self.connect('enter-notify-event', self._handle_focus_event, True) - #pixmap for drawing - self.pixmap = None ########################################################################## ## Handlers @@ -105,14 +104,19 @@ class DrawingArea(gtk.DrawingArea): coordinate=(event.x, event.y), ) + def _handle_window_configure(self, widget, event): + """ + Called when the window is resized. + Create a new pixmap for background buffer. + """ + width, height = self.get_size_request() + self.pixmap = gtk.gdk.Pixmap(self.window, width, height, -1) + def _handle_window_expose(self, widget, event): """ - Called when window is exposed, resized, or queue_draw is called. + Called when window is exposed, or queue_draw is called. + Double buffering: draw to pixmap, then draw pixmap to window. """ gc = self.window.new_gc() - width, height = self.get_size_request() - if not self.pixmap or (width, height) != self.pixmap.get_size(): - self.pixmap = gtk.gdk.Pixmap(self.window, width, height, -1) - #double buffering: draw to pixmap, then draw pixmap self._main_window.get_flow_graph().draw(gc, self.pixmap) self.window.draw_drawable(gc, self.pixmap, 0, 0, 0, 0, -1, -1) diff --git a/grc/src/platforms/gui/FlowGraph.py b/grc/src/platforms/gui/FlowGraph.py index 11942eb2e..82b45dc03 100644 --- a/grc/src/platforms/gui/FlowGraph.py +++ b/grc/src/platforms/gui/FlowGraph.py @@ -247,10 +247,6 @@ class FlowGraph(Element): Draw all of the elements in this flow graph onto the pixmap. Draw the pixmap to the drawable window of this flow graph. """ - try: #set the size of the flow graph area (if changed) - new_size = self.get_option('window_size') - if self.get_size() != tuple(new_size): self.set_size(*new_size) - except: pass W,H = self.get_size() #draw the background gc.foreground = Colors.BACKGROUND_COLOR @@ -275,27 +271,26 @@ class FlowGraph(Element): for selected_element in self.get_selected_connections() + self.get_selected_blocks(): selected_element.draw(gc, window) - def update_highlighting(self): + def update_selected(self): """ + Remove deleted elements from the selected elements list. Update highlighting so only the selected are highlighted. """ selected_elements = self.get_selected_elements() - for element in self.get_elements(): + elements = self.get_elements() + #remove deleted elements + for selected in selected_elements: + if selected in elements: continue + selected_elements.remove(selected) + #update highlighting + for element in elements: element.set_highlighted(element in selected_elements) def update(self): """ - Removed deleted elements from the selected elements list. Call update on all elements. """ - selected_elements = self.get_selected_elements() - elements = self.get_elements() - #remove deleted elements - for selected in selected_elements: - if selected in elements: continue - selected_elements.remove(selected) - #update all - for element in elements: element.update() + for element in self.get_elements(): element.update() ########################################################################## ## Get Selected |