1 // Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 #include "HYDROGUI_GeoreferencementOp.h"
25 #include "HYDROGUI_GeoreferencementDlg.h"
26 #include "HYDROGUI_DataModel.h"
27 #include "HYDROGUI_Module.h"
28 #include "HYDROGUI_Tool.h"
29 #include "HYDROGUI_UpdateFlags.h"
31 #include <HYDROData_Profile.h>
32 #include <HYDROData_Iterator.h>
33 #include <HYDROData_Entity.h>
35 #include <LightApp_Application.h>
36 #include <LightApp_UpdateFlags.h>
38 #include <SUIT_Desktop.h>
39 #include <SUIT_MessageBox.h>
40 #include <SUIT_ViewWindow.h>
42 #include <OCCViewer_ViewManager.h>
46 HYDROGUI_GeoreferencementOp::HYDROGUI_GeoreferencementOp( HYDROGUI_Module* theModule, const int theInitialMode )
47 : HYDROGUI_Operation( theModule ),
48 myInitialMode( theInitialMode )
50 setName( tr( "PROFILES_GEOREFERENCEMENT" ) );
53 HYDROGUI_GeoreferencementOp::~HYDROGUI_GeoreferencementOp()
57 void HYDROGUI_GeoreferencementOp::startOperation()
59 HYDROGUI_Operation::startOperation();
61 HYDROGUI_GeoreferencementDlg* aPanel =
62 ::qobject_cast<HYDROGUI_GeoreferencementDlg*>( inputPanel() );
69 if ( myInitialMode == All ) {
70 onModeActivated( HYDROGUI_GeoreferencementDlg::AllProfiles );
71 } else if ( myInitialMode == Selected ) {
72 onModeActivated( HYDROGUI_GeoreferencementDlg::SelectedProfiles );
75 LightApp_Application* anApp = module()->getApp();
76 OCCViewer_ViewManager* aViewManager =
77 dynamic_cast<OCCViewer_ViewManager*>( anApp->getViewManager( OCCViewer_Viewer::Type(), false ) );
79 connect( aViewManager, SIGNAL( mousePress( SUIT_ViewWindow*, QMouseEvent* ) ),
80 aPanel, SLOT( onMousePress( SUIT_ViewWindow*, QMouseEvent* ) ),
81 Qt::UniqueConnection );
84 connect( anApp->desktop(), SIGNAL( windowActivated( SUIT_ViewWindow* ) ),
85 this, SLOT( onWindowActivated( SUIT_ViewWindow* ) ), Qt::UniqueConnection );
88 void HYDROGUI_GeoreferencementOp::abortOperation()
90 LightApp_Application* anApp = module()->getApp();
91 if ( anApp && anApp->desktop() ) {
92 anApp->desktop()->disconnect( this );
95 HYDROGUI_Operation::abortOperation();
98 void HYDROGUI_GeoreferencementOp::commitOperation()
100 LightApp_Application* anApp = module()->getApp();
101 if ( anApp && anApp->desktop() ) {
102 anApp->desktop()->disconnect( this );
105 HYDROGUI_Operation::commitOperation();
108 HYDROGUI_InputPanel* HYDROGUI_GeoreferencementOp::createInputPanel() const
110 HYDROGUI_InputPanel* aPanel = new HYDROGUI_GeoreferencementDlg( module(), getName() );
111 connect( aPanel, SIGNAL( modeActivated( int ) ), SLOT( onModeActivated( int ) ) );
112 connect( aPanel, SIGNAL( updateSelection() ), SLOT( onUpdateSelection() ) );
117 bool HYDROGUI_GeoreferencementOp::processApply( int& theUpdateFlags,
118 QString& theErrorMsg )
120 theUpdateFlags = UF_Model | UF_OCCViewer | UF_OCC_Forced | UF_VTKViewer | UF_VTK_Forced | UF_VTK_Init;
122 return store( theErrorMsg );
125 void HYDROGUI_GeoreferencementOp::onModeActivated( const int theActualMode )
130 HYDROGUI_GeoreferencementDlg* aPanel =
131 ::qobject_cast<HYDROGUI_GeoreferencementDlg*>( inputPanel() );
136 aPanel->setMode( theActualMode == HYDROGUI_GeoreferencementDlg::AllProfiles ?
137 HYDROGUI_GeoreferencementDlg::SelectedProfiles :
138 HYDROGUI_GeoreferencementDlg::AllProfiles);
140 // Store the dialog data to the data model
141 bool isToStore = false;
142 // Check if modifications exists
143 if ( aPanel->isModified() ) {
144 // Show confirmation dialog
145 SUIT_MessageBox::StandardButtons aButtons =
146 SUIT_MessageBox::Yes | SUIT_MessageBox::No;
148 isToStore = SUIT_MessageBox::question( module()->getApp()->desktop(),
149 tr( "CONFIRMATION" ),
150 tr( "CONFIRM_STORE" ),
152 SUIT_MessageBox::Yes) == SUIT_MessageBox::Yes;
154 // Store modifications if needed
158 if ( !store( anErrorMsg ) )
162 anErrorMsg.append( "\n" + tr( "INPUT_VALID_DATA" ) );
163 SUIT_MessageBox::critical( module()->getApp()->desktop(),
164 tr( "INSUFFICIENT_INPUT_DATA" ),
170 commitDocOperation();
174 aPanel->setMode( theActualMode );
176 // Get the list of profiles
177 HYDROData_SequenceOfObjects aSeqOfProfiles;
179 if( theActualMode == HYDROGUI_GeoreferencementDlg::AllProfiles ) {
180 HYDROData_Iterator aProfilesIter( doc(), KIND_PROFILE );
181 while ( aProfilesIter.More() ) {
182 aSeqOfProfiles.Append( aProfilesIter.Current() );
183 aProfilesIter.Next();
185 } else if ( theActualMode == HYDROGUI_GeoreferencementDlg::SelectedProfiles ) {
186 aSeqOfProfiles = HYDROGUI_Tool::GetSelectedObjects( module() );
189 // Set the profiles to the panel
190 setPanelData( aSeqOfProfiles );
193 void HYDROGUI_GeoreferencementOp::onWindowActivated( SUIT_ViewWindow* theViewWindow )
195 if ( !theViewWindow ) {
199 OCCViewer_ViewManager* aViewManager =
200 dynamic_cast<OCCViewer_ViewManager*>( theViewWindow->getViewManager() );
202 if ( aViewManager ) {
203 HYDROGUI_GeoreferencementDlg* aPanel =
204 ::qobject_cast<HYDROGUI_GeoreferencementDlg*>( inputPanel() );
206 connect( aViewManager, SIGNAL( mousePress( SUIT_ViewWindow*, QMouseEvent* ) ),
207 aPanel, SLOT( onMousePress( SUIT_ViewWindow*, QMouseEvent* ) ),
208 Qt::UniqueConnection);
213 bool HYDROGUI_GeoreferencementOp::store( QString& theErrorMsg )
215 // Clear the error string
218 HYDROGUI_Module* aModule = module();
221 HYDROGUI_GeoreferencementDlg* aPanel =
222 ::qobject_cast<HYDROGUI_GeoreferencementDlg*>( inputPanel() );
227 // Get georeferencement data from the panel
228 HYDROGUI_GeoreferencementDlg::ProfilesGeoDataList aGeoDataList;
229 aPanel->getData( aGeoDataList );
230 if ( aGeoDataList.empty() ) {
234 // Check the data validity
235 foreach ( const HYDROGUI_GeoreferencementDlg::ProfileGeoData& aGeoData, aGeoDataList ) {
236 if ( aGeoData.isIncomplete ) {
237 theErrorMsg = tr( "INCOMPLETE_DATA" ).arg( aGeoData.Name );
242 // Store the data in the data model
243 foreach ( const HYDROGUI_GeoreferencementDlg::ProfileGeoData& aGeoData, aGeoDataList ) {
244 Handle(HYDROData_Profile) aProfile =
245 Handle(HYDROData_Profile)::DownCast(
246 HYDROGUI_Tool::FindObjectByName( module(), aGeoData.Name, KIND_PROFILE ) );
247 if ( !aProfile.IsNull() ) {
248 if ( !aGeoData.isEmpty ) {
249 if ( !aProfile->IsValid() ) // Show the profile after it became valid
250 aModule->setObjectVisible( HYDROGUI_Tool::GetActiveOCCViewId( aModule ), aProfile, true );
252 aProfile->SetLeftPoint( gp_XY( aGeoData.Xg, aGeoData.Yg ) );
253 aProfile->SetRightPoint( gp_XY( aGeoData.Xd, aGeoData.Yd ) );
255 aProfile->Invalidate();
256 aModule->setObjectVisible( HYDROGUI_Tool::GetActiveOCCViewId( aModule ), aProfile, false );
263 aModule->update( UF_Model | UF_OCCViewer | UF_OCC_Forced );
268 void HYDROGUI_GeoreferencementOp::onUpdateSelection()
270 // Get the selected profiles
271 HYDROData_SequenceOfObjects aSeqOfProfiles =
272 HYDROGUI_Tool::GetSelectedObjects( module() );
274 // Set them to the dialog
275 setPanelData( aSeqOfProfiles );
278 void HYDROGUI_GeoreferencementOp::setPanelData(
279 const HYDROData_SequenceOfObjects& theProfiles )
282 HYDROGUI_GeoreferencementDlg* aPanel =
283 ::qobject_cast<HYDROGUI_GeoreferencementDlg*>( inputPanel() );
288 // Get georeferencement data from the data model
289 HYDROGUI_GeoreferencementDlg::ProfilesGeoDataList aData;
291 HYDROData_SequenceOfObjects::Iterator anIter( theProfiles );
292 for ( ; anIter.More(); anIter.Next() ) {
293 Handle(HYDROData_Profile) aProfile =
294 Handle(HYDROData_Profile)::DownCast( anIter.Value() );
295 if ( aProfile.IsNull() ) {
299 HYDROGUI_GeoreferencementDlg::ProfileGeoData aGeoData( aProfile->GetName() );
301 gp_XY aFirstPoint, aLastPoint;
302 if ( aProfile->GetLeftPoint( aFirstPoint ) && aProfile->GetRightPoint( aLastPoint ) ) {
304 HYDROGUI_GeoreferencementDlg::ProfileGeoData( aGeoData.Name,
305 aFirstPoint.X(), aFirstPoint.Y(),
306 aLastPoint.X(), aLastPoint.Y() );
309 aData.append( aGeoData );
312 // Set the collected data to the dialog
313 aPanel->setData( aData );