From ed753e10df20fa484b68bf227e3e22ad98c54d6a Mon Sep 17 00:00:00 2001 From: nds Date: Thu, 10 Sep 2020 06:46:26 +0300 Subject: [PATCH] 0031658: Inspector - using AIS_ViewController in View package - View: using AIS_ViewController, AIS_ViewCube. --- tools/DFBrowser/DFBrowser_Window.cxx | 3 +- tools/ShapeView/ShapeView_Window.cxx | 3 +- tools/VInspector/VInspector_Window.cxx | 4 +- tools/View/View.qrc | 7 +- tools/View/View_Displayer.cxx | 23 + tools/View/View_Displayer.hxx | 9 +- tools/View/View_ToolActionType.hxx | 3 +- tools/View/View_ToolBar.cxx | 7 + tools/View/View_ViewActionType.hxx | 6 +- tools/View/View_Widget.cxx | 555 +++---------------------- tools/View/View_Widget.hxx | 181 +------- tools/View/View_Window.cxx | 40 +- tools/View/View_Window.hxx | 12 + tools/View/icons/cursor_rotate.png | Bin 291 -> 0 bytes tools/View/icons/cursor_zoom.png | Bin 245 -> 0 bytes tools/View/icons/view_cube.png | Bin 0 -> 331 bytes tools/View/icons/view_fitarea.png | Bin 224 -> 0 bytes tools/View/icons/view_pan.png | Bin 395 -> 0 bytes tools/View/icons/view_rotate.png | Bin 224 -> 0 bytes tools/View/icons/view_zoom.png | Bin 222 -> 0 bytes 20 files changed, 159 insertions(+), 694 deletions(-) delete mode 100644 tools/View/icons/cursor_rotate.png delete mode 100644 tools/View/icons/cursor_zoom.png create mode 100644 tools/View/icons/view_cube.png delete mode 100644 tools/View/icons/view_fitarea.png delete mode 100644 tools/View/icons/view_pan.png delete mode 100644 tools/View/icons/view_rotate.png delete mode 100644 tools/View/icons/view_zoom.png diff --git a/tools/DFBrowser/DFBrowser_Window.cxx b/tools/DFBrowser/DFBrowser_Window.cxx index 01b100b189..f0415e5eca 100644 --- a/tools/DFBrowser/DFBrowser_Window.cxx +++ b/tools/DFBrowser/DFBrowser_Window.cxx @@ -57,7 +57,6 @@ #include #include #include -#include #include #include @@ -194,7 +193,7 @@ DFBrowser_Window::DFBrowser_Window() // view myViewWindow = new View_Window (myMainWindow); - myViewWindow->ViewWidget()->SetPredefinedSize (DFBROWSER_DEFAULT_VIEW_WIDTH, DFBROWSER_DEFAULT_VIEW_HEIGHT); + myViewWindow->SetPredefinedSize (DFBROWSER_DEFAULT_VIEW_WIDTH, DFBROWSER_DEFAULT_VIEW_HEIGHT); QDockWidget* aViewDockWidget = new QDockWidget (tr ("View"), myMainWindow); aViewDockWidget->setObjectName (aViewDockWidget->windowTitle()); diff --git a/tools/ShapeView/ShapeView_Window.cxx b/tools/ShapeView/ShapeView_Window.cxx index bfe8d34eca..d6f54d75cc 100644 --- a/tools/ShapeView/ShapeView_Window.cxx +++ b/tools/ShapeView/ShapeView_Window.cxx @@ -31,7 +31,6 @@ #include #include #include -#include #include #include @@ -129,7 +128,7 @@ ShapeView_Window::ShapeView_Window (QWidget* theParent) connect (myViewWindow, SIGNAL(eraseAllPerformed()), this, SLOT(onEraseAllPerformed())); aVisibilityState->SetDisplayer (myViewWindow->Displayer()); aVisibilityState->SetPresentationType (View_PresentationType_Main); - myViewWindow->ViewWidget()->SetPredefinedSize (SHAPEVIEW_DEFAULT_VIEW_WIDTH, SHAPEVIEW_DEFAULT_VIEW_HEIGHT); + myViewWindow->SetPredefinedSize (SHAPEVIEW_DEFAULT_VIEW_WIDTH, SHAPEVIEW_DEFAULT_VIEW_HEIGHT); QDockWidget* aViewDockWidget = new QDockWidget (tr ("View"), myMainWindow); aViewDockWidget->setObjectName (aViewDockWidget->windowTitle()); diff --git a/tools/VInspector/VInspector_Window.cxx b/tools/VInspector/VInspector_Window.cxx index 1991dbe631..17fc850e6d 100644 --- a/tools/VInspector/VInspector_Window.cxx +++ b/tools/VInspector/VInspector_Window.cxx @@ -17,6 +17,7 @@ #include #include +#include #include @@ -48,6 +49,7 @@ #include #include #include +#include #include #include @@ -892,7 +894,7 @@ Handle(AIS_InteractiveContext) VInspector_Window::createView() Handle(AIS_InteractiveContext) aContext = View_Viewer::CreateStandardViewer(); myViewWindow = new View_Window (0, aContext, false /*for opening several BREP files*/, true); - myViewWindow->ViewWidget()->SetPredefinedSize (VINSPECTOR_DEFAULT_VIEW_WIDTH, VINSPECTOR_DEFAULT_VIEW_HEIGHT); + myViewWindow->SetPredefinedSize (VINSPECTOR_DEFAULT_VIEW_WIDTH, VINSPECTOR_DEFAULT_VIEW_HEIGHT); myViewWindow->move (VINSPECTOR_DEFAULT_VIEW_POSITION_X, VINSPECTOR_DEFAULT_VIEW_POSITION_Y); myViewWindow->show(); diff --git a/tools/View/View.qrc b/tools/View/View.qrc index 89d2f9a795..d403f34bb9 100644 --- a/tools/View/View.qrc +++ b/tools/View/View.qrc @@ -1,18 +1,13 @@ - icons/cursor_rotate.png - icons/cursor_zoom.png icons/keep_view_off.png icons/keep_view_on.png icons/trihedron.png icons/view_clear.png + icons/view_cube.png icons/view_dm_shading.png icons/view_dm_wireframe.png icons/view_fitall.png - icons/view_fitarea.png - icons/view_pan.png - icons/view_rotate.png - icons/view_zoom.png diff --git a/tools/View/View_Displayer.cxx b/tools/View/View_Displayer.cxx index 72c1c28ec7..82592275d7 100644 --- a/tools/View/View_Displayer.cxx +++ b/tools/View/View_Displayer.cxx @@ -20,6 +20,7 @@ #include #include #include +#include #include #include #include @@ -230,6 +231,28 @@ void View_Displayer::DisplayDefaultTrihedron (const Standard_Boolean toDisplay, GetContext()->Erase (aTrihedron, theToUpdateViewer); } +// ======================================================================= +// function : DisplayViewCube +// purpose : +// ======================================================================= +void View_Displayer::DisplayViewCube (const Standard_Boolean toDisplay, const bool theToUpdateViewer) +{ + if (myViewCube.IsNull() && toDisplay) + { + myViewCube = new AIS_ViewCube(); + myViewCube->SetSize (35.0); + myViewCube->SetBoxColor (Quantity_NOC_GRAY50); + } + + if (myViewCube.IsNull()) + return; + + if (toDisplay) + GetContext()->Display (myViewCube, theToUpdateViewer); + else + GetContext()->Erase (myViewCube, theToUpdateViewer); +} + // ======================================================================= // function : SetVisible // purpose : diff --git a/tools/View/View_Displayer.hxx b/tools/View/View_Displayer.hxx index da1f029a46..3ba29968d8 100644 --- a/tools/View/View_Displayer.hxx +++ b/tools/View/View_Displayer.hxx @@ -28,6 +28,7 @@ #include class AIS_Trihedron; +class AIS_ViewCube; class V3d_View; class View_DisplayPreview; @@ -121,6 +122,11 @@ public: //! \param isToUpdateView boolean state if viewer should be updated Standard_EXPORT void DisplayDefaultTrihedron (const Standard_Boolean toDisplay, const bool theToUpdateViewer); + //! Displays presentation of view cube, create it by the first call + //! \param toDisplay flag to display presentation if true, or erase it + //! \param isToUpdateView boolean state if viewer should be updated + Standard_EXPORT void DisplayViewCube (const Standard_Boolean toDisplay, const bool theToUpdateViewer); + //! Sets shape visible/invisible //! \theShape shape instance //! \theState visibility state @@ -186,7 +192,8 @@ private: View_DisplayPreview* myDisplayPreview; //!< class for preview display Handle(AIS_InteractiveContext) myContext; //!< context, where the displayer works - Handle(AIS_Trihedron) myDefaultTrihedron; //!< NULL presentation until the first display + Handle(AIS_Trihedron) myDefaultTrihedron; //!< trihedron presentation for the current context + Handle(AIS_ViewCube) myViewCube; //!< view cube presentation for current context NCollection_DataMap> myDisplayed; //!< visualized presentations NCollection_DataMap myColorAttributes; //!< color properties of presentations diff --git a/tools/View/View_ToolActionType.hxx b/tools/View/View_ToolActionType.hxx index a518d2ba54..b2b0d0d4cb 100644 --- a/tools/View/View_ToolActionType.hxx +++ b/tools/View/View_ToolActionType.hxx @@ -22,7 +22,8 @@ enum View_ToolActionType View_ToolActionType_KeepViewId, //!< Do not clear previously shown presentations View_ToolActionType_KeepViewOffId, //!< Do show only for new displayed presentation View_ToolActionType_ClearViewId, //!< Erase all displayed presentations - View_ToolActionType_Trihedron //!< Display/Erase trihedron presentation + View_ToolActionType_Trihedron, //!< Display/Erase trihedron presentation + View_ToolActionType_ViewCube //!< Display/Erase view cube presentation }; #endif diff --git a/tools/View/View_ToolBar.cxx b/tools/View/View_ToolBar.cxx index 7887ebbed6..e23b402ee3 100644 --- a/tools/View/View_ToolBar.cxx +++ b/tools/View/View_ToolBar.cxx @@ -69,6 +69,13 @@ View_ToolBar::View_ToolBar (QWidget* theParent, const bool isUseKeepView) myActionsMap[View_ToolActionType_Trihedron]->setCheckable (true); myActionsMap[View_ToolActionType_Trihedron]->setChecked (false); + myActionsMap[View_ToolActionType_ViewCube] = new QToolButton (theParent); + myActionsMap[View_ToolActionType_ViewCube]->setIcon (QIcon (":/icons/view_cube.png")); + myActionsMap[View_ToolActionType_ViewCube]->setToolTip (tr ("View Cube display")); + myActionsMap[View_ToolActionType_ViewCube]->setCheckable (true); + myActionsMap[View_ToolActionType_ViewCube]->setChecked (false); + + if (isUseKeepView) { myActionsMap[View_ToolActionType_KeepViewId] = new QToolButton (theParent); diff --git a/tools/View/View_ViewActionType.hxx b/tools/View/View_ViewActionType.hxx index 1f3288fa5f..d970c3554d 100644 --- a/tools/View/View_ViewActionType.hxx +++ b/tools/View/View_ViewActionType.hxx @@ -19,11 +19,7 @@ //! Actions of view widget enum View_ViewActionType { - View_ViewActionType_FitAllId, //!< fits the view to wrap the bounding box of displayed objects - View_ViewActionType_FitAreaId, //!< zoom the view to the given area - View_ViewActionType_ZoomId, //!< zoom in/out the view by some delta - View_ViewActionType_PanId, //!< move position of the view camera - View_ViewActionType_RotationId, //!< rotate the view + View_ViewActionType_FitAllId, //!< fits the view to wrap the bounding box of displayed objects View_ViewActionType_DisplayModeId //!< change display mode of visualized presentations (to wireframe or shading) }; diff --git a/tools/View/View_Widget.cxx b/tools/View/View_Widget.cxx index 878b19f708..e0c88e05a7 100644 --- a/tools/View/View_Widget.cxx +++ b/tools/View/View_Widget.cxx @@ -19,6 +19,7 @@ #include +#include #include #include @@ -50,13 +51,6 @@ #include #endif -// the key for multi selection : -#define MULTISELECTIONKEY Qt::ShiftModifier -// the key for shortcut (use to activate dynamic onRotate, panning) -#define CASCADESHORTCUTKEY Qt::ControlModifier -// for elastic bean selection -#define ValZWMin 1 - // ======================================================================= // function : Constructor // purpose : @@ -64,18 +58,20 @@ View_Widget::View_Widget (QWidget* theParent, const Handle(AIS_InteractiveContext)& theContext, const bool isFitAllActive) -: QWidget (theParent), myCurrentMode (View_CurrentAction3d_Nothing), myFirst (true), myDefaultWidth (-1), - myDefaultHeight (-1), myViewIsEnabled (true), myXmin (0), myYmin (0), myXmax (0), myYmax (0), myDragButtonDownX (0), - myDragButtonDownY (0), myDragMultiButtonDownX (0), myDragMultiButtonDownY (0), myIsRectVisible (false), myRectBand (0), +: QWidget (theParent), myFirst (true), myDefaultWidth (-1), + myDefaultHeight (-1), myViewIsEnabled (true), myHasInitProj (Standard_False), myInitVx (0), myInitVy (0), myInitVz (0) { myViewer = new View_Viewer (View_Viewer::DefaultColor()); if (!theContext.IsNull()) + { myViewer->InitViewer (theContext); + } else { myViewer->InitViewer (myViewer->CreateStandardViewer()); } + myController = new AIS_ViewController(); setAttribute (Qt::WA_PaintOnScreen); setAttribute (Qt::WA_NoSystemBackground); @@ -87,7 +83,6 @@ View_Widget::View_Widget (QWidget* theParent, initViewActions(); ((View_ToolButton*)myFitAllAction)->SetButtonChecked (isFitAllActive); - initCursors(); } // ======================================================================= @@ -204,8 +199,7 @@ void View_Widget::SetEnabledView (const bool theIsEnabled) if (myViewer->GetView()) myViewer->GetView()->SetBackgroundColor (theIsEnabled ? View_Viewer::DefaultColor() : View_Viewer::DisabledColor()); - for (int anActionId = View_ViewActionType_FitAreaId; anActionId <= View_ViewActionType_DisplayModeId; anActionId++) - ViewAction ((View_ViewActionType)anActionId)->setEnabled (theIsEnabled); + ViewAction (View_ViewActionType_DisplayModeId)->setEnabled (theIsEnabled); } // ======================================================================= @@ -254,53 +248,6 @@ void View_Widget::onCheckedStateChanged (bool isOn) emit checkedStateChanged(View_ViewActionType_FitAllId, isOn); } -// ======================================================================= -// function : OnUpdateToggled -// purpose : -// ======================================================================= -void View_Widget::OnUpdateToggled (bool isOn) -{ - QAction* aSentByAction = (QAction*)sender(); - - if (aSentByAction == myViewActions[View_ViewActionType_DisplayModeId]) - { - aSentByAction->setIcon (isOn ? QIcon (":/icons/view_dm_wireframe.png") - : QIcon (":/icons/view_dm_shading.png")); - return; - } - - if (!isOn) - return; - - for (int anActionId = View_ViewActionType_FitAreaId; anActionId <= View_ViewActionType_RotationId; anActionId++) - { - QAction* anAction = myViewActions[(View_ViewActionType)anActionId]; - if ((anAction == myViewActions[View_ViewActionType_FitAreaId]) || - (anAction == myViewActions[View_ViewActionType_ZoomId]) || - (anAction == myViewActions[View_ViewActionType_PanId]) || - (anAction == myViewActions[View_ViewActionType_RotationId])) - { - if (anAction && (anAction != aSentByAction)) - { - anAction->setChecked (false); - } - else - { - if (aSentByAction == myViewActions[View_ViewActionType_FitAreaId]) - setActiveCursor (View_CursorMode_HandCursor); - else if (aSentByAction == myViewActions[View_ViewActionType_ZoomId]) - setActiveCursor (View_CursorMode_ZoomCursor); - else if (aSentByAction == myViewActions[View_ViewActionType_PanId]) - setActiveCursor (View_CursorMode_PanCursor); - else if (aSentByAction == myViewActions[View_ViewActionType_RotationId]) - setActiveCursor (View_CursorMode_RotationCursor); - else - setActiveCursor (View_CursorMode_DefaultCursor); - } - } - } -} - // ======================================================================= // function : initViewActions // purpose : @@ -315,31 +262,8 @@ void View_Widget::initViewActions() createAction (View_ViewActionType_FitAllId, ":/icons/view_fitall.png", tr ("Fit All"), SLOT (OnFitAll())); myFitAllAction->setDefaultAction (ViewAction (View_ViewActionType_FitAllId)); - createAction (View_ViewActionType_FitAreaId, ":/icons/view_fitarea.png", tr ("Fit Area"), SLOT (OnFitArea()), true); - createAction (View_ViewActionType_ZoomId, ":/icons/view_zoom.png", tr ("Zoom"), SLOT (OnZoom()), true); - createAction (View_ViewActionType_PanId, ":/icons/view_pan.png", tr ("Pan"), SLOT (OnPan()), true); - createAction (View_ViewActionType_RotationId, ":/icons/view_rotate.png", tr ("Rotation"), SLOT (OnRotate()), true); createAction (View_ViewActionType_DisplayModeId, ":/icons/view_dm_shading.png", tr ("Display Mode"), SIGNAL (displayModeClicked()), true); - - for (int anActionId = View_ViewActionType_FitAreaId; anActionId <= View_ViewActionType_RotationId; anActionId++) - connect (myViewActions[(View_ViewActionType)anActionId], SIGNAL (toggled(bool)), this, SLOT (OnUpdateToggled(bool))); -} - -// ======================================================================= -// function : initCursors -// purpose : -// ======================================================================= -void View_Widget::initCursors() -{ - if (!myCursors.empty()) - return; - - myCursors[View_CursorMode_DefaultCursor] = QCursor (Qt::ArrowCursor); - myCursors[View_CursorMode_HandCursor] = QCursor (Qt::PointingHandCursor); - myCursors[View_CursorMode_PanCursor] = QCursor (Qt::SizeAllCursor); - myCursors[View_CursorMode_ZoomCursor] = QCursor(QIcon (":/icons/cursor_zoom.png").pixmap (20, 20)); - myCursors[View_CursorMode_RotationCursor] = QCursor(QIcon (":/icons/cursor_rotate.png").pixmap (20, 20)); } // ======================================================================= @@ -348,12 +272,13 @@ void View_Widget::initCursors() // ======================================================================= void View_Widget::mousePressEvent (QMouseEvent* theEvent) { - if (theEvent->button() == Qt::LeftButton) - processLeftButtonDown (theEvent->buttons() | theEvent->modifiers(), theEvent->pos()); - else if (theEvent->button() == Qt::MidButton) - processMiddleButtonDown (theEvent->buttons() | theEvent->modifiers(), theEvent->pos()); - else if (theEvent->button() == Qt::RightButton) - processRightButtonDown (theEvent->buttons() | theEvent->modifiers(), theEvent->pos()); + if (myController->PressMouseButton (Graphic3d_Vec2i (theEvent->x(), theEvent->y()), + keyMouse (theEvent->button()), + keyFlag (theEvent->modifiers()), + Standard_False)) + { + myController->FlushViewEvents (myViewer->GetContext(), myViewer->GetView(), Standard_True); + } } // ======================================================================= @@ -362,12 +287,13 @@ void View_Widget::mousePressEvent (QMouseEvent* theEvent) // ======================================================================= void View_Widget::mouseReleaseEvent (QMouseEvent* theEvent) { - if (theEvent->button() == Qt::LeftButton) - processLeftButtonUp (theEvent->buttons() | theEvent->modifiers(), theEvent->pos()); - else if (theEvent->button() == Qt::MidButton) - processMiddleButtonUp (theEvent->buttons() | theEvent->modifiers(), theEvent->pos()); - else if (theEvent->button() == Qt::RightButton) - processRightButtonUp (theEvent->buttons() | theEvent->modifiers(), theEvent->pos()); + if (myController->ReleaseMouseButton (Graphic3d_Vec2i (theEvent->x(), theEvent->y()), + keyMouse (theEvent->button()), + keyFlag (theEvent->modifiers()), + Standard_False)) + { + myController->FlushViewEvents (myViewer->GetContext(), myViewer->GetView(), Standard_True); + } } // ======================================================================= @@ -376,411 +302,11 @@ void View_Widget::mouseReleaseEvent (QMouseEvent* theEvent) // ======================================================================= void View_Widget::mouseMoveEvent (QMouseEvent* theEvent) { - processMouseMove (theEvent->buttons() | theEvent->modifiers(), theEvent->pos()); -} + myController->UpdateMousePosition (Graphic3d_Vec2i (theEvent->x(), theEvent->y()), + keyMouse (theEvent->button()), + keyFlag (theEvent->modifiers()), Standard_False); -// ======================================================================= -// function : activateCursor -// purpose : -// ======================================================================= -void View_Widget::activateCursor (const View_CurrentAction3d theMode) -{ - switch (theMode) - { - case View_CurrentAction3d_DynamicPanning: - { - setActiveCursor (View_CursorMode_PanCursor); - break; - } - case View_CurrentAction3d_DynamicZooming: - { - setActiveCursor (View_CursorMode_ZoomCursor); - break; - } - case View_CurrentAction3d_DynamicRotation: - { - setActiveCursor (View_CursorMode_RotationCursor); - break; - } - case View_CurrentAction3d_WindowZooming: - { - setActiveCursor (View_CursorMode_HandCursor); - break; - } - case View_CurrentAction3d_Nothing: - default: - { - setActiveCursor (View_CursorMode_DefaultCursor); - break; - } - } -} - -// ======================================================================= -// function : processLeftButtonDown -// purpose : -// ======================================================================= -void View_Widget::processLeftButtonDown (const int theFlags, const QPoint thePoint) -{ - // save the current mouse coordinate in min - myXmin = thePoint.x(); - myYmin = thePoint.y(); - myXmax = thePoint.x(); - myYmax = thePoint.y(); - - if (theFlags & CASCADESHORTCUTKEY) - { - myCurrentMode = View_CurrentAction3d_DynamicZooming; - OnUpdateToggled(true); - } - else - { - switch (myCurrentMode) - { - case View_CurrentAction3d_Nothing: - { - if (theFlags & MULTISELECTIONKEY) - processDragMultiEvent (myXmax, myYmax, View_DragMode_ButtonDown); - else - processDragEvent (myXmax, myYmax, View_DragMode_ButtonDown); - break; - } - case View_CurrentAction3d_DynamicZooming: - case View_CurrentAction3d_WindowZooming: - case View_CurrentAction3d_DynamicPanning: - break; - case View_CurrentAction3d_DynamicRotation: - { - myViewer->GetView()->StartRotation (thePoint.x(), thePoint.y()); - break; - } - default: - { - throw Standard_ProgramError ("View_Widget::processLeftButtonDown : Incompatible Current Mode"); - break; - } - } - } - activateCursor (myCurrentMode); - emit leftButtonDown(thePoint.x(), thePoint.y()); -} - -// ======================================================================= -// function : processMiddleButtonDown -// purpose : -// ======================================================================= -void View_Widget::processMiddleButtonDown (const int theFlags, const QPoint /*thePoint*/) -{ - if (theFlags & CASCADESHORTCUTKEY) { - myCurrentMode = View_CurrentAction3d_DynamicPanning; - OnUpdateToggled(true); - } - activateCursor (myCurrentMode); -} - -// ======================================================================= -// function : processRightButtonDown -// purpose : -// ======================================================================= -void View_Widget::processRightButtonDown (const int theFlags, const QPoint thePoint) -{ - if (theFlags & CASCADESHORTCUTKEY) - { - myCurrentMode = View_CurrentAction3d_DynamicRotation; - myViewer->GetView()->StartRotation (thePoint.x(), thePoint.y()); - OnUpdateToggled(true); - } - else - { - popup (thePoint.x(), thePoint.y()); - } - activateCursor (myCurrentMode); -} - -// ======================================================================= -// function : processLeftButtonUp -// purpose : -// ======================================================================= -void View_Widget::processLeftButtonUp (const int theFlags, const QPoint thePoint) -{ - switch (myCurrentMode) - { - case View_CurrentAction3d_Nothing: - { - if (thePoint.x() == myXmin && thePoint.y() == myYmin) - { - // no offset between down and up --> selectEvent - myXmax = thePoint.x(); - myYmax = thePoint.y(); - if (theFlags & MULTISELECTIONKEY) - processInputMultiEvent (thePoint.x(), thePoint.y()); - else - processInputEvent (thePoint.x(), thePoint.y()); - } - else - { - drawRectangle (myXmin, myYmin, myXmax, myYmax, Standard_False); - myXmax = thePoint.x(); - myYmax = thePoint.y(); - if (theFlags & MULTISELECTIONKEY) - processDragMultiEvent (thePoint.x(), thePoint.y(), View_DragMode_ButtonUp); - else - processDragEvent (thePoint.x(), thePoint.y(), View_DragMode_ButtonUp); - } - break; - } - case View_CurrentAction3d_DynamicZooming: - break; - case View_CurrentAction3d_WindowZooming: - { - drawRectangle (myXmin, myYmin, myXmax, myYmax, Standard_False); - myXmax = thePoint.x(); - myYmax = thePoint.y(); - if ((abs(myXmin - myXmax) > ValZWMin) || - (abs(myYmin - myYmax) > ValZWMin)) - myViewer->GetView()->WindowFitAll (myXmin, myYmin, myXmax, myYmax); - break; - } - case View_CurrentAction3d_DynamicPanning: - break; - case View_CurrentAction3d_DynamicRotation: - break; - default: - { - throw Standard_ProgramError("View_Widget::processLeftButtonUp : Incompatible Current Mode"); - break; - } - } - myDragButtonDownX = 0; - myDragButtonDownY = 0; - myDragMultiButtonDownX = 0; - myDragMultiButtonDownY = 0; - - emit selectionChanged(); - emit leftButtonUp(thePoint.x(), thePoint.y()); -} - -// ======================================================================= -// function : processMiddleButtonUp -// purpose : -// ======================================================================= -void View_Widget::processMiddleButtonUp (const int /*theFlags*/, const QPoint /*thePoint*/) -{ - myCurrentMode = View_CurrentAction3d_Nothing; - activateCursor (myCurrentMode); -} - -// ======================================================================= -// function : processRightButtonUp -// purpose : -// ======================================================================= -void View_Widget::processRightButtonUp (const int /*theFlags*/, const QPoint thePoint) -{ - if (myCurrentMode == View_CurrentAction3d_Nothing) - { - popup (thePoint.x(), thePoint.y()); - } - else - myCurrentMode = View_CurrentAction3d_Nothing; - activateCursor (myCurrentMode); -} - -// ======================================================================= -// function : processMouseMove -// purpose : -// ======================================================================= -void View_Widget::processMouseMove (const int theFlags, const QPoint thePoint) -{ - if (theFlags & Qt::LeftButton || theFlags & Qt::RightButton || theFlags & Qt::MidButton) - { - switch (myCurrentMode) - { - case View_CurrentAction3d_Nothing: - { - myXmax = thePoint.x(); - myYmax = thePoint.y(); - drawRectangle (myXmin, myYmin, myXmax, myYmax, Standard_False); - if (theFlags & MULTISELECTIONKEY) - processDragMultiEvent (myXmax, myYmax, View_DragMode_ButtonMove); - else - processDragEvent (myXmax, myYmax, View_DragMode_ButtonMove); - drawRectangle (myXmin, myYmin, myXmax, myYmax, Standard_True); - break; - } - case View_CurrentAction3d_DynamicZooming: - { - myViewer->GetView()->Zoom (myXmax, myYmax, thePoint.x(), thePoint.y()); - myXmax = thePoint.x(); - myYmax = thePoint.y(); - break; - } - case View_CurrentAction3d_WindowZooming: - { - myXmax = thePoint.x(); - myYmax = thePoint.y(); - drawRectangle (myXmin, myYmin, myXmax, myYmax, Standard_False); - drawRectangle (myXmin, myYmin, myXmax, myYmax, Standard_True); - break; - } - case View_CurrentAction3d_DynamicPanning: - { - myViewer->GetView()->Pan (thePoint.x() - myXmax, myYmax - thePoint.y()); - myXmax = thePoint.x(); - myYmax = thePoint.y(); - break; - } - case View_CurrentAction3d_DynamicRotation: - { - myViewer->GetView()->Rotation (thePoint.x(), thePoint.y()); - myViewer->GetView()->Redraw(); - break; - } - default: - { - throw Standard_ProgramError("View_Widget::processMouseMove : Incompatible Current Mode"); - break; - } - } - } - else - { - myXmax = thePoint.x(); - myYmax = thePoint.y(); - if (theFlags & MULTISELECTIONKEY) - processMoveMultiEvent (thePoint.x(), thePoint.y()); - else - processMoveEvent (thePoint.x(), thePoint.y()); - } - emit moveTo (thePoint.x(), thePoint.y()); -} - -// ======================================================================= -// function : processDragEvent -// purpose : -// ======================================================================= -void View_Widget::processDragEvent (const Standard_Integer theX, const Standard_Integer theY, const View_DragMode& theState) -{ - //myDragButtonDownX = 0; - //myDragButtonDownY = 0; - - switch (theState) - { - case View_DragMode_ButtonDown: - { - myDragButtonDownX = theX; - myDragButtonDownY = theY; - break; - } - case View_DragMode_ButtonMove: - break; - case View_DragMode_ButtonUp: - { - myViewer->GetContext()->Select (myDragButtonDownX, myDragButtonDownY, theX, theY, myViewer->GetView(), Standard_True); - emit selectionChanged(); - break; - } - default: - break; - } -} - -// ======================================================================= -// function : processInputEvent -// purpose : -// ======================================================================= -void View_Widget::processInputEvent (const Standard_Integer/* theX*/, const Standard_Integer/* theY*/) -{ - myViewer->GetContext()->Select (Standard_True); - emit selectionChanged(); -} - -// ======================================================================= -// function : processMoveEvent -// purpose : -// ======================================================================= -void View_Widget::processMoveEvent (const Standard_Integer theX, const Standard_Integer theY) -{ - if (myViewer->GetView()) - myViewer->GetContext()->MoveTo (theX, theY, myViewer->GetView(), Standard_True); -} - -// ======================================================================= -// function : processDragMultiEvent -// purpose : -// ======================================================================= -void View_Widget::processDragMultiEvent (const Standard_Integer theX, const Standard_Integer theY, - const View_DragMode& theState) -{ - switch (theState) - { - case View_DragMode_ButtonDown: - { - myDragMultiButtonDownX = theX; - myDragMultiButtonDownY = theY; - break; - } - case View_DragMode_ButtonMove: - { - myViewer->GetContext()->ShiftSelect (myDragMultiButtonDownX, myDragMultiButtonDownY, theX, theY, - myViewer->GetView(), Standard_True); - emit selectionChanged(); - break; - } - case View_DragMode_ButtonUp: - default: - break; - } -} - -// ======================================================================= -// function : processInputMultiEvent -// purpose : -// ======================================================================= -void View_Widget::processInputMultiEvent (const Standard_Integer /*theX*/, const Standard_Integer /*theY*/) -{ - myViewer->GetContext()->ShiftSelect (Standard_True); - emit selectionChanged(); -} - -// ======================================================================= -// function : drawRectangle -// purpose : -// ======================================================================= -void View_Widget::drawRectangle (const Standard_Integer theMinX, const Standard_Integer MinY, - const Standard_Integer MaxX, const Standard_Integer MaxY, - const Standard_Boolean theToDraw) -{ - Standard_Integer StoredMinX, StoredMaxX, StoredMinY, StoredMaxY; - - StoredMinX = (theMinX < MaxX) ? theMinX : MaxX; - StoredMinY = (MinY < MaxY) ? MinY : MaxY; - StoredMaxX = (theMinX > MaxX) ? theMinX : MaxX; - StoredMaxY = (MinY > MaxY) ? MinY : MaxY; - - QRect aRect; - aRect.setRect(StoredMinX, StoredMinY, abs (StoredMaxX-StoredMinX), abs (StoredMaxY-StoredMinY)); - - if (!myRectBand) - { - myRectBand = new QRubberBand (QRubberBand::Rectangle, this); - myRectBand->setStyle (QStyleFactory::create ("windows")); - myRectBand->setGeometry (aRect); - myRectBand->show(); - } - - if (myIsRectVisible && !theToDraw) // move or up : erase at the old position - { - myRectBand->hide(); - delete myRectBand; - myRectBand = 0; - myIsRectVisible = false; - } - - if (theToDraw) // move : draw - { - myIsRectVisible = true; - myRectBand->setGeometry (aRect); - } + myController->FlushViewEvents (myViewer->GetContext(), myViewer->GetView(), Standard_True); } // ======================================================================= @@ -801,11 +327,34 @@ void View_Widget::createAction (const View_ViewActionType theActionId, const QSt } // ======================================================================= -// function : setActiveCursor +// function : keyFlag // purpose : // ======================================================================= -void View_Widget::setActiveCursor (const View_CursorMode& theMode) +Aspect_VKeyFlags View_Widget::keyFlag (const int theModifierId) { - QCursor aCursor = myCursors[theMode]; - setCursor (myCursors[theMode]); + switch (theModifierId) + { + case Qt::NoModifier: return Aspect_VKeyFlags_NONE; + case Qt::ShiftModifier: return Aspect_VKeyFlags_SHIFT; + case Qt::ControlModifier: return Aspect_VKeyFlags_CTRL; + default: break; + } + return Aspect_VKeyFlags_NONE; +} + +// ======================================================================= +// function : keyMouse +// purpose : +// ======================================================================= +Aspect_VKeyMouse View_Widget::keyMouse (const int theButtonId) +{ + switch (theButtonId) + { + case Qt::NoButton: return Aspect_VKeyMouse_NONE; + case Qt::LeftButton: return Aspect_VKeyMouse_LeftButton; + case Qt::RightButton: return Aspect_VKeyMouse_RightButton; + case Qt::MidButton: return Aspect_VKeyMouse_MiddleButton; + default: break; + } + return Aspect_VKeyMouse_NONE; } diff --git a/tools/View/View_Widget.hxx b/tools/View/View_Widget.hxx index 3fd7fdb069..b882f32619 100644 --- a/tools/View/View_Widget.hxx +++ b/tools/View/View_Widget.hxx @@ -17,6 +17,8 @@ #define View_View_H #include +#include +#include #include #include #include @@ -31,8 +33,6 @@ class View_Viewer; -class QRubberBand; - //! \class View_Widget //! \brief It is a Qt control that visualizes content of OCCT 3D view //! It creates control and actions of manipulating of this view, @@ -41,38 +41,8 @@ class QRubberBand; class View_Widget : public QWidget { Q_OBJECT -protected: - - //! Enumeration defines manipulating actions of the widget - enum View_CurrentAction3d - { - View_CurrentAction3d_Nothing, //!< Empty action - View_CurrentAction3d_DynamicZooming, //!< Zoom action - View_CurrentAction3d_WindowZooming, //!< Zoom action using rectangle - View_CurrentAction3d_DynamicPanning, //!< Panning action - View_CurrentAction3d_DynamicRotation //!< Rotation action - }; - - //! Enumeration defines cursor kind - enum View_CursorMode - { - View_CursorMode_DefaultCursor, //!< default Qt cursor - View_CursorMode_HandCursor, //!< hand cursor - View_CursorMode_PanCursor, //!< panning cursor - View_CursorMode_ZoomCursor, //!< zoom cursor - View_CursorMode_RotationCursor //!< onRotate cursor - }; - - //! Enumeration defines drag mode - enum View_DragMode - { - View_DragMode_ButtonDown, //!< theState == -1 button down - View_DragMode_ButtonMove, //!< theState == 0 move - View_DragMode_ButtonUp //< theState == 1 button up - }; public: - //! Constructor Standard_EXPORT View_Widget (QWidget* theParent, const Handle(AIS_InteractiveContext)& theContext, @@ -154,21 +124,6 @@ signals: //! Sends a signal about selection change if the left mouse button is pressed and current action does not process it void selectionChanged(); - //! Sends a signal about moving to the point in the view - //! \param theX X mouse position in pixels - //! \param theY Y mouse position in pixels - void moveTo (const int theX, const int theY); - - //! Sends a signal about up the left mouse button down - //! \param theX X mouse position in pixels - //! \param theY Y mouse position in pixels - void leftButtonDown (const int theX, const int theY); - - //! Sends a signal about up the left mouse button up - //! \param theX X mouse position in pixels - //! \param theY Y mouse position in pixels - void leftButtonUp (const int theX, const int theY); - //! Sends a signal about display mode change void displayModeClicked(); @@ -182,29 +137,11 @@ public slots: //! Fits all the V3d view and redraw view void OnFitAll() { myViewer->GetView()->FitAll(); } - //! Stores state about fitting all to use it by the mouse move - void OnFitArea() { myCurrentMode = View_CurrentAction3d_WindowZooming; } - - //! Stores state about zoom to use it by the mouse move - void OnZoom() { myCurrentMode = View_CurrentAction3d_DynamicZooming; } - - //! Stores state about pan to use it by the mouse move - void OnPan() { myCurrentMode = View_CurrentAction3d_DynamicPanning; } - - //! Stores state about onRotate to use it by the mouse move - void OnRotate() { myCurrentMode = View_CurrentAction3d_DynamicRotation; } - //! Updates states of widget actions //! //! - if the state is checked, uncheck all other actions Standard_EXPORT void onCheckedStateChanged (bool isOn); - //! Updates states of tool actions: - //! - if the action is display mode, it changes an icon for action(wireframe or shading) - //! - if the state is checked, uncheck all other actions - //! \param isOn boolean value about check - Standard_EXPORT void OnUpdateToggled (bool isOn); - protected: //! Avoids Qt standard execution of this method, redraw V3d view @@ -232,99 +169,11 @@ protected: //! Creates view actions and fills an internal map void initViewActions(); - //! Creates cursors and fills an internal map - void initCursors(); - - //! Sets widget cursor by the action type - //! \param theMode an active action mode - void activateCursor (const View_CurrentAction3d theMode); - - //! Activates cursor of the active operation, perform drag, onRotate depending on mode, - //! stores the point position in xmin/xmax and ymin/ymax - //! \param theFlags an event buttons and modifiers - //! \param thePoint a clicked point - void processLeftButtonDown (const int theFlags, const QPoint thePoint); - - //! Activates cursor of the active operation and performs dynamic pan if it is active - //! \param theFlags an event buttons and modifiers - //! \param thePoint a clicked point - void processMiddleButtonDown (const int theFlags, const QPoint thePoint); - - //! Activates cursor of the active operation, build popup menu - //! \param theFlags an event buttons and modifiers - //! \param thePoint a clicked point - void processRightButtonDown (const int theFlags, const QPoint thePoint); - - //! Performs the active operation or performs Input/Drag event processing, emits selection changed signal - //! \param theFlags an event buttons and modifiers - //! \param thePoint a clicked point - void processLeftButtonUp (const int theFlags, const QPoint thePoint); - - //! Changes the active operation to None - //! \param theFlags an event buttons and modifiers - //! \param thePoint a clicked point - void processMiddleButtonUp (const int theFlags, const QPoint thePoint); - - //! Calls popup menu build and changes the active operation to None - //! \param theFlags an event buttons and modifiers - //! \param thePoint a clicked point - void processRightButtonUp (const int theFlags, const QPoint thePoint); - - //! Performs active operation or draws rectangle of zoom - //! \param theFlags an event buttons and modifiers - //! \param thePoint a clicked point - void processMouseMove (const int theFlags, const QPoint thePoint); - - //! Performs selection: store clicked point by botton down, call Select by button up - //! Emits signal about selection changed - //! \param theX a horizontal position of mouse event - //! \param theX a vertical position of mouse event - //! \param theState a mouse button state: down, move or up - void processDragEvent (const Standard_Integer theX, const Standard_Integer theY, const View_DragMode& theState); - - //! Performs selection in context without parameter, it means the selection of picked object - //! \param theX a horizontal position of mouse event - //! \param theX a vertical position of mouse event - void processInputEvent (const Standard_Integer theX, const Standard_Integer theY); - - //! Calls MoveTo of the context for the parameter coordinates - //! \param theX a horizontal position of mouse event - //! \param theX a vertical position of mouse event - void processMoveEvent (const Standard_Integer theX, const Standard_Integer theY); - - //! Empty: template to process mouse move with multi selection key pressed - //! \param theX a horizontal position of mouse event - //! \param theX a vertical position of mouse event - void processMoveMultiEvent (const Standard_Integer theX, const Standard_Integer theY) - { (void)theX; (void)theY; } - - //! Performs selection: store clicked point by botton down, call ShiftSelect by button move - //! Emits signal about selection changed - //! \param theX a horizontal position of mouse event - //! \param theX a vertical position of mouse event - //! \param theState a mouse button state: down, move or up - void processDragMultiEvent (const Standard_Integer theX, const Standard_Integer theY, const View_DragMode& theState); - - //! Performs shift selection in context without parameter, it means the selection of picked object - //! \param theX a horizontal position of mouse event - //! \param theX a vertical position of mouse event - void processInputMultiEvent (const Standard_Integer theX, const Standard_Integer theY); - //! Empty: template to create popup menu //! \param theX a horizontal position of mouse event //! \param theX a vertical position of mouse event void popup (const Standard_Integer theX, const Standard_Integer theY) { (void)theX; (void)theY; } - //! Draws Qt rectangle for the given area (e.g. for panning operation) - //! \param theMinX a minimal X coordinate - //! \param theMinY a minimal Y coordinate - //! \param theMinZ a minimal Z coordinate - //! \param theMaxX a maximum X coordinate - //! \param theMaxY a maximum Y coordinate - //! \param theMaxZ a maximum Z coordinate - //! \param theToDraw state whether the rectangle should be visualized or hidden - void drawRectangle (const Standard_Integer theMinX, const Standard_Integer theMinY, const Standard_Integer theMaxX, - const Standard_Integer theMaxY, const Standard_Boolean theToDraw); private: //! Creates action and stores it in a map of actions //! \param theActionId an identifier of action in internal map @@ -336,38 +185,32 @@ private: const char* theSlot, const bool isCheckable = false, const QString& theToolBar = QString(), const QString& theStatusBar = QString()); - //! Sets active action cursor for application - //! \param theMode a cursor mode - void setActiveCursor (const View_CursorMode& theMode); +private: + //! Converts Qt modifier key to Aspect key flag + //! \param theModifierId the event modifier + static Aspect_VKeyFlags keyFlag (const int theModifierId); + + //! Converts Qt button key to Aspect key mouse + //! \param theButtonId the event button + static Aspect_VKeyMouse keyMouse (const int theButtonId); private: View_Viewer* myViewer; //!< connector to context, V3d viewer and V3d View + AIS_ViewController* myController; //!< controller to process view actions + QToolButton* myFitAllAction; //!< widget for fit all, processed double click to perform action automatically QMap myViewActions; //!< tool bar view actions - QMap myCursors; //!< possible cursors for view actions - View_CurrentAction3d myCurrentMode; //!< an active action mode for viewer Standard_Boolean myFirst; //!< flag to Init view by the first resize/paint call Standard_Integer myDefaultWidth; //!< default width for the first sizeHint Standard_Integer myDefaultHeight; //!< default height for the first sizeHint Standard_Boolean myViewIsEnabled; //!< flag if the view and tool bar view actions are enabled/disabled - Standard_Integer myXmin; //!< cached X minimal position by mouse press event - Standard_Integer myYmin; //!< cached Y minimal position by mouse press event - Standard_Integer myXmax; //!< cached X maximum position by mouse press event - Standard_Integer myYmax; //!< cached Y maximum position by mouse press event - Standard_Integer myDragButtonDownX; //!< cached X button down by drag event - Standard_Integer myDragButtonDownY; //!< cached Y button down by drag event - Standard_Integer myDragMultiButtonDownX; //!< cached X button down by multi drag event - Standard_Integer myDragMultiButtonDownY; //!< cached Y button down by multi drag event - Standard_Boolean myIsRectVisible; //!< true if rectangle is visible now - QRubberBand* myRectBand; //!< selection rectangle rubber band Standard_Boolean myHasInitProj; //!< is initial camera position defined Standard_Real myInitVx; //!< initial camera position on X Standard_Real myInitVy; //!< initial camera position on Y Standard_Real myInitVz; //!< initial camera position on Z - }; #endif diff --git a/tools/View/View_Window.cxx b/tools/View/View_Window.cxx index f47cbeb9c2..beb4cda431 100644 --- a/tools/View/View_Window.cxx +++ b/tools/View/View_Window.cxx @@ -69,8 +69,7 @@ View_Window::View_Window (QWidget* theParent, myActionsToolBar->setOrientation (Qt::Vertical); myActionsToolBar->addWidget (myView-> GetWidget (View_ViewActionType_FitAllId)); - for (int anActionId = View_ViewActionType_FitAreaId; anActionId <= View_ViewActionType_DisplayModeId; anActionId++) - myActionsToolBar->addAction (myView->ViewAction ((View_ViewActionType)anActionId)); + myActionsToolBar->addAction (myView->ViewAction (View_ViewActionType_DisplayModeId)); aViewLayout->addWidget (myActionsToolBar, 1, 0); aViewLayout->addWidget (myView, 1, 1); @@ -96,6 +95,33 @@ void View_Window::SetContext (View_ContextType /*theType*/, const Handle(AIS_Int ViewToolBar()->SetContext (View_ContextType_External, theContext); } +// ======================================================================= +// function : SetPredefinedSize +// purpose : +// ======================================================================= +void View_Window::SetPredefinedSize (int theDefaultWidth, int theDefaultHeight) +{ + myView->SetPredefinedSize (theDefaultWidth, theDefaultHeight); +} + +// ======================================================================= +// function : SetInitProj +// purpose : +// ======================================================================= +void View_Window::SetInitProj (const Standard_Real theVx, const Standard_Real theVy, const Standard_Real theVz) +{ + myView->SetInitProj (theVx, theVy, theVz); +} + +// ======================================================================= +// function : View +// purpose : +// ======================================================================= +Handle(V3d_View) View_Window::View() const +{ + return myView->GetViewer()->GetView(); +} + // ======================================================================= // function : SaveState // purpose : @@ -105,7 +131,7 @@ void View_Window::SaveState (View_Window* theView, QMap& theIt { QStringList aCameraDirection; Standard_Real aVX, aVY, aVZ; - Handle(V3d_View) aView = theView->ViewWidget()->GetViewer()->GetView(); + Handle(V3d_View) aView = theView->View(); if (aView.IsNull()) return; @@ -135,7 +161,7 @@ bool View_Window::RestoreState (View_Window* theView, const QString& theKey, con Standard_Real aVY = aValues.at (1).toDouble(); Standard_Real aVZ = aValues.at (2).toDouble(); - theView->ViewWidget()->SetInitProj (aVX, aVY, aVZ); + theView->SetInitProj (aVX, aVY, aVZ); } return true; } @@ -196,6 +222,12 @@ void View_Window::onToolBarActionClicked (const int theActionId) myDisplayer->DisplayDefaultTrihedron (myViewToolBar->IsActionChecked (theActionId), Standard_True); break; } + case View_ToolActionType_ViewCube: + { + myDisplayer->DisplayViewCube (myViewToolBar->IsActionChecked (theActionId), Standard_True); + break; + } + case View_ToolActionType_KeepViewId: { myDisplayer->KeepPresentations (myViewToolBar->IsActionChecked (theActionId)); diff --git a/tools/View/View_Window.hxx b/tools/View/View_Window.hxx index b270f816d3..8d85646fbc 100644 --- a/tools/View/View_Window.hxx +++ b/tools/View/View_Window.hxx @@ -64,6 +64,18 @@ public: //! \param theContext an AIS context Standard_EXPORT void SetContext (View_ContextType theType, const Handle(AIS_InteractiveContext)& theContext); + //! Sets default size that is used in sizeHint when the widget is firstly show + Standard_EXPORT void SetPredefinedSize (int theDefaultWidth, int theDefaultHeight); + + //! Sets initial camera position + //! \param theVx direction on Ox + //! \param theVy direction on Oy + //! \param theVz direction on Oz + Standard_EXPORT void SetInitProj (const Standard_Real theVx, const Standard_Real theVy, const Standard_Real theVz); + + //! Returns an active view + Standard_EXPORT Handle(V3d_View) View() const; + //! Saves state of view window in a container in form: key, value. It saves: //! - visibility of columns, //! - columns width diff --git a/tools/View/icons/cursor_rotate.png b/tools/View/icons/cursor_rotate.png deleted file mode 100644 index a3cb0c1ecc31ed66595b4387c55dd2731809a5e1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 291 zcmeAS@N?(olHy`uVBq!ia0vp^3LwnH%)r1{DZJ<-ki!|^6XJT{zyToh|NsBJ3q{m` zEXI-`zhDN3XE)M7oFs2|7lsa2Sq~sbti&~FS$q5M)5)u*~FeEXuNpvI#I2A}-X}F}rqr=I=%gfWlk;uj_@bD7j z6|DtF4jh=G!12UL&ENr>PlD1KMh`VE4Ti0yjJ+8Jj78ER4MKcUJUm)LTnfPsZpKOG zEV4cgmtt0nIY{(yPjhvQn8U-#ZQ{ry%Esx*uHnq2v$d(wm(@i-H9286!$zGf)iWM5 e)|F^Z8<^g0e zmIV0)GdMiEkp|?5mAFQf1m~xflqVLYGNfmw85QKED;Vh+=o#9^?aKhFU`h9MOJ`zW zkPLd4!Up7Lc)B=-RLn_EP!KOz+h7#dX4;UsjI)PRK$4w})1Y}W<0Lc-a$k!M*zN28VxpF`U#yCAY@F9!>Q{yu)SmYHks0PSS(boFyt=akR{08E}qwEzGB diff --git a/tools/View/icons/view_cube.png b/tools/View/icons/view_cube.png new file mode 100644 index 0000000000000000000000000000000000000000..d373c4b238f43a7b76556584dcb8056d7e901b99 GIT binary patch literal 331 zcmeAS@N?(olHy`uVBq!ia0vp^LLkh+1|-AI^@Rf|mSQK*5Dp-y;YjHK@)?VR+?^QK zos)S9l1z8>b!1@J*w6hZkrl}2EbxddW?X?_wfUrhf|4b!5hcO-X(i=}MX3zs z<>h*rdD+Fui3O>8`9^Jz|CTa&+zU+RdK~ z7(JNnt_Ruws{j9!IdvlY12#j$z-Jaa^3t*-UHBSQnFSP1D@ut&UyVGwb4F&kn{3Q&KyxcC9^U8#L+Zr3)5CC?^ay8Lp(i!;II=Qf%gzP$2n+3sbV6*vs$OLr~GV5y&| z!YRh>EOY$)$Da*#_YI^Zmt7X$EcyKwd%yePhY2^{uiZ7_LiDuMs|#(;Yk%aPKmE$5 zy86@qZ{$VZE557oBkTS(AI1Zhp9; nykp9|lP#|4a+>w*-xyXh>|XUxHt8fV6c{{R{an^LB{Ts5x_F=7 diff --git a/tools/View/icons/view_rotate.png b/tools/View/icons/view_rotate.png deleted file mode 100644 index 7e5d013b9f5a84d5ac7d0379496e2588f6a5f059..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 224 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!9%)r1XI!iqT$l(d_32{Ae;K2X?3=ItpK!J$? zSG$1}V@Z%-FoVOh8)+a;lDE4HvmlSpCm=_x#5JNMI6tkVJh3R1Aw4tAs30$0!AQ?Q z&(Jn*Uj|S`u&0Y-NX4Aw1coNIHdY=v1vY24W)^1lW-(@FcJ}7UjLgZ*9v7M#4>}7j z>2hs6n9SI5@YI0=ER!BZ^E@%q(CB7jwQV@W8RMXLnM;8&giA$2g5k?Mu9nFjw?Iy2 N@O1TaS?83{1OP9;KPmtK diff --git a/tools/View/icons/view_zoom.png b/tools/View/icons/view_zoom.png deleted file mode 100644 index 1b50a37bc83699313dca347cfdcbecf32336f425..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 222 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!7%)r1n>(-?sKn{O^Pl)S*0|y!!82>SW;nlh^!(-7IGw3; zCi9EJX`97f+%|n0_TaH`^vZV^{HGoZ?fUmb;cjl+TRD>lr*1D4HlM$R)k68Gp)$~9 N22WQ%mvv4FO#sFsO!@!-