Create annotation interaction and "hidden line" mode

This commit is contained in:
apl 2016-10-21 12:52:30 +03:00
parent 71725ed92f
commit 2e7629270a
10 changed files with 280 additions and 70 deletions

View File

@ -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;

View File

@ -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 );
} }

View File

@ -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.

View File

@ -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
View 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 )
{ {

View File

@ -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
View File

@ -137,7 +137,11 @@ void MeasureGUI_AnnotationInteractor::Disable()
myActiveViewPort = NULL; myActiveViewPort = NULL;
} }
if ( !myActiveIO.IsNull() )
{
emit SignalInteractionFinished( myActiveIO );
myActiveIO.Nullify(); myActiveIO.Nullify();
}
} }
//================================================================================= //=================================================================================
@ -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
View 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.

View File

@ -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,22 +193,66 @@ 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 :
// ======================================================================= // =======================================================================
void GEOM_Annotation::SetTextHeight( const Standard_Real theHeight ) void GEOM_Annotation::SetTextHeight( const Standard_Real theHeight )
{ {
if (GetTextHeight() != theHeight) if ( GetTextHeight() != theHeight )
{ {
myDrawer->TextAspect()->SetHeight( theHeight ); myDrawer->TextAspect()->SetHeight( theHeight );
SetToUpdate (); SetToUpdate();
} }
} }
@ -213,7 +262,7 @@ void GEOM_Annotation::SetTextHeight( const Standard_Real theHeight )
// ======================================================================= // =======================================================================
void GEOM_Annotation::SetFontAspect( const Font_FontAspect theFontAspect ) void GEOM_Annotation::SetFontAspect( const Font_FontAspect theFontAspect )
{ {
if (GetFontAspect() != theFontAspect) if ( GetFontAspect() != theFontAspect )
{ {
myDrawer->TextAspect()->Aspect()->SetTextFontAspect( theFontAspect ); myDrawer->TextAspect()->Aspect()->SetTextFontAspect( theFontAspect );
@ -227,7 +276,7 @@ void GEOM_Annotation::SetFontAspect( const Font_FontAspect theFontAspect )
// ======================================================================= // =======================================================================
void GEOM_Annotation::SetFont( const TCollection_AsciiString& theFont ) void GEOM_Annotation::SetFont( const TCollection_AsciiString& theFont )
{ {
if (GetFont() != theFont) if ( GetFont() != theFont )
{ {
myDrawer->TextAspect()->Aspect()->SetFont( theFont ); myDrawer->TextAspect()->Aspect()->SetFont( theFont );
@ -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,14 +715,19 @@ void GEOM_Annotation::OpenGl_Annotation::Render( const Handle(OpenGl_Workspace)&
aContext->ModelWorldState.Pop(); aContext->ModelWorldState.Pop();
aContext->WorldViewState.Pop(); aContext->WorldViewState.Pop();
if (myAISObject->myIsScreenFixed) if ( myOldDepthMode )
{
aContext->core11fwd->glDepthFunc( myOldDepthMode );
}
if ( myAISObject->myIsScreenFixed )
{ {
aContext->WorldViewState.Pop(); aContext->WorldViewState.Pop();
} }
aContext->ApplyModelViewMatrix(); aContext->ApplyModelViewMatrix();
if (toHighlight != theWorkspace->ToHighlight()) if ( toHighlight != theWorkspace->ToHighlight() )
{ {
theWorkspace->SetHighlight( toHighlight ); theWorkspace->SetHighlight( toHighlight );
} }

View File

@ -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.