1 // Copyright (C) 2014-2015 EDF-R&D
2 // This library is free software; you can redistribute it and/or
3 // modify it under the terms of the GNU Lesser General Public
4 // License as published by the Free Software Foundation; either
5 // version 2.1 of the License, or (at your option) any later version.
7 // This library is distributed in the hope that it will be useful,
8 // but WITHOUT ANY WARRANTY; without even the implied warranty of
9 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
10 // Lesser General Public License for more details.
12 // You should have received a copy of the GNU Lesser General Public
13 // License along with this library; if not, write to the Free Software
14 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 #include <HYDROGUI_ShapeBathymetry.h>
20 #include <HYDROGUI_OCCDisplayer.h>
21 #include <HYDROGUI_BathymetryPrs.h>
22 #include <HYDROData_Bathymetry.h>
24 #include <AIS_InteractiveContext.hxx>
25 #include <AIS_ColorScale.hxx>
26 #include <Prs3d_PointAspect.hxx>
28 HYDROGUI_ShapeBathymetry::HYDROGUI_ShapeBathymetry( HYDROGUI_OCCDisplayer* theDisplayer,
29 const Handle(AIS_InteractiveContext)& theContext,
30 const Handle(HYDROData_Bathymetry)& theBathymetry,
32 : HYDROGUI_Shape( theContext, theBathymetry, theZLayer ),
33 myDisplayer( theDisplayer )
35 setDisplayMode( AIS_PointCloud::DM_Points );
38 HYDROGUI_ShapeBathymetry::~HYDROGUI_ShapeBathymetry()
40 setToUpdateColorScale( true );
43 void HYDROGUI_ShapeBathymetry::update( bool theIsUpdateViewer, bool isDeactivateSelection )
45 setIsToUpdate( false );
47 // Try to retrieve information from object
49 Handle(HYDROData_Bathymetry) aBath = Handle(HYDROData_Bathymetry)::DownCast( getObject() );
51 if ( !aBath.IsNull() && !aBath->GetAltitudePoints().empty())
54 updateShape( false, false );
57 HYDROGUI_Shape::update( theIsUpdateViewer, isDeactivateSelection );
61 Handle(AIS_InteractiveObject) HYDROGUI_ShapeBathymetry::createShape() const
63 Handle(AIS_InteractiveObject) aPntCloud;
65 Handle(HYDROData_Bathymetry) aBath = Handle(HYDROData_Bathymetry)::DownCast( getObject() );
68 aPntCloud = new HYDROGUI_BathymetryPrs();
69 aPntCloud->SetHilightMode( AIS_PointCloud::DM_BndBox );
70 aPntCloud->Attributes()->SetPointAspect (new Prs3d_PointAspect (Aspect_TOM_POINT, Quantity_NOC_WHITE, 2.0));
72 const HYDROData_Bathymetry::AltitudePoints& aBathPoints = aBath->GetAltitudePoints();
74 int anUpper = (int)aBathPoints.size()-1;
76 HYDROGUI_ShapeBathymetry* aThat = const_cast<HYDROGUI_ShapeBathymetry*>( this );
77 aThat->myCoords = new TColgp_HArray1OfPnt( aLower, anUpper );
78 aThat->myColors = new Quantity_HArray1OfColor( aLower, anUpper );
79 for( int i=aLower; i<=anUpper; i++ )
80 aThat->myCoords->SetValue( i, gp_Pnt( aBathPoints[i].X, aBathPoints[i].Y, aBathPoints[i].Z ) );
86 void HYDROGUI_ShapeBathymetry::GetRange( double& theMin, double& theMax ) const
90 if( myCoords.IsNull() )
94 for( int i=myCoords->Lower(), n=myCoords->Upper(); i<=n; i++ )
96 double aValue = myCoords->Value( i ).Z();
97 if( isFirst || aValue < theMin )
99 if( isFirst || aValue > theMax )
105 void HYDROGUI_ShapeBathymetry::UpdateWithColorScale( const Handle(AIS_ColorScale)& theColorScale )
109 for( int i=myCoords->Lower(), n=myCoords->Upper(); i<=n; i++ )
111 double z = myCoords->Value( i ).Z();
112 Quantity_Color aColor;
113 theColorScale->FindColor( z, aColor );
114 myColors->SetValue( i, aColor );
116 Handle(AIS_PointCloud) aPntCloud = Handle(AIS_PointCloud)::DownCast( getAISObject() );
117 aPntCloud->SetPoints( myCoords, myColors );
118 getContext()->Redisplay( aPntCloud, Standard_False );
121 void HYDROGUI_ShapeBathymetry::setVisible( const bool theState,
122 const bool theIsUpdateViewer )
124 bool isShown = getContext()->IsDisplayed( getAISObject() );
125 bool isChanged = ( isShown != theState );
126 HYDROGUI_Shape::setVisible( theState, theIsUpdateViewer );
127 setToUpdateColorScale( isChanged );
130 void HYDROGUI_ShapeBathymetry::displayShape( const bool theIsUpdateViewer )
132 bool isShown = getContext()->IsDisplayed( getAISObject() );
133 bool isChanged = ( !isShown );
134 HYDROGUI_Shape::displayShape( theIsUpdateViewer );
135 setToUpdateColorScale( isChanged );
138 void HYDROGUI_ShapeBathymetry::display( const bool theIsUpdateViewer )
140 bool isShown = getContext()->IsDisplayed( getAISObject() );
141 bool isChanged = ( !isShown );
142 HYDROGUI_Shape::display( theIsUpdateViewer );
143 setToUpdateColorScale( isChanged );
146 void HYDROGUI_ShapeBathymetry::erase( const bool theIsUpdateViewer )
148 bool isShown = getContext()->IsDisplayed( getAISObject() );
149 bool isChanged = ( isShown );
150 HYDROGUI_Shape::erase( theIsUpdateViewer );
151 setToUpdateColorScale( isChanged );
154 void HYDROGUI_ShapeBathymetry::setToUpdateColorScale( bool isChanged )
157 if( isChanged && myDisplayer )
158 myDisplayer->SetToUpdateColorScale();