mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-28 14:00:33 +05:00
Fixed underline position and central alignment of annotation text
This commit is contained in:
parent
bc38a38ac1
commit
dd80de5b8c
@ -355,10 +355,10 @@ Bnd_Box GEOM_Annotation::TextBoundingBox() const
|
|||||||
aResolution ) )
|
aResolution ) )
|
||||||
{
|
{
|
||||||
const NCollection_String aText( (Standard_Utf16Char* )myText.ToExtString() );
|
const NCollection_String aText( (Standard_Utf16Char* )myText.ToExtString() );
|
||||||
const Font_Rect aFontRect = aFont.BoundingBox( aText, Graphic3d_HTA_LEFT, Graphic3d_VTA_BOTTOM );
|
const Font_Rect aFontRect = aFont.BoundingBox( aText, Graphic3d_HTA_CENTER, Graphic3d_VTA_CENTER );
|
||||||
Bnd_Box aBox;
|
Bnd_Box aBox;
|
||||||
aBox.Add( gp_Pnt( 0.0, 0.0, 0.0 ) );
|
aBox.Add( gp_Pnt( aFontRect.Left, aFontRect.Bottom, 0.0 ) );
|
||||||
aBox.Add( gp_Pnt( aFontRect.Width(), aFontRect.Height(), 0.0 ) );
|
aBox.Add( gp_Pnt( aFontRect.Right, aFontRect.Top, 0.0 ) );
|
||||||
return aBox;
|
return aBox;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -434,8 +434,8 @@ GEOM_Annotation::OpenGl_Annotation::OpenGl_Annotation( GEOM_Annotation* theAnnot
|
|||||||
{
|
{
|
||||||
// graphical resources for drawing text and underline
|
// graphical resources for drawing text and underline
|
||||||
myTextParams.Height = theTextHeight;
|
myTextParams.Height = theTextHeight;
|
||||||
myTextParams.HAlign = Graphic3d_HTA_LEFT;
|
myTextParams.HAlign = Graphic3d_HTA_CENTER;
|
||||||
myTextParams.VAlign = Graphic3d_VTA_BOTTOM;
|
myTextParams.VAlign = Graphic3d_VTA_CENTER;
|
||||||
myTextDraw = new OpenGl_Text( myText.ToCString(), OpenGl_Vec3(), myTextParams );
|
myTextDraw = new OpenGl_Text( myText.ToCString(), OpenGl_Vec3(), myTextParams );
|
||||||
myTextLineDraw = new OpenGl_PrimitiveArray( theDriver );
|
myTextLineDraw = new OpenGl_PrimitiveArray( theDriver );
|
||||||
|
|
||||||
@ -505,16 +505,32 @@ void GEOM_Annotation::OpenGl_Annotation::Render( const Handle(OpenGl_Workspace)&
|
|||||||
// getting string size will also initialize font library
|
// getting string size will also initialize font library
|
||||||
myTextDraw->StringSize( aContext,
|
myTextDraw->StringSize( aContext,
|
||||||
myText, *anAspect, myTextParams, aDPI,
|
myText, *anAspect, myTextParams, aDPI,
|
||||||
myTextSize.x(), myTextSize.y(), myTextSize.z() );
|
myTextSize.x, myTextSize.a, myTextSize.d );
|
||||||
|
|
||||||
myTextDPI = aDPI;
|
myTextDPI = aDPI;
|
||||||
myTextUnderline.x() = 0.f;
|
myTextSize.y = myTextSize.a - myTextSize.d;
|
||||||
myTextUnderline.y() = ceil( myTextSize.y() * -0.2f );
|
switch (myTextParams.HAlign)
|
||||||
|
{
|
||||||
|
case Graphic3d_HTA_LEFT: myTextUnderline.x() = 0.f; break;
|
||||||
|
case Graphic3d_HTA_CENTER: myTextUnderline.x() = -myTextSize.x / 2.f; break;
|
||||||
|
case Graphic3d_HTA_RIGHT: myTextUnderline.x() = -myTextSize.x; break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (myTextParams.VAlign)
|
||||||
|
{
|
||||||
|
case Graphic3d_VTA_TOPFIRSTLINE:
|
||||||
|
case Graphic3d_VTA_TOP: myTextUnderline.y() = -myTextSize.y; break;
|
||||||
|
case Graphic3d_VTA_CENTER: myTextUnderline.y() = -myTextSize.y / 2.f; break;
|
||||||
|
case Graphic3d_VTA_BOTTOM: myTextUnderline.y() = myTextSize.d; break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
Handle(Graphic3d_ArrayOfSegments)
|
Handle(Graphic3d_ArrayOfSegments)
|
||||||
aVertexArray = new Graphic3d_ArrayOfSegments( 2 );
|
aVertexArray = new Graphic3d_ArrayOfSegments( 2 );
|
||||||
aVertexArray->AddVertex( 0.0f, myTextUnderline.y(), 0.0f );
|
aVertexArray->AddVertex( myTextUnderline.x(), myTextUnderline.y(), 0.0f );
|
||||||
aVertexArray->AddVertex( myTextSize.x(), myTextUnderline.y(), 0.0f );
|
aVertexArray->AddVertex( myTextUnderline.x() + myTextSize.x, myTextUnderline.y(), 0.0f );
|
||||||
myTextLineDraw->InitBuffers( aContext, Graphic3d_TOPA_SEGMENTS,
|
myTextLineDraw->InitBuffers( aContext, Graphic3d_TOPA_SEGMENTS,
|
||||||
aVertexArray->Indices(), aVertexArray->Attributes(), aVertexArray->Bounds() );
|
aVertexArray->Indices(), aVertexArray->Attributes(), aVertexArray->Bounds() );
|
||||||
}
|
}
|
||||||
@ -556,6 +572,8 @@ void GEOM_Annotation::OpenGl_Annotation::Render( const Handle(OpenGl_Workspace)&
|
|||||||
|
|
||||||
if ( myAISObject->myIsScreenFixed )
|
if ( myAISObject->myIsScreenFixed )
|
||||||
{
|
{
|
||||||
|
// use text position property instead of matrix setup
|
||||||
|
// to avoid jittering when dragging text
|
||||||
myTextDraw->SetPosition( OpenGl_Vec3( static_cast<float>( myAISObject->myPosition.X() ),
|
myTextDraw->SetPosition( OpenGl_Vec3( static_cast<float>( myAISObject->myPosition.X() ),
|
||||||
static_cast<float>( myAISObject->myPosition.Y() ),
|
static_cast<float>( myAISObject->myPosition.Y() ),
|
||||||
static_cast<float>( myAISObject->myPosition.Z() ) ) );
|
static_cast<float>( myAISObject->myPosition.Z() ) ) );
|
||||||
@ -588,10 +606,26 @@ void GEOM_Annotation::OpenGl_Annotation::Render( const Handle(OpenGl_Workspace)&
|
|||||||
// render dynamic extension line using synthetic transformation
|
// render dynamic extension line using synthetic transformation
|
||||||
// ------------------------------------------------------------
|
// ------------------------------------------------------------
|
||||||
|
|
||||||
|
OpenGl_Vec4 aCenter (0.f, 0.f, 0.f, 1.f);
|
||||||
|
switch (myTextParams.HAlign)
|
||||||
|
{
|
||||||
|
case Graphic3d_HTA_LEFT: aCenter.x() = myTextSize.x / 2.f; break;
|
||||||
|
case Graphic3d_HTA_CENTER: aCenter.x() = 0.f; break;
|
||||||
|
case Graphic3d_HTA_RIGHT: aCenter.x() = -myTextSize.x / 2.f; break;
|
||||||
|
default: break;
|
||||||
|
}
|
||||||
|
switch (myTextParams.VAlign)
|
||||||
|
{
|
||||||
|
case Graphic3d_VTA_TOPFIRSTLINE:
|
||||||
|
case Graphic3d_VTA_TOP: aCenter.y() = -myTextSize.y / 2.f; break;
|
||||||
|
case Graphic3d_VTA_CENTER: aCenter.y() = 0.f; break;
|
||||||
|
case Graphic3d_VTA_BOTTOM: aCenter.y() = myTextSize.y / 2.f; break;
|
||||||
|
default: break;
|
||||||
|
}
|
||||||
|
|
||||||
// compute label's center in view coordinate space
|
// compute label's center in view coordinate space
|
||||||
const OpenGl_Mat4& aViewMat = aContext->WorldViewState.Current();
|
const OpenGl_Mat4& aViewMat = aContext->WorldViewState.Current();
|
||||||
const OpenGl_Vec4 aCenterView =
|
const OpenGl_Vec4 aCenterView = aViewMat * aCenter;
|
||||||
aViewMat * OpenGl_Vec4( myTextSize.x() / 2.0f, myTextSize.y() / 2.0f, 0.0f, 1.0f );
|
|
||||||
|
|
||||||
// the value below defines whether the extension line should be hanging
|
// the value below defines whether the extension line should be hanging
|
||||||
// on the left side of the label or on the right
|
// on the left side of the label or on the right
|
||||||
@ -599,7 +633,7 @@ void GEOM_Annotation::OpenGl_Annotation::Render( const Handle(OpenGl_Workspace)&
|
|||||||
|
|
||||||
// compute extension line point at the text label in view coordinate space
|
// compute extension line point at the text label in view coordinate space
|
||||||
const OpenGl_Vec4 aHingeView = aViewMat * OpenGl_Vec4(
|
const OpenGl_Vec4 aHingeView = aViewMat * OpenGl_Vec4(
|
||||||
( isLeftHanded ? myTextUnderline.x() : myTextUnderline.x() + myTextSize.x() ), myTextUnderline.y(), 0.0f, 1.0f );
|
( isLeftHanded ? myTextUnderline.x() : myTextUnderline.x() + myTextSize.x ), myTextUnderline.y(), 0.0f, 1.0f );
|
||||||
|
|
||||||
// prepare matrix to specify geometry of extension line in view space
|
// prepare matrix to specify geometry of extension line in view space
|
||||||
// by multiplication of unit z coordinate vector on given matrix.
|
// by multiplication of unit z coordinate vector on given matrix.
|
||||||
|
@ -247,6 +247,13 @@ private:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
struct TextSize {
|
||||||
|
float x; // width
|
||||||
|
float y; // height
|
||||||
|
float a; // ascent
|
||||||
|
float d; // descent
|
||||||
|
};
|
||||||
|
|
||||||
GEOM_Annotation* myAISObject; //!< Instance of presentation class.
|
GEOM_Annotation* myAISObject; //!< Instance of presentation class.
|
||||||
NCollection_String myText; //!< Text string of annotation label.
|
NCollection_String myText; //!< Text string of annotation label.
|
||||||
OpenGl_TextParam myTextParams; //!< Text draw parameters.
|
OpenGl_TextParam myTextParams; //!< Text draw parameters.
|
||||||
@ -255,7 +262,7 @@ private:
|
|||||||
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.
|
||||||
mutable float myTextLineY; //!< Text's underlines relative position.
|
mutable float myTextLineY; //!< Text's underlines relative position.
|
||||||
mutable Graphic3d_Vec3 myTextSize; //!< Text's width, height and descent.
|
mutable TextSize myTextSize; //!< Text's size parameters
|
||||||
mutable Graphic3d_Vec2 myTextUnderline; //!< Text's underline position.
|
mutable Graphic3d_Vec2 myTextUnderline; //!< Text's underline position.
|
||||||
mutable unsigned int myTextDPI; //!< Text's DPI scale used for last rendering.
|
mutable unsigned int myTextDPI; //!< Text's DPI scale used for last rendering.
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user