mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-09-02 10:40:41 +02:00
Revert "LCL/Graphics: Fix win32 WS not drawing incomplete continuous Bezier segments in PolyBezier. Do not copy points in overloaded procedure."
This reverts commit 12799e965a
.
This commit is contained in:
parent
12799e965a
commit
b21a3243d5
@ -840,11 +840,19 @@ end;
|
||||
procedure TCanvas.PolyBezier(const Points: array of TPoint;
|
||||
Filled: boolean = False;
|
||||
Continuous: boolean = True);
|
||||
var NPoints: integer;
|
||||
var NPoints, i: integer;
|
||||
PointArray: ^TPoint;
|
||||
begin
|
||||
NPoints:=High(Points)-Low(Points)+1;
|
||||
if NPoints<4 then exit; // Curve must have at least 4 points
|
||||
PolyBezier(@Points[0], NPoints, Filled, Continuous);
|
||||
GetMem(PointArray,SizeOf(TPoint)*NPoints);
|
||||
try
|
||||
for i:=0 to NPoints-1 do
|
||||
PointArray[i]:=Points[i+Low(Points)];
|
||||
PolyBezier(PointArray, NPoints, Filled, Continuous);
|
||||
finally
|
||||
FreeMem(PointArray);
|
||||
end;
|
||||
end;
|
||||
|
||||
procedure TCanvas.PolyBezier(Points: PPoint; NumPts: Integer;
|
||||
|
@ -2852,12 +2852,7 @@ begin
|
||||
If Filled or (not Continuous) then
|
||||
Result := Inherited PolyBezier(DC,Points,NumPts, Filled, Continuous)
|
||||
else
|
||||
begin
|
||||
// Make sure that only complete bezier segments are included in this mode.
|
||||
// Otherwise, Windows will not draw anything at all.
|
||||
NumPts := (NumPts - 1) div 3 * 3 + 1;
|
||||
Result := Boolean(Windows.PolyBezier(DC, LPPOINT(Points)^, NumPts));
|
||||
end;
|
||||
end;
|
||||
|
||||
{------------------------------------------------------------------------------
|
||||
|
Loading…
Reference in New Issue
Block a user