mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-06-20 11:54:07 +03:00
Possibility for adding LengthUnit info to XCAF document using special class XCAFDoc_LenghtUnit and XCAFDoc_LenghtUnitTool is implemented. Package UnitsMethods is split: geom methods were placed to new file GeomConvert_Units which is in the toolkit TKXSBase, internal step scale factors was placed to StepData. Updated UnitMethods to convert scale factor to different unit types. Now, XSAlgo::XSAlgo_AlgoContainer is used to update unit info from static interface values. New Draw command "XSetLengthUnit" and "XGetLengthUnit" for set or get XDE attribute. Upgraded tests for STEP, IGES, OBJ, glTF, VRML formats to check area regressing with used unit. Upgraded tests\de test cases to use any units in the "loop back" algorithms.
91 lines
3.1 KiB
C++
91 lines
3.1 KiB
C++
// Created on: 1994-09-02
|
|
// Created by: Frederic MAUPAS
|
|
// Copyright (c) 1994-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 <Geom2d_Ellipse.hxx>
|
|
#include <Geom_Ellipse.hxx>
|
|
#include <GeomToStep_MakeAxis2Placement2d.hxx>
|
|
#include <GeomToStep_MakeAxis2Placement3d.hxx>
|
|
#include <GeomToStep_MakeEllipse.hxx>
|
|
#include <gp_Elips.hxx>
|
|
#include <gp_Elips2d.hxx>
|
|
#include <StdFail_NotDone.hxx>
|
|
#include <StepData_GlobalFactors.hxx>
|
|
#include <StepGeom_Axis2Placement2d.hxx>
|
|
#include <StepGeom_Axis2Placement3d.hxx>
|
|
#include <StepGeom_Ellipse.hxx>
|
|
#include <TCollection_HAsciiString.hxx>
|
|
|
|
//=============================================================================
|
|
// Creation d'une ellipse de prostep a partir d'une ellipse 3d de gp
|
|
//=============================================================================
|
|
GeomToStep_MakeEllipse::GeomToStep_MakeEllipse( const gp_Elips& E)
|
|
{
|
|
#include "GeomToStep_MakeEllipse_gen.pxx"
|
|
}
|
|
|
|
|
|
//=============================================================================
|
|
// Creation d'une ellipse de prostep a partir d'une ellipse de
|
|
// Geom
|
|
//=============================================================================
|
|
|
|
GeomToStep_MakeEllipse::GeomToStep_MakeEllipse( const Handle(Geom_Ellipse)& Cer)
|
|
{
|
|
gp_Elips E;
|
|
E = Cer->Elips();
|
|
#include "GeomToStep_MakeEllipse_gen.pxx"
|
|
}
|
|
|
|
|
|
//=============================================================================
|
|
// Creation d'une ellipse 2d de prostep a partir d'une ellipse de
|
|
// Geom2d
|
|
//=============================================================================
|
|
|
|
GeomToStep_MakeEllipse::GeomToStep_MakeEllipse( const Handle(Geom2d_Ellipse)& Cer)
|
|
{
|
|
gp_Elips2d E2d;
|
|
E2d = Cer->Elips2d();
|
|
|
|
Handle(StepGeom_Ellipse) EStep = new StepGeom_Ellipse;
|
|
StepGeom_Axis2Placement Ax2;
|
|
Handle(StepGeom_Axis2Placement2d) Ax2Step;
|
|
Standard_Real majorR, minorR;
|
|
|
|
GeomToStep_MakeAxis2Placement2d MkAxis2(E2d.Axis());
|
|
Ax2Step = MkAxis2.Value();
|
|
majorR = E2d.MajorRadius();
|
|
minorR = E2d.MinorRadius();
|
|
Ax2.SetValue(Ax2Step);
|
|
Handle(TCollection_HAsciiString) name = new TCollection_HAsciiString("");
|
|
EStep->Init(name, Ax2, majorR, minorR);
|
|
theEllipse = EStep;
|
|
done = Standard_True;
|
|
|
|
}
|
|
|
|
//=============================================================================
|
|
// renvoi des valeurs
|
|
//=============================================================================
|
|
|
|
const Handle(StepGeom_Ellipse) &
|
|
GeomToStep_MakeEllipse::Value() const
|
|
{
|
|
StdFail_NotDone_Raise_if (!done, "GeomToStep_MakeEllipse::Value() - no result");
|
|
return theEllipse;
|
|
}
|