1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00
occt/src/ShapeProcessAPI/ShapeProcessAPI_ApplySequence.cxx
kgv b2d1851c43 0029814: Modeling Data - add method TopoDS_Shape::NbChildren() for simple check of sub-shapes number
TopoDS_Shape::NbChildren() - new method has been introduced.
TopoDS_Shape.lxx, TopoDS_TShape.lxx - inline methods have been moved to hxx.
TopoDS_TShape_Flags has been redeclared as enumeration instead of preprocessor macros.

Cyclic dependency between headers TopoDS_Shape.hxx and TopoDS_TShape.hxx eliminated.

Places where TopoDS_Iterator is used only for calculation of number of sub-shapes are updated to use NbChildren() instead
2018-06-14 14:03:09 +03:00

165 lines
6.0 KiB
C++

// Created on: 1999-06-22
// Created by: data exchange team
// Copyright (c) 1999-1999 Matra Datavision
// 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 <Message_Messenger.hxx>
#include <Message_Msg.hxx>
#include <Resource_Manager.hxx>
#include <ShapeProcess.hxx>
#include <ShapeProcess_OperLibrary.hxx>
#include <ShapeProcess_ShapeContext.hxx>
#include <ShapeProcessAPI_ApplySequence.hxx>
#include <TCollection_AsciiString.hxx>
#include <TopoDS_Shape.hxx>
#include <TopTools_DataMapIteratorOfDataMapOfShapeShape.hxx>
//=======================================================================
//function : ShapeProcessAPI_ApplySequence
//purpose :
//=======================================================================
ShapeProcessAPI_ApplySequence::ShapeProcessAPI_ApplySequence(const Standard_CString rscName,
const Standard_CString seqName)
{
myContext = new ShapeProcess_ShapeContext(rscName);
myContext->SetDetalisation ( TopAbs_FACE );
TCollection_AsciiString str ( seqName );
// initialize operators
ShapeProcess_OperLibrary::Init ();
mySeq = str;
}
//=======================================================================
//function : Context
//purpose :
//=======================================================================
Handle(ShapeProcess_ShapeContext)& ShapeProcessAPI_ApplySequence::Context()
{
return myContext;
}
//=======================================================================
//function : PrepareShape
//purpose :
//=======================================================================
TopoDS_Shape ShapeProcessAPI_ApplySequence::PrepareShape(const TopoDS_Shape& shape,
const Standard_Boolean /*fillmap*/,
const TopAbs_ShapeEnum /*until*/)
{
if (shape.IsNull())
return shape;
Handle(Resource_Manager) rsc = myContext->ResourceManager();
myContext->Init(shape);
TCollection_AsciiString str(mySeq);
str += ".exec.op";
if ( rsc->Find ( str.ToCString() ) ) {
ShapeProcess::Perform ( myContext, mySeq.ToCString() );
}
return myContext->Result();
}
//=======================================================================
//function : ClearMap
//purpose :
//=======================================================================
void ShapeProcessAPI_ApplySequence::ClearMap()
{
//myContext->Map().Clear();
}
//=======================================================================
//function : Map
//purpose :
//=======================================================================
const TopTools_DataMapOfShapeShape& ShapeProcessAPI_ApplySequence::Map() const
{
return myContext->Map();
}
//=======================================================================
//function : PrintPreparationResult
//purpose :
//=======================================================================
void ShapeProcessAPI_ApplySequence::PrintPreparationResult () const
{
Standard_Integer SS = 0, SN = 0, FF = 0, FS = 0, FN = 0;
for (TopTools_DataMapIteratorOfDataMapOfShapeShape It (myContext->Map()); It.More(); It.Next()) {
TopoDS_Shape keyshape = It.Key(), valueshape = It.Value();
if (keyshape.ShapeType() == TopAbs_SHELL) {
if (valueshape.IsNull()) SN++;
else SS++;
}
else if (keyshape.ShapeType() == TopAbs_FACE) {
if (valueshape.IsNull()) FN++;
else if (valueshape.ShapeType() == TopAbs_SHELL) FS++;
else FF++;
}
}
Handle(Message_Messenger) aMessenger = myContext->Messenger();
// mapping
Message_Msg EPMSG100 ("PrResult.Print.MSG100"); //Mapping:
aMessenger->Send (EPMSG100, Message_Info, Standard_True);
Message_Msg TPMSG50 ("PrResult.Print.MSG50"); // Shells:
aMessenger->Send (TPMSG50, Message_Info, Standard_True);
Message_Msg EPMSG110 ("PrResult.Print.MSG110"); // Result is Shell : %d
EPMSG110.Arg (SS);
aMessenger->Send (EPMSG110, Message_Info, Standard_True);
Message_Msg EPMSG150 ("PrResult.Print.MSG150"); // No Result : %d
EPMSG150.Arg (SN);
aMessenger->Send (EPMSG150, Message_Info, Standard_True);
TCollection_AsciiString tmp110 (EPMSG110.Original()), tmp150 (EPMSG150.Original());
EPMSG110.Set (tmp110.ToCString());
EPMSG150.Set (tmp150.ToCString());
Message_Msg TPMSG55 ("PrResult.Print.MSG55"); // Faces:
aMessenger->Send (TPMSG55, Message_Info, Standard_True);
Message_Msg EPMSG115 ("PrResult.Print.MSG115"); // Result is Face : %d
EPMSG115.Arg (FF);
aMessenger->Send (EPMSG115, Message_Info, Standard_True);
EPMSG110.Arg (FS);
aMessenger->Send (EPMSG110, Message_Info, Standard_True);
EPMSG150.Arg (FN);
aMessenger->Send (EPMSG150, Message_Info, Standard_True);
// preparation ratio
Standard_Real SPR = 1, FPR = 1;
Standard_Integer STotalR = SS, FTotalR = FF + FS;
Standard_Integer NbS = STotalR + SN, NbF = FTotalR + FN;
if (NbS > 0) SPR = 1. * (NbS - SN) / NbS;
if (NbF > 0) FPR = 1. * (NbF - FN) / NbF;
Message_Msg PMSG200 ("PrResult.Print.MSG200"); //Preparation ratio:
aMessenger->Send (PMSG200, Message_Info, Standard_True);
Message_Msg PMSG205 ("PrResult.Print.MSG205"); // Shells: %d per cent
PMSG205.Arg ((Standard_Integer) (100 * SPR));
aMessenger->Send (PMSG205, Message_Info, Standard_True);
Message_Msg PMSG210 ("PrResult.Print.MSG210"); // Faces : %d per cent
PMSG210.Arg ((Standard_Integer) (100 * FPR));
aMessenger->Send (PMSG210, Message_Info, Standard_True);
}