mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-09 18:50:54 +03:00
Automatic upgrade of OCCT code by command "occt_upgrade . -nocdl": - WOK-generated header files from inc and sources from drv are moved to src - CDL files removed - All packages are converted to nocdlpack
166 lines
5.7 KiB
C++
166 lines
5.7 KiB
C++
// Created on: 1998-07-30
|
|
// Created by: Pavel DURANDIN <pdn@nnov.matra-dtv.fr>
|
|
// Copyright (c) 1998-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.
|
|
|
|
#ifndef _ShapeAnalysis_FreeBoundsProperties_HeaderFile
|
|
#define _ShapeAnalysis_FreeBoundsProperties_HeaderFile
|
|
|
|
#include <Standard.hxx>
|
|
#include <Standard_DefineAlloc.hxx>
|
|
#include <Standard_Handle.hxx>
|
|
|
|
#include <TopoDS_Shape.hxx>
|
|
#include <Standard_Real.hxx>
|
|
#include <Standard_Boolean.hxx>
|
|
#include <ShapeAnalysis_HSequenceOfFreeBounds.hxx>
|
|
#include <Standard_Integer.hxx>
|
|
class TopoDS_Shape;
|
|
class ShapeAnalysis_FreeBoundData;
|
|
class TopoDS_Wire;
|
|
|
|
|
|
//! This class is intended to calculate shape free bounds
|
|
//! properties.
|
|
//! This class provides the following functionalities:
|
|
//! - calculates area of the contour,
|
|
//! - calculates perimeter of the contour,
|
|
//! - calculates ratio of average length to average width of the
|
|
//! contour,
|
|
//! - estimates average width of contour,
|
|
//! - finds the notches (narrow 'V'-like sub-contour) on the
|
|
//! contour.
|
|
//!
|
|
//! For getting free bounds this class uses
|
|
//! ShapeAnalysis_FreeBounds class.
|
|
//!
|
|
//! For description of parameters used for initializing this
|
|
//! class refer to CDL of ShapeAnalysis_FreeBounds.
|
|
//!
|
|
//! Properties of each contour are stored in the data structure
|
|
//! ShapeAnalysis_FreeBoundData.
|
|
class ShapeAnalysis_FreeBoundsProperties
|
|
{
|
|
public:
|
|
|
|
DEFINE_STANDARD_ALLOC
|
|
|
|
|
|
//! Empty constructor
|
|
Standard_EXPORT ShapeAnalysis_FreeBoundsProperties();
|
|
|
|
//! Creates the object and calls corresponding Init.
|
|
//! <shape> should be a compound of faces.
|
|
Standard_EXPORT ShapeAnalysis_FreeBoundsProperties(const TopoDS_Shape& shape, const Standard_Real tolerance, const Standard_Boolean splitclosed = Standard_False, const Standard_Boolean splitopen = Standard_False);
|
|
|
|
//! Creates the object and calls corresponding Init.
|
|
//! <shape> should be a compound of shells.
|
|
Standard_EXPORT ShapeAnalysis_FreeBoundsProperties(const TopoDS_Shape& shape, const Standard_Boolean splitclosed = Standard_False, const Standard_Boolean splitopen = Standard_False);
|
|
|
|
//! Initializes the object with given parameters.
|
|
//! <shape> should be a compound of faces.
|
|
Standard_EXPORT void Init (const TopoDS_Shape& shape, const Standard_Real tolerance, const Standard_Boolean splitclosed = Standard_False, const Standard_Boolean splitopen = Standard_False);
|
|
|
|
//! Initializes the object with given parameters.
|
|
//! <shape> should be a compound of shells.
|
|
Standard_EXPORT void Init (const TopoDS_Shape& shape, const Standard_Boolean splitclosed = Standard_False, const Standard_Boolean splitopen = Standard_False);
|
|
|
|
//! Builds and analyzes free bounds of the shape.
|
|
//! First calls ShapeAnalysis_FreeBounds for building free
|
|
//! bounds.
|
|
//! Then on each free bound computes its properties:
|
|
//! - area of the contour,
|
|
//! - perimeter of the contour,
|
|
//! - ratio of average length to average width of the contour,
|
|
//! - average width of contour,
|
|
//! - notches on the contour and for each notch
|
|
//! - maximum width of the notch.
|
|
Standard_EXPORT Standard_Boolean Perform();
|
|
|
|
//! Returns True if shape is loaded
|
|
Standard_Boolean IsLoaded() const;
|
|
|
|
//! Returns shape
|
|
TopoDS_Shape Shape() const;
|
|
|
|
//! Returns tolerance
|
|
Standard_Real Tolerance() const;
|
|
|
|
//! Returns number of free bounds
|
|
Standard_Integer NbFreeBounds() const;
|
|
|
|
//! Returns number of closed free bounds
|
|
Standard_Integer NbClosedFreeBounds() const;
|
|
|
|
//! Returns number of open free bounds
|
|
Standard_Integer NbOpenFreeBounds() const;
|
|
|
|
//! Returns all closed free bounds
|
|
Handle(ShapeAnalysis_HSequenceOfFreeBounds) ClosedFreeBounds() const;
|
|
|
|
//! Returns all open free bounds
|
|
Handle(ShapeAnalysis_HSequenceOfFreeBounds) OpenFreeBounds() const;
|
|
|
|
//! Returns properties of closed free bound specified by its rank
|
|
//! number
|
|
Handle(ShapeAnalysis_FreeBoundData) ClosedFreeBound (const Standard_Integer index) const;
|
|
|
|
//! Returns properties of open free bound specified by its rank
|
|
//! number
|
|
Handle(ShapeAnalysis_FreeBoundData) OpenFreeBound (const Standard_Integer index) const;
|
|
|
|
Standard_EXPORT Standard_Boolean DispatchBounds();
|
|
|
|
Standard_EXPORT Standard_Boolean CheckContours (const Standard_Real prec = 0.0);
|
|
|
|
Standard_EXPORT Standard_Boolean CheckNotches (const Standard_Real prec = 0.0);
|
|
|
|
Standard_EXPORT Standard_Boolean CheckNotches (Handle(ShapeAnalysis_FreeBoundData)& fbData, const Standard_Real prec = 0.0);
|
|
|
|
Standard_EXPORT Standard_Boolean CheckNotches (const TopoDS_Wire& freebound, const Standard_Integer num, TopoDS_Wire& notch, Standard_Real& distMax, const Standard_Real prec = 0.0);
|
|
|
|
Standard_EXPORT Standard_Boolean FillProperties (Handle(ShapeAnalysis_FreeBoundData)& fbData, const Standard_Real prec = 0.0);
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
TopoDS_Shape myShape;
|
|
Standard_Real myTolerance;
|
|
Standard_Boolean mySplitClosed;
|
|
Standard_Boolean mySplitOpen;
|
|
Handle(ShapeAnalysis_HSequenceOfFreeBounds) myClosedFreeBounds;
|
|
Handle(ShapeAnalysis_HSequenceOfFreeBounds) myOpenFreeBounds;
|
|
|
|
|
|
};
|
|
|
|
|
|
#include <ShapeAnalysis_FreeBoundsProperties.lxx>
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _ShapeAnalysis_FreeBoundsProperties_HeaderFile
|