From 7dedbec49c1735e6e0de09fa4cd2c22e7b8bb58c Mon Sep 17 00:00:00 2001 From: gdd Date: Thu, 30 Jun 2011 07:55:50 +0000 Subject: [PATCH] rnc: - Allowed arc and segment creation by selection in the 3D view for the relative selection mode too. - Added a preview of the center point and the end point when creating an arc by center and end point --- src/EntityGUI/EntityGUI_SketcherDlg.cxx | 90 ++++++++++++++++++++----- src/EntityGUI/EntityGUI_SketcherDlg.h | 11 ++- 2 files changed, 84 insertions(+), 17 deletions(-) diff --git a/src/EntityGUI/EntityGUI_SketcherDlg.cxx b/src/EntityGUI/EntityGUI_SketcherDlg.cxx index 923e5e973..83577f3f9 100644 --- a/src/EntityGUI/EntityGUI_SketcherDlg.cxx +++ b/src/EntityGUI/EntityGUI_SketcherDlg.cxx @@ -51,6 +51,7 @@ #include #include #include +#include #include #include @@ -1173,10 +1174,6 @@ void EntityGUI_SketcherDlg::SelectionIntoArgument() int nbSel = aSelList.Extent(); MESSAGE("NbSel = "<LineEdit1) { GEOM::GEOM_Object_var aSelectedObject = GEOMBase::ConvertIOinGEOMObject( aSelList.First() ); if ( !CORBA::is_nil(aSelectedObject) ) { @@ -1352,7 +1349,13 @@ void EntityGUI_SketcherDlg::SelectionIntoArgument() } } } - GEOMBase_Helper::displayPreview( true, false, true, true, myLineWidth ); + if (nbSel == 0){ + myX=tmpX; + myY=tmpY; + } + else{ + GEOMBase_Helper::displayPreview( true, false, true, true, myLineWidth ); + } } @@ -1506,23 +1509,34 @@ void EntityGUI_SketcherDlg::closeEvent( QCloseEvent* e ) void EntityGUI_SketcherDlg::OnPointSelected(Qt::KeyboardModifiers modifiers, const gp_Pnt& thePnt) { MESSAGE("EntityGUI_SketcherDlg::OnPointSelected") + + double x, y; + x = y = 0; + if ( getPnt1ConstructorId() == 0 ){ // Relative selection mode + x = thePnt.X() - myLastX1; + y = thePnt.Y() - myLastY1; + } + else { + x = thePnt.X(); + y = thePnt.Y(); + } switch (getPnt2ConstructorId()){ case 1: - Group2Spin->SpinBox_DX->setValue( thePnt.X() ); - Group2Spin->SpinBox_DY->setValue( thePnt.Y() ); + Group2Spin->SpinBox_DX->setValue( x ); + Group2Spin->SpinBox_DY->setValue( y ); break; case 0: - Group3Spin->SpinBox_DX->setValue( thePnt.X() ); - Group3Spin->SpinBox_DY->setValue( thePnt.Y() ); + Group3Spin->SpinBox_DX->setValue( x ); + Group3Spin->SpinBox_DY->setValue( y ); break; case 2: if (modifiers == Qt::MetaModifier){ // Select center with Meta key - Group4Spin->SpinBox_DX->setValue( thePnt.X() ); - Group4Spin->SpinBox_DY->setValue( thePnt.Y() ); + Group4Spin->SpinBox_DX->setValue( x ); + Group4Spin->SpinBox_DY->setValue( y ); } else{ // The select end point - Group4Spin->SpinBox_DZ->setValue( thePnt.X() ); - Group4Spin->SpinBox_DS->setValue( thePnt.Y() ); + Group4Spin->SpinBox_DZ->setValue( x ); + Group4Spin->SpinBox_DS->setValue( y ); } break; } @@ -1815,7 +1829,27 @@ void EntityGUI_SketcherDlg::ValueChangedInSpinBox( double newValue ) } } - GEOMBase_Helper::displayPreview( true, false, true, true, myLineWidth ); + GEOMBase_Helper::displayPreview( true, false, true, true, myLineWidth ); + + double x, y, xc, yc; + x = y = xc = yc = 0.0; + if ( mySketchType == PT_ABS_CENTER || mySketchType == PT_REL_CENTER ) + { + if ( mySketchType == PT_REL_CENTER ){ + x = myDX + myLastX1; + y = myDY + myLastY1; + xc = myDXc + myLastX1; + yc = myDYc + myLastY1; + } + else { + x = myX ; + y = myY ; + xc = myXc; + yc = myYc; + } + displayPntPreview(xc,yc); + displayPntPreview(x,y); + } } @@ -2021,7 +2055,7 @@ bool EntityGUI_SketcherDlg::execute( ObjectList& objects ) Format = 'g'; // g --> DigNum is the maximum number of significant digits QString aParameters; - + if ( mySketchState == FIRST_POINT ) { myLastX2 = myX; myLastY2 = myY; @@ -2249,6 +2283,32 @@ void EntityGUI_SketcherDlg::displayPreview( GEOM::GEOM_Object_ptr object, getDisplayer()->SetToActivate( true ); } +//================================================================ +// Function : displayPntPreview +// Purpose : creates a TopoDS_VERTEX and display a preview of it +//================================================================ +void EntityGUI_SketcherDlg::displayPntPreview(const double x, + const double y, + bool append, + bool update + ) +{ + gp_Pnt aPnt = gp_Pnt(x,y,0.0); + BRepBuilderAPI_MakeVertex mkVertex (aPnt); + TopoDS_Shape aVertex = mkVertex.Shape(); + + // Disable activation of selection + getDisplayer()->SetToActivate( false ); + + // Build prs + SALOME_Prs* aPrs = getDisplayer()->BuildPrs( aVertex ); + if ( aPrs != 0 && !aPrs->IsNull() ) + GEOMBase_Helper::displayPreview( aPrs, append, update ); + + // Enable back activation of selection + getDisplayer()->SetToActivate( true ); +} + //================================================================ // Function : createShapes // Purpose : Create applyed wire, and last segment from entry object diff --git a/src/EntityGUI/EntityGUI_SketcherDlg.h b/src/EntityGUI/EntityGUI_SketcherDlg.h index 93a6835ff..f93bbef3b 100644 --- a/src/EntityGUI/EntityGUI_SketcherDlg.h +++ b/src/EntityGUI/EntityGUI_SketcherDlg.h @@ -73,8 +73,9 @@ public: bool eventFilter (QObject* object, QEvent* event); - bool acceptMouseEvent() const { return ( getPnt1ConstructorId() == 1 ); } //accept mouse event only on absolute selection mode - void OnPointSelected( Qt::KeyboardModifiers, const gp_Pnt& ); // called by EntityGUI::OnMousePress() + bool acceptMouseEvent() const { return ( getPnt1ConstructorId() == 1 + || getPnt1ConstructorId() == 0 ); } //accept mouse event only on absolute and relative selection mode + void OnPointSelected( Qt::KeyboardModifiers, const gp_Pnt& ); // called by EntityGUI::OnMousePress() protected: void initSpinBox( SalomeApp_DoubleSpinBox*, @@ -105,6 +106,12 @@ private: const double = -1, const int = -1, const int = -1); + + void displayPntPreview( const double = 0.0, + const double = 0.0, + bool /*append*/ = true, + bool /*update*/ = true + ); bool createShapes( GEOM::GEOM_Object_ptr, TopoDS_Shape&,