projects
/
platform
/
core
/
uifw
/
dali-toolkit.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'devel/master' into devel/new_mesh
[platform/core/uifw/dali-toolkit.git]
/
dali-toolkit
/
internal
/
controls
/
text-controls
/
text-label-impl.cpp
diff --git
a/dali-toolkit/internal/controls/text-controls/text-label-impl.cpp
b/dali-toolkit/internal/controls/text-controls/text-label-impl.cpp
index
de713ac
..
4bbadfb
100644
(file)
--- a/
dali-toolkit/internal/controls/text-controls/text-label-impl.cpp
+++ b/
dali-toolkit/internal/controls/text-controls/text-label-impl.cpp
@@
-453,6
+453,7
@@
void TextLabel::OnInitialize()
// Enable the text ellipsis.
LayoutEngine& engine = mController->GetLayoutEngine();
engine.SetTextEllipsisEnabled( true );
// Enable the text ellipsis.
LayoutEngine& engine = mController->GetLayoutEngine();
engine.SetTextEllipsisEnabled( true );
+ self.OnStageSignal().Connect( this, &TextLabel::OnStageConnect );
}
void TextLabel::OnStyleChange( Toolkit::StyleManager styleManager, StyleChange::Type change )
}
void TextLabel::OnStyleChange( Toolkit::StyleManager styleManager, StyleChange::Type change )
@@
-479,38
+480,58
@@
void TextLabel::OnRelayout( const Vector2& size, RelayoutContainer& container )
{
mRenderer = Backend::Get().NewRenderer( mRenderingBackend );
}
{
mRenderer = Backend::Get().NewRenderer( mRenderingBackend );
}
+ RenderText();
+ }
+}
- RenderableActor renderableActor;
- if( mRenderer )
- {
- renderableActor = mRenderer->Render( mController->GetView() );
- }
+void TextLabel::RequestTextRelayout()
+{
+ RelayoutRequest();
+}
- if( renderableActor != mRenderableActor )
- {
- UnparentAndReset( mRenderableActor );
+void TextLabel::RenderText()
+{
+ Actor renderableActor;
+ if( mRenderer )
+ {
+ renderableActor = mRenderer->Render( mController->GetView(), mDepth );
+ }
- if( renderableActor )
- {
- const Vector2& alignmentOffset = mController->GetAlignmentOffset();
- renderableActor.SetPosition( alignmentOffset.x, alignmentOffset.y );
+ if( renderableActor != mRenderableActor )
+ {
+ UnparentAndReset( mRenderableActor );
- Self().Add( renderableActor );
- }
+ if( renderableActor )
+ {
+ const Vector2& alignmentOffset = mController->GetAlignmentOffset();
+ renderableActor.SetPosition( alignmentOffset.x, alignmentOffset.y );
-
mRenderableActor = renderableActor
;
+
Self().Add( renderableActor )
;
}
}
+ mRenderableActor = renderableActor;
+ }
+}
+
+void TextLabel::OnStageConnect( Dali::Actor actor )
+{
+ if ( mHasBeenStaged )
+ {
+ RenderText();
+ }
+ else
+ {
+ mHasBeenStaged = true;
}
}
}
}
-void TextLabel::AddDecoration( Actor& actor )
+void TextLabel::AddDecoration( Actor& actor
, bool needsClipping
)
{
// TextLabel does not show decorations
}
{
// TextLabel does not show decorations
}
-void TextLabel::
RequestTextRelayout(
)
+void TextLabel::
OnStageConnection( unsigned int depth
)
{
{
-
RelayoutRequest()
;
+
mDepth = depth
;
}
void TextLabel::TextChanged()
}
void TextLabel::TextChanged()
@@
-525,7
+546,9
@@
void TextLabel::MaxLengthReached()
TextLabel::TextLabel()
: Control( ControlBehaviour( REQUIRES_STYLE_CHANGE_SIGNALS ) ),
TextLabel::TextLabel()
: Control( ControlBehaviour( REQUIRES_STYLE_CHANGE_SIGNALS ) ),
- mRenderingBackend( DEFAULT_RENDERING_BACKEND )
+ mRenderingBackend( DEFAULT_RENDERING_BACKEND ),
+ mDepth( 0 ),
+ mHasBeenStaged( false )
{
}
{
}