From 4697d21bcd65aad772ea90d217aaebbd92890307 Mon Sep 17 00:00:00 2001 From: apl Date: Thu, 29 Sep 2016 17:36:19 +0300 Subject: [PATCH] Shape index and type property. Compilation errors has been fixed. --- src/GEOMGUI/CMakeLists.txt | 2 + src/GEOMGUI/GEOMGUI_ShapeAnnotations.cxx | 83 +++++++++++++++--------- src/GEOMGUI/GEOMGUI_ShapeAnnotations.h | 29 +++++++-- 3 files changed, 79 insertions(+), 35 deletions(-) diff --git a/src/GEOMGUI/CMakeLists.txt b/src/GEOMGUI/CMakeLists.txt index dba48f806..db3cb4cea 100755 --- a/src/GEOMGUI/CMakeLists.txt +++ b/src/GEOMGUI/CMakeLists.txt @@ -76,6 +76,7 @@ SET(GEOMGUI_HEADERS GEOMGUI_CreationInfoWdg.h GEOMGUI_TextTreeWdg.h GEOMGUI_DimensionProperty.h + GEOMGUI_ShapeAnnotations.h ) # header files / to be processed by moc @@ -116,6 +117,7 @@ SET(GEOMGUI_SOURCES GEOMGUI_CreationInfoWdg.cxx GEOMGUI_TextTreeWdg.cxx GEOMGUI_DimensionProperty.cxx + GEOMGUI_ShapeAnnotations.cxx ${_moc_SOURCES} ${_rcc_SOURCES} ) diff --git a/src/GEOMGUI/GEOMGUI_ShapeAnnotations.cxx b/src/GEOMGUI/GEOMGUI_ShapeAnnotations.cxx index 964453ce2..25cb86416 100755 --- a/src/GEOMGUI/GEOMGUI_ShapeAnnotations.cxx +++ b/src/GEOMGUI/GEOMGUI_ShapeAnnotations.cxx @@ -38,26 +38,30 @@ // ENTRY: { text[string] : visibility[bool] : screen fixed[bool] : position[xyz] : attach[xyz] } namespace { - static const QString PATTERN_ITEM_GROUP = "\\{ (Text=(?::{2,}|.)*:(?!:)Visible=.*:Screen=.*:Position=\\{(.*):(.*):(.*)\\}:Attach=\\{(.*):(.*):(.*)\\}) \\}"; - static const QString PATTERN_ITEM = "Text=((?::{2,}|.)*):(?!:)Visible=(\\d{1}):Screen=(\\d{1}):Position=\\{(.*):(.*):(.*)\\}:Attach=\\{(.*):(.*):(.*)\\}"; + static const QString PATTERN_ITEM_GROUP = "\\{ (Text=(?::{2,}|.)*:(?!:)Visible=.*:Screen=.*:Position=\\{(.*):(.*):(.*)\\}:Attach=\\{(.*):(.*):(.*)\\}:ShapeIdx=.*:ShapeType=.*) \\}"; + static const QString PATTERN_ITEM = "Text=((?::{2,}|.)*):(?!:)Visible=(\\d{1}):Screen=(\\d{1}):Position=\\{(.*):(.*):(.*)\\}:Attach=\\{(.*):(.*):(.*)\\}:ShapeIdx=(\\d{1,*}):ShapeType=(\\d{1})"; static QString toPattern (const QString& theText, const bool theIsVisible, const bool theIsFixed, const gp_Pnt& thePosition, - const gp_Pnt& theAttach) + const gp_Pnt& theAttach, + const int theShapeIndex, + const int theShapeType) { - return QString("{ Text=") + theText + - QString(":") + QString("Visible=") + QString::number( theIsVisible ? 1 : 0 ) + - QString(":") + QString("Screen=") + QString::number( theIsFixed ? 1 : 0 ) + - QString(":") + QString("Position={") + - QString::number( thePosition.X() ) + QString(":") + - QString::number( thePosition.Y() ) + QString(":") + - QString::number( thePosition.Z() ) + QString("}") + - QString(":") + QString("Attach={") + - QString::number( theAttach.X() ) + QString(":") + - QString::number( theAttach.Y() ) + QString(":") + - QString::number( theAttach.Z() ) + QString("}") + - QString(" }"); + return QString( "{ Text=" ) + theText + + QString( ":" ) + QString( "Visible=" ) + QString::number( theIsVisible ? 1 : 0 ) + + QString( ":" ) + QString( "Screen=" ) + QString::number( theIsFixed ? 1 : 0 ) + + QString( ":" ) + QString( "Position={" ) + + QString::number( thePosition.X() ) + QString( ":" ) + + QString::number( thePosition.Y() ) + QString( ":" ) + + QString::number( thePosition.Z() ) + QString( "}" ) + + QString( ":" ) + QString( "Attach={" ) + + QString::number( theAttach.X() ) + QString( ":" ) + + QString::number( theAttach.Y() ) + QString( ":" ) + + QString::number( theAttach.Z() ) + QString( "}" ) + + QString( ":" ) + QString( "ShapeIdx=" ) + QString::number( theShapeIndex ) + + QString( ":" ) + QString( "ShapeType=" ) + QString::number( theShapeType ) + + QString( " }" ); } }; @@ -110,15 +114,17 @@ GEOMGUI_ShapeAnnotations::GEOMGUI_ShapeAnnotations( const QString& theProperty ) continue; } - QString aStrText = aRegExpItem.cap( 1 ); - QString aStrVisible = aRegExpItem.cap( 2 ); - QString aStrFixed = aRegExpItem.cap( 3 ); - QString aStrPosX = aRegExpItem.cap( 4 ); - QString aStrPosY = aRegExpItem.cap( 5 ); - QString aStrPosZ = aRegExpItem.cap( 6 ); - QString aStrAttX = aRegExpItem.cap( 7 ); - QString aStrAttY = aRegExpItem.cap( 8 ); - QString aStrAttZ = aRegExpItem.cap( 9 ); + QString aStrText = aRegExpItem.cap( 1 ); + QString aStrVisible = aRegExpItem.cap( 2 ); + QString aStrFixed = aRegExpItem.cap( 3 ); + QString aStrPosX = aRegExpItem.cap( 4 ); + QString aStrPosY = aRegExpItem.cap( 5 ); + QString aStrPosZ = aRegExpItem.cap( 6 ); + QString aStrAttX = aRegExpItem.cap( 7 ); + QString aStrAttY = aRegExpItem.cap( 8 ); + QString aStrAttZ = aRegExpItem.cap( 9 ); + QString aStrShapeIdx = aRegExpItem.cap( 10 ); + QString aStrShapeType = aRegExpItem.cap( 11 ); aStrText.replace( "::", ":" ); ShapeAnnotation aEntry; @@ -131,6 +137,8 @@ GEOMGUI_ShapeAnnotations::GEOMGUI_ShapeAnnotations( const QString& theProperty ) aEntry.Attach.SetX( aStrAttX.toDouble() ); aEntry.Attach.SetY( aStrAttY.toDouble() ); aEntry.Attach.SetZ( aStrAttZ.toDouble() ); + aEntry.ShapeIndex = aStrShapeIdx.toInt(); + aEntry.ShapeType = aStrShapeType.toInt(); myAnnotations.append( aEntry ); } @@ -167,7 +175,13 @@ GEOMGUI_ShapeAnnotations::operator QString() const { const ShapeAnnotation& aEntry = myAnnotations[i]; // - anItems.append (toPattern (aEntry.Text, aEntry.IsVisible, aEntry.IsScreenFixed, aEntry.Position, aEntry.Attach)); + anItems.append( toPattern( aEntry.Text, + aEntry.IsVisible, + aEntry.IsScreenFixed, + aEntry.Position, + aEntry.Attach, + aEntry.ShapeIndex, + aEntry.ShapeType ) ); } return anItems.join( ":" ); @@ -179,12 +193,12 @@ GEOMGUI_ShapeAnnotations::operator QString() const //================================================================================= bool GEOMGUI_ShapeAnnotations::operator == (const GEOMGUI_ShapeAnnotations& theOther) const { - if ( myAnnotation.size() != theOther.myAnnotations.size() ) + if ( myAnnotations.size() != theOther.myAnnotations.size() ) { return false; } - for ( int i = 0; i < myAnnotation.size(); ++i ) + for ( int i = 0; i < myAnnotations.size(); ++i ) { if ( myAnnotations[i] != theOther.myAnnotations[i] ) { @@ -219,7 +233,7 @@ void GEOMGUI_ShapeAnnotations::FromPresentation( const int theIndex, // ShapeAnnotation& aChangeEntry = myAnnotations[theIndex]; aChangeEntry.IsScreenFixed = theShapeAnnotation->GetIsScreenFixed(); - aChangeEntry.Text = QString( theShapeAnnotation->GetText().ToExtString() ); + aChangeEntry.Text = QString( (QChar*) theShapeAnnotation->GetText().ToExtString(), theShapeAnnotation->GetText().Length() ); aChangeEntry.Attach = theShapeAnnotation->GetAttachPoint().Transformed( aFromLCS ); aChangeEntry.Position = theShapeAnnotation->GetPosition(); } @@ -236,8 +250,13 @@ void GEOMGUI_ShapeAnnotations::ToPresentation( const int theIndex, aToLCS.SetTransformation( theLCS, gp_Ax3() ); // const ShapeAnnotation& aEntry = myAnnotations[theIndex]; + // + TCollection_ExtendedString aText; + for (int i = 0; i < (int)aEntry.Text.length(); i++ ) + aText.Insert( i + 1, aEntry.Text[ i ].unicode() ); + // theShapeAnnotation->SetScreenFixed( aEntry.IsScreenFixed ); - theShapeAnnotation->SetText( aEntry.Text ); + theShapeAnnotation->SetText( aText ); theShapeAnnotation->SetPosition( aEntry.Position ); theShapeAnnotation->SetAttachPoint( aEntry.Attach.Transformed( aToLCS ) ); } @@ -273,7 +292,7 @@ void GEOMGUI_ShapeAnnotations::LoadFromAttribute( SalomeApp_Study* theStudy, con std::vector aPropertyArray = aDataAtt->GetColumn( i ); ShapeAnnotation aEntry; - aEntry.Text = QString( aDataAtt->GetColumnTitle( i ).c_str() ); + aEntry.Text = aDataAtt->GetColumnTitle( i ).c_str(); aEntry.IsVisible = static_cast( aPropertyArray[i++] ); aEntry.IsScreenFixed = static_cast( aPropertyArray[i++] ); aEntry.Position.SetX( static_cast( aPropertyArray[i++] ) ); @@ -282,6 +301,8 @@ void GEOMGUI_ShapeAnnotations::LoadFromAttribute( SalomeApp_Study* theStudy, con aEntry.Attach.SetX( static_cast( aPropertyArray[i++] ) ); aEntry.Attach.SetY( static_cast( aPropertyArray[i++] ) ); aEntry.Attach.SetZ( static_cast( aPropertyArray[i++] ) ); + aEntry.ShapeIndex = static_cast( aPropertyArray[i++] ); + aEntry.ShapeType = static_cast( aPropertyArray[i++] ); myAnnotations.append( aEntry ); } @@ -319,6 +340,8 @@ void GEOMGUI_ShapeAnnotations::SaveToAttribute( SalomeApp_Study *theStudy, const aPropertyArray.push_back( aEntry.Attach.X() ); aPropertyArray.push_back( aEntry.Attach.Y() ); aPropertyArray.push_back( aEntry.Attach.Z() ); + aPropertyArray.push_back( static_cast( aEntry.ShapeIndex ) ); + aPropertyArray.push_back( static_cast( aEntry.ShapeType ) ); aDataAtt->AddColumn( aPropertyArray ); aDataAtt->SetColumnTitle( i + 1, aEntry.Text.toStdString() ); diff --git a/src/GEOMGUI/GEOMGUI_ShapeAnnotations.h b/src/GEOMGUI/GEOMGUI_ShapeAnnotations.h index 8b9e7410f..3c1c2558d 100755 --- a/src/GEOMGUI/GEOMGUI_ShapeAnnotations.h +++ b/src/GEOMGUI/GEOMGUI_ShapeAnnotations.h @@ -38,6 +38,7 @@ #include class SalomeApp_Study; +class GEOM_Annotation; /*! * \brief Algorithms to translate and manitain list of shape annotation properties. @@ -55,11 +56,29 @@ public: */ struct ShapeAnnotation { - QString Text; - bool IsVisible; - bool IsScreenFixed; - gp_Pnt Position; - gp_Pnt Attach; + QString Text; // annotation text label + bool IsVisible; // visibility of annotation + bool IsScreenFixed; // fixed screen mode flag + gp_Pnt Position; // position of the annotation + gp_Pnt Attach; // attachment point of the annotation + int ShapeIndex; // index of the annotated subshape + int ShapeType; // type of the annotated subshape + + bool operator == (const ShapeAnnotation& theOther) const + { + return Text == theOther.Text + && IsVisible == theOther.IsVisible + && IsScreenFixed == theOther.IsScreenFixed + && Position.IsEqual (theOther.Position, 0.0) + && Attach.IsEqual (theOther.Attach, 0.0) + && ShapeIndex == theOther.ShapeIndex + && ShapeType == theOther.ShapeType; + } + + bool operator != (const ShapeAnnotation& theOther) const + { + return !(operator == (theOther)); + } }; public: