mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
- new STEP entities for Saved Views - import of STEP Saved Views - new XCAF tool for clipping planes - new draw commands - update test
302 lines
9.8 KiB
C++
302 lines
9.8 KiB
C++
// Created on: 2016-10-19
|
|
// Created by: Irina KRYLOVA
|
|
// Copyright (c) 2016 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_View.hxx>
|
|
|
|
#include <Standard_GUID.hxx>
|
|
#include <TDataStd_AsciiString.hxx>
|
|
#include <TDataStd_Integer.hxx>
|
|
#include <TDataStd_Real.hxx>
|
|
#include <TDataStd_RealArray.hxx>
|
|
#include <TDataXtd_Axis.hxx>
|
|
#include <TDataXtd_Geometry.hxx>
|
|
#include <TDataXtd_Plane.hxx>
|
|
#include <TDataXtd_Point.hxx>
|
|
#include <TDF_ChildIterator.hxx>
|
|
#include <TColStd_HArray1OfReal.hxx>
|
|
#include <XCAFDoc.hxx>
|
|
#include <XCAFView_Object.hxx>
|
|
|
|
IMPLEMENT_STANDARD_RTTIEXT(XCAFDoc_View, TDF_Attribute)
|
|
|
|
enum ChildLab
|
|
{
|
|
ChildLab_Name = 1,
|
|
ChildLab_Type,
|
|
ChildLab_ProjectionPoint,
|
|
ChildLab_ViewDirection,
|
|
ChildLab_UpDirection,
|
|
ChildLab_ZoomFactor,
|
|
ChildLab_WindowHorizontalSize,
|
|
ChildLab_WindowVerticalSize,
|
|
ChildLab_FrontPlaneDistance,
|
|
ChildLab_BackPlaneDistance,
|
|
ChildLab_ViewVolumeSidesClipping,
|
|
ChildLab_ClippingExpression,
|
|
ChildLab_GDTPoints
|
|
};
|
|
|
|
//=======================================================================
|
|
//function : XCAFDoc_View
|
|
//purpose :
|
|
//=======================================================================
|
|
XCAFDoc_View::XCAFDoc_View()
|
|
{
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : GetID
|
|
//purpose :
|
|
//=======================================================================
|
|
const Standard_GUID& XCAFDoc_View::GetID()
|
|
{
|
|
static Standard_GUID ViewID ("efd213e8-6dfd-11d4-b9c8-0060b0ee281b");
|
|
return ViewID;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Set
|
|
//purpose :
|
|
//=======================================================================
|
|
Handle(XCAFDoc_View) XCAFDoc_View::Set(const TDF_Label& theLabel)
|
|
{
|
|
Handle(XCAFDoc_View) A;
|
|
if (!theLabel.FindAttribute(XCAFDoc_View::GetID(), A)) {
|
|
A = new XCAFDoc_View();
|
|
theLabel.AddAttribute(A);
|
|
}
|
|
return A;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetObject
|
|
//purpose :
|
|
//=======================================================================
|
|
void XCAFDoc_View::SetObject (const Handle(XCAFView_Object)& theObject)
|
|
{
|
|
Backup();
|
|
|
|
TDF_ChildIterator anIter(Label());
|
|
for(;anIter.More(); anIter.Next())
|
|
{
|
|
anIter.Value().ForgetAllAttributes();
|
|
}
|
|
|
|
// Name
|
|
TDataStd_AsciiString::Set(Label().FindChild(ChildLab_Name), theObject->Name()->String());
|
|
|
|
// Type
|
|
TDataStd_Integer::Set(Label().FindChild(ChildLab_Type), theObject->Type());
|
|
|
|
// Projection point
|
|
TDataXtd_Point::Set(Label().FindChild(ChildLab_ProjectionPoint), theObject->ProjectionPoint());
|
|
|
|
// View direction
|
|
gp_Ax1 aViewDir(gp_Pnt(), theObject->ViewDirection());
|
|
TDataXtd_Axis::Set(Label().FindChild(ChildLab_ViewDirection), aViewDir);
|
|
|
|
// Up direction
|
|
gp_Ax1 anUpDir(gp_Pnt(), theObject->UpDirection());
|
|
TDataXtd_Axis::Set(Label().FindChild(ChildLab_UpDirection), anUpDir);
|
|
|
|
// Zoom factor
|
|
TDataStd_Real::Set(Label().FindChild(ChildLab_ZoomFactor), theObject->ZoomFactor());
|
|
|
|
// Window horizontal size
|
|
TDataStd_Real::Set(Label().FindChild(ChildLab_WindowHorizontalSize), theObject->WindowHorizontalSize());
|
|
|
|
// Window vertical size
|
|
TDataStd_Real::Set(Label().FindChild(ChildLab_WindowVerticalSize), theObject->WindowVerticalSize());
|
|
|
|
// Front plane clipping
|
|
if (theObject->HasFrontPlaneClipping())
|
|
{
|
|
TDataStd_Real::Set(Label().FindChild(ChildLab_FrontPlaneDistance), theObject->FrontPlaneDistance());
|
|
}
|
|
|
|
// Back plane clipping
|
|
if (theObject->HasBackPlaneClipping())
|
|
{
|
|
TDataStd_Real::Set(Label().FindChild(ChildLab_BackPlaneDistance), theObject->BackPlaneDistance());
|
|
}
|
|
|
|
// View volume sides clipping
|
|
Standard_Integer aValue = theObject->HasViewVolumeSidesClipping() ? 1 : 0;
|
|
TDataStd_Integer::Set(Label().FindChild(ChildLab_ViewVolumeSidesClipping), aValue);
|
|
|
|
// Clipping Expression
|
|
if (!theObject->ClippingExpression().IsNull())
|
|
TDataStd_AsciiString::Set(Label().FindChild(ChildLab_ClippingExpression), theObject->ClippingExpression()->String());
|
|
|
|
// GDT points
|
|
if (theObject->HasGDTPoints())
|
|
{
|
|
TDF_Label aPointsLabel = Label().FindChild(ChildLab_GDTPoints);
|
|
for (Standard_Integer i = 1; i <= theObject->NbGDTPoints(); i++) {
|
|
TDataXtd_Point::Set(aPointsLabel.FindChild(i), theObject->GDTPoint(i));
|
|
}
|
|
}
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : GetObject
|
|
//purpose :
|
|
//=======================================================================
|
|
Handle(XCAFView_Object) XCAFDoc_View::GetObject() const
|
|
{
|
|
Handle(XCAFView_Object) anObj = new XCAFView_Object();
|
|
|
|
// Name
|
|
Handle(TDataStd_AsciiString) aName;
|
|
if (Label().FindChild(ChildLab_Name).FindAttribute(TDataStd_AsciiString::GetID(), aName))
|
|
{
|
|
anObj->SetName(new TCollection_HAsciiString(aName->Get()));
|
|
}
|
|
|
|
// Type
|
|
Handle(TDataStd_Integer) aType;
|
|
if (Label().FindChild(ChildLab_Type).FindAttribute(TDataStd_Integer::GetID(), aType))
|
|
{
|
|
anObj->SetType((XCAFView_ProjectionType)aType->Get());
|
|
}
|
|
|
|
// Projection point
|
|
Handle(TDataXtd_Point) aPointAttr;
|
|
if (Label().FindChild(ChildLab_ProjectionPoint).FindAttribute(TDataXtd_Point::GetID(), aPointAttr)) {
|
|
gp_Pnt aPoint;
|
|
TDataXtd_Geometry::Point(aPointAttr->Label(), aPoint);
|
|
anObj->SetProjectionPoint(aPoint);
|
|
}
|
|
|
|
// View direction
|
|
Handle(TDataXtd_Axis) aViewDirAttr;
|
|
if (Label().FindChild(ChildLab_ViewDirection).FindAttribute(TDataXtd_Axis::GetID(), aViewDirAttr)) {
|
|
gp_Ax1 aDir;
|
|
TDataXtd_Geometry::Axis(aViewDirAttr->Label(), aDir);
|
|
anObj->SetViewDirection(aDir.Direction());
|
|
}
|
|
|
|
// Up direction
|
|
Handle(TDataXtd_Axis) anUpDirAttr;
|
|
if (Label().FindChild(ChildLab_UpDirection).FindAttribute(TDataXtd_Axis::GetID(), anUpDirAttr)) {
|
|
gp_Ax1 aDir;
|
|
TDataXtd_Geometry::Axis(anUpDirAttr->Label(), aDir);
|
|
anObj->SetUpDirection(aDir.Direction());
|
|
}
|
|
|
|
// Zoom factor
|
|
Handle(TDataStd_Real) aZoomFactor;
|
|
if (Label().FindChild(ChildLab_ZoomFactor).FindAttribute(TDataStd_Real::GetID(), aZoomFactor))
|
|
{
|
|
anObj->SetZoomFactor(aZoomFactor->Get());
|
|
}
|
|
|
|
// Window horizontal size
|
|
Handle(TDataStd_Real) aWindowHorizontalSize;
|
|
if (Label().FindChild(ChildLab_WindowHorizontalSize).FindAttribute(TDataStd_Real::GetID(), aWindowHorizontalSize))
|
|
{
|
|
anObj->SetWindowHorizontalSize(aWindowHorizontalSize->Get());
|
|
}
|
|
|
|
// Window vertical size
|
|
Handle(TDataStd_Real) aWindowVerticalSize;
|
|
if (Label().FindChild(ChildLab_WindowVerticalSize).FindAttribute(TDataStd_Real::GetID(), aWindowVerticalSize))
|
|
{
|
|
anObj->SetWindowVerticalSize(aWindowVerticalSize->Get());
|
|
}
|
|
|
|
// Front plane clipping
|
|
Handle(TDataStd_Real) aFrontPlaneDistance;
|
|
if (Label().FindChild(ChildLab_FrontPlaneDistance).FindAttribute(TDataStd_Real::GetID(), aFrontPlaneDistance))
|
|
{
|
|
anObj->SetFrontPlaneDistance(aFrontPlaneDistance->Get());
|
|
}
|
|
|
|
// Back plane clipping
|
|
Handle(TDataStd_Real) aBackPlaneDistance;
|
|
if (Label().FindChild(ChildLab_BackPlaneDistance).FindAttribute(TDataStd_Real::GetID(), aBackPlaneDistance))
|
|
{
|
|
anObj->SetBackPlaneDistance(aBackPlaneDistance->Get());
|
|
}
|
|
|
|
// View volume sides clipping
|
|
Handle(TDataStd_Integer) aViewVolumeSidesClipping;
|
|
if (Label().FindChild(ChildLab_ViewVolumeSidesClipping).FindAttribute(TDataStd_Integer::GetID(), aViewVolumeSidesClipping))
|
|
{
|
|
Standard_Boolean aValue = (aViewVolumeSidesClipping->Get() == 1);
|
|
anObj->SetViewVolumeSidesClipping(aValue);
|
|
}
|
|
|
|
// Name
|
|
Handle(TDataStd_AsciiString) aClippingExpression;
|
|
if (Label().FindChild(ChildLab_ClippingExpression).FindAttribute(TDataStd_AsciiString::GetID(), aClippingExpression))
|
|
{
|
|
anObj->SetClippingExpression(new TCollection_HAsciiString(aClippingExpression->Get()));
|
|
}
|
|
|
|
// GDT Points
|
|
if (!Label().FindChild(ChildLab_GDTPoints, Standard_False).IsNull()) {
|
|
TDF_Label aPointsLabel = Label().FindChild(ChildLab_GDTPoints);
|
|
anObj->CreateGDTPoints(aPointsLabel.NbChildren());
|
|
for (Standard_Integer i = 1; i <= aPointsLabel.NbChildren(); i++) {
|
|
gp_Pnt aPoint;
|
|
Handle(TDataXtd_Point) aPointAttr;
|
|
aPointsLabel.FindChild(i).FindAttribute(TDataXtd_Point::GetID(), aPointAttr);
|
|
TDataXtd_Geometry::Point(aPointAttr->Label(), aPoint);
|
|
anObj->SetGDTPoint(i, aPoint);
|
|
}
|
|
}
|
|
|
|
return anObj;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : ID
|
|
//purpose :
|
|
//=======================================================================
|
|
const Standard_GUID& XCAFDoc_View::ID() const
|
|
{
|
|
return GetID();
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Restore
|
|
//purpose :
|
|
//=======================================================================
|
|
void XCAFDoc_View::Restore(const Handle(TDF_Attribute)& /*With*/)
|
|
{
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : NewEmpty
|
|
//purpose :
|
|
//=======================================================================
|
|
Handle(TDF_Attribute) XCAFDoc_View::NewEmpty() const
|
|
{
|
|
return new XCAFDoc_View();
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : Paste
|
|
//purpose :
|
|
//=======================================================================
|
|
void XCAFDoc_View::Paste(const Handle(TDF_Attribute)& /*Into*/,
|
|
const Handle(TDF_RelocationTable)& /*RT*/) const
|
|
{
|
|
}
|