X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FNewGeom%2FNewGeom_SalomeViewer.cpp;h=d9ce85febf901d738fa94427301ce74ddd4c10ca;hb=24f1ad2fd93475684288c899fb4fffcf05f6c21e;hp=c81d706ab769bf52b00f4d2cad4d05f12c0f76e6;hpb=9417f62889b68490dd9624e479d9c0b18556a9e9;p=modules%2Fshaper.git diff --git a/src/NewGeom/NewGeom_SalomeViewer.cpp b/src/NewGeom/NewGeom_SalomeViewer.cpp index c81d706ab..d9ce85feb 100644 --- a/src/NewGeom/NewGeom_SalomeViewer.cpp +++ b/src/NewGeom/NewGeom_SalomeViewer.cpp @@ -1,28 +1,37 @@ - #include "NewGeom_SalomeViewer.h" #include "NewGeom_OCCSelector.h" #include #include +#include #include +#include +#include + NewGeom_SalomeViewer::NewGeom_SalomeViewer(QObject* theParent) -: XGUI_SalomeViewer(theParent), mySelector(0) + : ModuleBase_IViewer(theParent), + mySelector(0) { } - +//********************************************** Handle(AIS_InteractiveContext) NewGeom_SalomeViewer::AISContext() const { - return mySelector->viewer()->getAISContext(); + if (mySelector && mySelector->viewer()) + return mySelector->viewer()->getAISContext(); + Handle(AIS_InteractiveContext) aNull; + return aNull; } +//********************************************** Handle(V3d_Viewer) NewGeom_SalomeViewer::v3dViewer() const { return mySelector->viewer()->getViewer3d(); } +//********************************************** Handle(V3d_View) NewGeom_SalomeViewer::activeView() const { OCCViewer_Viewer* aViewer = mySelector->viewer(); @@ -31,6 +40,7 @@ Handle(V3d_View) NewGeom_SalomeViewer::activeView() const return aWnd->getViewPort()->getView(); } +//********************************************** void NewGeom_SalomeViewer::setSelector(NewGeom_OCCSelector* theSel) { if (mySelector) { @@ -41,61 +51,119 @@ void NewGeom_SalomeViewer::setSelector(NewGeom_OCCSelector* theSel) } } mySelector = theSel; + if (!mySelector) + return; OCCViewer_Viewer* aViewer = mySelector->viewer(); SUIT_ViewManager* aMgr = aViewer->getViewManager(); - connect(aMgr, SIGNAL(lastViewClosed(SUIT_ViewManager*)), - this, SIGNAL(lastViewClosed())); - connect(aMgr, SIGNAL(tryCloseView(SUIT_ViewManager*)), - this, SIGNAL(tryCloseView())); - connect(aMgr, SIGNAL(deleteView(SUIT_ViewManager*)), - this, SIGNAL(deleteView())); - connect(aMgr, SIGNAL(viewCreated(SUIT_ViewManager*)), - this, SIGNAL(viewCreated())); - connect(aMgr, SIGNAL(activated(SUIT_ViewManager*)), - this, SIGNAL(activated())); - - connect(aMgr, SIGNAL(mousePress(SUIT_ViewWindow*, QMouseEvent*)), - this, SLOT(onMousePress(SUIT_ViewWindow*, QMouseEvent*))); - connect(aMgr, SIGNAL(mouseRelease(SUIT_ViewWindow*, QMouseEvent*)), - this, SLOT(onMouseRelease(SUIT_ViewWindow*, QMouseEvent*))); - connect(aMgr, SIGNAL(mouseDoubleClick(SUIT_ViewWindow*, QMouseEvent*)), - this, SLOT(onMouseDoubleClick(SUIT_ViewWindow*, QMouseEvent*))); - connect(aMgr, SIGNAL(mouseMove(SUIT_ViewWindow*, QMouseEvent*)), - this, SLOT(onMouseMove(SUIT_ViewWindow*, QMouseEvent*))); - connect(aMgr, SIGNAL(keyPress(SUIT_ViewWindow*, QKeyEvent*)), - this, SLOT(onKeyPress(SUIT_ViewWindow*, QKeyEvent*))); - connect(aMgr, SIGNAL(keyRelease(SUIT_ViewWindow*, QKeyEvent*)), - this, SLOT(onKeyRelease(SUIT_ViewWindow*, QKeyEvent*))); + connect(aMgr, SIGNAL(lastViewClosed(SUIT_ViewManager*)), this, SIGNAL(lastViewClosed())); + connect(aMgr, SIGNAL(tryCloseView(SUIT_ViewManager*)), this, SIGNAL(tryCloseView())); + connect(aMgr, SIGNAL(deleteView(SUIT_ViewManager*)), this, SIGNAL(deleteView())); + connect(aMgr, SIGNAL(viewCreated(SUIT_ViewManager*)), this, SIGNAL(viewCreated())); + connect(aMgr, SIGNAL(activated(SUIT_ViewManager*)), this, SIGNAL(activated())); + + connect(aMgr, SIGNAL(mousePress(SUIT_ViewWindow*, QMouseEvent*)), this, + SLOT(onMousePress(SUIT_ViewWindow*, QMouseEvent*))); + connect(aMgr, SIGNAL(mouseRelease(SUIT_ViewWindow*, QMouseEvent*)), this, + SLOT(onMouseRelease(SUIT_ViewWindow*, QMouseEvent*))); + connect(aMgr, SIGNAL(mouseDoubleClick(SUIT_ViewWindow*, QMouseEvent*)), this, + SLOT(onMouseDoubleClick(SUIT_ViewWindow*, QMouseEvent*))); + connect(aMgr, SIGNAL(mouseMove(SUIT_ViewWindow*, QMouseEvent*)), this, + SLOT(onMouseMove(SUIT_ViewWindow*, QMouseEvent*))); + connect(aMgr, SIGNAL(keyPress(SUIT_ViewWindow*, QKeyEvent*)), this, + SLOT(onKeyPress(SUIT_ViewWindow*, QKeyEvent*))); + connect(aMgr, SIGNAL(keyRelease(SUIT_ViewWindow*, QKeyEvent*)), this, + SLOT(onKeyRelease(SUIT_ViewWindow*, QKeyEvent*))); + + connect(aViewer, SIGNAL(selectionChanged()), this, SIGNAL(selectionChanged())); } - +//********************************************** void NewGeom_SalomeViewer::onMousePress(SUIT_ViewWindow*, QMouseEvent* theEvent) { emit mousePress(theEvent); } +//********************************************** void NewGeom_SalomeViewer::onMouseRelease(SUIT_ViewWindow*, QMouseEvent* theEvent) { emit mouseRelease(theEvent); + //if ((theEvent->button() == Qt::RightButton) && + // (theEvent->modifiers() == Qt::NoModifier)) { + // QContextMenuEvent aEvent(QContextMenuEvent::Mouse, theEvent->pos(), theEvent->globalPos()); + // emit contextMenuRequested(&aEvent); + //} } +//********************************************** void NewGeom_SalomeViewer::onMouseDoubleClick(SUIT_ViewWindow*, QMouseEvent* theEvent) { emit mouseDoubleClick(theEvent); } +//********************************************** void NewGeom_SalomeViewer::onMouseMove(SUIT_ViewWindow*, QMouseEvent* theEvent) { emit mouseMove(theEvent); } +//********************************************** void NewGeom_SalomeViewer::onKeyPress(SUIT_ViewWindow*, QKeyEvent* theEvent) { emit keyPress(theEvent); } +//********************************************** void NewGeom_SalomeViewer::onKeyRelease(SUIT_ViewWindow*, QKeyEvent* theEvent) { emit keyRelease(theEvent); } + +//********************************************** +void NewGeom_SalomeViewer::enableSelection(bool isEnabled) +{ + mySelector->viewer()->enableSelection(isEnabled); +} + +//********************************************** +bool NewGeom_SalomeViewer::isSelectionEnabled() const +{ + return mySelector->viewer()->isSelectionEnabled(); +} + +//********************************************** +void NewGeom_SalomeViewer::enableMultiselection(bool isEnable) +{ + mySelector->viewer()->enableMultiselection(isEnable); +} + +//********************************************** +bool NewGeom_SalomeViewer::isMultiSelectionEnabled() const +{ + return mySelector->viewer()->isMultiSelectionEnabled(); +} + +//********************************************** +void NewGeom_SalomeViewer::fitAll() +{ + SUIT_ViewManager* aMgr = mySelector->viewer()->getViewManager(); + OCCViewer_ViewFrame* aVFrame = dynamic_cast(aMgr->getActiveView()); + if (aVFrame) { + aVFrame->onFitAll(); + } +} + +//********************************************** +void NewGeom_SalomeViewer::setViewProjection(double theX, double theY, double theZ) +{ + SUIT_ViewManager* aMgr = mySelector->viewer()->getViewManager(); + OCCViewer_ViewFrame* aVFrame = dynamic_cast(aMgr->getActiveView()); + if (aVFrame) { + Handle(V3d_View) aView3d = aVFrame->getViewPort()->getView(); + if (!aView3d.IsNull()) { + aView3d->SetProj(theX, theY, theZ); + aView3d->FitAll(0.01, true, true); + aView3d->SetZSize(0.); + } + } +} \ No newline at end of file