am 4258bfb7: Merge "Fix some drawing artifacts/bugs around overlays/text anchors" into gingerbread
Merge commit '4258bfb7a9fb18907fbfbe79ec0a937b4e7382b1' into gingerbread-plus-aosp * commit '4258bfb7a9fb18907fbfbe79ec0a937b4e7382b1': Fix some drawing artifacts/bugs around overlays/text anchors
This commit is contained in:
@@ -3542,10 +3542,10 @@ public abstract class ViewGroup extends View implements ViewParent, ViewManager
|
||||
for (int i = 0; i < childCount; i++) {
|
||||
final View child = getChildAt(i);
|
||||
if (child.isOverlayEnabled()) {
|
||||
canvas.translate(child.mLeft + child.mScrollX, child.mTop + child.mScrollY);
|
||||
canvas.translate(child.mLeft - child.mScrollX, child.mTop - child.mScrollY);
|
||||
child.onDrawOverlay(canvas);
|
||||
canvas.translate(-(child.mLeft + child.mScrollX),
|
||||
-(child.mTop + child.mScrollY));
|
||||
canvas.translate(-(child.mLeft - child.mScrollX),
|
||||
-(child.mTop - child.mScrollY));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -7732,8 +7732,9 @@ public class TextView extends View implements ViewTreeObserver.OnPreDrawListener
|
||||
bounds.bottom = bounds.top + drawableHeight;
|
||||
|
||||
convertFromViewportToContentCoordinates(bounds);
|
||||
invalidate();
|
||||
mDrawable.setBounds(bounds);
|
||||
postInvalidate();
|
||||
invalidate();
|
||||
}
|
||||
|
||||
boolean hasFingerOn(float x, float y) {
|
||||
@@ -7750,9 +7751,16 @@ public class TextView extends View implements ViewTreeObserver.OnPreDrawListener
|
||||
return Rect.intersects(mDrawable.getBounds(), fingerRect);
|
||||
}
|
||||
|
||||
void invalidate() {
|
||||
final Rect bounds = mDrawable.getBounds();
|
||||
TextView.this.invalidate(bounds.left, bounds.top,
|
||||
bounds.right, bounds.bottom);
|
||||
}
|
||||
|
||||
void postInvalidate() {
|
||||
final Rect bounds = mDrawable.getBounds();
|
||||
TextView.this.postInvalidate(bounds.left, bounds.top, bounds.right, bounds.bottom);
|
||||
TextView.this.postInvalidate(bounds.left, bounds.top,
|
||||
bounds.right, bounds.bottom);
|
||||
}
|
||||
|
||||
void postInvalidateDelayed(long delay) {
|
||||
|
||||
Reference in New Issue
Block a user