Added missing directive #include <OCCViewer_ViewModel.h>

This commit is contained in:
stv 2008-02-20 12:10:09 +00:00
parent ab9aa28a64
commit d46f50f94a

View File

@ -1,22 +1,22 @@
// GEOM GEOMGUI : GUI for Geometry component // GEOM GEOMGUI : GUI for Geometry component
// //
// Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
// //
// This library is free software; you can redistribute it and/or // This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public // modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either // License as published by the Free Software Foundation; either
// version 2.1 of the License. // version 2.1 of the License.
// //
// This library is distributed in the hope that it will be useful, // This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of // but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details. // Lesser General Public License for more details.
// //
// You should have received a copy of the GNU Lesser General Public // You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software // License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
// //
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
// //
// File : OperationGUI_ClippingDlg.cxx // File : OperationGUI_ClippingDlg.cxx
@ -34,8 +34,11 @@
#include <SUIT_ViewManager.h> #include <SUIT_ViewManager.h>
#include <SVTK_ViewWindow.h> #include <SVTK_ViewWindow.h>
#include <SVTK_ViewModel.h> #include <SVTK_ViewModel.h>
#include <OCCViewer_ViewModel.h>
#include <OCCViewer_ViewWindow.h> #include <OCCViewer_ViewWindow.h>
#include <OCCViewer_ViewPort3d.h> #include <OCCViewer_ViewPort3d.h>
#include <VTKViewer.h> #include <VTKViewer.h>
// OCC Includes // OCC Includes
@ -48,7 +51,7 @@
//================================================================================= //=================================================================================
// class : OperationGUI_ClippingDlg() // class : OperationGUI_ClippingDlg()
// purpose : // purpose :
//================================================================================= //=================================================================================
OperationGUI_ClippingDlg::OperationGUI_ClippingDlg( GeometryGUI* theGeometryGUI, QWidget* parent ) OperationGUI_ClippingDlg::OperationGUI_ClippingDlg( GeometryGUI* theGeometryGUI, QWidget* parent )
: GEOMBase_Skeleton( theGeometryGUI, parent, false ) : GEOMBase_Skeleton( theGeometryGUI, parent, false )
@ -126,68 +129,68 @@ void OperationGUI_ClippingDlg::Init()
SUIT_ViewWindow* anActiveWindow = SUIT_Session::session()->activeApplication()->desktop()->activeWindow(); SUIT_ViewWindow* anActiveWindow = SUIT_Session::session()->activeApplication()->desktop()->activeWindow();
if ( !anActiveWindow ) if ( !anActiveWindow )
return; return;
if ( anActiveWindow->getViewManager()->getType() == SVTK_Viewer::Type() ) { if ( anActiveWindow->getViewManager()->getType() == SVTK_Viewer::Type() ) {
SVTK_ViewWindow* aVTKFrame = dynamic_cast<SVTK_ViewWindow*>( anActiveWindow ); SVTK_ViewWindow* aVTKFrame = dynamic_cast<SVTK_ViewWindow*>( anActiveWindow );
if ( !aVTKFrame ) if ( !aVTKFrame )
return; return;
TextLabelNear->setText( tr( "Near" ) ); TextLabelNear->setText( tr( "Near" ) );
TextLabelFar->setText( tr( "Far" ) ); TextLabelFar->setText( tr( "Far" ) );
TypeCB->hide(); TypeCB->hide();
vtkRenderer* aRenderer = aVTKFrame->getRenderer(); vtkRenderer* aRenderer = aVTKFrame->getRenderer();
if ( !aRenderer ) return; if ( !aRenderer ) return;
vtkCamera* anActiveCamera = aRenderer->GetActiveCamera(); vtkCamera* anActiveCamera = aRenderer->GetActiveCamera();
if ( anActiveCamera == NULL ) { if ( anActiveCamera == NULL ) {
return; return;
} }
// Find the plane equation for the camera view plane // Find the plane equation for the camera view plane
double vn[3]; double vn[3];
anActiveCamera->GetViewPlaneNormal( vn ); anActiveCamera->GetViewPlaneNormal( vn );
double position[3]; double position[3];
anActiveCamera->GetPosition( position ); anActiveCamera->GetPosition( position );
vtkFloatingPointType bounds[6]; vtkFloatingPointType bounds[6];
aRenderer->ComputeVisiblePropBounds( bounds ); aRenderer->ComputeVisiblePropBounds( bounds );
double center[3]; double center[3];
center[0] = ( bounds[0] + bounds[1] ) / 2.0; center[0] = ( bounds[0] + bounds[1] ) / 2.0;
center[1] = ( bounds[2] + bounds[3] ) / 2.0; center[1] = ( bounds[2] + bounds[3] ) / 2.0;
center[2] = ( bounds[4] + bounds[5] ) / 2.0; center[2] = ( bounds[4] + bounds[5] ) / 2.0;
double width = sqrt( ( bounds[1]-bounds[0] ) * ( bounds[1]-bounds[0] ) + double width = sqrt( ( bounds[1]-bounds[0] ) * ( bounds[1]-bounds[0] ) +
( bounds[3]-bounds[2] ) * ( bounds[3]-bounds[2] ) + ( bounds[3]-bounds[2] ) * ( bounds[3]-bounds[2] ) +
( bounds[5]-bounds[4] ) * ( bounds[5]-bounds[4] ) ); ( bounds[5]-bounds[4] ) * ( bounds[5]-bounds[4] ) );
double distance = sqrt( ( position[0]-center[0] ) * ( position[0]-center[0] ) + double distance = sqrt( ( position[0]-center[0] ) * ( position[0]-center[0] ) +
( position[1]-center[1] ) * ( position[1]-center[1] ) + ( position[1]-center[1] ) * ( position[1]-center[1] ) +
( position[2]-center[2] ) * ( position[2]-center[2] ) ); ( position[2]-center[2] ) * ( position[2]-center[2] ) );
vtkFloatingPointType range[2] = { distance - width/2.0, distance + width/2.0 }; vtkFloatingPointType range[2] = { distance - width/2.0, distance + width/2.0 };
SpinBox_Near->setValue( range[0] ); SpinBox_Near->setValue( range[0] );
SpinBox_Far->setValue( range[1] ); SpinBox_Far->setValue( range[1] );
return; return;
} }
else if ( anActiveWindow->getViewManager()->getType() == OCCViewer_Viewer::Type() ) { else if ( anActiveWindow->getViewManager()->getType() == OCCViewer_Viewer::Type() ) {
OCCViewer_ViewWindow* aOCCFrame = dynamic_cast<OCCViewer_ViewWindow*>( anActiveWindow ); OCCViewer_ViewWindow* aOCCFrame = dynamic_cast<OCCViewer_ViewWindow*>( anActiveWindow );
TextLabelNear->setText( tr( "Depth" ) ); TextLabelNear->setText( tr( "Depth" ) );
TextLabelFar->setText( tr( "Thickness" ) ); TextLabelFar->setText( tr( "Thickness" ) );
Handle(V3d_View) view3d = ( (OCCViewer_ViewPort3d*)aOCCFrame->getViewPort() )->getView(); Handle(V3d_View) view3d = ( (OCCViewer_ViewPort3d*)aOCCFrame->getViewPort() )->getView();
double depth, thickness; double depth, thickness;
int ztype = view3d->ZClipping( depth, thickness ); int ztype = view3d->ZClipping( depth, thickness );
SpinBox_Near->setValue( depth ); SpinBox_Near->setValue( depth );
SpinBox_Far->setValue( thickness ); SpinBox_Far->setValue( thickness );
TypeCB->setCurrentIndex( ztype ); TypeCB->setCurrentIndex( ztype );
//Handle(V3d_Plane) aPlane = new V3d_Plane( aOCCFrame->getViewer()->getViewer3d() ,0, 0, 1, -100); //Handle(V3d_Plane) aPlane = new V3d_Plane( aOCCFrame->getViewer()->getViewer3d() ,0, 0, 1, -100);
//aPlane->Display(view3d); //aPlane->Display(view3d);
} }
@ -203,40 +206,40 @@ bool OperationGUI_ClippingDlg::ClickOnApply()
SUIT_ViewWindow* anActiveWindow = SUIT_Session::session()->activeApplication()->desktop()->activeWindow(); SUIT_ViewWindow* anActiveWindow = SUIT_Session::session()->activeApplication()->desktop()->activeWindow();
if ( !anActiveWindow ) if ( !anActiveWindow )
return false; return false;
if ( anActiveWindow->getViewManager()->getType() == SVTK_Viewer::Type() ) { if ( anActiveWindow->getViewManager()->getType() == SVTK_Viewer::Type() ) {
SVTK_ViewWindow* aVTKFrame = dynamic_cast<SVTK_ViewWindow*>( anActiveWindow ); SVTK_ViewWindow* aVTKFrame = dynamic_cast<SVTK_ViewWindow*>( anActiveWindow );
if ( !aVTKFrame ) if ( !aVTKFrame )
return false; return false;
vtkRenderer* aRenderer = aVTKFrame->getRenderer(); vtkRenderer* aRenderer = aVTKFrame->getRenderer();
if ( !aRenderer ) return false; if ( !aRenderer ) return false;
vtkCamera* anActiveCamera = aRenderer->GetActiveCamera(); vtkCamera* anActiveCamera = aRenderer->GetActiveCamera();
if ( anActiveCamera == NULL ) { if ( anActiveCamera == NULL ) {
return false; return false;
} }
vtkFloatingPointType range[2] = { SpinBox_Near->value(), SpinBox_Far->value() }; vtkFloatingPointType range[2] = { SpinBox_Near->value(), SpinBox_Far->value() };
if ( range[0] < 0.0 ) range[0] = 0.0; if ( range[0] < 0.0 ) range[0] = 0.0;
anActiveCamera->SetClippingRange( range ); anActiveCamera->SetClippingRange( range );
return true; return true;
} }
else if ( anActiveWindow->getViewManager()->getType() == OCCViewer_Viewer::Type() ) { else if ( anActiveWindow->getViewManager()->getType() == OCCViewer_Viewer::Type() ) {
OCCViewer_ViewWindow* aOCCFrame = dynamic_cast<OCCViewer_ViewWindow*>( anActiveWindow ); OCCViewer_ViewWindow* aOCCFrame = dynamic_cast<OCCViewer_ViewWindow*>( anActiveWindow );
Handle(V3d_View) view3d = ( (OCCViewer_ViewPort3d*)aOCCFrame->getViewPort() )->getView(); Handle(V3d_View) view3d = ( (OCCViewer_ViewPort3d*)aOCCFrame->getViewPort() )->getView();
double depth = SpinBox_Near->value(); double depth = SpinBox_Near->value();
double thickness = SpinBox_Far->value(); double thickness = SpinBox_Far->value();
int aType = TypeCB->currentIndex(); int aType = TypeCB->currentIndex();
view3d->SetZClippingType( V3d_TypeOfZclipping( aType ) ); view3d->SetZClippingType( V3d_TypeOfZclipping( aType ) );
view3d->SetZClippingDepth( depth ); view3d->SetZClippingDepth( depth );
view3d->SetZClippingWidth( thickness ); view3d->SetZClippingWidth( thickness );
} }
return true; return true;
} }
@ -278,60 +281,60 @@ void OperationGUI_ClippingDlg::onReset()
SUIT_Session::session()->activeApplication()->desktop()->activeWindow(); SUIT_Session::session()->activeApplication()->desktop()->activeWindow();
if ( !anActiveWindow ) if ( !anActiveWindow )
return; return;
if ( anActiveWindow->getViewManager()->getType() == SVTK_Viewer::Type() ) { if ( anActiveWindow->getViewManager()->getType() == SVTK_Viewer::Type() ) {
SVTK_ViewWindow* aVTKFrame = dynamic_cast<SVTK_ViewWindow*>( anActiveWindow ); SVTK_ViewWindow* aVTKFrame = dynamic_cast<SVTK_ViewWindow*>( anActiveWindow );
if ( !aVTKFrame ) if ( !aVTKFrame )
return; return;
vtkRenderer* aRenderer = aVTKFrame->getRenderer(); vtkRenderer* aRenderer = aVTKFrame->getRenderer();
if ( !aRenderer ) return; if ( !aRenderer ) return;
vtkCamera* anActiveCamera = aRenderer->GetActiveCamera(); vtkCamera* anActiveCamera = aRenderer->GetActiveCamera();
if ( anActiveCamera == NULL ) { if ( anActiveCamera == NULL ) {
return; return;
} }
// Find the plane equation for the camera view plane // Find the plane equation for the camera view plane
double vn[3]; double vn[3];
anActiveCamera->GetViewPlaneNormal( vn ); anActiveCamera->GetViewPlaneNormal( vn );
double position[3]; double position[3];
anActiveCamera->GetPosition( position ); anActiveCamera->GetPosition( position );
vtkFloatingPointType bounds[6]; vtkFloatingPointType bounds[6];
aRenderer->ComputeVisiblePropBounds( bounds ); aRenderer->ComputeVisiblePropBounds( bounds );
double center[3]; double center[3];
center[0] = ( bounds[0] + bounds[1] ) / 2.0; center[0] = ( bounds[0] + bounds[1] ) / 2.0;
center[1] = ( bounds[2] + bounds[3] ) / 2.0; center[1] = ( bounds[2] + bounds[3] ) / 2.0;
center[2] = ( bounds[4] + bounds[5] ) / 2.0; center[2] = ( bounds[4] + bounds[5] ) / 2.0;
double width = sqrt( ( bounds[1]-bounds[0] ) * ( bounds[1]-bounds[0] ) + double width = sqrt( ( bounds[1]-bounds[0] ) * ( bounds[1]-bounds[0] ) +
( bounds[3]-bounds[2] ) * ( bounds[3]-bounds[2] ) + ( bounds[3]-bounds[2] ) * ( bounds[3]-bounds[2] ) +
( bounds[5]-bounds[4] ) * ( bounds[5]-bounds[4] ) ); ( bounds[5]-bounds[4] ) * ( bounds[5]-bounds[4] ) );
double distance = sqrt( ( position[0]-center[0] ) * ( position[0]-center[0] ) + double distance = sqrt( ( position[0]-center[0] ) * ( position[0]-center[0] ) +
( position[1]-center[1] ) * ( position[1]-center[1] ) + ( position[1]-center[1] ) * ( position[1]-center[1] ) +
( position[2]-center[2] ) * ( position[2]-center[2] ) ); ( position[2]-center[2] ) * ( position[2]-center[2] ) );
vtkFloatingPointType range[2] = { distance - width/2.0, distance + width/2.0 }; vtkFloatingPointType range[2] = { distance - width/2.0, distance + width/2.0 };
SpinBox_Near->setValue( range[0] ); SpinBox_Near->setValue( range[0] );
SpinBox_Far->setValue( range[1] ); SpinBox_Far->setValue( range[1] );
return; return;
} }
else if ( anActiveWindow->getViewManager()->getType() == OCCViewer_Viewer::Type() ) { else if ( anActiveWindow->getViewManager()->getType() == OCCViewer_Viewer::Type() ) {
OCCViewer_ViewWindow* aOCCFrame = dynamic_cast<OCCViewer_ViewWindow*>( anActiveWindow ); OCCViewer_ViewWindow* aOCCFrame = dynamic_cast<OCCViewer_ViewWindow*>( anActiveWindow );
TextLabelNear->setText( tr( "Depth" ) ); TextLabelNear->setText( tr( "Depth" ) );
TextLabelFar->setText( tr( "Thickness" ) ); TextLabelFar->setText( tr( "Thickness" ) );
Handle(V3d_View) view3d = ( (OCCViewer_ViewPort3d*)aOCCFrame->getViewPort() )->getView(); Handle(V3d_View) view3d = ( (OCCViewer_ViewPort3d*)aOCCFrame->getViewPort() )->getView();
view3d->SetZClippingType( V3d_TypeOfZclipping( 0 ) ); view3d->SetZClippingType( V3d_TypeOfZclipping( 0 ) );
view3d->ZFitAll(); view3d->ZFitAll();
double depth, thickness; double depth, thickness;
int ztype= view3d->ZClipping( depth, thickness ); int ztype= view3d->ZClipping( depth, thickness );
SpinBox_Near->setValue( 0 ); SpinBox_Near->setValue( 0 );
SpinBox_Far->setValue( 1000 ); SpinBox_Far->setValue( 1000 );