Dialog usability fixes

This commit is contained in:
apl 2016-10-13 19:01:13 +03:00
parent 8935becb09
commit bc38a38ac1

View File

@ -149,8 +149,8 @@ MeasureGUI_AnnotationDlg::MeasureGUI_AnnotationDlg( GeometryGUI* theGeometryGUI,
// data type // data type
QLabel* typeLabel = new QLabel( tr( "ANNOTATION_TYPE" ), propGroup ); QLabel* typeLabel = new QLabel( tr( "ANNOTATION_TYPE" ), propGroup );
myTypeCombo = new QComboBox( propGroup ); myTypeCombo = new QComboBox( propGroup );
myTypeCombo->insertItem( 0, tr( "3D" ) ); myTypeCombo->addItem( tr( "3D" ), 0 );
myTypeCombo->insertItem( 1, tr( "2D" ) ); myTypeCombo->addItem( tr( "2D" ), 1 );
myTypeCombo->setCurrentIndex( 0 ); // 3D, not fixed myTypeCombo->setCurrentIndex( 0 ); // 3D, not fixed
propLayout->addWidget( shapeLabel, 1, 0 ); propLayout->addWidget( shapeLabel, 1, 0 );
@ -211,7 +211,6 @@ MeasureGUI_AnnotationDlg::MeasureGUI_AnnotationDlg( GeometryGUI* theGeometryGUI,
myInteractor->Enable(); myInteractor->Enable();
Init(); Init();
//updateState();
} }
//======================================================================= //=======================================================================
@ -246,7 +245,7 @@ void MeasureGUI_AnnotationDlg::Init()
activateSelectionArgument( myShapeSelBtn ); activateSelectionArgument( myShapeSelBtn );
myTextEdit->setText( myAnnotationProperties.Text ); myTextEdit->setText( myAnnotationProperties.Text );
myShapeNameModified = false; myShapeNameModified = false;
myTypeCombo->setCurrentIndex( !myAnnotationProperties.IsScreenFixed ); myTypeCombo->setCurrentIndex( 0 );
int aSubShapeTypeIndex = -1; int aSubShapeTypeIndex = -1;
int aTypesCount = aTypesCount = mySubShapeTypeCombo->count(); int aTypesCount = aTypesCount = mySubShapeTypeCombo->count();
@ -285,10 +284,10 @@ void MeasureGUI_AnnotationDlg::Init()
//================================================================================= //=================================================================================
void MeasureGUI_AnnotationDlg::activateSelection() void MeasureGUI_AnnotationDlg::activateSelection()
{ {
//globalSelection( GEOM_ALLSHAPES ); globalSelection( GEOM_ALLOBJECTS );
//if ( !myShape->_is_nil() && mySelectionMode != TopAbs_SHAPE ) { if ( !myShape->_is_nil() && mySelectionMode != TopAbs_SHAPE ) {
// localSelection( myShape.get(), mySelectionMode ); localSelection( myShape.get(), mySelectionMode );
//} }
} }
//================================================================================= //=================================================================================
@ -424,7 +423,7 @@ void MeasureGUI_AnnotationDlg::SelectionIntoArgument()
myEditCurrentArgument->setText( aName ); myEditCurrentArgument->setText( aName );
if ( !myShapeNameModified ) { if ( !myShapeNameModified ) {
myTextEdit->setText( aName ); myTextEdit->setText( aName );
myShapeNameModified = false; onTextChange();
} }
} }
@ -434,7 +433,7 @@ void MeasureGUI_AnnotationDlg::SelectionIntoArgument()
activateSelection(); activateSelection();
if ( !myShape->_is_nil() ) { if ( !aNullShape ) {
if ( !getPickedPoint( anAttachPoint ) ) if ( !getPickedPoint( anAttachPoint ) )
{ {
TopoDS_Shape aShape; TopoDS_Shape aShape;
@ -444,34 +443,36 @@ void MeasureGUI_AnnotationDlg::SelectionIntoArgument()
} }
} else if ( myEditCurrentArgument == mySubShapeName ) { } else if ( myEditCurrentArgument == mySubShapeName ) {
if ( !myShape->_is_nil() ) { if ( !myShape->_is_nil() ) {
QString aName = GEOMBase::GetName( anObj.get() );
myEditCurrentArgument->setText( aName );
TopTools_IndexedMapOfShape aMainMap; if ( anObj->_is_nil() ) {
TopoDS_Shape aMainShape; myEditCurrentArgument->setText( QString() );
GEOMBase::GetShape( myShape.get(), aMainShape ); }
TopExp::MapShapes( aMainShape, aMainMap ); else {
TopExp_Explorer anExp( aMainShape, getShapeType() ); QString aName = GEOMBase::GetName( anObj.get() );
bool isShowWarning = true; myEditCurrentArgument->setText( aName );
TopoDS_Shape aSubShape; TopTools_IndexedMapOfShape aMainMap;
for ( ; anExp.More() && aSubShapeIndex < 0; anExp.Next() ) { TopoDS_Shape aMainShape;
TopoDS_Shape aCurrentSubShape = anExp.Current(); TopoDS_Shape aSubShape;
int anIndex = aMainMap.FindIndex( aCurrentSubShape ); GEOMBase::GetShape( myShape.get(), aMainShape );
if ( anIndex >= 0 ) { GEOMBase::GetShape( anObj.get(), aSubShape );
aSubShapeIndex = anIndex; TopExp::MapShapes( aMainShape, getShapeType(), aMainMap );
aSubShape = aCurrentSubShape;
if ( aMainMap.Contains( aSubShape ) ) {
aSubShapeIndex = aMainMap.FindIndex( aSubShape );
}
if ( !aSubShape.IsNull() )
{
if ( !getPickedPoint( anAttachPoint ) )
{
anAttachPoint = getAttachPoint( aSubShape );
}
} }
} }
if ( !getPickedPoint( anAttachPoint ) )
{
anAttachPoint = getAttachPoint( aSubShape );
}
myAnnotationProperties.ShapeIndex = aSubShapeIndex;
} }
myAnnotationProperties.ShapeIndex = aSubShapeIndex;
} }
myAnnotationProperties.Attach = anAttachPoint; myAnnotationProperties.Attach = anAttachPoint;
} }
@ -507,10 +508,12 @@ void MeasureGUI_AnnotationDlg::onTypeChange()
//======================================================================= //=======================================================================
void MeasureGUI_AnnotationDlg::onSubShapeTypeChange() void MeasureGUI_AnnotationDlg::onSubShapeTypeChange()
{ {
activateSelectionArgument( mySubShapeSelBtn ); const TopAbs_ShapeEnum aShapeType = getShapeType();
activateSelectionArgument( aShapeType == TopAbs_SHAPE ? myShapeSelBtn : mySubShapeSelBtn );
TopAbs_ShapeEnum aShapeType = getShapeType();
myAnnotationProperties.ShapeType = aShapeType; myAnnotationProperties.ShapeType = aShapeType;
if ( aShapeType != mySelectionMode ) { if ( aShapeType != mySelectionMode ) {
mySubShapeName->setText( "" ); mySubShapeName->setText( "" );
myAnnotationProperties.ShapeIndex = -1; myAnnotationProperties.ShapeIndex = -1;
@ -636,6 +639,7 @@ SALOME_Prs* MeasureGUI_AnnotationDlg::buildPrs()
aPresentation->SetLineWidth( aLineWidth ); aPresentation->SetLineWidth( aLineWidth );
aPresentation->SetLineStyle( static_cast<Aspect_TypeOfLine>( aLineStyle ) ); aPresentation->SetLineStyle( static_cast<Aspect_TypeOfLine>( aLineStyle ) );
aPresentation->SetAutoHide( isAutoHide ? Standard_True : Standard_False ); aPresentation->SetAutoHide( isAutoHide ? Standard_True : Standard_False );
aPresentation->SetScreenFixed( myAnnotationProperties.IsScreenFixed );
TopoDS_Shape aShape; TopoDS_Shape aShape;
GEOMBase::GetShape( myShape.get(), aShape ); GEOMBase::GetShape( myShape.get(), aShape );
@ -682,9 +686,8 @@ void MeasureGUI_AnnotationDlg::redisplayPreview()
erasePreview( false ); erasePreview( false );
try { try {
//SUIT_OverrideCursor wc; SUIT_OverrideCursor wc;
//getDisplayer()->SetColor( Quantity_NOC_VIOLET ); getDisplayer()->SetToActivate( true );
//getDisplayer()->SetToActivate( false );
if ( SALOME_Prs* aPrs = buildPrs() ) if ( SALOME_Prs* aPrs = buildPrs() )
displayPreview( aPrs ); displayPreview( aPrs );
@ -705,7 +708,7 @@ bool MeasureGUI_AnnotationDlg::getPickedPoint( gp_Pnt& thePnt )
return false; return false;
const OCCViewer_ViewWindow* anOccView = qobject_cast<const OCCViewer_ViewWindow*>( anActiveView ); const OCCViewer_ViewWindow* anOccView = qobject_cast<const OCCViewer_ViewWindow*>( anActiveView );
if ( !anOccView ) if ( !anOccView || !anOccView->underMouse() )
return false; return false;
OCCViewer_ViewManager* aVM = ( OCCViewer_ViewManager* )anOccView->getViewManager(); OCCViewer_ViewManager* aVM = ( OCCViewer_ViewManager* )anOccView->getViewManager();