Mercurial > octave
diff libgui/graphics/Canvas.cc @ 27645:028205a91a07
eliminate global access to Octave resources in qt graphics classes
Provide reference to base_qobject to qt graphics classes to
eliminate need for accessing it through a global variable.
* qt-graphics-toolkit.h, qt-graphics-toolkit.cc
(qt_graphics_toolkit::m_octave_qobj): New member variable.
(qt_graphics_toolkit::qt_graphics_toolkit): Accept reference to
base_qobject as argument.
(qt_graphics_toolkit::create_object): Pass m_octave_qobj to create
functions for individual graphics objects.
* __init_qt__.cc (__init__): Temporarily access base_qobject by
calling octave::base_qobject::the_octave_qobject. Pass it to
qt_graphics_toolkit constructor.
* BaseControl.h, BaseControl.cc, ButtonControl.h, ButtonControl.cc,
ButtonGroup.h, ButtonGroup.cc, Canvas.h, Canvas.cc, CheckBoxControl.h,
CheckBoxControl.cc, Container.h, Container.cc, ContextMenu.h,
ContextMenu.cc, EditControl.h, EditControl.cc, Figure.h, Figure.cc,
GLCanvas.h, GLCanvas.cc, ListBoxControl.h, ListBoxControl.cc, Menu.h,
Menu.cc, Panel.h, Panel.cc, PopupMenuControl.h, PopupMenuControl.cc,
PushButtonControl.h, PushButtonControl.cc, PushTool.h, PushTool.cc,
RadioButtonControl.h, RadioButtonControl.cc, SliderControl.h,
SliderControl.cc, Table.h, Table.cc, TextControl.h, TextControl.cc,
ToggleButtonControl.h, ToggleButtonControl.cc, ToggleTool.h,
ToggleTool.cc, ToolBar.h, ToolBar.cc, ToolBarButton.h,
ToolBarButton.cc, annotation-dialog.h, annotation-dialog.cc:
Accept reference to base_qobject in create function and constructors
for graphics objects. Eliminate global access to GUI resources.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Tue, 05 Nov 2019 13:28:45 -0500 |
parents | 8b6e928e0705 |
children | 2a506bc4a7af |
line wrap: on
line diff
--- a/libgui/graphics/Canvas.cc Tue Nov 05 08:31:06 2019 -0500 +++ b/libgui/graphics/Canvas.cc Tue Nov 05 13:28:45 2019 -0500 @@ -72,11 +72,10 @@ m_redrawBlocked = block; } - static QCursor - make_cursor (const QString& name, int hot_x = -1, int hot_y = -1) + QCursor + Canvas::make_cursor (const QString& name, int hot_x, int hot_y) { - octave::resource_manager& rmgr - = octave::__get_resource_manager__ ("make_cursor"); + octave::resource_manager& rmgr = m_octave_qobj.get_resource_manager (); QIcon icon = rmgr.icon (name); @@ -873,7 +872,7 @@ octave_value_list props = ovl ("textbox", bb); - annotation_dialog anno_dlg (w, props); + annotation_dialog anno_dlg (m_octave_qobj, w, props); if (anno_dlg.exec () == QDialog::Accepted) { @@ -1077,11 +1076,12 @@ } Canvas* - Canvas::create (const std::string& /* name */, QWidget *parent, - const graphics_handle& handle) + Canvas::create (octave::base_qobject& oct_qobj, + const graphics_handle& handle, QWidget *parent, + const std::string& /* name */) { // Only OpenGL - return new GLCanvas (parent, handle); + return new GLCanvas (oct_qobj, handle, parent); } }