mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
1) New Graphic3d_TransformPers structure for defining parameters and algorithm methods, featuring: a) application of transformation to projection and world view matrices; b) computation of model-world transformation of persistent object; c) computation of transformed bounding box of persistent object. 2) Transform persistence algorithm does not make any changes to model-world transformation of object (deals with projection and world view matrices only), thus making possible to employ local transformation in a usual way. 3) Support of BVH selection for transform persistent objects (pan, rotate, zoom, trihedron persistence only). 4) Support efficient frustum culling for transform persistent objects (pan, rotate, zoom, trihedron persistence only). 5) Support of z-fitting algorithm for world-view space transform persistent objects (rotate, zoom persistence only). 6) Rewrite usage of transform persistence structures and utilities classes: a) Replaced Graphic3d_CTransPers, TEL_TRANSFORM_PERSISTENCE by Graphic3d_TransformPers; b) Move functions from OpenGl_Utils.hxx to Graphic3d_TransformUtils.hxx; c) Extract matrix stack class from OpenGl_Utils.hxx to OpenGl_MatrixStack.hxx; 7) New class Graphic3d_WorldViewProjState to keep track of projection, world view matrices changes for a camera. 8) New test case bugs/vis/bug26344. 9) Renamed method Graphic3d_Camera::ModelViewState of to ::WorldViewState for consistency.
131 lines
4.8 KiB
C++
131 lines
4.8 KiB
C++
// Created on: 2014-08-15
|
|
// Created by: Varvara POSKONINA
|
|
// Copyright (c) 2005-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 <Bnd_Box.hxx>
|
|
#include <BVH_BinnedBuilder.hxx>
|
|
|
|
#include <SelectMgr_SelectableObjectSet.hxx>
|
|
|
|
//=======================================================================
|
|
// function : SelectMgr_SelectableObjectSet
|
|
// purpose : Creates new empty objects set and initializes BVH tree
|
|
// builder to Binned builder with 1 element per list
|
|
//=======================================================================
|
|
SelectMgr_SelectableObjectSet::SelectMgr_SelectableObjectSet()
|
|
{
|
|
myBuilder = new BVH_BinnedBuilder<Standard_Real, 3, 32> (1, 32, Standard_False);
|
|
}
|
|
|
|
//=======================================================================
|
|
// function : Append
|
|
// purpose : Adds new object to the set and marks BVH tree for rebuild
|
|
//=======================================================================
|
|
Standard_Boolean SelectMgr_SelectableObjectSet::Append (const Handle(SelectMgr_SelectableObject)& theObject)
|
|
{
|
|
Standard_Integer aSize = Size();
|
|
|
|
if (aSize < myObjects.Add (theObject))
|
|
{
|
|
MarkDirty();
|
|
|
|
return Standard_True;
|
|
}
|
|
|
|
return Standard_False;
|
|
}
|
|
|
|
//=======================================================================
|
|
// function : Remove
|
|
// purpose : Removes object theObject from set and marks BVH tree for
|
|
// rebuild
|
|
//=======================================================================
|
|
Standard_Boolean SelectMgr_SelectableObjectSet::Remove (const Handle(SelectMgr_SelectableObject)& theObject)
|
|
{
|
|
const Standard_Integer anIndex = myObjects.FindIndex (theObject);
|
|
|
|
if (anIndex != 0)
|
|
{
|
|
if (anIndex != Size())
|
|
{
|
|
Swap (anIndex - 1, Size() - 1);
|
|
}
|
|
|
|
myObjects.RemoveLast();
|
|
|
|
MarkDirty();
|
|
|
|
return Standard_True;
|
|
}
|
|
|
|
return Standard_False;
|
|
}
|
|
|
|
//=======================================================================
|
|
// function : Box
|
|
// purpose : Returns bounding box of object with index theIndex
|
|
//=======================================================================
|
|
Select3D_BndBox3d SelectMgr_SelectableObjectSet::Box (const Standard_Integer theIndex) const
|
|
{
|
|
const Handle(SelectMgr_SelectableObject)& anObject = GetObjectById (theIndex);
|
|
Bnd_Box aBox;
|
|
anObject->BoundingBox (aBox);
|
|
if (aBox.IsVoid())
|
|
return Select3D_BndBox3d();
|
|
|
|
return Select3D_BndBox3d (SelectMgr_Vec3 (aBox.CornerMin().X(), aBox.CornerMin().Y(), aBox.CornerMin().Z()),
|
|
SelectMgr_Vec3 (aBox.CornerMax().X(), aBox.CornerMax().Y(), aBox.CornerMax().Z()));
|
|
}
|
|
|
|
//=======================================================================
|
|
// function : Center
|
|
// purpose : Returns center of object with index theIndex in the set
|
|
// along the given axis theAxis
|
|
//=======================================================================
|
|
Standard_Real SelectMgr_SelectableObjectSet::Center (const Standard_Integer theIndex,
|
|
const Standard_Integer theAxis) const
|
|
{
|
|
Select3D_BndBox3d aBndBox = Box (theIndex);
|
|
|
|
return (aBndBox.CornerMin()[theAxis] +
|
|
aBndBox.CornerMax()[theAxis]) * 0.5;
|
|
}
|
|
|
|
//=======================================================================
|
|
// function : Swap
|
|
// purpose : Swaps items with indexes theIndex1 and theIndex2 in the set
|
|
//=======================================================================
|
|
void SelectMgr_SelectableObjectSet::Swap (const Standard_Integer theIndex1,
|
|
const Standard_Integer theIndex2)
|
|
{
|
|
const Standard_Integer aIndex1 = theIndex1 + 1;
|
|
const Standard_Integer aIndex2 = theIndex2 + 1;
|
|
|
|
Handle(SelectMgr_SelectableObject) anObject1 = myObjects.FindKey (aIndex1);
|
|
Handle(SelectMgr_SelectableObject) anObject2 = myObjects.FindKey (aIndex2);
|
|
|
|
myObjects.Substitute (aIndex1, EMPTY_OBJ);
|
|
myObjects.Substitute (aIndex2, anObject1);
|
|
myObjects.Substitute (aIndex1, anObject2);
|
|
}
|
|
|
|
//=======================================================================
|
|
// function : Size
|
|
// purpose : Returns size of objects set
|
|
//=======================================================================
|
|
Standard_Integer SelectMgr_SelectableObjectSet::Size() const
|
|
{
|
|
return myObjects.Size();
|
|
}
|