mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-15 10:20:34 +05:00
Create annotation interaction and "hidden line" mode
This commit is contained in:
parent
71725ed92f
commit
2e7629270a
@ -65,6 +65,8 @@ public:
|
|||||||
static SUIT_ViewWindow* getActiveView();
|
static SUIT_ViewWindow* getActiveView();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
typedef std::list<SALOME_Prs*> PrsList;
|
||||||
|
|
||||||
static GEOM::GEOM_Gen_ptr getGeomEngine();
|
static GEOM::GEOM_Gen_ptr getGeomEngine();
|
||||||
|
|
||||||
void display ( const ObjectList&, const bool = true );
|
void display ( const ObjectList&, const bool = true );
|
||||||
@ -97,6 +99,8 @@ protected:
|
|||||||
const bool = true );
|
const bool = true );
|
||||||
void erasePreview ( const bool = true );
|
void erasePreview ( const bool = true );
|
||||||
|
|
||||||
|
const PrsList& getPreview() const { return myPreview; }
|
||||||
|
|
||||||
void localSelection( const ObjectList&, const std::list<int> );
|
void localSelection( const ObjectList&, const std::list<int> );
|
||||||
void localSelection( const ObjectList&, const int );
|
void localSelection( const ObjectList&, const int );
|
||||||
void localSelection( GEOM::GEOM_Object_ptr, const std::list<int> );
|
void localSelection( GEOM::GEOM_Object_ptr, const std::list<int> );
|
||||||
@ -210,7 +214,6 @@ private:
|
|||||||
void clearShapeBuffer( GEOM::GEOM_Object_ptr );
|
void clearShapeBuffer( GEOM::GEOM_Object_ptr );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typedef std::list<SALOME_Prs*> PrsList;
|
|
||||||
|
|
||||||
PrsList myPreview;
|
PrsList myPreview;
|
||||||
GEOM_Displayer* myDisplayer;
|
GEOM_Displayer* myDisplayer;
|
||||||
|
@ -29,9 +29,6 @@
|
|||||||
#include <GEOM_Annotation.hxx>
|
#include <GEOM_Annotation.hxx>
|
||||||
#include <SALOMEDSImpl_AttributeParameter.hxx>
|
#include <SALOMEDSImpl_AttributeParameter.hxx>
|
||||||
|
|
||||||
// OCCT includes
|
|
||||||
#include <gp_Ax3.hxx>
|
|
||||||
|
|
||||||
// STL includes
|
// STL includes
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
@ -353,10 +350,19 @@ void GEOMGUI_AnnotationAttrs::GetShapeSel( const int theIndex, int& theShapeType
|
|||||||
// purpose :
|
// purpose :
|
||||||
//=================================================================================
|
//=================================================================================
|
||||||
void GEOMGUI_AnnotationAttrs::Append( const Properties& theProps )
|
void GEOMGUI_AnnotationAttrs::Append( const Properties& theProps )
|
||||||
|
{
|
||||||
|
this->Append( theProps, gp_Ax3() );
|
||||||
|
}
|
||||||
|
|
||||||
|
//=================================================================================
|
||||||
|
// function : Append
|
||||||
|
// purpose :
|
||||||
|
//=================================================================================
|
||||||
|
void GEOMGUI_AnnotationAttrs::Append( const Properties& theProps, const gp_Ax3& theShapeLCS )
|
||||||
{
|
{
|
||||||
const int aCount = this->GetNbAnnotation();
|
const int aCount = this->GetNbAnnotation();
|
||||||
this->SetNbAnnotation( aCount + 1 );
|
this->SetNbAnnotation( aCount + 1 );
|
||||||
this->SetProperties( aCount, theProps );
|
this->SetProperties( aCount, theProps, theShapeLCS );
|
||||||
}
|
}
|
||||||
|
|
||||||
//=================================================================================
|
//=================================================================================
|
||||||
@ -365,13 +371,27 @@ void GEOMGUI_AnnotationAttrs::Append( const Properties& theProps )
|
|||||||
//=================================================================================
|
//=================================================================================
|
||||||
void GEOMGUI_AnnotationAttrs::SetProperties( const int theIndex, const Properties& theProps )
|
void GEOMGUI_AnnotationAttrs::SetProperties( const int theIndex, const Properties& theProps )
|
||||||
{
|
{
|
||||||
|
this->SetProperties( theIndex, theProps, gp_Ax3() );
|
||||||
|
}
|
||||||
|
|
||||||
|
//=================================================================================
|
||||||
|
// function : SetProperties
|
||||||
|
// purpose :
|
||||||
|
//=================================================================================
|
||||||
|
void GEOMGUI_AnnotationAttrs::SetProperties( const int theIndex, const Properties& theProps,
|
||||||
|
const gp_Ax3& theShapeLCS )
|
||||||
|
{
|
||||||
|
gp_Trsf aToShapeLCS;
|
||||||
|
aToShapeLCS.SetTransformation( gp_Ax3(), theShapeLCS );
|
||||||
|
|
||||||
this->SetName( theIndex, theProps.Name );
|
this->SetName( theIndex, theProps.Name );
|
||||||
this->SetText( theIndex, theProps.Text );
|
this->SetText( theIndex, theProps.Text );
|
||||||
this->SetIsVisible( theIndex, theProps.IsVisible );
|
this->SetIsVisible( theIndex, theProps.IsVisible );
|
||||||
this->SetIsScreenFixed( theIndex, theProps.IsScreenFixed );
|
this->SetIsScreenFixed( theIndex, theProps.IsScreenFixed );
|
||||||
this->SetPosition( theIndex, theProps.Position );
|
|
||||||
this->SetAttach( theIndex, theProps.Attach );
|
|
||||||
this->SetShapeSel( theIndex, theProps.ShapeType, theProps.ShapeIndex );
|
this->SetShapeSel( theIndex, theProps.ShapeType, theProps.ShapeIndex );
|
||||||
|
this->SetAttach( theIndex, theProps.Attach.Transformed( aToShapeLCS ) );
|
||||||
|
this->SetPosition( theIndex, (theProps.IsScreenFixed) ?
|
||||||
|
theProps.Position : theProps.Position.Transformed( aToShapeLCS ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
//=================================================================================
|
//=================================================================================
|
||||||
@ -396,19 +416,20 @@ void GEOMGUI_AnnotationAttrs::GetProperties( const int theIndex, Properties& the
|
|||||||
//=================================================================================
|
//=================================================================================
|
||||||
void GEOMGUI_AnnotationAttrs::SetupPresentation( const Handle(GEOM_Annotation)& thePresentation,
|
void GEOMGUI_AnnotationAttrs::SetupPresentation( const Handle(GEOM_Annotation)& thePresentation,
|
||||||
const Properties& theProps,
|
const Properties& theProps,
|
||||||
const gp_Ax3& theLCS )
|
const gp_Ax3& theShapeLCS )
|
||||||
{
|
{
|
||||||
gp_Trsf aToLCS;
|
gp_Trsf aFromShapeLCS;
|
||||||
aToLCS.SetTransformation( theLCS, gp_Ax3() );
|
aFromShapeLCS.SetTransformation( theShapeLCS, gp_Ax3() );
|
||||||
|
|
||||||
TCollection_ExtendedString aText;
|
TCollection_ExtendedString aText;
|
||||||
for (int i = 0; i < (int)theProps.Text.length(); i++ )
|
for (int i = 0; i < (int)theProps.Text.length(); i++ )
|
||||||
aText.Insert( i + 1, theProps.Text[ i ].unicode() );
|
aText.Insert( i + 1, theProps.Text[ i ].unicode() );
|
||||||
//
|
|
||||||
thePresentation->SetText( aText );
|
thePresentation->SetText( aText );
|
||||||
thePresentation->SetScreenFixed( theProps.IsScreenFixed );
|
thePresentation->SetScreenFixed( theProps.IsScreenFixed );
|
||||||
thePresentation->SetPosition( theProps.Position );
|
thePresentation->SetAttachPoint( theProps.Attach.Transformed( aFromShapeLCS ) );
|
||||||
thePresentation->SetAttachPoint( theProps.Attach.Transformed( aToLCS ) );
|
thePresentation->SetPosition( (theProps.IsScreenFixed) ?
|
||||||
|
theProps.Position : theProps.Position.Transformed( aFromShapeLCS ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
//=================================================================================
|
//=================================================================================
|
||||||
@ -417,9 +438,9 @@ void GEOMGUI_AnnotationAttrs::SetupPresentation( const Handle(GEOM_Annotation)&
|
|||||||
//=================================================================================
|
//=================================================================================
|
||||||
void GEOMGUI_AnnotationAttrs::SetupPresentation( const Handle(GEOM_Annotation)& thePresentation,
|
void GEOMGUI_AnnotationAttrs::SetupPresentation( const Handle(GEOM_Annotation)& thePresentation,
|
||||||
const int theIndex,
|
const int theIndex,
|
||||||
const gp_Ax3& theLCS )
|
const gp_Ax3& theShapeLCS )
|
||||||
{
|
{
|
||||||
Properties aProps;
|
Properties aProps;
|
||||||
this->GetProperties( theIndex, aProps );
|
this->GetProperties( theIndex, aProps );
|
||||||
this->SetupPresentation( thePresentation, aProps, theLCS );
|
this->SetupPresentation( thePresentation, aProps, theShapeLCS );
|
||||||
}
|
}
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include <SalomeApp_Study.h>
|
#include <SalomeApp_Study.h>
|
||||||
|
|
||||||
// OCCT includes
|
// OCCT includes
|
||||||
|
#include <gp_Ax3.hxx>
|
||||||
#include <gp_Pnt.hxx>
|
#include <gp_Pnt.hxx>
|
||||||
#include <Standard_Transient.hxx>
|
#include <Standard_Transient.hxx>
|
||||||
|
|
||||||
@ -80,18 +81,18 @@ public:
|
|||||||
//! Setup parameters of the annotation presentation with the properties given.
|
//! Setup parameters of the annotation presentation with the properties given.
|
||||||
//! @param thePresentation [in] the presentation to setup.
|
//! @param thePresentation [in] the presentation to setup.
|
||||||
//! @param theProps [in] the set of properties.
|
//! @param theProps [in] the set of properties.
|
||||||
//! @param theLCS [in] the local coordinate system of the shape.
|
//! @param theShapeLCS [in] the local coordinate system of the shape.
|
||||||
GEOMGUI_EXPORT static void SetupPresentation( const Handle(GEOM_Annotation)& thePresentation,
|
GEOMGUI_EXPORT static void SetupPresentation( const Handle(GEOM_Annotation)& thePresentation,
|
||||||
const Properties& theProps,
|
const Properties& theProps,
|
||||||
const gp_Ax3& theLCS );
|
const gp_Ax3& theShapeLCS );
|
||||||
|
|
||||||
//! Setup parameters of the annotation presentation with the properties of a definition.
|
//! Setup parameters of the annotation presentation with the properties of a definition.
|
||||||
//! @param thePresentation [in] the presentation to setup.
|
//! @param thePresentation [in] the presentation to setup.
|
||||||
//! @param theIndex [in] the index of the annotation definition.
|
//! @param theIndex [in] the index of the annotation definition.
|
||||||
//! @param theLCS [in] the local coordinate system of the shape.
|
//! @param theShapeLCS [in] the local coordinate system of the shape.
|
||||||
GEOMGUI_EXPORT void SetupPresentation( const Handle(GEOM_Annotation)& thePresentation,
|
GEOMGUI_EXPORT void SetupPresentation( const Handle(GEOM_Annotation)& thePresentation,
|
||||||
const int theIndex,
|
const int theIndex,
|
||||||
const gp_Ax3& theLCS );
|
const gp_Ax3& theShapeLCS );
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@ -168,11 +169,26 @@ public:
|
|||||||
//! Appends new annotation definition with the given properties.
|
//! Appends new annotation definition with the given properties.
|
||||||
GEOMGUI_EXPORT void Append( const Properties& theProps );
|
GEOMGUI_EXPORT void Append( const Properties& theProps );
|
||||||
|
|
||||||
|
//! Appends new annotation definition with the given properties and converts
|
||||||
|
//! position and attachment points to the given shape's local frame of reference.
|
||||||
|
//! @param theShapeLCS [in] the position of shape's local frame of reference with respect
|
||||||
|
//! to the world frame of reference.
|
||||||
|
GEOMGUI_EXPORT void Append( const Properties& theProps, const gp_Ax3& theShapeLCS );
|
||||||
|
|
||||||
//! Sets complete properties of an annotation definition.
|
//! Sets complete properties of an annotation definition.
|
||||||
//! @param theIndex [in] the index of the annotation definition.
|
//! @param theIndex [in] the index of the annotation definition.
|
||||||
//! @param theProps [in] the structure containing the properties.
|
//! @param theProps [in] the structure containing the properties.
|
||||||
GEOMGUI_EXPORT void SetProperties( const int theIndex, const Properties& theProps );
|
GEOMGUI_EXPORT void SetProperties( const int theIndex, const Properties& theProps );
|
||||||
|
|
||||||
|
//! Sets complete properties of an annotation definition with converting
|
||||||
|
//! position and attachment points to the given shape's local frame
|
||||||
|
//! of reference.
|
||||||
|
//! @param theIndex [in] the index of the annotation definition.
|
||||||
|
//! @param theProps [in] the structure containing the properties.
|
||||||
|
//! @param theShapeLCS [in] the position of shape's local frame of reference with respect
|
||||||
|
//! to the world frame of reference.
|
||||||
|
GEOMGUI_EXPORT void SetProperties( const int theIndex, const Properties& theProps, const gp_Ax3& theShapeLCS );
|
||||||
|
|
||||||
//! Returns complete properties of an annotation definition.
|
//! Returns complete properties of an annotation definition.
|
||||||
//! @param theIndex [in] the index of the annotation definition.
|
//! @param theIndex [in] the index of the annotation definition.
|
||||||
//! @param theProps [out] the structure containing the properties.
|
//! @param theProps [out] the structure containing the properties.
|
||||||
|
@ -1444,6 +1444,7 @@ void GEOM_Displayer::updateShapeAnnotations( const Handle(SALOME_InteractiveObje
|
|||||||
aPresentation->SetLineWidth( aLineWidth );
|
aPresentation->SetLineWidth( aLineWidth );
|
||||||
aPresentation->SetLineStyle( static_cast<Aspect_TypeOfLine>( aLineStyle ) );
|
aPresentation->SetLineStyle( static_cast<Aspect_TypeOfLine>( aLineStyle ) );
|
||||||
aPresentation->SetAutoHide( isAutoHide ? Standard_True : Standard_False );
|
aPresentation->SetAutoHide( isAutoHide ? Standard_True : Standard_False );
|
||||||
|
aPresentation->SetDepthCulling( Standard_True );
|
||||||
|
|
||||||
aListOfIO.Append( aPresentation );
|
aListOfIO.Append( aPresentation );
|
||||||
}
|
}
|
||||||
|
86
src/MeasureGUI/MeasureGUI_AnnotationDlg.cxx
Normal file → Executable file
86
src/MeasureGUI/MeasureGUI_AnnotationDlg.cxx
Normal file → Executable file
@ -31,7 +31,6 @@
|
|||||||
#include <GEOMBase_Skeleton.h>
|
#include <GEOMBase_Skeleton.h>
|
||||||
#include <GEOM_Displayer.h>
|
#include <GEOM_Displayer.h>
|
||||||
#include <GeometryGUI.h>
|
#include <GeometryGUI.h>
|
||||||
#include <GEOM_Annotation.hxx>
|
|
||||||
|
|
||||||
#include <SOCC_Prs.h>
|
#include <SOCC_Prs.h>
|
||||||
#include <SOCC_ViewModel.h>
|
#include <SOCC_ViewModel.h>
|
||||||
@ -210,6 +209,9 @@ MeasureGUI_AnnotationDlg::MeasureGUI_AnnotationDlg( GeometryGUI* theGeometryGUI,
|
|||||||
myInteractor = new MeasureGUI_AnnotationInteractor( theGeometryGUI, parent );
|
myInteractor = new MeasureGUI_AnnotationInteractor( theGeometryGUI, parent );
|
||||||
myInteractor->Enable();
|
myInteractor->Enable();
|
||||||
|
|
||||||
|
connect( myInteractor, SIGNAL( SignalInteractionFinished( Handle_GEOM_Annotation ) ),
|
||||||
|
this, SLOT( onDragged( Handle_GEOM_Annotation ) ) );
|
||||||
|
|
||||||
Init();
|
Init();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -438,12 +440,19 @@ void MeasureGUI_AnnotationDlg::SelectionIntoArgument()
|
|||||||
activateSelection();
|
activateSelection();
|
||||||
|
|
||||||
if ( !aNullShape ) {
|
if ( !aNullShape ) {
|
||||||
if ( !getPickedPoint( anAttachPoint ) )
|
|
||||||
{
|
|
||||||
TopoDS_Shape aShape;
|
TopoDS_Shape aShape;
|
||||||
GEOMBase::GetShape( myShape.get(), aShape );
|
GEOMBase::GetShape( myShape.get(), aShape );
|
||||||
|
|
||||||
|
if ( !getPickedPoint( anAttachPoint ) ) {
|
||||||
|
|
||||||
anAttachPoint = getAttachPoint( aShape );
|
anAttachPoint = getAttachPoint( aShape );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gp_Ax3 aShapeLCS = gp_Ax3().Transformed( aShape.Location().Transformation() );
|
||||||
|
gp_Trsf aToShapeLCS;
|
||||||
|
aToShapeLCS.SetTransformation( gp_Ax3(), aShapeLCS );
|
||||||
|
anAttachPoint.Transform( aToShapeLCS );
|
||||||
}
|
}
|
||||||
} else if ( myEditCurrentArgument == mySubShapeName ) {
|
} else if ( myEditCurrentArgument == mySubShapeName ) {
|
||||||
if ( !myShape->_is_nil() ) {
|
if ( !myShape->_is_nil() ) {
|
||||||
@ -467,12 +476,20 @@ void MeasureGUI_AnnotationDlg::SelectionIntoArgument()
|
|||||||
aSubShapeIndex = aMainMap.FindIndex( aSubShape );
|
aSubShapeIndex = aMainMap.FindIndex( aSubShape );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !aSubShape.IsNull() )
|
if ( !aSubShape.IsNull() ) {
|
||||||
{
|
|
||||||
if ( !getPickedPoint( anAttachPoint ) )
|
TopoDS_Shape aShape;
|
||||||
{
|
GEOMBase::GetShape( myShape.get(), aShape );
|
||||||
|
|
||||||
|
if ( !getPickedPoint( anAttachPoint ) ) {
|
||||||
|
|
||||||
anAttachPoint = getAttachPoint( aSubShape );
|
anAttachPoint = getAttachPoint( aSubShape );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gp_Ax3 aShapeLCS = gp_Ax3().Transformed( aShape.Location().Transformation() );
|
||||||
|
gp_Trsf aToShapeLCS;
|
||||||
|
aToShapeLCS.SetTransformation( gp_Ax3(), aShapeLCS );
|
||||||
|
anAttachPoint.Transform( aToShapeLCS );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -483,6 +500,18 @@ void MeasureGUI_AnnotationDlg::SelectionIntoArgument()
|
|||||||
redisplayPreview();
|
redisplayPreview();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=======================================================================
|
||||||
|
//function : closeEvent
|
||||||
|
//purpose :
|
||||||
|
//=======================================================================
|
||||||
|
void MeasureGUI_AnnotationDlg::closeEvent( QCloseEvent* theEv )
|
||||||
|
{
|
||||||
|
if ( myInteractor ) {
|
||||||
|
myInteractor->Disable();
|
||||||
|
}
|
||||||
|
GEOMBase_Skeleton::closeEvent( theEv );
|
||||||
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : onTextChange
|
//function : onTextChange
|
||||||
//purpose : change annotation text
|
//purpose : change annotation text
|
||||||
@ -530,6 +559,42 @@ void MeasureGUI_AnnotationDlg::onSubShapeTypeChange()
|
|||||||
redisplayPreview();
|
redisplayPreview();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=================================================================================
|
||||||
|
// function : onDragged
|
||||||
|
// purpose :
|
||||||
|
//=================================================================================
|
||||||
|
void MeasureGUI_AnnotationDlg::onDragged( Handle_GEOM_Annotation theAnnotation )
|
||||||
|
{
|
||||||
|
const PrsList& aPreview = getPreview();
|
||||||
|
PrsList::const_iterator anIt = aPreview.cbegin();
|
||||||
|
for ( ; anIt != aPreview.cend(); ++anIt ) {
|
||||||
|
|
||||||
|
AIS_ListOfInteractive aIObjects;
|
||||||
|
((SOCC_Prs*)(*anIt))->GetObjects( aIObjects );
|
||||||
|
AIS_ListOfInteractive::Iterator aIOIt( aIObjects );
|
||||||
|
for ( ; aIOIt.More(); aIOIt.Next() ) {
|
||||||
|
|
||||||
|
if ( aIOIt.Value() == theAnnotation ) {
|
||||||
|
|
||||||
|
TopoDS_Shape aShape;
|
||||||
|
GEOMBase::GetShape( myShape.get(), aShape );
|
||||||
|
gp_Ax3 aShapeLCS = gp_Ax3().Transformed( aShape.Location().Transformation() );
|
||||||
|
gp_Trsf aToShapeLCS;
|
||||||
|
aToShapeLCS.SetTransformation( gp_Ax3(), aShapeLCS );
|
||||||
|
|
||||||
|
if ( !myAnnotationProperties.IsScreenFixed ) {
|
||||||
|
myAnnotationProperties.Position = theAnnotation->GetPosition().Transformed( aToShapeLCS );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
myAnnotationProperties.Position = theAnnotation->GetPosition();
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#define RETURN_WITH_MSG( a, b ) \
|
#define RETURN_WITH_MSG( a, b ) \
|
||||||
if ( ( a ) ) { \
|
if ( ( a ) ) { \
|
||||||
theMessage += ( b ); \
|
theMessage += ( b ); \
|
||||||
@ -638,6 +703,7 @@ SALOME_Prs* MeasureGUI_AnnotationDlg::buildPrs()
|
|||||||
aPresentation->SetLineStyle( static_cast<Aspect_TypeOfLine>( aLineStyle ) );
|
aPresentation->SetLineStyle( static_cast<Aspect_TypeOfLine>( aLineStyle ) );
|
||||||
aPresentation->SetAutoHide( isAutoHide ? Standard_True : Standard_False );
|
aPresentation->SetAutoHide( isAutoHide ? Standard_True : Standard_False );
|
||||||
aPresentation->SetScreenFixed( myAnnotationProperties.IsScreenFixed );
|
aPresentation->SetScreenFixed( myAnnotationProperties.IsScreenFixed );
|
||||||
|
aPresentation->SetDepthCulling( Standard_False );
|
||||||
|
|
||||||
TopoDS_Shape aShape;
|
TopoDS_Shape aShape;
|
||||||
GEOMBase::GetShape( myShape.get(), aShape );
|
GEOMBase::GetShape( myShape.get(), aShape );
|
||||||
@ -771,9 +837,9 @@ gp_Pnt MeasureGUI_AnnotationDlg::getAttachPoint( const TopoDS_Shape& theShape )
|
|||||||
BRepBndLib::Add( aAttachShape, aBox );
|
BRepBndLib::Add( aAttachShape, aBox );
|
||||||
const gp_Pnt aMin = aBox.CornerMin();
|
const gp_Pnt aMin = aBox.CornerMin();
|
||||||
const gp_Pnt aMax = aBox.CornerMax();
|
const gp_Pnt aMax = aBox.CornerMax();
|
||||||
return gp_Pnt( aMin.X() + aMax.X() / 2.0,
|
return gp_Pnt( (aMin.X() + aMax.X()) / 2.0,
|
||||||
aMin.Y() + aMax.Y() / 2.0,
|
(aMin.Y() + aMax.Y()) / 2.0,
|
||||||
aMin.Z() + aMax.Z() / 2.0 );
|
(aMin.Z() + aMax.Z()) / 2.0 );
|
||||||
}
|
}
|
||||||
else if ( aAttachShape.ShapeType() == TopAbs_FACE )
|
else if ( aAttachShape.ShapeType() == TopAbs_FACE )
|
||||||
{
|
{
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
|
|
||||||
#include <GEOMBase_Skeleton.h>
|
#include <GEOMBase_Skeleton.h>
|
||||||
|
|
||||||
|
#include <GEOM_Annotation.hxx>
|
||||||
#include <GEOM_Constants.h>
|
#include <GEOM_Constants.h>
|
||||||
#include <GEOMGUI_AnnotationAttrs.h>
|
#include <GEOMGUI_AnnotationAttrs.h>
|
||||||
|
|
||||||
@ -73,6 +74,8 @@ protected:
|
|||||||
void updateSubShapeEnableState();
|
void updateSubShapeEnableState();
|
||||||
void redisplayPreview();
|
void redisplayPreview();
|
||||||
|
|
||||||
|
void closeEvent( QCloseEvent* theEv );
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void ClickOnOk();
|
void ClickOnOk();
|
||||||
bool ClickOnApply();
|
bool ClickOnApply();
|
||||||
@ -83,6 +86,8 @@ private slots:
|
|||||||
void onTypeChange();
|
void onTypeChange();
|
||||||
void onSubShapeTypeChange();
|
void onSubShapeTypeChange();
|
||||||
|
|
||||||
|
void onDragged( Handle_GEOM_Annotation theAnnotation );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void Init();
|
void Init();
|
||||||
|
|
||||||
|
8
src/MeasureGUI/MeasureGUI_AnnotationInteractor.cxx
Normal file → Executable file
8
src/MeasureGUI/MeasureGUI_AnnotationInteractor.cxx
Normal file → Executable file
@ -137,8 +137,12 @@ void MeasureGUI_AnnotationInteractor::Disable()
|
|||||||
myActiveViewPort = NULL;
|
myActiveViewPort = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( !myActiveIO.IsNull() )
|
||||||
|
{
|
||||||
|
emit SignalInteractionFinished( myActiveIO );
|
||||||
myActiveIO.Nullify();
|
myActiveIO.Nullify();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//=================================================================================
|
//=================================================================================
|
||||||
// function : ConnectView
|
// function : ConnectView
|
||||||
@ -245,6 +249,8 @@ bool MeasureGUI_AnnotationInteractor::eventFilter( QObject* theObject, QEvent* t
|
|||||||
myActiveIO = aAnnotation;
|
myActiveIO = aAnnotation;
|
||||||
myActiveIO->BeginDrag();
|
myActiveIO->BeginDrag();
|
||||||
|
|
||||||
|
emit SignalInteractionStarted( myActiveIO );
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,6 +310,8 @@ bool MeasureGUI_AnnotationInteractor::eventFilter( QObject* theObject, QEvent* t
|
|||||||
anAISContext->UpdateCurrentViewer();
|
anAISContext->UpdateCurrentViewer();
|
||||||
anAISContext->MoveTo( aMouseEv->pos().x(), aMouseEv->pos().y(), aView3d );
|
anAISContext->MoveTo( aMouseEv->pos().x(), aMouseEv->pos().y(), aView3d );
|
||||||
|
|
||||||
|
emit SignalInteractionFinished( myActiveIO );
|
||||||
|
|
||||||
mySelection.Clear();
|
mySelection.Clear();
|
||||||
myActiveIO.Nullify();
|
myActiveIO.Nullify();
|
||||||
return (theEvent->type() == QEvent::MouseButtonRelease);
|
return (theEvent->type() == QEvent::MouseButtonRelease);
|
||||||
|
8
src/MeasureGUI/MeasureGUI_AnnotationInteractor.h
Normal file → Executable file
8
src/MeasureGUI/MeasureGUI_AnnotationInteractor.h
Normal file → Executable file
@ -78,6 +78,14 @@ protected:
|
|||||||
//! Disconnect interactor's event handler from the view window given.
|
//! Disconnect interactor's event handler from the view window given.
|
||||||
void DisconnectView( SUIT_ViewWindow* theWindow );
|
void DisconnectView( SUIT_ViewWindow* theWindow );
|
||||||
|
|
||||||
|
signals:
|
||||||
|
|
||||||
|
//! Emitted when interactor begins modification of the interactive object.
|
||||||
|
void SignalInteractionStarted( Handle_GEOM_Annotation theIO );
|
||||||
|
|
||||||
|
//! Emitted when interactor finished modification of the interactive object.
|
||||||
|
void SignalInteractionFinished( Handle_GEOM_Annotation theIO );
|
||||||
|
|
||||||
protected slots:
|
protected slots:
|
||||||
|
|
||||||
//! Handler for signal coming from GUI layer.
|
//! Handler for signal coming from GUI layer.
|
||||||
|
@ -67,6 +67,7 @@ GEOM_Annotation::GEOM_Annotation() : AIS_InteractiveObject()
|
|||||||
SetAutoHide( Standard_True );
|
SetAutoHide( Standard_True );
|
||||||
SetHilightMode( HighlightAll );
|
SetHilightMode( HighlightAll );
|
||||||
SetMutable( Standard_True );
|
SetMutable( Standard_True );
|
||||||
|
SetDepthCulling( Standard_True );
|
||||||
|
|
||||||
Handle(Prs3d_TextAspect) aTextAspect = new Prs3d_TextAspect();
|
Handle(Prs3d_TextAspect) aTextAspect = new Prs3d_TextAspect();
|
||||||
aTextAspect->SetHeight( 20.0 );
|
aTextAspect->SetHeight( 20.0 );
|
||||||
@ -77,6 +78,10 @@ GEOM_Annotation::GEOM_Annotation() : AIS_InteractiveObject()
|
|||||||
new Prs3d_LineAspect( Quantity_NOC_WHITE, Aspect_TOL_SOLID, 1.0 );
|
new Prs3d_LineAspect( Quantity_NOC_WHITE, Aspect_TOL_SOLID, 1.0 );
|
||||||
myDrawer->SetLineAspect( aLineAspect );
|
myDrawer->SetLineAspect( aLineAspect );
|
||||||
|
|
||||||
|
Handle(Prs3d_LineAspect) aHiddenLineAspect =
|
||||||
|
new Prs3d_LineAspect( Quantity_NOC_WHITE, Aspect_TOL_DOT, 1.0 );
|
||||||
|
myDrawer->SetHiddenLineAspect( aHiddenLineAspect );
|
||||||
|
|
||||||
Handle(Prs3d_PointAspect) aPointAspect =
|
Handle(Prs3d_PointAspect) aPointAspect =
|
||||||
new Prs3d_PointAspect( Aspect_TOM_POINT, Quantity_NOC_WHITE, 4.0 );
|
new Prs3d_PointAspect( Aspect_TOM_POINT, Quantity_NOC_WHITE, 4.0 );
|
||||||
myDrawer->SetPointAspect( aPointAspect );
|
myDrawer->SetPointAspect( aPointAspect );
|
||||||
@ -188,11 +193,55 @@ void GEOM_Annotation::SetTextColor( const Quantity_Color& theColor )
|
|||||||
void GEOM_Annotation::SetLineColor( const Quantity_Color& theColor )
|
void GEOM_Annotation::SetLineColor( const Quantity_Color& theColor )
|
||||||
{
|
{
|
||||||
myDrawer->LineAspect()->SetColor( theColor );
|
myDrawer->LineAspect()->SetColor( theColor );
|
||||||
|
myDrawer->HiddenLineAspect()->SetColor( theColor );
|
||||||
myDrawer->PointAspect()->SetColor( theColor );
|
myDrawer->PointAspect()->SetColor( theColor );
|
||||||
|
|
||||||
SetToUpdate();
|
SetToUpdate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// =======================================================================
|
||||||
|
// function : SetLineWidth
|
||||||
|
// purpose :
|
||||||
|
// =======================================================================
|
||||||
|
void GEOM_Annotation::SetLineWidth( const Standard_Real theLineWidth )
|
||||||
|
{
|
||||||
|
if ( GetLineWidth() != theLineWidth )
|
||||||
|
{
|
||||||
|
myDrawer->LineAspect()->SetWidth( theLineWidth );
|
||||||
|
myDrawer->HiddenLineAspect()->SetWidth( theLineWidth );
|
||||||
|
|
||||||
|
SetToUpdate();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// =======================================================================
|
||||||
|
// function : SetLineStyle
|
||||||
|
// purpose :
|
||||||
|
// =======================================================================
|
||||||
|
void GEOM_Annotation::SetLineStyle( const Aspect_TypeOfLine theStyle )
|
||||||
|
{
|
||||||
|
if ( GetLineStyle() != theStyle )
|
||||||
|
{
|
||||||
|
myDrawer->LineAspect()->SetTypeOfLine( theStyle );
|
||||||
|
|
||||||
|
SetToUpdate();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// =======================================================================
|
||||||
|
// function : SetHiddenLineStyle
|
||||||
|
// purpose :
|
||||||
|
// =======================================================================
|
||||||
|
void GEOM_Annotation::SetHiddenLineStyle( const Aspect_TypeOfLine theStyle )
|
||||||
|
{
|
||||||
|
if ( GetHiddenLineStyle() != theStyle )
|
||||||
|
{
|
||||||
|
myDrawer->HiddenLineAspect()->SetTypeOfLine( theStyle );
|
||||||
|
|
||||||
|
SetToUpdate();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// =======================================================================
|
// =======================================================================
|
||||||
// function : SetTextHeight
|
// function : SetTextHeight
|
||||||
// purpose :
|
// purpose :
|
||||||
@ -236,28 +285,14 @@ void GEOM_Annotation::SetFont( const TCollection_AsciiString& theFont )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// =======================================================================
|
// =======================================================================
|
||||||
// function : SetLineWidth
|
// function : SetDepthCulling
|
||||||
// purpose :
|
// purpose :
|
||||||
// =======================================================================
|
// =======================================================================
|
||||||
void GEOM_Annotation::SetLineWidth( const Standard_Real theLineWidth )
|
void GEOM_Annotation::SetDepthCulling( const Standard_Boolean theToEnable )
|
||||||
{
|
{
|
||||||
if (GetLineWidth() != theLineWidth)
|
if ( GetDepthCulling() != theToEnable )
|
||||||
{
|
{
|
||||||
myDrawer->LineAspect()->SetWidth( theLineWidth );
|
myIsDepthCulling = theToEnable;
|
||||||
|
|
||||||
SetToUpdate();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// =======================================================================
|
|
||||||
// function : SetLineStyle
|
|
||||||
// purpose :
|
|
||||||
// =======================================================================
|
|
||||||
void GEOM_Annotation::SetLineStyle( const Aspect_TypeOfLine theStyle )
|
|
||||||
{
|
|
||||||
if (GetLineStyle() != theStyle)
|
|
||||||
{
|
|
||||||
myDrawer->LineAspect()->SetTypeOfLine( theStyle );
|
|
||||||
|
|
||||||
SetToUpdate();
|
SetToUpdate();
|
||||||
}
|
}
|
||||||
@ -289,10 +324,23 @@ void GEOM_Annotation::Compute( const Handle(PrsMgr_PresentationManager3d)& /*the
|
|||||||
OpenGl_Annotation* aAnnotationDraw =
|
OpenGl_Annotation* aAnnotationDraw =
|
||||||
new OpenGl_Annotation( this, static_cast<Standard_Integer>( anAsp->Height() ), aGroup->GlStruct()->GlDriver() );
|
new OpenGl_Annotation( this, static_cast<Standard_Integer>( anAsp->Height() ), aGroup->GlStruct()->GlDriver() );
|
||||||
|
|
||||||
aGroup->AddElement( aAnnotationDraw );
|
aAnnotationDraw->SetDepthMode( 0 );
|
||||||
aGroup->SetGroupPrimitivesAspect( myDrawer->TextAspect()->Aspect() );
|
aGroup->SetGroupPrimitivesAspect( myDrawer->TextAspect()->Aspect() );
|
||||||
aGroup->SetGroupPrimitivesAspect( myDrawer->LineAspect()->Aspect() );
|
aGroup->SetGroupPrimitivesAspect( myDrawer->LineAspect()->Aspect() );
|
||||||
aGroup->SetGroupPrimitivesAspect( myDrawer->PointAspect()->Aspect() );
|
aGroup->SetGroupPrimitivesAspect( myDrawer->PointAspect()->Aspect() );
|
||||||
|
aGroup->AddElement( aAnnotationDraw );
|
||||||
|
|
||||||
|
if ( !myIsDepthCulling )
|
||||||
|
{
|
||||||
|
OpenGl_Annotation* aAnnotationDraw =
|
||||||
|
new OpenGl_Annotation( this, static_cast<Standard_Integer>( anAsp->Height() ), aGroup->GlStruct()->GlDriver() );
|
||||||
|
|
||||||
|
aAnnotationDraw->SetDepthMode( GL_GREATER );
|
||||||
|
aGroup->SetPrimitivesAspect( myDrawer->TextAspect()->Aspect() );
|
||||||
|
aGroup->SetPrimitivesAspect( myDrawer->HiddenLineAspect()->Aspect() );
|
||||||
|
aGroup->SetPrimitivesAspect( myDrawer->PointAspect()->Aspect() );
|
||||||
|
aGroup->AddElement( aAnnotationDraw );
|
||||||
|
}
|
||||||
|
|
||||||
Bnd_Box aBox = TextBoundingBox();
|
Bnd_Box aBox = TextBoundingBox();
|
||||||
if ( myIsScreenFixed )
|
if ( myIsScreenFixed )
|
||||||
@ -427,6 +475,7 @@ GEOM_Annotation::OpenGl_Annotation::OpenGl_Annotation( GEOM_Annotation* theAnnot
|
|||||||
const Standard_Integer theTextHeight,
|
const Standard_Integer theTextHeight,
|
||||||
const OpenGl_GraphicDriver* theDriver )
|
const OpenGl_GraphicDriver* theDriver )
|
||||||
: OpenGl_Element(),
|
: OpenGl_Element(),
|
||||||
|
myDepthMode( 0 ),
|
||||||
myAISObject( theAnnotation ),
|
myAISObject( theAnnotation ),
|
||||||
myText( theAnnotation->myText.ToExtString() ),
|
myText( theAnnotation->myText.ToExtString() ),
|
||||||
myTextLineY( 0.f ),
|
myTextLineY( 0.f ),
|
||||||
@ -566,6 +615,14 @@ void GEOM_Annotation::OpenGl_Annotation::Render( const Handle(OpenGl_Workspace)&
|
|||||||
theWorkspace->ApplyAspectLine();
|
theWorkspace->ApplyAspectLine();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GLint myOldDepthMode = 0;
|
||||||
|
|
||||||
|
if ( myDepthMode )
|
||||||
|
{
|
||||||
|
aContext->core11fwd->glGetIntegerv( GL_DEPTH_FUNC, &myOldDepthMode );
|
||||||
|
aContext->core11fwd->glDepthFunc( myDepthMode );
|
||||||
|
}
|
||||||
|
|
||||||
// -------------------------------------------------------------
|
// -------------------------------------------------------------
|
||||||
// render text label in current persistence matrix and underline
|
// render text label in current persistence matrix and underline
|
||||||
// -------------------------------------------------------------
|
// -------------------------------------------------------------
|
||||||
@ -658,6 +715,11 @@ void GEOM_Annotation::OpenGl_Annotation::Render( const Handle(OpenGl_Workspace)&
|
|||||||
aContext->ModelWorldState.Pop();
|
aContext->ModelWorldState.Pop();
|
||||||
aContext->WorldViewState.Pop();
|
aContext->WorldViewState.Pop();
|
||||||
|
|
||||||
|
if ( myOldDepthMode )
|
||||||
|
{
|
||||||
|
aContext->core11fwd->glDepthFunc( myOldDepthMode );
|
||||||
|
}
|
||||||
|
|
||||||
if ( myAISObject->myIsScreenFixed )
|
if ( myAISObject->myIsScreenFixed )
|
||||||
{
|
{
|
||||||
aContext->WorldViewState.Pop();
|
aContext->WorldViewState.Pop();
|
||||||
|
@ -126,6 +126,24 @@ public:
|
|||||||
//! Returns color for the connection line.
|
//! Returns color for the connection line.
|
||||||
Quantity_Color GetLineColor() const { return myDrawer->LineAspect()->Aspect()->Color(); }
|
Quantity_Color GetLineColor() const { return myDrawer->LineAspect()->Aspect()->Color(); }
|
||||||
|
|
||||||
|
//! Sets line width to be used for drawing the annotation's extension line and underline.
|
||||||
|
Standard_EXPORT void SetLineWidth( const Standard_Real theLineWidth );
|
||||||
|
|
||||||
|
//! Returns line width for drawing the annotation's extension line and underline.
|
||||||
|
Standard_Real GetLineWidth() const { return myDrawer->LineAspect()->Aspect()->Width(); }
|
||||||
|
|
||||||
|
//! Sets style of connection line.
|
||||||
|
Standard_EXPORT void SetLineStyle( const Aspect_TypeOfLine theStyle );
|
||||||
|
|
||||||
|
//! Retusn style of connection line.
|
||||||
|
Aspect_TypeOfLine GetLineStyle() const { return myDrawer->LineAspect()->Aspect()->Type(); }
|
||||||
|
|
||||||
|
//! Sets style of hidden connection line.
|
||||||
|
Standard_EXPORT void SetHiddenLineStyle( const Aspect_TypeOfLine theStyle );
|
||||||
|
|
||||||
|
//! Retusn style of hidden connection line.
|
||||||
|
Aspect_TypeOfLine GetHiddenLineStyle() const { return myDrawer->HiddenLineAspect()->Aspect()->Type(); }
|
||||||
|
|
||||||
//! Sets text height in pixels.
|
//! Sets text height in pixels.
|
||||||
Standard_EXPORT void SetTextHeight( const Standard_Real theHeight );
|
Standard_EXPORT void SetTextHeight( const Standard_Real theHeight );
|
||||||
|
|
||||||
@ -144,18 +162,6 @@ public:
|
|||||||
//! Returns font used for drawing the label.
|
//! Returns font used for drawing the label.
|
||||||
TCollection_AsciiString GetFont() const { return myDrawer->TextAspect()->Aspect()->Font(); }
|
TCollection_AsciiString GetFont() const { return myDrawer->TextAspect()->Aspect()->Font(); }
|
||||||
|
|
||||||
//! Sets line width to be used for drawing the annotation's extension line and underline.
|
|
||||||
Standard_EXPORT void SetLineWidth( const Standard_Real theLineWidth );
|
|
||||||
|
|
||||||
//! Returns line width for drawing the annotation's extension line and underline.
|
|
||||||
Standard_Real GetLineWidth() const { return myDrawer->LineAspect()->Aspect()->Width(); }
|
|
||||||
|
|
||||||
//! Sets style of connection line.
|
|
||||||
Standard_EXPORT void SetLineStyle( const Aspect_TypeOfLine theStyle );
|
|
||||||
|
|
||||||
//! Retusn style of connection line.
|
|
||||||
Aspect_TypeOfLine GetLineStyle() const { return myDrawer->LineAspect()->Aspect()->Type(); }
|
|
||||||
|
|
||||||
//! Sets annotation auto-hiding option.
|
//! Sets annotation auto-hiding option.
|
||||||
//! \param theIsEnable [in] the option flag. If passed true, the annotation
|
//! \param theIsEnable [in] the option flag. If passed true, the annotation
|
||||||
//! will be automatically hidden in the view if the attachment point
|
//! will be automatically hidden in the view if the attachment point
|
||||||
@ -172,6 +178,16 @@ public:
|
|||||||
//! Returns highlight mode
|
//! Returns highlight mode
|
||||||
HighlightMode GetHilightMode() const { return myHilightMode; }
|
HighlightMode GetHilightMode() const { return myHilightMode; }
|
||||||
|
|
||||||
|
//! Sets special flag that allows disabling depth testing when rendering
|
||||||
|
//! the graphical presentation. When disable the hidden parts such as
|
||||||
|
//! lines and text become visible and a rendered with another drawing
|
||||||
|
//! aspect. This mode should be explicitly used with setting top layer
|
||||||
|
//! for the presentation. Otherwise the behavior is undefined.
|
||||||
|
Standard_EXPORT void SetDepthCulling (const Standard_Boolean theToEnable);
|
||||||
|
|
||||||
|
//! Returns depth culling state.
|
||||||
|
Standard_Boolean GetDepthCulling() const { return myIsDepthCulling; }
|
||||||
|
|
||||||
// Interactive dragging:
|
// Interactive dragging:
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@ -216,6 +232,7 @@ private:
|
|||||||
gp_Pnt myStartPosition; //!< Position before starting dragging operation.
|
gp_Pnt myStartPosition; //!< Position before starting dragging operation.
|
||||||
Standard_Boolean myIsScreenFixed; //!< Flag indicating whether "screen fixed" positioning mode is turned on or off.
|
Standard_Boolean myIsScreenFixed; //!< Flag indicating whether "screen fixed" positioning mode is turned on or off.
|
||||||
Standard_Boolean myIsAutoHide; //!< Flag indicating whether "auto-hiding" option is turned on.
|
Standard_Boolean myIsAutoHide; //!< Flag indicating whether "auto-hiding" option is turned on.
|
||||||
|
Standard_Boolean myIsDepthCulling; //!< Flag indiciating whether the "depth culling" is turned on.
|
||||||
HighlightMode myHilightMode; //!< Highlight mode for presentation.
|
HighlightMode myHilightMode; //!< Highlight mode for presentation.
|
||||||
TCollection_ExtendedString myText; //!< Text string of the label presentation.
|
TCollection_ExtendedString myText; //!< Text string of the label presentation.
|
||||||
|
|
||||||
@ -245,6 +262,8 @@ private:
|
|||||||
//! Renders the annotation graphical elements.
|
//! Renders the annotation graphical elements.
|
||||||
virtual void Render( const Handle(OpenGl_Workspace)& theWorkspace ) const Standard_OVERRIDE;
|
virtual void Render( const Handle(OpenGl_Workspace)& theWorkspace ) const Standard_OVERRIDE;
|
||||||
|
|
||||||
|
void SetDepthMode( const int theMode ) { myDepthMode = theMode; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
struct TextSize {
|
struct TextSize {
|
||||||
@ -261,6 +280,7 @@ private:
|
|||||||
OpenGl_PrimitiveArray* myTextLineDraw; //!< Text underline draw element.
|
OpenGl_PrimitiveArray* myTextLineDraw; //!< Text underline draw element.
|
||||||
OpenGl_PrimitiveArray* myExtLineDraw; //!< Extension line draw element.
|
OpenGl_PrimitiveArray* myExtLineDraw; //!< Extension line draw element.
|
||||||
OpenGl_PrimitiveArray* myExtMarkerDraw; //!< Extension marker draw element.
|
OpenGl_PrimitiveArray* myExtMarkerDraw; //!< Extension marker draw element.
|
||||||
|
int myDepthMode; //!< Depth mode for drawing hidden line presentation.
|
||||||
mutable float myTextLineY; //!< Text's underlines relative position.
|
mutable float myTextLineY; //!< Text's underlines relative position.
|
||||||
mutable TextSize myTextSize; //!< Text's size parameters
|
mutable TextSize myTextSize; //!< Text's size parameters
|
||||||
mutable Graphic3d_Vec2 myTextUnderline; //!< Text's underline position.
|
mutable Graphic3d_Vec2 myTextUnderline; //!< Text's underline position.
|
||||||
|
Loading…
Reference in New Issue
Block a user