mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-02-09 03:53:08 +05:00
138 lines
5.0 KiB
C++
138 lines
5.0 KiB
C++
// This file is generated by WOK (CPPExt).
|
|
// Please do not edit this file; modify original file instead.
|
|
// The copyright and license terms as defined for the original file apply to
|
|
// this header file considered to be the "object code" form of the original source.
|
|
|
|
#ifndef _BRepBuilderAPI_GTransform_21423_HeaderFile
|
|
#define _BRepBuilderAPI_GTransform_21423_HeaderFile
|
|
|
|
#ifndef _Standard_HeaderFile
|
|
#include <Standard.hxx>
|
|
#endif
|
|
#ifndef _Standard_Macro_HeaderFile
|
|
#include <Standard_Macro.hxx>
|
|
#endif
|
|
|
|
#ifndef _gp_GTrsf_HeaderFile
|
|
#include <gp_GTrsf.hxx>
|
|
#endif
|
|
#ifndef _Standard_Boolean_HeaderFile
|
|
#include <Standard_Boolean.hxx>
|
|
#endif
|
|
#ifndef _BRepBuilderAPI_Collect_HeaderFile
|
|
#include <BRepBuilderAPI_Collect.hxx>
|
|
#endif
|
|
#ifndef _BRepBuilderAPI_ModifyShape_21423_HeaderFile
|
|
#include <BRepBuilderAPI_ModifyShape_21423.hxx>
|
|
#endif
|
|
class Standard_NoSuchObject;
|
|
class gp_GTrsf;
|
|
class TopoDS_Shape;
|
|
class TopTools_ListOfShape;
|
|
|
|
|
|
//! Geometric transformation on a shape. <br>
|
|
//! The transformation to be applied is defined as a gp_GTrsf <br>
|
|
//! transformation. It may be: <br>
|
|
//! - a transformation equivalent to a gp_Trsf transformation, the <br>
|
|
//! most common case: you should , however, use a BRepAPI_Transform <br>
|
|
//! object to perform this kind of transformation; or <br>
|
|
//! - an affinity, or <br>
|
|
//! - more generally, any type of point transformation which may <br>
|
|
//! be defined by a three row, four column matrix of transformation. <br>
|
|
//! In the last two cases, the underlying geometry of the <br>
|
|
//! following shapes may change: <br>
|
|
//! - a curve which supports an edge of the shape, or <br>
|
|
//! - a surface which supports a face of the shape; <br>
|
|
//! For example, a circle may be transformed into an ellipse when <br>
|
|
//! applying an affinity transformation. <br>
|
|
//! The transformation is applied to: <br>
|
|
//! - all the curves which support edges of the shape, and <br>
|
|
//! - all the surfaces which support faces of the shape. <br>
|
|
//! A GTransform object provides a framework for: <br>
|
|
//! - defining the geometric transformation to be applied, <br>
|
|
//! - implementing the transformation algorithm, and <br>
|
|
//! - consulting the result. <br>
|
|
class BRepBuilderAPI_GTransform_21423 : public BRepBuilderAPI_ModifyShape_21423 {
|
|
public:
|
|
|
|
void* operator new(size_t,void* anAddress)
|
|
{
|
|
return anAddress;
|
|
}
|
|
void* operator new(size_t size)
|
|
{
|
|
return Standard::Allocate(size);
|
|
}
|
|
void operator delete(void *anAddress)
|
|
{
|
|
if (anAddress) Standard::Free((Standard_Address&)anAddress);
|
|
}
|
|
|
|
//! Constructs a framework for applying the geometric <br>
|
|
//! transformation T to a shape. Use the function <br>
|
|
//! Perform to define the shape to transform. <br>
|
|
Standard_EXPORT BRepBuilderAPI_GTransform_21423(const gp_GTrsf& T);
|
|
//! Constructs a framework for applying the geometric <br>
|
|
//! transformation T to a shape, and applies it to the shape S. <br>
|
|
//! - If the transformation T is direct and isometric (i.e. if <br>
|
|
//! the determinant of the vectorial part of T is equal to <br>
|
|
//! 1.), and if Copy equals false (default value), the <br>
|
|
//! resulting shape is the same as the original but with <br>
|
|
//! a new location assigned to it. <br>
|
|
//! - In all other cases, the transformation is applied to <br>
|
|
//! a duplicate of S. <br>
|
|
//! Use the function Shape to access the result. <br>
|
|
//! Note: the constructed framework can be reused to <br>
|
|
//! apply the same geometric transformation to other <br>
|
|
//! shapes: just specify them with the function Perform. <br>
|
|
Standard_EXPORT BRepBuilderAPI_GTransform_21423(const TopoDS_Shape& S,const gp_GTrsf& T,const Standard_Boolean Copy = Standard_False);
|
|
//! Applies the geometric transformation defined at the <br>
|
|
//! time of construction of this framework to the shape S. <br>
|
|
//! - If the transformation T is direct and isometric (i.e. if <br>
|
|
//! the determinant of the vectorial part of T is equal to <br>
|
|
//! 1.), and if Copy equals false (default value), the <br>
|
|
//! resulting shape is the same as the original but with <br>
|
|
//! a new location assigned to it. <br>
|
|
//! - In all other cases, the transformation is applied to a duplicate of S. <br>
|
|
//! Use the function Shape to access the result. <br>
|
|
//! Note: this framework can be reused to apply the same <br>
|
|
//! geometric transformation to other shapes: just specify <br>
|
|
//! them by calling the function Perform again. <br>
|
|
Standard_EXPORT void Perform(const TopoDS_Shape& S,const Standard_Boolean Copy = Standard_False) ;
|
|
//! Returns the list of shapes modified from the shape <br>
|
|
//! <S>. <br>
|
|
Standard_EXPORT virtual const TopTools_ListOfShape& Modified(const TopoDS_Shape& S) ;
|
|
//! Returns the modified shape corresponding to <S>. <br>
|
|
Standard_EXPORT virtual const TopoDS_Shape& ModifiedShape(const TopoDS_Shape& S) const;
|
|
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
gp_GTrsf myGTrsf;
|
|
Standard_Boolean myUseModif;
|
|
BRepBuilderAPI_Collect myHist;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// other Inline functions and methods (like "C++: function call" methods)
|
|
|
|
|
|
#endif
|