#include <LightApp_Application.h>
#include <OCCViewer_ViewModel.h>
#include <OCCViewer_ViewManager.h>
+#include <SUIT_Desktop.h>
+#include <SUIT_MessageBox.h>
#include <gp_Pnt2d.hxx>
#include <BRepLib_MakeVertex.hxx>
#include <BRep_Builder.hxx>
Handle( HYDROData_PolylineXY ) aToolPolyline = aPanel->GetToolPolyline();
HYDROData_SequenceOfObjects aPolylinesList = aPanel->GetPolylines();
gp_Pnt2d aPoint = aPanel->GetPoint();
- double aTolerance = 1E-7; //TODO
+ double aTolerance = 1E-2; //TODO
HYDROData_PolylineOperator anOp;
switch( aPanel->GetMode() )
anOp.Split( doc(), aMainPolyline, aPoint, aTolerance );
break;
case HYDROGUI_SplitPolylinesDlg::ByTool:
- anOp.Split( doc(), aMainPolyline, aToolPolyline, aTolerance );
+ {
+ bool isIntersected = false;
+ anOp.Split( doc(), aMainPolyline, aToolPolyline, aTolerance, isIntersected);
+
+ if (!isIntersected)
+ {
+ const QString aTitle = tr("SPLIT_POLYLINE_BY_TOOL_WARNING_TITLE");
+ const QString aMsg = tr("SPLIT_POLYLINE_BY_TOOL_WARNING_MSG");
+ SUIT_MessageBox::warning(module()->getApp()->desktop(), aTitle, aMsg);
+ }
break;
+ }
case HYDROGUI_SplitPolylinesDlg::Split:
anOp.Split( doc(), aPolylinesList, aTolerance );
break;