diff --git a/src/BVH/BVH_Box.hxx b/src/BVH/BVH_Box.hxx index 8e0dc9fac5..311cec1183 100644 --- a/src/BVH/BVH_Box.hxx +++ b/src/BVH/BVH_Box.hxx @@ -189,18 +189,65 @@ public: OCCT_DUMP_FIELD_VALUE_NUMERICAL (theOStream, myMinPoint[0]) OCCT_DUMP_FIELD_VALUE_NUMERICAL (theOStream, myMinPoint[0]) } - if (n == 2) + else if (n == 2) { OCCT_DUMP_FIELD_VALUES_NUMERICAL (theOStream, "MinPoint", n, myMinPoint[0], myMinPoint[1]) OCCT_DUMP_FIELD_VALUES_NUMERICAL (theOStream, "MaxPoint", n, myMaxPoint[0], myMaxPoint[1]) } - if (n == 3) + else if (n == 3) { OCCT_DUMP_FIELD_VALUES_NUMERICAL (theOStream, "MinPoint", n, myMinPoint[0], myMinPoint[1], myMinPoint[2]) OCCT_DUMP_FIELD_VALUES_NUMERICAL (theOStream, "MaxPoint", n, myMaxPoint[0], myMaxPoint[1], myMaxPoint[2]) } } + //! Inits the content of me from the stream + Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) + { + Standard_Integer aPos = theStreamPos; + + Standard_Integer anIsInited = 0; + TCollection_AsciiString aStreamStr = Standard_Dump::Text (theSStream); + + OCCT_INIT_FIELD_VALUE_INTEGER (aStreamStr, aPos, anIsInited); + myIsInited = anIsInited != 0; + + int n = Min (N, 3); + if (n == 1) + { + Standard_Real aValue; + OCCT_INIT_FIELD_VALUE_REAL (aStreamStr, aPos, aValue); + myMinPoint[0] = (T)aValue; + } + else if (n == 2) + { + Standard_Real aValue1, aValue2; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "MinPoint", aPos, n, &aValue1, &aValue2); + myMinPoint[0] = (T)aValue1; + myMinPoint[1] = (T)aValue2; + + OCCT_INIT_VECTOR_CLASS (aStreamStr, "MaxPoint", aPos, n, &aValue1, &aValue2); + myMaxPoint[0] = (T)aValue1; + myMaxPoint[1] = (T)aValue2; + } + else if (n == 3) + { + Standard_Real aValue1, aValue2, aValue3; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "MinPoint", aPos, n, &aValue1, &aValue2, &aValue3); + myMinPoint[0] = (T)aValue1; + myMinPoint[1] = (T)aValue2; + myMinPoint[2] = (T)aValue3; + + OCCT_INIT_VECTOR_CLASS (aStreamStr, "MaxPoint", aPos, n, &aValue1, &aValue2, &aValue3); + myMaxPoint[0] = (T)aValue1; + myMaxPoint[1] = (T)aValue2; + myMaxPoint[2] = (T)aValue3; + } + + theStreamPos = aPos; + return Standard_True; + } + public: //! Checks if the Box is out of the other box. diff --git a/src/Bnd/Bnd_Box.cxx b/src/Bnd/Bnd_Box.cxx index cb4fbedad9..0b09e26cf3 100644 --- a/src/Bnd/Bnd_Box.cxx +++ b/src/Bnd/Bnd_Box.cxx @@ -983,3 +983,22 @@ void Bnd_Box::DumpJson (Standard_OStream& theOStream, Standard_Integer) const OCCT_DUMP_FIELD_VALUE_NUMERICAL (theOStream, Gap) OCCT_DUMP_FIELD_VALUE_NUMERICAL (theOStream, Flags) } + +//======================================================================= +//function : InitFromJson +//purpose : +//======================================================================= +Standard_Boolean Bnd_Box::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + + TCollection_AsciiString aStreamStr = Standard_Dump::Text (theSStream); + OCCT_INIT_VECTOR_CLASS (aStreamStr, "CornerMin", aPos, 3, &Xmin, &Ymin, &Zmin) + OCCT_INIT_VECTOR_CLASS (aStreamStr, "CornerMax", aPos, 3, &Xmax, &Ymax, &Zmax) + + OCCT_INIT_FIELD_VALUE_REAL (aStreamStr, aPos, Gap); + OCCT_INIT_FIELD_VALUE_INTEGER (aStreamStr, aPos, Flags); + + theStreamPos = aPos; + return Standard_True; +} diff --git a/src/Bnd/Bnd_Box.hxx b/src/Bnd/Bnd_Box.hxx index b716902f07..3d3656373d 100644 --- a/src/Bnd/Bnd_Box.hxx +++ b/src/Bnd/Bnd_Box.hxx @@ -305,6 +305,9 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); + protected: //! Bit flags. diff --git a/src/Quantity/Quantity_Color.cxx b/src/Quantity/Quantity_Color.cxx index cb8962e1af..28ccc3cccd 100644 --- a/src/Quantity/Quantity_Color.cxx +++ b/src/Quantity/Quantity_Color.cxx @@ -676,3 +676,17 @@ void Quantity_Color::DumpJson (Standard_OStream& theOStream, Standard_Integer) c { OCCT_DUMP_FIELD_VALUES_NUMERICAL (theOStream, "RGB", 3, myRgb.r(), myRgb.g(), myRgb.b()) } + +//======================================================================= +//function : InitFromJson +//purpose : +//======================================================================= +Standard_Boolean Quantity_Color::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + Standard_Real aRed, aGreen, aBlue; + OCCT_INIT_VECTOR_CLASS (Standard_Dump::Text (theSStream), "RGB", aPos, 3, &aRed, &aGreen, &aBlue) + + SetValues ((Standard_ShortReal)aRed, (Standard_ShortReal)aGreen, (Standard_ShortReal)aBlue, Quantity_TOC_RGB); + return Standard_True; +} diff --git a/src/Quantity/Quantity_Color.hxx b/src/Quantity/Quantity_Color.hxx index 82e3bdc9c8..8a0b224f97 100644 --- a/src/Quantity/Quantity_Color.hxx +++ b/src/Quantity/Quantity_Color.hxx @@ -365,6 +365,9 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); + private: //! Returns the values of a predefined color according to the mode. diff --git a/src/Quantity/Quantity_ColorRGBA.cxx b/src/Quantity/Quantity_ColorRGBA.cxx index 80016d8b7e..908135c990 100644 --- a/src/Quantity/Quantity_ColorRGBA.cxx +++ b/src/Quantity/Quantity_ColorRGBA.cxx @@ -208,3 +208,18 @@ void Quantity_ColorRGBA::DumpJson (Standard_OStream& theOStream, Standard_Intege { OCCT_DUMP_FIELD_VALUES_NUMERICAL (theOStream, "RGBA", 4, myRgb.Red(), myRgb.Green(), myRgb.Blue(), myAlpha) } + +//======================================================================= +//function : InitFromJson +//purpose : +//======================================================================= +Standard_Boolean Quantity_ColorRGBA::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + + Standard_Real aRed, aGreen, aBlue, anAlpha; + OCCT_INIT_VECTOR_CLASS (Standard_Dump::Text (theSStream), "RGBA", aPos, 4, &aRed, &aGreen, &aBlue, &anAlpha) + + SetValues ((Standard_ShortReal)aRed, (Standard_ShortReal)aGreen, (Standard_ShortReal)aBlue, (Standard_ShortReal)anAlpha); + return Standard_True; +} diff --git a/src/Quantity/Quantity_ColorRGBA.hxx b/src/Quantity/Quantity_ColorRGBA.hxx index bf4e47b211..ccdc6e6b37 100644 --- a/src/Quantity/Quantity_ColorRGBA.hxx +++ b/src/Quantity/Quantity_ColorRGBA.hxx @@ -158,6 +158,9 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); + private: static void myTestSize3() { Standard_STATIC_ASSERT (sizeof(float) * 3 == sizeof(Quantity_Color)); } diff --git a/src/Standard/Standard_Dump.cxx b/src/Standard/Standard_Dump.cxx index e897901d97..49e0d16c3b 100644 --- a/src/Standard/Standard_Dump.cxx +++ b/src/Standard/Standard_Dump.cxx @@ -74,6 +74,135 @@ void Standard_Dump::DumpRealValues (Standard_OStream& theOStream, int theCount, va_end(vl); } +//======================================================================= +//function : ProcessStreamName +//purpose : +//======================================================================= +Standard_Boolean Standard_Dump::ProcessStreamName (const TCollection_AsciiString& theStreamStr, + const TCollection_AsciiString& theName, + Standard_Integer& theStreamPos) +{ + if (theStreamStr.IsEmpty()) + return Standard_False; + + if (theStreamStr.Length () < theStreamPos) + return Standard_False; + + TCollection_AsciiString aSubText = theStreamStr.SubString (theStreamPos, theStreamStr.Length()); + if (aSubText.StartsWith (JsonKeyToString (Standard_JsonKey_SeparatorValueToValue))) + { + theStreamPos += JsonKeyLength (Standard_JsonKey_SeparatorValueToValue); + aSubText = theStreamStr.SubString (theStreamPos, theStreamStr.Length()); + } + TCollection_AsciiString aKeyName = TCollection_AsciiString (JsonKeyToString (Standard_JsonKey_Quote)) + + theName + + TCollection_AsciiString (JsonKeyToString (Standard_JsonKey_Quote)) + + JsonKeyToString (Standard_JsonKey_SeparatorKeyToValue); + Standard_Boolean aResult = aSubText.StartsWith (aKeyName); + if (aResult) + theStreamPos += aKeyName.Length(); + + return aResult; +} + +//======================================================================= +//function : ProcessFieldName +//purpose : +//======================================================================= +Standard_Boolean Standard_Dump::ProcessFieldName (const TCollection_AsciiString& theStreamStr, + const TCollection_AsciiString& theName, + Standard_Integer& theStreamPos) +{ + if (theStreamStr.IsEmpty()) + return Standard_False; + + TCollection_AsciiString aSubText = theStreamStr.SubString (theStreamPos, theStreamStr.Length()); + if (aSubText.StartsWith (JsonKeyToString (Standard_JsonKey_SeparatorValueToValue))) + { + theStreamPos += JsonKeyLength (Standard_JsonKey_SeparatorValueToValue); + aSubText = theStreamStr.SubString (theStreamPos, theStreamStr.Length()); + } + + TCollection_AsciiString aName = Standard_Dump::DumpFieldToName (theName.ToCString()); + TCollection_AsciiString aKeyName = TCollection_AsciiString (JsonKeyToString (Standard_JsonKey_Quote)) + + aName + + TCollection_AsciiString (JsonKeyToString (Standard_JsonKey_Quote)) + + JsonKeyToString (Standard_JsonKey_SeparatorKeyToValue); + + Standard_Boolean aResult = aSubText.StartsWith (aKeyName); + if (aResult) + theStreamPos += aKeyName.Length(); + + return aResult; +} + +//======================================================================= +//function : InitRealValues +//purpose : +//======================================================================= +Standard_Boolean Standard_Dump::InitRealValues (const TCollection_AsciiString& theStreamStr, + Standard_Integer& theStreamPos, + int theCount, ...) +{ + Standard_Integer aStreamPos = theStreamPos + JsonKeyLength (Standard_JsonKey_OpenContainer); + + TCollection_AsciiString aSubText = theStreamStr.SubString (aStreamPos, theStreamStr.Length()); + + va_list vl; + va_start(vl, theCount); + aStreamPos = 1; + Standard_Integer aClosePos = aSubText.Location (JsonKeyToString (Standard_JsonKey_CloseContainer), aStreamPos, aSubText.Length()); + for(int i = 0; i < theCount; ++i) + { + Standard_Integer aNextPos = (i < theCount-1) ? aSubText.Location (JsonKeyToString (Standard_JsonKey_SeparatorValueToValue), aStreamPos, aSubText.Length()) + : aClosePos; + + TCollection_AsciiString aValueText = aSubText.SubString (aStreamPos, aNextPos - 1); + + if (!aValueText.IsRealValue()) + return Standard_False; + + Standard_Real aValue = aValueText.RealValue(); + *(va_arg(vl, Standard_Real*)) = aValue; + + aStreamPos = aNextPos + JsonKeyLength (Standard_JsonKey_SeparatorValueToValue); + } + va_end(vl); + aClosePos = theStreamStr.Location (JsonKeyToString (Standard_JsonKey_CloseContainer), theStreamPos, theStreamStr.Length()); + theStreamPos = aClosePos + JsonKeyLength (Standard_JsonKey_CloseContainer); + + return Standard_True; +} + +//======================================================================= +//function : InitValue +//purpose : +//======================================================================= +Standard_Boolean Standard_Dump::InitValue (const TCollection_AsciiString& theStreamStr, + Standard_Integer& theStreamPos, + TCollection_AsciiString& theValue) +{ + Standard_Integer aStreamPos = theStreamPos; + + TCollection_AsciiString aSubText = theStreamStr.SubString (aStreamPos, theStreamStr.Length()); + + aStreamPos = 1; + Standard_Integer aNextPos = aSubText.Location (JsonKeyToString (Standard_JsonKey_SeparatorValueToValue), aStreamPos, aSubText.Length()); + Standard_JsonKey aNextKey = Standard_JsonKey_SeparatorValueToValue; + + Standard_Integer aCloseChildPos = aSubText.Location (JsonKeyToString (Standard_JsonKey_CloseChild), aStreamPos, aSubText.Length()); + Standard_Boolean isUseClosePos = (aNextPos > 0 && aCloseChildPos > 0 && aCloseChildPos < aNextPos) || !aNextPos; + if (isUseClosePos) + { + aNextPos = aCloseChildPos; + aNextKey = Standard_JsonKey_CloseChild; + } + + theValue = aNextPos ? aSubText.SubString (aStreamPos, aNextPos - 1) : aSubText; + theStreamPos = aNextPos ? (theStreamPos + (aNextPos - aStreamPos) + JsonKeyLength (aNextKey)) : theStreamStr.Length(); + return Standard_True; +} + // ======================================================================= // function : GetPointerInfo // purpose : diff --git a/src/Standard/Standard_Dump.hxx b/src/Standard/Standard_Dump.hxx index 72e7ccb45c..d2b294c7d1 100644 --- a/src/Standard/Standard_Dump.hxx +++ b/src/Standard/Standard_Dump.hxx @@ -77,6 +77,38 @@ theOStream << "\"" << aName << "\": " << theField; \ } +//! @def OCCT_INIT_FIELD_VALUE_REAL +//! Append vector values into output value: "Name": [value_1, value_2, ...] +//! This macro is intended to have only one row for dumped object in Json. +//! It's possible to use it without necessity of OCCT_DUMP_CLASS_BEGIN call, but pay attention that it should be only one row in the object dump. +#define OCCT_INIT_FIELD_VALUE_REAL(theOStream, theStreamPos, theField) \ +{ \ + Standard_Integer aStreamPos = theStreamPos; \ + if (!Standard_Dump::ProcessFieldName (theOStream, #theField, aStreamPos)) \ + return Standard_False; \ + TCollection_AsciiString aValueText; \ + if (!Standard_Dump::InitValue (theOStream, aStreamPos, aValueText) || !aValueText.IsRealValue()) \ + return Standard_False; \ + theField = aValueText.RealValue(); \ + theStreamPos = aStreamPos; \ +} + +//! @def OCCT_INIT_FIELD_VALUE_NUMERICAL +//! Append vector values into output value: "Name": [value_1, value_2, ...] +//! This macro is intended to have only one row for dumped object in Json. +//! It's possible to use it without necessity of OCCT_DUMP_CLASS_BEGIN call, but pay attention that it should be only one row in the object dump. +#define OCCT_INIT_FIELD_VALUE_INTEGER(theOStream, theStreamPos, theField) \ +{ \ + Standard_Integer aStreamPos = theStreamPos; \ + if (!Standard_Dump::ProcessFieldName (theOStream, #theField, aStreamPos)) \ + return Standard_False; \ + TCollection_AsciiString aValueText; \ + if (!Standard_Dump::InitValue (theOStream, aStreamPos, aValueText) || !aValueText.IsIntegerValue()) \ + return Standard_False; \ + theField = aValueText.IntegerValue(); \ + theStreamPos = aStreamPos; \ +} + //! @def OCCT_DUMP_FIELD_VALUE_STRING //! Append into output value: "Name": "Field" #define OCCT_DUMP_FIELD_VALUE_STRING(theOStream, theField) \ @@ -123,6 +155,18 @@ } \ } +//! @def OCCT_INIT_FIELD_VALUES_DUMPED +//! Append into output value: "Name": { field dumped values } +//! It computes Dump of the fields. The expected field is a pointer. +//! Use this macro for fields of the dumped class which has own Dump implementation. +//! The macros is recursive. Recursion is stopped when the depth value becomes equal to zero. +//! Depth = -1 is the default value, dump here is unlimited. +#define OCCT_INIT_FIELD_VALUES_DUMPED(theSStream, theStreamPos, theField) \ +{ \ + if ((theField) == NULL || !(theField)->InitFromJson (theSStream, theStreamPos)) \ + return Standard_False; \ +} + //! @def OCCT_DUMP_FIELD_VALUES_NUMERICAL //! Append real values into output values in an order: [value_1, value_2, ...] //! It computes Dump of the parent. The expected field is a parent class name to call ClassName::Dump. @@ -172,6 +216,20 @@ theOStream << "]"; \ } +//! @def OCCT_INIT_VECTOR_CLASS +//! Append vector values into output value: "Name": [value_1, value_2, ...] +//! This macro is intended to have only one row for dumped object in Json. +//! It's possible to use it without necessity of OCCT_DUMP_CLASS_BEGIN call, but pay attention that it should be only one row in the object dump. +#define OCCT_INIT_VECTOR_CLASS(theOStream, theName, theStreamPos, theCount, ...) \ +{ \ + Standard_Integer aStreamPos = theStreamPos; \ + if (!Standard_Dump::ProcessStreamName (theOStream, theName, aStreamPos)) \ + return Standard_False; \ + if (!Standard_Dump::InitRealValues (theOStream, aStreamPos, theCount, __VA_ARGS__)) \ + return Standard_False; \ + theStreamPos = aStreamPos; \ +} + //! Kind of key in Json string enum Standard_JsonKey { @@ -271,14 +329,46 @@ public: //! Unite values in one value using template: "value_1", "value_2", ..., "value_n" //! @param theOStream [out] stream to be fill with values - //! @param theCount numer of values + //! @param theCount [in] number of values Standard_EXPORT static void DumpCharacterValues (Standard_OStream& theOStream, int theCount, ...); //! Unite values in one value using template: value_1, value_2, ..., value_n //! @param theOStream [out] stream to be fill with values - //! @param theCount numer of values + //! @param theCount [in] number of values Standard_EXPORT static void DumpRealValues (Standard_OStream& theOStream, int theCount, ...); + //! Check whether the parameter name is equal to the name in the stream at position + //! @param theSStream [in] stream with values + //! @param theName [in] stream key value + //! @param theStreamPos [out] current position in the stream + Standard_EXPORT static Standard_Boolean ProcessStreamName (const TCollection_AsciiString& theStreamStr, + const TCollection_AsciiString& theName, + Standard_Integer& theStreamPos); + + //! Check whether the field name is equal to the name in the stream at position + //! @param theSStream [in] stream with values + //! @param theName [in] stream key field value + //! @param theStreamPos [out] current position in the stream + Standard_EXPORT static Standard_Boolean ProcessFieldName (const TCollection_AsciiString& theStreamStr, + const TCollection_AsciiString& theName, + Standard_Integer& theStreamPos); + + //! Unite values in one value using template: value_1, value_2, ..., value_n + //! @param theSStream [in] stream with values + //! @param theStreamPos [out] current position in the stream + //! @param theCount [in] number of values + Standard_EXPORT static Standard_Boolean InitRealValues (const TCollection_AsciiString& theStreamStr, + Standard_Integer& theStreamPos, + int theCount, ...); + + //! Returns real value + //! @param theSStream [in] stream with values + //! @param theStreamPos [out] current position in the stream + //! @param theValue [out] stream value + Standard_EXPORT static Standard_Boolean InitValue (const TCollection_AsciiString& theStreamStr, + Standard_Integer& theStreamPos, + TCollection_AsciiString& theValue); + //! Convert field name into dump text value, removes "&" and "my" prefixes //! An example, for field myValue, theName is Value, for &myCLass, the name is Class //! @param theField a source value diff --git a/src/gp/gp_Ax1.cxx b/src/gp/gp_Ax1.cxx index 3ee0231b34..19a5cfb286 100644 --- a/src/gp/gp_Ax1.cxx +++ b/src/gp/gp_Ax1.cxx @@ -90,3 +90,20 @@ void gp_Ax1::DumpJson (Standard_OStream& theOStream, Standard_Integer) const OCCT_DUMP_VECTOR_CLASS (theOStream, "Location", 3, loc.X(), loc.Y(), loc.Z()) OCCT_DUMP_VECTOR_CLASS (theOStream, "Direction", 3, vdir.X(), vdir.Y(), vdir.Z()) } + +Standard_Boolean gp_Ax1::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + TCollection_AsciiString aStreamStr = Standard_Dump::Text (theSStream); + + gp_XYZ& anXYZLoc = loc.ChangeCoord(); + OCCT_INIT_VECTOR_CLASS (aStreamStr, "Location", aPos, 3, + &anXYZLoc.ChangeCoord (1), &anXYZLoc.ChangeCoord (2), &anXYZLoc.ChangeCoord (3)) + gp_XYZ aDir; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "Direction", aPos, 3, + &aDir.ChangeCoord (1), &aDir.ChangeCoord (2), &aDir.ChangeCoord (3)) + SetDirection (aDir); + + theStreamPos = aPos; + return Standard_True; +} diff --git a/src/gp/gp_Ax1.hxx b/src/gp/gp_Ax1.hxx index f71a0829fe..c358413d6b 100644 --- a/src/gp/gp_Ax1.hxx +++ b/src/gp/gp_Ax1.hxx @@ -208,7 +208,8 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; - + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); protected: diff --git a/src/gp/gp_Ax2.cxx b/src/gp/gp_Ax2.cxx index ba8e7b155d..4a1ed084c8 100644 --- a/src/gp/gp_Ax2.cxx +++ b/src/gp/gp_Ax2.cxx @@ -122,3 +122,34 @@ void gp_Ax2::DumpJson (Standard_OStream& theOStream, Standard_Integer) const OCCT_DUMP_VECTOR_CLASS (theOStream, "XDirection", 3, vxdir.X(), vxdir.Y(), vxdir.Z()) OCCT_DUMP_VECTOR_CLASS (theOStream, "YDirection", 3, vydir.X(), vydir.Y(), vydir.Z()) } + +Standard_Boolean gp_Ax2::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + TCollection_AsciiString aStreamStr = Standard_Dump::Text (theSStream); + + gp_XYZ anXYZLoc; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "Location", aPos, 3, + &anXYZLoc.ChangeCoord (1), &anXYZLoc.ChangeCoord (2), &anXYZLoc.ChangeCoord (3)) + SetLocation (anXYZLoc); + + gp_XYZ aDir; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "Direction", aPos, 3, + &aDir.ChangeCoord (1), &aDir.ChangeCoord (2), &aDir.ChangeCoord (3)) + gp_XYZ aXDir; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "XDirection", aPos, 3, + &aXDir.ChangeCoord (1), &aXDir.ChangeCoord (2), &aXDir.ChangeCoord (3)) + gp_XYZ anYDir; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "YDirection", aPos, 3, + &anYDir.ChangeCoord (1), &anYDir.ChangeCoord (2), &anYDir.ChangeCoord (3)) + + axis.SetDirection (gp_Dir (aDir)); + vxdir = gp_Dir (aXDir); + vydir = gp_Dir (anYDir); + + if (!Direction().IsEqual (aDir, Precision::Confusion())) + return Standard_False; + + theStreamPos = aPos; + return Standard_True; +} diff --git a/src/gp/gp_Ax2.hxx b/src/gp/gp_Ax2.hxx index 1586dfed73..43536b47de 100644 --- a/src/gp/gp_Ax2.hxx +++ b/src/gp/gp_Ax2.hxx @@ -326,6 +326,9 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); + protected: diff --git a/src/gp/gp_Ax3.cxx b/src/gp/gp_Ax3.cxx index ec5e8b7c4d..5e233bf74c 100644 --- a/src/gp/gp_Ax3.cxx +++ b/src/gp/gp_Ax3.cxx @@ -115,3 +115,31 @@ void gp_Ax3::DumpJson (Standard_OStream& theOStream, Standard_Integer) const OCCT_DUMP_VECTOR_CLASS (theOStream, "XDirection", 3, XDirection().X(), XDirection().Y(), XDirection().Z()) OCCT_DUMP_VECTOR_CLASS (theOStream, "YDirection", 3, YDirection().X(), YDirection().Y(), YDirection().Z()) } + +Standard_Boolean gp_Ax3::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + TCollection_AsciiString aStreamStr = Standard_Dump::Text (theSStream); + + gp_XYZ anXYZLoc; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "Location", aPos, 3, + &anXYZLoc.ChangeCoord (1), &anXYZLoc.ChangeCoord (2), &anXYZLoc.ChangeCoord (3)) + SetLocation (anXYZLoc); + + gp_XYZ aDir; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "Direction", aPos, 3, + &aDir.ChangeCoord (1), &aDir.ChangeCoord (2), &aDir.ChangeCoord (3)) + gp_XYZ aXDir; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "XDirection", aPos, 3, + &aXDir.ChangeCoord (1), &aXDir.ChangeCoord (2), &aXDir.ChangeCoord (3)) + gp_XYZ anYDir; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "YDirection", aPos, 3, + &anYDir.ChangeCoord (1), &anYDir.ChangeCoord (2), &anYDir.ChangeCoord (3)) + + axis.SetDirection (gp_Dir (aDir)); + vxdir = gp_Dir (aXDir); + vydir = gp_Dir (anYDir); + + theStreamPos = aPos; + return Standard_True; +} diff --git a/src/gp/gp_Ax3.hxx b/src/gp/gp_Ax3.hxx index 50068bea7b..80d2205eaf 100644 --- a/src/gp/gp_Ax3.hxx +++ b/src/gp/gp_Ax3.hxx @@ -293,7 +293,8 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; - + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); protected: diff --git a/src/gp/gp_Dir.cxx b/src/gp/gp_Dir.cxx index 0714a34e6b..3dfb999b2d 100644 --- a/src/gp/gp_Dir.cxx +++ b/src/gp/gp_Dir.cxx @@ -144,3 +144,13 @@ void gp_Dir::DumpJson (Standard_OStream& theOStream, Standard_Integer) const { OCCT_DUMP_VECTOR_CLASS (theOStream, "gp_Dir", 3, coord.X(), coord.Y(), coord.Z()) } + +Standard_Boolean gp_Dir::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + + OCCT_INIT_VECTOR_CLASS (Standard_Dump::Text (theSStream), "gp_Dir", aPos, 3, &coord.ChangeCoord (1), &coord.ChangeCoord (2), &coord.ChangeCoord (3)) + + theStreamPos = aPos; + return Standard_True; +} diff --git a/src/gp/gp_Dir.hxx b/src/gp/gp_Dir.hxx index 0892155c00..a6215b29e3 100644 --- a/src/gp/gp_Dir.hxx +++ b/src/gp/gp_Dir.hxx @@ -266,6 +266,8 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); protected: diff --git a/src/gp/gp_Pnt.cxx b/src/gp/gp_Pnt.cxx index 10a9b5d434..8929df71ea 100644 --- a/src/gp/gp_Pnt.cxx +++ b/src/gp/gp_Pnt.cxx @@ -90,3 +90,13 @@ void gp_Pnt::DumpJson (Standard_OStream& theOStream, Standard_Integer) const { OCCT_DUMP_VECTOR_CLASS (theOStream, "gp_Pnt", 3, coord.X(), coord.Y(), coord.Z()) } + +Standard_Boolean gp_Pnt::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + + OCCT_INIT_VECTOR_CLASS (Standard_Dump::Text (theSStream), "gp_Pnt", aPos, 3, &coord.ChangeCoord (1), &coord.ChangeCoord (2), &coord.ChangeCoord (3)) + + theStreamPos = aPos; + return Standard_True; +} diff --git a/src/gp/gp_Pnt.hxx b/src/gp/gp_Pnt.hxx index b9c4b5c087..5f6e396c1a 100644 --- a/src/gp/gp_Pnt.hxx +++ b/src/gp/gp_Pnt.hxx @@ -177,7 +177,8 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; - + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); protected: diff --git a/src/gp/gp_Trsf.cxx b/src/gp/gp_Trsf.cxx index 1ddf2eb304..b5b7551b15 100644 --- a/src/gp/gp_Trsf.cxx +++ b/src/gp/gp_Trsf.cxx @@ -915,3 +915,39 @@ void gp_Trsf::DumpJson (Standard_OStream& theOStream, Standard_Integer) const OCCT_DUMP_FIELD_VALUE_NUMERICAL (theOStream, shape) OCCT_DUMP_FIELD_VALUE_NUMERICAL (theOStream, scale) } + +//======================================================================= +//function : InitFromJson +//purpose : +//======================================================================= +Standard_Boolean gp_Trsf::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + TCollection_AsciiString aStreamStr = Standard_Dump::Text (theSStream); + + gp_XYZ anXYZLoc; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "Location", aPos, 3, + &anXYZLoc.ChangeCoord (1), &anXYZLoc.ChangeCoord (2), &anXYZLoc.ChangeCoord (3)) + SetTranslation (anXYZLoc); + + Standard_Real mymatrix[3][3]; + OCCT_INIT_VECTOR_CLASS (aStreamStr, "Matrix", aPos, 9, &mymatrix[0][0], &mymatrix[0][1], &mymatrix[0][2], + &mymatrix[1][0], &mymatrix[1][1], &mymatrix[1][2], + &mymatrix[2][0], &mymatrix[2][1], &mymatrix[2][2]) + for (int i = 0; i < 3; i++) + { + for (int j = 0; j < 3; j++) + { + matrix.SetValue (i + 1, j + 1, mymatrix[i][j]); + } + } + + Standard_Real ashape; + OCCT_INIT_FIELD_VALUE_INTEGER (aStreamStr, aPos, ashape); + shape = (gp_TrsfForm)((Standard_Integer)ashape); + + OCCT_INIT_FIELD_VALUE_REAL (aStreamStr, aPos, scale); + + theStreamPos = aPos; + return Standard_True; +} diff --git a/src/gp/gp_Trsf.hxx b/src/gp/gp_Trsf.hxx index 5148d4d95b..1625ac7b45 100644 --- a/src/gp/gp_Trsf.hxx +++ b/src/gp/gp_Trsf.hxx @@ -25,6 +25,7 @@ #include #include #include +#include #include class Standard_ConstructionError; @@ -354,6 +355,9 @@ void operator *= (const gp_Trsf& T) //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); + friend class gp_GTrsf; protected: diff --git a/src/gp/gp_XYZ.cxx b/src/gp/gp_XYZ.cxx index 0599ad950e..1c85ef60b7 100644 --- a/src/gp/gp_XYZ.cxx +++ b/src/gp/gp_XYZ.cxx @@ -42,3 +42,17 @@ void gp_XYZ::DumpJson (Standard_OStream& theOStream, Standard_Integer) const { OCCT_DUMP_VECTOR_CLASS (theOStream, "gp_XYZ", 3, x, y, z) } + +//======================================================================= +//function : InitFromJson +//purpose : +//======================================================================= +Standard_Boolean gp_XYZ::InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos) +{ + Standard_Integer aPos = theStreamPos; + OCCT_INIT_VECTOR_CLASS (Standard_Dump::Text (theSStream), "gp_XYZ", aPos, 3, &x, &y, &z) + + theStreamPos = aPos; + return Standard_True; +} + diff --git a/src/gp/gp_XYZ.hxx b/src/gp/gp_XYZ.hxx index e3b49d82ec..99dbb1ce0b 100644 --- a/src/gp/gp_XYZ.hxx +++ b/src/gp/gp_XYZ.hxx @@ -24,6 +24,7 @@ #include #include +#include class Standard_ConstructionError; class Standard_OutOfRange; @@ -330,6 +331,9 @@ public: //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; + //! Inits the content of me from the stream + Standard_EXPORT Standard_Boolean InitFromJson (const Standard_SStream& theSStream, Standard_Integer& theStreamPos); + protected: diff --git a/tools/Convert/Convert_Tools.cxx b/tools/Convert/Convert_Tools.cxx index 47b640738d..411fb1fd40 100644 --- a/tools/Convert/Convert_Tools.cxx +++ b/tools/Convert/Convert_Tools.cxx @@ -16,8 +16,19 @@ #include #include +#include +#include #include +#include +#include +#include #include +#include +#include +#include +#include +#include +#include // ======================================================================= // function : ReadShape @@ -36,19 +47,214 @@ TopoDS_Shape Convert_Tools::ReadShape (const TCollection_AsciiString& theFileNam //function : ConvertStreamToPresentations //purpose : //======================================================================= -void Convert_Tools::ConvertStreamToPresentations (const Standard_SStream&, - const Standard_Integer, - const Standard_Integer, - NCollection_List&) +void Convert_Tools::ConvertStreamToPresentations (const Standard_SStream& theSStream, + const Standard_Integer theStartPos, + const Standard_Integer /*theLastPos*/, + NCollection_List& thePresentations) { + int aStartPos = theStartPos; + + gp_XYZ aPoint; + if (aPoint.InitFromJson (theSStream, aStartPos)) + { + thePresentations.Append (new Convert_TransientShape (BRepBuilderAPI_MakeVertex (aPoint))); + return; + } + + gp_Pnt aPnt; + if (aPnt.InitFromJson (theSStream, aStartPos)) + { + thePresentations.Append (new Convert_TransientShape (BRepBuilderAPI_MakeVertex (aPnt))); + return; + } + + gp_Dir aDir; + if (aDir.InitFromJson (theSStream, aStartPos)) + { + thePresentations.Append (new Convert_TransientShape (BRepBuilderAPI_MakeEdge (gp::Origin(), aDir.XYZ()))); + return; + } + + gp_Ax2 anAx2; + if (anAx2.InitFromJson (theSStream, aStartPos)) + { + Handle(Geom_Plane) aGeomPlane = new Geom_Plane (gp_Ax3 (anAx2)); + CreatePresentation (aGeomPlane, thePresentations); + return; + } + + gp_Ax3 anAx3; // should be after gp_Ax2 + if (anAx3.InitFromJson (theSStream, aStartPos)) + { + Handle(Geom_Plane) aGeomPlane = new Geom_Plane (anAx3); + CreatePresentation (aGeomPlane, thePresentations); + return; + } + + // should be after gp_Ax3 + gp_Ax1 anAxis; + if (anAxis.InitFromJson (theSStream, aStartPos)) + { + thePresentations.Append (new Convert_TransientShape (BRepBuilderAPI_MakeEdge (anAxis.Location(), anAxis.Location().Coord() + anAxis.Direction().XYZ()))); + return; + } + + gp_Trsf aTrsf; + if (aTrsf.InitFromJson (theSStream, aStartPos)) + { + CreatePresentation (aTrsf, thePresentations); + return; + } + + Bnd_Box aBox; + if (aBox.InitFromJson (theSStream, aStartPos)) + { + TopoDS_Shape aShape; + if (Convert_Tools::CreateShape (aBox, aShape)) + thePresentations.Append (new Convert_TransientShape (aShape)); + return; + } + + Select3D_BndBox3d aSelectBndBox; + if (aSelectBndBox.InitFromJson (theSStream, aStartPos)) + { + TopoDS_Shape aShape; + + gp_Pnt aPntMin = gp_Pnt (aSelectBndBox.CornerMin().x(), aSelectBndBox.CornerMin().y(), aSelectBndBox.CornerMin().z()); + gp_Pnt aPntMax = gp_Pnt (aSelectBndBox.CornerMax().x(), aSelectBndBox.CornerMax().y(), aSelectBndBox.CornerMax().z()); + if (CreateBoxShape (aPntMin, aPntMax, aShape)) + thePresentations.Append (new Convert_TransientShape (aShape)); + return; + } } //======================================================================= //function : ConvertStreamToColor //purpose : //======================================================================= -Standard_Boolean Convert_Tools::ConvertStreamToColor (const Standard_SStream&, - Quantity_Color&) +Standard_Boolean Convert_Tools::ConvertStreamToColor (const Standard_SStream& theSStream, + Quantity_Color& theColor) { + Standard_Integer aStartPos = 1; + Quantity_ColorRGBA aColorRGBA; + if (aColorRGBA.InitFromJson (theSStream, aStartPos)) + { + theColor = aColorRGBA.GetRGB(); + return Standard_True; + } + + Quantity_Color aColor; + if (aColor.InitFromJson (theSStream, aStartPos)) + { + theColor = aColor; + return Standard_True; + } + return Standard_False; } + +//======================================================================= +//function : CreateShape +//purpose : +//======================================================================= +Standard_Boolean Convert_Tools::CreateShape (const Bnd_Box& theBoundingBox, TopoDS_Shape& theShape) +{ + if (theBoundingBox.IsVoid() || theBoundingBox.IsWhole()) + return Standard_False; + + Standard_Real aXmin, anYmin, aZmin, aXmax, anYmax, aZmax; + theBoundingBox.Get (aXmin, anYmin, aZmin, aXmax, anYmax, aZmax); + + gp_Pnt aPntMin = gp_Pnt (aXmin, anYmin, aZmin); + gp_Pnt aPntMax = gp_Pnt (aXmax, anYmax, aZmax); + + return CreateBoxShape (aPntMin, aPntMax, theShape); +} + +//======================================================================= +//function : CreateShape +//purpose : +//======================================================================= +Standard_Boolean Convert_Tools::CreateShape (const Bnd_OBB& theBoundingBox, TopoDS_Shape& theShape) +{ + if (theBoundingBox.IsVoid()) + return Standard_False; + + TColgp_Array1OfPnt anArrPnts(0, 8); + theBoundingBox.GetVertex(&anArrPnts(0)); + + BRep_Builder aBuilder; + TopoDS_Compound aCompound; + aBuilder.MakeCompound (aCompound); + + aBuilder.Add (aCompound, BRepBuilderAPI_MakeEdge (gp_Pnt (anArrPnts.Value(0)), gp_Pnt (anArrPnts.Value(1)))); + aBuilder.Add (aCompound, BRepBuilderAPI_MakeEdge (gp_Pnt (anArrPnts.Value(0)), gp_Pnt (anArrPnts.Value(2)))); + aBuilder.Add (aCompound, BRepBuilderAPI_MakeEdge (gp_Pnt (anArrPnts.Value(1)), gp_Pnt (anArrPnts.Value(3)))); + aBuilder.Add (aCompound, BRepBuilderAPI_MakeEdge (gp_Pnt (anArrPnts.Value(2)), gp_Pnt (anArrPnts.Value(3)))); + + theShape = aCompound; + return Standard_True; +} + +//======================================================================= +//function : CreateBoxShape +//purpose : +//======================================================================= +Standard_Boolean Convert_Tools::CreateBoxShape (const gp_Pnt& thePntMin, const gp_Pnt& thePntMax, TopoDS_Shape& theShape) +{ + BRepPreviewAPI_MakeBox aMakeBox; + aMakeBox.Init (thePntMin, thePntMax); + theShape = aMakeBox.Shape(); + + return Standard_True; +} + +//======================================================================= +//function : CreatePresentation +//purpose : +//======================================================================= +void Convert_Tools::CreatePresentation (const Handle(Geom_Plane)& thePlane, + NCollection_List& thePresentations) +{ + Handle(AIS_Plane) aPlanePrs = new AIS_Plane (thePlane); + + aPlanePrs->Attributes()->SetPlaneAspect (new Prs3d_PlaneAspect()); + Handle (Prs3d_PlaneAspect) aPlaneAspect = aPlanePrs->Attributes()->PlaneAspect(); + aPlaneAspect->SetPlaneLength (100, 100); + aPlaneAspect->SetDisplayCenterArrow (Standard_True); + aPlaneAspect->SetDisplayEdgesArrows (Standard_True); + aPlaneAspect->SetArrowsSize (100); + aPlaneAspect->SetArrowsLength (100); + aPlaneAspect->SetDisplayCenterArrow (Standard_True); + aPlaneAspect->SetDisplayEdges (Standard_True); + + aPlanePrs->SetColor (Quantity_NOC_WHITE); + aPlanePrs->SetTransparency (0); + + thePresentations.Append (aPlanePrs); +} + +//======================================================================= +//function : CreatePresentation +//purpose : +//======================================================================= +void Convert_Tools::CreatePresentation (const gp_Trsf& theTrsf, + NCollection_List& thePresentations) +{ + Bnd_Box aBox (gp_Pnt(), gp_Pnt(10., 10., 10)); + + TopoDS_Shape aBoxShape; + if (!Convert_Tools::CreateShape (aBox, aBoxShape)) + return; + + Handle(AIS_Shape) aSourcePrs = new AIS_Shape (aBoxShape); + aSourcePrs->SetColor (Quantity_NOC_WHITE); + aSourcePrs->SetTransparency (0.5); + thePresentations.Append (aSourcePrs); + + Handle(AIS_Shape) aTransformedPrs = new AIS_Shape (aBoxShape); + aTransformedPrs->SetColor (Quantity_NOC_TOMATO); + aTransformedPrs->SetTransparency (0.5); + aTransformedPrs->SetLocalTransformation (theTrsf); + thePresentations.Append (aTransformedPrs); +} diff --git a/tools/Convert/Convert_Tools.hxx b/tools/Convert/Convert_Tools.hxx index 3145c77cce..728c096c74 100644 --- a/tools/Convert/Convert_Tools.hxx +++ b/tools/Convert/Convert_Tools.hxx @@ -16,16 +16,33 @@ #ifndef Convert_Tools_H #define Convert_Tools_H +#include +#include +#include +#include +#include +#include #include #include #include #include -#include +#include +#include #include +#include #include +#include + +#include +#include +#include +#include + +class Geom_Plane; +class Geom_Transformation; //! \class Convert_Tools -//! \brief The tool that gives auxiliary methods converting. +//! \brief The tool that gives auxiliary methods for qt elements manipulation. class Convert_Tools { public: @@ -49,6 +66,37 @@ public: //! \returns true if done Standard_EXPORT static Standard_Boolean ConvertStreamToColor (const Standard_SStream& theSStream, Quantity_Color& theColor); + + //! Creates box shape + //! \param theBoundingBox box shape parameters + //! \return created shape + Standard_EXPORT static Standard_Boolean CreateShape (const Bnd_Box& theBoundingBox, TopoDS_Shape& theShape); + + //! Creates box shape + //! \param theBoundingBox box shape parameters + //! \return created shape + Standard_EXPORT static Standard_Boolean CreateShape (const Bnd_OBB& theBoundingBox, TopoDS_Shape& theShape); + + //! Creates box shape + //! \param thePntMin minimum point on the bounding box + //! \param thePntMax maximum point on the bounding box + //! \return created shape + Standard_EXPORT static Standard_Boolean CreateBoxShape (const gp_Pnt& thePntMin, + const gp_Pnt& thePntMax, + TopoDS_Shape& theShape); + + //! Creates presentation AIS_Plane + //! \param thePlane source plane + //! \param thePresentations container to collect new presentation/s + Standard_EXPORT static void CreatePresentation (const Handle(Geom_Plane)& thePlane, + NCollection_List& thePresentations); + + //! Creates two presentations base on gp_Trsf: box in initial place and transformed box + //! \param thePlane source plane + //! \param thePresentations container to collect new presentation/s + Standard_EXPORT static void CreatePresentation (const gp_Trsf& theTrsf, + NCollection_List& thePresentations); + }; #endif diff --git a/tools/TreeModel/TreeModel_ItemBase.cxx b/tools/TreeModel/TreeModel_ItemBase.cxx index 38ef9b23ca..1b23b909cb 100644 --- a/tools/TreeModel/TreeModel_ItemBase.cxx +++ b/tools/TreeModel/TreeModel_ItemBase.cxx @@ -92,6 +92,22 @@ TreeModel_ItemBasePtr TreeModel_ItemBase::Child (int theRow, int theColumn, cons return anItem; } +// ======================================================================= +// function : Presentations +// purpose : +// ======================================================================= +void TreeModel_ItemBase::Presentations (NCollection_List& thePresentations) +{ + if (Column() != 0) + return; + + const Handle(TreeModel_ItemProperties)& anItemProperties = Properties(); + if (anItemProperties) + { + anItemProperties->Presentations (thePresentations); + } +} + // ======================================================================= // function : currentItem // purpose : diff --git a/tools/TreeModel/TreeModel_ItemBase.hxx b/tools/TreeModel/TreeModel_ItemBase.hxx index 99f7d21068..4c121f8213 100644 --- a/tools/TreeModel/TreeModel_ItemBase.hxx +++ b/tools/TreeModel/TreeModel_ItemBase.hxx @@ -16,6 +16,7 @@ #ifndef TreeModel_ItemBase_H #define TreeModel_ItemBase_H +#include #include #include #include @@ -149,6 +150,7 @@ public: //! Returns the item properties const Handle(TreeModel_ItemProperties)& Properties() const { return myProperties; } + Standard_EXPORT virtual void Presentations (NCollection_List& thePresentations); protected: //! \param theParent the parent item diff --git a/tools/VInspector/VInspector_ItemPresentableObject.cxx b/tools/VInspector/VInspector_ItemPresentableObject.cxx index 135170ea1b..9babba37ff 100644 --- a/tools/VInspector/VInspector_ItemPresentableObject.cxx +++ b/tools/VInspector/VInspector_ItemPresentableObject.cxx @@ -156,7 +156,7 @@ void VInspector_ItemPresentableObject::Init() } std::sort (aListOfIOSorted.begin(), aListOfIOSorted.end()); - int aCurrentIndex = 0; + int aCurrentIndex = 1; /* Properties item of context*/ for (std::vector::const_iterator anIOIt = aListOfIOSorted.begin(); anIOIt != aListOfIOSorted.end(); anIOIt++, aCurrentIndex++) { if (aCurrentIndex != aRowId) @@ -228,9 +228,10 @@ QString VInspector_ItemPresentableObject::PointerInfo() const // ======================================================================= void VInspector_ItemPresentableObject::Presentations (NCollection_List& thePresentations) { + TreeModel_ItemBase::Presentations (thePresentations); + if (Column() != 0) return; - thePresentations.Append (GetInteractiveObject()); } diff --git a/tools/VInspector/VInspector_Window.cxx b/tools/VInspector/VInspector_Window.cxx index 22ed9e50f6..1991dbe631 100644 --- a/tools/VInspector/VInspector_Window.cxx +++ b/tools/VInspector/VInspector_Window.cxx @@ -22,7 +22,6 @@ #include #include -#include #include #include @@ -392,7 +391,10 @@ void VInspector_Window::SelectedShapes (NCollection_List(anItem); if (!aVItem /*|| aVItem->Row() == 0*/) + { + anItem->Presentations (theSelPresentations); continue; + } TopoDS_Shape aShape = aVItem->GetPresentationShape(); if (aShape.IsNull()) @@ -595,15 +597,11 @@ void VInspector_Window::onTreeViewSelectionChanged (const QItemSelection&, if (!anItemBase) continue; - const Handle(TreeModel_ItemProperties)& anItemProperties = anItemBase->Properties(); - if (anItemProperties) - { - anItemProperties->Presentations (aSelPresentations); - } + anItemBase->Presentations (aSelPresentations); } SelectedShapes (aSelPresentations); - displayer()->DisplayPreview()->UpdatePreview (View_DisplayActionType_DisplayId, aSelPresentations, myViewWindow->ViewWidget()->DisplayMode()); + displayer()->UpdatePreview (View_DisplayActionType_DisplayId, aSelPresentations); } // ======================================================================= diff --git a/tools/View/View_DisplayPreview.cxx b/tools/View/View_DisplayPreview.cxx index 7e6c55123b..e129416f33 100644 --- a/tools/View/View_DisplayPreview.cxx +++ b/tools/View/View_DisplayPreview.cxx @@ -79,12 +79,13 @@ void View_DisplayPreview::SetContext (const Handle(AIS_InteractiveContext)& theC // purpose : // ======================================================================= void View_DisplayPreview::UpdatePreview (const View_DisplayActionType, - const NCollection_List& thePresentations, - int theDisplayMode) + const NCollection_List& thePresentations) { if (myContext.IsNull()) return; + int aPreviewDisplayMode = AIS_Shaded; + // clear previous previews for (NCollection_List::Iterator anIterator (myPreviewReadyPresentations); anIterator.More(); anIterator.Next()) { @@ -115,7 +116,7 @@ void View_DisplayPreview::UpdatePreview (const View_DisplayActionType, Handle(AIS_InteractiveObject) aPrs = Handle(AIS_InteractiveObject)::DownCast (anIterator.Value()); if (!aPrs.IsNull() && aPrs->GetContext().IsNull()/*is not displayed in another context*/) { - myContext->Display (aPrs, theDisplayMode, -1/*does not participate in selection*/, Standard_True); + myContext->Display (aPrs, aPreviewDisplayMode, -1/*does not participate in selection*/, Standard_True); enableGlobalClipping(aPrs, false); myPreviewReadyPresentations.Append (aPrs); } @@ -128,7 +129,7 @@ void View_DisplayPreview::UpdatePreview (const View_DisplayActionType, myPreviewPresentation->Attributes()->SetPointAspect (new Prs3d_PointAspect (Aspect_TOM_O_PLUS, aColor, 3.0)); myPreviewPresentation->SetAttributes (myPreviewParameters->GetDrawer()); - myContext->Display (myPreviewPresentation, theDisplayMode, -1/*does not participate in selection*/, Standard_True); + myContext->Display (myPreviewPresentation, aPreviewDisplayMode, -1/*does not participate in selection*/, Standard_True); enableGlobalClipping(myPreviewPresentation, false); } else @@ -140,28 +141,3 @@ void View_DisplayPreview::UpdatePreview (const View_DisplayActionType, } } } - -// ======================================================================= -// function : SetDisplayMode -// purpose : -// ======================================================================= -void View_DisplayPreview::SetDisplayMode (const int theDisplayMode, const bool theToUpdateViewer) -{ - if (myContext.IsNull()) - return; - - if (!myPreviewPresentation.IsNull()) - { - if (myContext == myPreviewPresentation->GetContext()) - myContext->SetDisplayMode (myPreviewPresentation, theDisplayMode, Standard_False); - } - - for (NCollection_List::Iterator aPreviewIt (myPreviewReadyPresentations); aPreviewIt.More(); aPreviewIt.Next()) - { - if (myContext == aPreviewIt.Value()->GetContext()) - myContext->SetDisplayMode (aPreviewIt.Value(), theDisplayMode, Standard_False); - } - - if (theToUpdateViewer) - myContext->UpdateCurrentViewer(); -} diff --git a/tools/View/View_DisplayPreview.hxx b/tools/View/View_DisplayPreview.hxx index 530bfea248..550e681289 100644 --- a/tools/View/View_DisplayPreview.hxx +++ b/tools/View/View_DisplayPreview.hxx @@ -53,12 +53,7 @@ public: //! Updates visibility of the presentations for the display type Standard_EXPORT void UpdatePreview (const View_DisplayActionType theType, - const NCollection_List& thePresentations, - int theDisplayMode); - - //! Sets display mode for all displayed presentations - Standard_EXPORT void SetDisplayMode (const int theDisplayMode, - const bool theToUpdateViewer = true); + const NCollection_List& thePresentations); //! Returns true if preview presentation is shown Standard_Boolean HasPreview() const { return !myPreviewPresentation.IsNull(); } diff --git a/tools/View/View_Displayer.cxx b/tools/View/View_Displayer.cxx index 9d36606c96..72c1c28ec7 100644 --- a/tools/View/View_Displayer.cxx +++ b/tools/View/View_Displayer.cxx @@ -34,7 +34,7 @@ // purpose : // ======================================================================= View_Displayer::View_Displayer() -: myIsKeepPresentations (false), myFitAllActive (false), myDisplayMode (-1) +: myIsKeepPresentations (false), myFitAllActive (false), myDisplayMode (0) { myDisplayPreview = new View_DisplayPreview(); } @@ -79,8 +79,6 @@ void View_Displayer::SetDisplayMode (const int theDisplayMode, for (AIS_ListIteratorOfListOfInteractive aDisplayedIt (aDisplayed); aDisplayedIt.More(); aDisplayedIt.Next()) GetContext()->SetDisplayMode (aDisplayedIt.Value(), theDisplayMode, Standard_False); - myDisplayPreview->SetDisplayMode (theDisplayMode, Standard_False); - if (theToUpdateViewer) UpdateViewer(); } @@ -270,7 +268,7 @@ bool View_Displayer::IsVisible (const TopoDS_Shape& theShape, const View_Present void View_Displayer::UpdatePreview (const View_DisplayActionType theType, const NCollection_List& thePresentations) { - myDisplayPreview->UpdatePreview (theType, thePresentations, myDisplayMode); + myDisplayPreview->UpdatePreview (theType, thePresentations); if (!myIsKeepPresentations || myFitAllActive) fitAllView(); } diff --git a/tools/View/View_PreviewParameters.cxx b/tools/View/View_PreviewParameters.cxx index 8cc48d06b1..44e2968384 100644 --- a/tools/View/View_PreviewParameters.cxx +++ b/tools/View/View_PreviewParameters.cxx @@ -28,6 +28,7 @@ View_PreviewParameters::View_PreviewParameters() myDrawer = new Prs3d_Drawer(); Quantity_Color aColor(Quantity_NOC_TOMATO); + Standard_ShortReal aTransparency = 0.8f; // point parameters myDrawer->SetPointAspect (new Prs3d_PointAspect (Aspect_TOM_O_PLUS, aColor, 3.0)); @@ -41,6 +42,10 @@ View_PreviewParameters::View_PreviewParameters() myDrawer->ShadingAspect()->SetColor (aColor); myDrawer->ShadingAspect()->SetMaterial (aShadingMaterial); + myDrawer->ShadingAspect()->Aspect()->ChangeFrontMaterial().SetTransparency (aTransparency); + myDrawer->ShadingAspect()->Aspect()->ChangeBackMaterial() .SetTransparency (aTransparency); + myDrawer->SetTransparency (aTransparency); + // common parameters myDrawer->SetZLayer (Graphic3d_ZLayerId_Topmost); }