Mercurial > octave-nkf
diff libgui/graphics/Figure.cc @ 19697:dfea01b3425f
more mouse interaction features for Qt plotting widget
* graphics.in.h, graphics.cc (figure::properties::__mouse_mode__,
figure::properties::__pan_mode__, figure::properties::__rotate_mode__,
figure::properties::__zoom_mode__): New properties.
(figure::properties::set___mouse_mode__): New function.
(axes::properties::pan, axes::properties::rotate3d,
axes::properties::zoom): New functions. Handle zoom, and pan modes.
(axes::properties::clear_zoom_stack): New arg, do_unzoom.
Conditionally call unzoom.
(axes::properties::unzoom): Also restore view property.
(axes::properties::rotate_view): Conditionall save state to zoom stack.
(axes::properties::push_zoom_stack): New function.
(axes::properties::pan, axes::properties::rotate3d):
Delete properties.
(axes::properties::update_xlim, axes::properties::update_ylim,
axes::properties::update_zlim): Don't clear zoom stack. Delete
do_clr_zoom argument.
(axes::properties::set_pan, axes::properties::set_rotate3d): Delete.
(F__zoom__): New function.
* Canvas.h, Canvas.cc (Canvas::toggleAxes, Canvas::toggleGrid):
New pure virtual functions.
(Canvas::setCursor, Canvas::canvasToggleAxes,
Canvas::canvasToggleGrid, Canvas::canvasMouseDoubleClickEvent,
Canvas::canvasWheelEvent): New functions.
(zoom_enabled, pan_enabled, pan_mode, rotate_enabled, rotate_mode):
New static functions.
(Canvas::canvasMouseMoveEvent): Call axes::properties::rotate3d to do
rotation. Handle panning.
(Canvas::canvasMousePressEvent): Also handle "unzoom" action when in
pan and rotate modes.
(Canvas::canvasMouseReleaseEvent): Zoom by factor if mouse has not
moved from mouse press event.
* Figure.h, Figure.cc (MouseMode): New enum value, TextMode.
(Figure::m_mouseMode, Figure::m_lastMouseMode): Delete member
variables.
(Figure::mouseMode, Figure::setMouseMode): Get info from and save info
to figure properties.
(Figure::updateFigureToolBarAndMenuBar, Figure::toggleAxes,
Figure::toggleGrid): New functions.
(Figure::m_mouseModeGroup): New member variable.
(Figure::createFigureToolBarAndMenuBar): Add actions for toggling Axes
and Grid. Maintain pointer to MouseModeActionGroup.
(mouse_mode_to_string, mouse_mode_from_string): New functions.
* GLCanvas.h, GLCanvas.cc (GLCanvas::toggleAxes, GLCanvas::ToggleGrid,
GLCanvas::mouseDoubleClickEvent, GLCanvas::wheelEvent): New functions.
* MouseModeActionGroup.h, MouseModeActionGroup.cc
(MouseModeActionGroup::mouseMode): Delete.
(MouseModeActionGroup::setMode): New function.
(MouseModeActionGroup::MouseModeActionGroup): Also include action to
insert text in the list.
* figure.m: Set default pan, rotate, and zoom mode properties for the
figure object.
* pan.m, rotate3d.m, zoom.m: Improve compatibility with Matlab. Set
mode properties for figure.
* __init_fltk__.cc: Cope with changes to graphics properties.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Fri, 06 Feb 2015 13:06:54 -0500 |
parents | 2f4406e9dad6 |
children | 35bca657d74d |
line wrap: on
line diff
--- a/libgui/graphics/Figure.cc Fri Feb 06 08:31:49 2015 -0800 +++ b/libgui/graphics/Figure.cc Fri Feb 06 13:06:54 2015 -0500 @@ -104,9 +104,9 @@ } Figure::Figure (const graphics_object& go, FigureWindow* win) - : Object (go, win), m_blockUpdates (false), m_mouseMode (NoMode), - m_lastMouseMode (NoMode), m_figureToolBar (0), m_menuBar (0), - m_innerRect (), m_outerRect () + : Object (go, win), m_blockUpdates (false), m_figureToolBar (0), + m_menuBar (0), m_innerRect (), m_outerRect (), + m_mouseModeGroup (0) { m_container = new Container (win); win->setCentralWidget (m_container); @@ -163,6 +163,64 @@ { } +static std::string mouse_mode_to_string (MouseMode mode) +{ + switch (mode) + { + case NoMode: + return "none"; + + case RotateMode: + return "rotate"; + + case ZoomMode: + return "zoom"; + + case PanMode: + return "pan"; + + case TextMode: + return "text"; + + case SelectMode: + return "select"; + + default: + break; + } + + return "none"; +} + +static MouseMode mouse_mode_from_string (const std::string& mode) +{ + if (mode == "none") + return NoMode; + else if (mode == "rotate") + return RotateMode; + else if (mode == "zoom") + return ZoomMode; + else if (mode == "pan") + return PanMode; + else if (mode == "text") + return TextMode; + else if (mode == "select") + return SelectMode; + else + return NoMode; +} + +MouseMode Figure::mouseMode (void) +{ + gh_manager::auto_lock lock; + + const figure::properties& fp = properties<figure> (); + + std::string mode = fp.get___mouse_mode__ (); + + return mouse_mode_from_string (mode); +} + void Figure::createFigureToolBarAndMenuBar (void) { QMainWindow* win = qWidget<QMainWindow> (); @@ -171,10 +229,18 @@ m_figureToolBar->setMovable (false); m_figureToolBar->setFloatable (false); - MouseModeActionGroup* mouseModeGroup = new MouseModeActionGroup (win); - connect (mouseModeGroup, SIGNAL (modeChanged (MouseMode)), + m_mouseModeGroup = new MouseModeActionGroup (win); + connect (m_mouseModeGroup, SIGNAL (modeChanged (MouseMode)), SLOT (setMouseMode (MouseMode))); - m_figureToolBar->addActions (mouseModeGroup->actions ()); + m_figureToolBar->addActions (m_mouseModeGroup->actions ()); + + QAction *toggle_axes = m_figureToolBar->addAction ("Axes"); + connect (toggle_axes, SIGNAL (triggered (void)), + this, SLOT (toggleAxes (void))); + + QAction *toggle_grid = m_figureToolBar->addAction ("Grid"); + connect (toggle_grid, SIGNAL (triggered (void)), + this, SLOT (toggleGrid (void))); m_menuBar = new MenuBar (win); win->setMenuBar (m_menuBar); @@ -199,7 +265,7 @@ editMenu->addAction (tr ("&Paste"), this, SLOT (editPaste(void)), Qt::CTRL|Qt::Key_V)->setEnabled (false); editMenu->addSeparator (); - editMenu->addActions (mouseModeGroup->actions ()); + editMenu->addActions (m_mouseModeGroup->actions ()); QMenu* helpMenu = m_menuBar->addMenu (tr ("&Help")); helpMenu->menuAction ()->setObjectName ("builtinMenu"); @@ -210,6 +276,16 @@ m_menuBar->addReceiver (this); } +void Figure::updateFigureToolBarAndMenuBar (void) +{ + if (m_mouseModeGroup) + { + m_blockUpdates = true; + m_mouseModeGroup->setMode (mouseMode ()); + m_blockUpdates = false; + } +} + Container* Figure::innerContainer (void) { return m_container; @@ -233,6 +309,8 @@ if (obj) obj->slotRedraw (); } + + updateFigureToolBarAndMenuBar (); } void Figure::beingDeleted (void) @@ -342,14 +420,6 @@ m_blockUpdates = false; updateBoundingBox (false); - - if (visible) - m_mouseMode = m_lastMouseMode; - else - { - m_lastMouseMode = m_mouseMode; - m_mouseMode = NoMode; - } } } @@ -600,6 +670,23 @@ ABOUT_TEXT); } +void Figure::setMouseMode (MouseMode mode) +{ + if (m_blockUpdates) + return; + + gh_manager::auto_lock lock; + + figure::properties& fp = properties<figure> (); + + fp.set___mouse_mode__ (mouse_mode_to_string (mode)); + + Canvas* canvas = m_container->canvas (m_handle); + + if (canvas) + canvas->setCursor (mode); +} + void Figure::fileNewFigure (void) { } @@ -674,4 +761,20 @@ redraw (); } +void Figure::toggleAxes (void) +{ + Canvas* canvas = m_container->canvas (m_handle); + + if (canvas) + canvas->toggleAxes (m_handle); +} + +void Figure::toggleGrid (void) +{ + Canvas* canvas = m_container->canvas (m_handle); + + if (canvas) + canvas->toggleGrid (m_handle); +} + }; // namespace QtHandles