mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
RCTText should clip when the creates Layout is wider than requested
Summary: AbstractDrawCommand's bounds are supposed to be the rectangle that the DrawCommand will draw into, so that it can compare bounds against clip rect bounds and reliable skip clipping when it's not needed. It is however not true for RCTText that can create text Layout that in some cases can go out of it's requested bounds (happens with TextView, too). To fix the issue, instead of passing requested bounds, pass the actual ones. In this case, AbstractDrawCommand will make sure to clip DrawTextLayout if for some reason it draws outside of the allowed boundaries. Reviewed By: ahmedre Differential Revision: D2786306
This commit is contained in:
committed by
Ahmed El-Helw
parent
d23f86e47b
commit
e3abc51dd7
@@ -18,9 +18,10 @@ import android.text.Layout;
|
||||
/* package */ final class DrawTextLayout extends AbstractDrawCommand {
|
||||
|
||||
private Layout mLayout;
|
||||
private float mLayoutWidth;
|
||||
|
||||
/* package */ DrawTextLayout(Layout layout) {
|
||||
mLayout = layout;
|
||||
setLayout(layout);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -28,12 +29,30 @@ import android.text.Layout;
|
||||
*/
|
||||
public void setLayout(Layout layout) {
|
||||
mLayout = layout;
|
||||
|
||||
// determine how wide we actually are
|
||||
float maxLineWidth = 0;
|
||||
int lineCount = layout.getLineCount();
|
||||
for (int i = 0; i != lineCount; ++i) {
|
||||
maxLineWidth = Math.max(maxLineWidth, layout.getLineMax(i));
|
||||
}
|
||||
|
||||
mLayoutWidth = maxLineWidth;
|
||||
}
|
||||
|
||||
public Layout getLayout() {
|
||||
return mLayout;
|
||||
}
|
||||
|
||||
public float getLayoutWidth() {
|
||||
// mLayout.getWidth() doesn't return correct width of the text Layout
|
||||
return mLayoutWidth;
|
||||
}
|
||||
|
||||
public float getLayoutHeight() {
|
||||
return mLayout.getHeight();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onDraw(Canvas canvas) {
|
||||
float left = getLeft();
|
||||
|
||||
Reference in New Issue
Block a user