mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-04-16 06:09:29 +02:00
LCL: TScrollingWinControl.ScrollInView or TScrollBox.ScrollInView does not calculate stacked controls, second attempt. Issue #38838.
git-svn-id: trunk@65083 -
This commit is contained in:
parent
5c8e7c1abb
commit
c25e153265
@ -249,18 +249,15 @@ end;
|
||||
procedure TScrollingWinControl.ScrollInView(AControl: TControl);
|
||||
var
|
||||
LRect: TRect;
|
||||
LParent: TWinControl;
|
||||
LPoint: TPoint;
|
||||
begin
|
||||
if AControl = nil then Exit;
|
||||
LRect := AControl.BoundsRect;
|
||||
LParent := AControl.Parent;
|
||||
while LParent <> Self do
|
||||
begin
|
||||
OffsetRect(LRect, LParent.BoundsRect.Left, LParent.BoundsRect.Top);
|
||||
LParent := LParent.Parent;
|
||||
if LParent = nil then Exit; //ScrollingWinControl isn't parent of AControl
|
||||
end;
|
||||
OffsetRect(LRect, -HorzScrollBar.Position, -VertScrollBar.Position);
|
||||
LPoint := AControl.ClientToParent(Point(0, 0), Self);
|
||||
LRect.Left := LPoint.x;
|
||||
LRect.Top := LPoint.y;
|
||||
LPoint := AControl.ClientToParent(Point(AControl.Width, AControl.Height), Self);
|
||||
LRect.Right := LPoint.x;
|
||||
LRect.Bottom := LPoint.y;
|
||||
if LRect.Left < 0 then
|
||||
HorzScrollBar.Position := HorzScrollBar.Position + LRect.Left
|
||||
else if LRect.Right > ClientWidth then
|
||||
|
Loading…
Reference in New Issue
Block a user