mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
- do not dump document in CDM_MetaData, just pointer text; - move ID dump in to TDF_Attribute; - extend TDF_Attribute with other important states(obtained by methods); - extend TDocStd_Document with other important states; - avoid dumping of shapes in TNaming_UsedShapes (it takes much time); - extend XCAFDoc, XCAFDimTolObjects dump to json; - correct XCAFDoc_ColorTool, XCAFDoc_MaterialTool, XCAFDoc_LayerTool to dump only connected to the object information; - correct XCAFDoc_Material to dump name and density value only if it exists; - add check on correct direction in gp_Ax3.
792 lines
25 KiB
C++
792 lines
25 KiB
C++
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
|
//
|
|
// This file is part of Open CASCADE Technology software library.
|
|
//
|
|
// This library is free software; you can redistribute it and/or modify it under
|
|
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
// by the Free Software Foundation, with special exception defined in the file
|
|
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
// distribution for complete text of the license and disclaimer of any warranty.
|
|
//
|
|
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
// commercial license or contractual agreement.
|
|
|
|
#include <XCAFDoc_ColorTool.hxx>
|
|
|
|
#include <Quantity_Color.hxx>
|
|
#include <Standard_Dump.hxx>
|
|
#include <Standard_GUID.hxx>
|
|
#include <Standard_Type.hxx>
|
|
#include <TDataStd_Name.hxx>
|
|
#include <TDataStd_TreeNode.hxx>
|
|
#include <TDataStd_UAttribute.hxx>
|
|
#include <TDF_Attribute.hxx>
|
|
#include <TDF_ChildIDIterator.hxx>
|
|
#include <TDF_Label.hxx>
|
|
#include <TDF_RelocationTable.hxx>
|
|
#include <TDF_Tool.hxx>
|
|
#include <TNaming_NamedShape.hxx>
|
|
#include <TopoDS_Shape.hxx>
|
|
#include <XCAFDoc.hxx>
|
|
#include <XCAFDoc_Color.hxx>
|
|
#include <XCAFDoc_DocumentTool.hxx>
|
|
#include <XCAFDoc_GraphNode.hxx>
|
|
#include <XCAFDoc_ShapeTool.hxx>
|
|
|
|
IMPLEMENT_DERIVED_ATTRIBUTE_WITH_TYPE(XCAFDoc_ColorTool,TDataStd_GenericEmpty,"xcaf","ColorTool")
|
|
|
|
static Standard_Boolean XCAFDoc_ColorTool_AutoNaming = Standard_True;
|
|
|
|
//=======================================================================
|
|
//function : SetAutoNaming
|
|
//purpose :
|
|
//=======================================================================
|
|
void XCAFDoc_ColorTool::SetAutoNaming (Standard_Boolean theIsAutoNaming)
|
|
{
|
|
XCAFDoc_ColorTool_AutoNaming = theIsAutoNaming;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : AutoNaming
|
|
//purpose :
|
|
//=======================================================================
|
|
Standard_Boolean XCAFDoc_ColorTool::AutoNaming()
|
|
{
|
|
return XCAFDoc_ColorTool_AutoNaming;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : BaseLabel
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
TDF_Label XCAFDoc_ColorTool::BaseLabel() const
|
|
{
|
|
return Label();
|
|
}
|
|
//=======================================================================
|
|
//function : ShapeTool
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const Handle(XCAFDoc_ShapeTool)& XCAFDoc_ColorTool::ShapeTool()
|
|
{
|
|
if (myShapeTool.IsNull())
|
|
myShapeTool = XCAFDoc_DocumentTool::ShapeTool(Label());
|
|
return myShapeTool;
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : IsColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::IsColor (const TDF_Label& lab) const
|
|
{
|
|
Quantity_Color C;
|
|
return GetColor ( lab, C );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetColor (const TDF_Label& lab,
|
|
Quantity_Color& col) const
|
|
{
|
|
Quantity_ColorRGBA aCol;
|
|
Standard_Boolean isDone = GetColor(lab, aCol);
|
|
if (isDone)
|
|
col = aCol.GetRGB();
|
|
return isDone;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetColor(const TDF_Label& lab,
|
|
Quantity_ColorRGBA& col) const
|
|
{
|
|
if (lab.Father() != Label()) return Standard_False;
|
|
|
|
Handle(XCAFDoc_Color) ColorAttribute;
|
|
if (!lab.FindAttribute(XCAFDoc_Color::GetID(), ColorAttribute))
|
|
return Standard_False;
|
|
|
|
col = ColorAttribute->GetColorRGBA();
|
|
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : FindColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::FindColor (const Quantity_Color& col, TDF_Label& lab) const
|
|
{
|
|
Quantity_ColorRGBA aCol;
|
|
aCol.SetRGB(col);
|
|
return FindColor(aCol, lab);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : FindColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::FindColor(const Quantity_ColorRGBA& col, TDF_Label& lab) const
|
|
{
|
|
TDF_ChildIDIterator it(Label(), XCAFDoc_Color::GetID());
|
|
for (; it.More(); it.Next()) {
|
|
TDF_Label aLabel = it.Value()->Label();
|
|
Quantity_ColorRGBA C;
|
|
if (!GetColor(aLabel, C)) continue;
|
|
if (C.IsEqual(col)) {
|
|
lab = aLabel;
|
|
return Standard_True;
|
|
}
|
|
}
|
|
return Standard_False;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : FindColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
TDF_Label XCAFDoc_ColorTool::FindColor (const Quantity_ColorRGBA& col) const
|
|
{
|
|
TDF_Label L;
|
|
FindColor ( col, L );
|
|
return L;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : FindColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
TDF_Label XCAFDoc_ColorTool::FindColor(const Quantity_Color& col) const
|
|
{
|
|
TDF_Label L;
|
|
FindColor(col, L);
|
|
return L;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : AddColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
TDF_Label XCAFDoc_ColorTool::AddColor (const Quantity_Color& col) const
|
|
{
|
|
Quantity_ColorRGBA aCol;
|
|
aCol.SetRGB(col);
|
|
return AddColor(aCol);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : AddColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
TDF_Label XCAFDoc_ColorTool::AddColor (const Quantity_ColorRGBA& theColor) const
|
|
{
|
|
TDF_Label aLab;
|
|
if (FindColor (theColor, aLab))
|
|
{
|
|
return aLab;
|
|
}
|
|
|
|
// create a new color entry
|
|
TDF_TagSource aTag;
|
|
aLab = aTag.NewChild (Label());
|
|
XCAFDoc_Color::Set (aLab, theColor);
|
|
|
|
if (XCAFDoc_ColorTool_AutoNaming)
|
|
{
|
|
// set name according to color value
|
|
const NCollection_Vec4<float>& anRgbaF = theColor;
|
|
const NCollection_Vec4<unsigned int> anRgba (anRgbaF * 255.0f);
|
|
char aColorHex[32];
|
|
Sprintf (aColorHex, "%02X%02X%02X%02X", anRgba.r(), anRgba.g(), anRgba.b(), anRgba.a());
|
|
const TCollection_AsciiString aName = TCollection_AsciiString (Quantity_Color::StringName (theColor.GetRGB().Name()))
|
|
+ " (#" + aColorHex + ")";
|
|
TDataStd_Name::Set (aLab, aName);
|
|
}
|
|
|
|
return aLab;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : RemoveColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void XCAFDoc_ColorTool::RemoveColor (const TDF_Label& lab) const
|
|
{
|
|
lab.ForgetAllAttributes (Standard_True);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColors
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void XCAFDoc_ColorTool::GetColors (TDF_LabelSequence& Labels) const
|
|
{
|
|
Labels.Clear();
|
|
|
|
TDF_ChildIDIterator ChildIDIterator(Label(),XCAFDoc_Color::GetID());
|
|
for (; ChildIDIterator.More(); ChildIDIterator.Next()) {
|
|
TDF_Label L = ChildIDIterator.Value()->Label();
|
|
if ( IsColor ( L ) ) Labels.Append ( L );
|
|
}
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void XCAFDoc_ColorTool::SetColor (const TDF_Label& L,
|
|
const TDF_Label& colorL,
|
|
const XCAFDoc_ColorType type) const
|
|
{
|
|
// set reference
|
|
Handle(TDataStd_TreeNode) refNode, mainNode;
|
|
mainNode = TDataStd_TreeNode::Set ( colorL, XCAFDoc::ColorRefGUID(type) );
|
|
refNode = TDataStd_TreeNode::Set ( L, XCAFDoc::ColorRefGUID(type) );
|
|
refNode->Remove(); // abv: fix against bug in TreeNode::Append()
|
|
mainNode->Prepend(refNode);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void XCAFDoc_ColorTool::SetColor (const TDF_Label& L,
|
|
const Quantity_Color& Color,
|
|
const XCAFDoc_ColorType type) const
|
|
{
|
|
TDF_Label colorL = AddColor ( Color );
|
|
SetColor ( L, colorL, type );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void XCAFDoc_ColorTool::SetColor(const TDF_Label& L,
|
|
const Quantity_ColorRGBA& Color,
|
|
const XCAFDoc_ColorType type) const
|
|
{
|
|
TDF_Label colorL = AddColor(Color);
|
|
SetColor(L, colorL, type);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : UnSetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void XCAFDoc_ColorTool::UnSetColor (const TDF_Label& L, const XCAFDoc_ColorType type) const
|
|
{
|
|
L.ForgetAttribute ( XCAFDoc::ColorRefGUID(type) );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : IsSet
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::IsSet (const TDF_Label& L, const XCAFDoc_ColorType type) const
|
|
{
|
|
Handle(TDataStd_TreeNode) Node;
|
|
return L.FindAttribute ( XCAFDoc::ColorRefGUID(type), Node) && Node->HasFather();
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetColor (const TDF_Label& L,
|
|
const XCAFDoc_ColorType type,
|
|
TDF_Label& colorL)
|
|
{
|
|
Handle(TDataStd_TreeNode) Node;
|
|
if ( ! L.FindAttribute ( XCAFDoc::ColorRefGUID(type), Node) ||
|
|
! Node->HasFather() ) return Standard_False;
|
|
colorL = Node->Father()->Label();
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetColor (const TDF_Label& L,
|
|
const XCAFDoc_ColorType type,
|
|
Quantity_Color& color)
|
|
{
|
|
TDF_Label colorL;
|
|
if ( ! GetColor ( L, type, colorL ) ) return Standard_False;
|
|
return GetColor ( colorL, color );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetColor(const TDF_Label& L,
|
|
const XCAFDoc_ColorType type,
|
|
Quantity_ColorRGBA& color)
|
|
{
|
|
TDF_Label colorL;
|
|
if (!GetColor(L, type, colorL)) return Standard_False;
|
|
return GetColor(colorL, color);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::SetColor (const TopoDS_Shape& S,
|
|
const TDF_Label& colorL,
|
|
const XCAFDoc_ColorType type)
|
|
{
|
|
TDF_Label L;
|
|
if ( ! ShapeTool()->Search ( S, L ) ) return Standard_False;
|
|
SetColor ( L, colorL, type );
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::SetColor (const TopoDS_Shape& S,
|
|
const Quantity_Color& Color,
|
|
const XCAFDoc_ColorType type)
|
|
{
|
|
TDF_Label colorL = AddColor ( Color );
|
|
return SetColor ( S, colorL, type );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::SetColor(const TopoDS_Shape& S,
|
|
const Quantity_ColorRGBA& Color,
|
|
const XCAFDoc_ColorType type)
|
|
{
|
|
TDF_Label colorL = AddColor(Color);
|
|
return SetColor(S, colorL, type);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : UnSetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::UnSetColor (const TopoDS_Shape& S,
|
|
const XCAFDoc_ColorType type)
|
|
{
|
|
TDF_Label L;
|
|
if ( ! ShapeTool()->Search ( S, L ) ) return Standard_False;
|
|
UnSetColor ( L, type );
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : IsSet
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::IsSet (const TopoDS_Shape& S,
|
|
const XCAFDoc_ColorType type)
|
|
{
|
|
TDF_Label L;
|
|
if ( ! ShapeTool()->Search ( S, L ) ) return Standard_False;
|
|
return IsSet ( L, type );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetColor (const TopoDS_Shape& S,
|
|
const XCAFDoc_ColorType type,
|
|
TDF_Label& colorL)
|
|
{
|
|
TDF_Label L;
|
|
if ( ! ShapeTool()->Search ( S, L ) ) return Standard_False;
|
|
return GetColor ( L, type, colorL );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetColor (const TopoDS_Shape& S,
|
|
const XCAFDoc_ColorType type,
|
|
Quantity_Color& color)
|
|
{
|
|
TDF_Label colorL;
|
|
if ( ! GetColor ( S, type, colorL ) ) return Standard_False;
|
|
return GetColor ( colorL, color );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetColor(const TopoDS_Shape& S,
|
|
const XCAFDoc_ColorType type,
|
|
Quantity_ColorRGBA& color)
|
|
{
|
|
TDF_Label colorL;
|
|
if (!GetColor(S, type, colorL)) return Standard_False;
|
|
return GetColor(colorL, color);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetID
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const Standard_GUID& XCAFDoc_ColorTool::GetID()
|
|
{
|
|
static Standard_GUID ColorTblID ("efd212ed-6dfd-11d4-b9c8-0060b0ee281b");
|
|
return ColorTblID;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Set
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Handle(XCAFDoc_ColorTool) XCAFDoc_ColorTool::Set(const TDF_Label& L)
|
|
{
|
|
Handle(XCAFDoc_ColorTool) A;
|
|
if (!L.FindAttribute (XCAFDoc_ColorTool::GetID(), A)) {
|
|
A = new XCAFDoc_ColorTool ();
|
|
L.AddAttribute(A);
|
|
A->myShapeTool = XCAFDoc_DocumentTool::ShapeTool(L);
|
|
}
|
|
return A;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : ID
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const Standard_GUID& XCAFDoc_ColorTool::ID() const
|
|
{
|
|
return GetID();
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : XCAFDoc_ColorTool
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
XCAFDoc_ColorTool::XCAFDoc_ColorTool()
|
|
{
|
|
}
|
|
|
|
// PTV 23.01.2003 add visibility flag for objects (CAX-IF TRJ11)
|
|
//=======================================================================
|
|
//function : IsVisible
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::IsVisible (const TDF_Label& L) const
|
|
{
|
|
Handle(TDataStd_UAttribute) aUAttr;
|
|
return (!L.FindAttribute(XCAFDoc::InvisibleGUID(), aUAttr));
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetVisibility
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void XCAFDoc_ColorTool::SetVisibility (const TDF_Label& L,
|
|
const Standard_Boolean isvisible)
|
|
{
|
|
Handle(TDataStd_UAttribute) aUAttr;
|
|
if (! isvisible ) {
|
|
Handle(XCAFDoc_GraphNode) aSHUO;
|
|
if (ShapeTool()->IsShape(L) || ShapeTool()->GetSHUO( L, aSHUO ) )
|
|
if (!L.FindAttribute(XCAFDoc::InvisibleGUID(), aUAttr))
|
|
TDataStd_UAttribute::Set( L, XCAFDoc::InvisibleGUID() );
|
|
}
|
|
else L.ForgetAttribute( XCAFDoc::InvisibleGUID() );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : IsColorByLayer
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::IsColorByLayer (const TDF_Label& L) const
|
|
{
|
|
Handle(TDataStd_UAttribute) aUAttr;
|
|
return L.FindAttribute(XCAFDoc::ColorByLayerGUID(), aUAttr);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetColorByLayer
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void XCAFDoc_ColorTool::SetColorByLayer (const TDF_Label& L,
|
|
const Standard_Boolean isColorByLayer)
|
|
{
|
|
Handle(TDataStd_UAttribute) aUAttr;
|
|
if ( isColorByLayer ) {
|
|
Handle(XCAFDoc_GraphNode) aSHUO;
|
|
if (ShapeTool()->IsShape(L) || ShapeTool()->GetSHUO( L, aSHUO ) )
|
|
if (!L.FindAttribute(XCAFDoc::ColorByLayerGUID(), aUAttr))
|
|
TDataStd_UAttribute::Set( L, XCAFDoc::ColorByLayerGUID() );
|
|
}
|
|
else L.ForgetAttribute( XCAFDoc::ColorByLayerGUID() );
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetInstanceColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::SetInstanceColor (const TopoDS_Shape& theShape,
|
|
const XCAFDoc_ColorType type,
|
|
const Quantity_Color& color,
|
|
const Standard_Boolean IsCreateSHUO)
|
|
{
|
|
Quantity_ColorRGBA aCol;
|
|
aCol.SetRGB(color);
|
|
return SetInstanceColor(theShape, type, aCol, IsCreateSHUO);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetInstanceColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::SetInstanceColor(const TopoDS_Shape& theShape,
|
|
const XCAFDoc_ColorType type,
|
|
const Quantity_ColorRGBA& color,
|
|
const Standard_Boolean IsCreateSHUO)
|
|
{
|
|
// find shuo label structure
|
|
TDF_LabelSequence aLabels;
|
|
if (!ShapeTool()->FindComponent(theShape, aLabels))
|
|
return Standard_False;
|
|
Handle(XCAFDoc_GraphNode) aSHUO;
|
|
// set the SHUO structure for this component if it is not exist
|
|
if (!ShapeTool()->FindSHUO(aLabels, aSHUO)) {
|
|
if (aLabels.Length() == 1) {
|
|
// set color directly for component as NAUO
|
|
SetColor(aLabels.Value(1), color, type);
|
|
return Standard_True;
|
|
}
|
|
else if (!IsCreateSHUO || !ShapeTool()->SetSHUO(aLabels, aSHUO)) {
|
|
return Standard_False;
|
|
}
|
|
}
|
|
TDF_Label aSHUOLabel = aSHUO->Label();
|
|
SetColor(aSHUOLabel, color, type);
|
|
return Standard_True;
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : GetInstanceColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetInstanceColor (const TopoDS_Shape& theShape,
|
|
const XCAFDoc_ColorType type,
|
|
Quantity_Color& color)
|
|
{
|
|
Quantity_ColorRGBA aCol;
|
|
Standard_Boolean isDone = GetInstanceColor(theShape, type, aCol);
|
|
if (isDone)
|
|
color = aCol.GetRGB();
|
|
return isDone;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetInstanceColor
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::GetInstanceColor(const TopoDS_Shape& theShape,
|
|
const XCAFDoc_ColorType type,
|
|
Quantity_ColorRGBA& color)
|
|
{
|
|
// find shuo label structure
|
|
TDF_LabelSequence aLabels;
|
|
if (!ShapeTool()->FindComponent(theShape, aLabels))
|
|
return Standard_False;
|
|
Handle(XCAFDoc_GraphNode) aSHUO;
|
|
// get shuo from document by label structure
|
|
TDF_Label aCompLab = aLabels.Value(aLabels.Length());
|
|
while (aLabels.Length() > 1) {
|
|
if (!ShapeTool()->FindSHUO(aLabels, aSHUO)) {
|
|
// try to find other shuo
|
|
aLabels.Remove(aLabels.Length());
|
|
continue;
|
|
}
|
|
else {
|
|
TDF_Label aSHUOLabel = aSHUO->Label();
|
|
if (GetColor(aSHUOLabel, type, color))
|
|
return Standard_True;
|
|
else
|
|
// try to find other shuo
|
|
aLabels.Remove(aLabels.Length());
|
|
}
|
|
}
|
|
// attempt to get color exactly of component
|
|
if (GetColor(aCompLab, type, color))
|
|
return Standard_True;
|
|
|
|
// attempt to get color of solid
|
|
TopLoc_Location aLoc;
|
|
TopoDS_Shape S0 = theShape;
|
|
S0.Location(aLoc);
|
|
TDF_Label aRefLab = ShapeTool()->FindShape(S0);
|
|
if (!aRefLab.IsNull())
|
|
return GetColor(aRefLab, type, color);
|
|
// no color assigned
|
|
return Standard_False;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : IsInstanceVisible
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::IsInstanceVisible (const TopoDS_Shape& theShape)
|
|
{
|
|
// check visibility status of top-level solid, cause it is have highest priority
|
|
TopLoc_Location NullLoc;
|
|
TopoDS_Shape S0 = theShape;
|
|
S0.Location( NullLoc );
|
|
TDF_Label aRefL = ShapeTool()->FindShape( S0 );
|
|
if (!aRefL.IsNull() && !IsVisible(aRefL))
|
|
return Standard_False;
|
|
// find shuo label structure
|
|
TDF_LabelSequence aLabels;
|
|
if ( !ShapeTool()->FindComponent( theShape, aLabels ) )
|
|
return Standard_True;
|
|
TDF_Label aCompLab = aLabels.Value(aLabels.Length());
|
|
// visibility status of component withouts SHUO.
|
|
if (!IsVisible( aCompLab ))
|
|
return Standard_False;
|
|
// check by SHUO structure
|
|
TDF_LabelSequence aCurLabels;
|
|
aCurLabels.Append(aCompLab);
|
|
Standard_Integer i = aLabels.Length() - 1;
|
|
// while (aCurLabels.Length() < aLabels.Length()) {
|
|
while (i >= 1) {
|
|
aCurLabels.Prepend( aLabels.Value(i--) );
|
|
// get shuo from document by label structure
|
|
Handle(XCAFDoc_GraphNode) aSHUO;
|
|
if ( !ShapeTool()->FindSHUO( aCurLabels, aSHUO ) )
|
|
continue;
|
|
if ( !IsVisible(aSHUO->Label()) )
|
|
return Standard_False;
|
|
}
|
|
return Standard_True; //visible, cause cannot find invisibility status
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : ReverseTreeNodes
|
|
//purpose : auxilary
|
|
//=======================================================================
|
|
static void ReverseTreeNodes(Handle(TDataStd_TreeNode)& mainNode)
|
|
{
|
|
if(mainNode->HasFirst()) {
|
|
Handle(TDataStd_TreeNode) tmpNode;
|
|
Handle(TDataStd_TreeNode) pNode = mainNode->First();
|
|
Handle(TDataStd_TreeNode) nNode = pNode->Next();
|
|
while(!nNode.IsNull()) {
|
|
tmpNode = pNode->Previous();
|
|
pNode->SetPrevious(nNode);
|
|
pNode->SetNext(tmpNode);
|
|
pNode = nNode;
|
|
nNode = pNode->Next();
|
|
}
|
|
tmpNode = pNode->Previous();
|
|
pNode->SetPrevious(nNode);
|
|
pNode->SetNext(tmpNode);
|
|
mainNode->SetFirst(pNode);
|
|
}
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : ReverseChainsOfTreeNodes
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean XCAFDoc_ColorTool::ReverseChainsOfTreeNodes()
|
|
{
|
|
TDF_ChildIDIterator it(Label(),XCAFDoc_Color::GetID());
|
|
for (; it.More(); it.Next()) {
|
|
TDF_Label aLabel = it.Value()->Label();
|
|
Handle(TDataStd_TreeNode) mainNode;
|
|
if(aLabel.FindAttribute(XCAFDoc::ColorRefGUID(XCAFDoc_ColorSurf),mainNode)) {
|
|
ReverseTreeNodes(mainNode);
|
|
}
|
|
if(aLabel.FindAttribute(XCAFDoc::ColorRefGUID(XCAFDoc_ColorCurv),mainNode)) {
|
|
ReverseTreeNodes(mainNode);
|
|
}
|
|
if(aLabel.FindAttribute(XCAFDoc::ColorRefGUID(XCAFDoc_ColorGen),mainNode)) {
|
|
ReverseTreeNodes(mainNode);
|
|
}
|
|
}
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : DumpJson
|
|
//purpose :
|
|
//=======================================================================
|
|
void XCAFDoc_ColorTool::DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth) const
|
|
{
|
|
OCCT_DUMP_TRANSIENT_CLASS_BEGIN (theOStream)
|
|
|
|
OCCT_DUMP_BASE_CLASS (theOStream, theDepth, TDF_Attribute)
|
|
|
|
TDF_LabelSequence aLabels;
|
|
GetColors (aLabels);
|
|
for (TDF_LabelSequence::Iterator aColorLabelIt (aLabels); aColorLabelIt.More(); aColorLabelIt.Next())
|
|
{
|
|
TCollection_AsciiString aColorLabel;
|
|
TDF_Tool::Entry (aColorLabelIt.Value(), aColorLabel);
|
|
OCCT_DUMP_FIELD_VALUE_STRING (theOStream, aColorLabel)
|
|
}
|
|
}
|