mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-08-19 09:59:10 +02:00
Printers, Fix printing regression under linux, issue #34680
git-svn-id: trunk@59823 -
This commit is contained in:
parent
75136b6580
commit
8965b70a28
@ -34,6 +34,7 @@ type
|
|||||||
{$ifdef pangocairo}
|
{$ifdef pangocairo}
|
||||||
fFontDesc: PPangoFontDescription;
|
fFontDesc: PPangoFontDescription;
|
||||||
fFontDescStr: string;
|
fFontDescStr: string;
|
||||||
|
fPageBegun: boolean;
|
||||||
function StylesToStr(Styles: TFontStyles):string;
|
function StylesToStr(Styles: TFontStyles):string;
|
||||||
procedure UpdatePangoLayout(Layout: PPangoLayout);
|
procedure UpdatePangoLayout(Layout: PPangoLayout);
|
||||||
{$endif}
|
{$endif}
|
||||||
@ -89,6 +90,8 @@ type
|
|||||||
procedure BeginDoc; override;
|
procedure BeginDoc; override;
|
||||||
procedure EndDoc; override;
|
procedure EndDoc; override;
|
||||||
procedure NewPage; override;
|
procedure NewPage; override;
|
||||||
|
procedure BeginPage; override;
|
||||||
|
procedure EndPage; override;
|
||||||
procedure FillRect(const ARect: TRect); override;
|
procedure FillRect(const ARect: TRect); override;
|
||||||
procedure Rectangle(X1,Y1,X2,Y2: Integer); override;
|
procedure Rectangle(X1,Y1,X2,Y2: Integer); override;
|
||||||
procedure Polyline(Points: PPoint; NumPts: Integer); override;
|
procedure Polyline(Points: PPoint; NumPts: Integer); override;
|
||||||
@ -113,6 +116,7 @@ type
|
|||||||
public
|
public
|
||||||
procedure MixedRoundRect(X1, Y1, X2, Y2: Integer; RX, RY: Integer; SquaredCorners: TSquaredCorners);
|
procedure MixedRoundRect(X1, Y1, X2, Y2: Integer; RX, RY: Integer; SquaredCorners: TSquaredCorners);
|
||||||
procedure DrawSurface(const SourceRect, DestRect: TRect; surface: Pcairo_surface_t);
|
procedure DrawSurface(const SourceRect, DestRect: TRect; surface: Pcairo_surface_t);
|
||||||
|
procedure UpdatePageSize; virtual;
|
||||||
{ Not implemented
|
{ Not implemented
|
||||||
procedure FloodFill(X, Y: Integer; FillColor: TColor; FillStyle: TFillStyle); override;
|
procedure FloodFill(X, Y: Integer; FillColor: TColor; FillStyle: TFillStyle); override;
|
||||||
procedure CopyRect(const Dest: TRect; SrcCanvas: TCanvas; const Source: TRect); override;
|
procedure CopyRect(const Dest: TRect; SrcCanvas: TCanvas; const Source: TRect); override;
|
||||||
@ -127,7 +131,6 @@ type
|
|||||||
fStream: TStream;
|
fStream: TStream;
|
||||||
procedure DestroyCairoHandle; override;
|
procedure DestroyCairoHandle; override;
|
||||||
public
|
public
|
||||||
procedure UpdatePageSize; virtual;
|
|
||||||
property Stream: TStream read fStream write fStream;
|
property Stream: TStream read fStream write fStream;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
@ -349,15 +352,13 @@ end;
|
|||||||
procedure TCairoPrinterCanvas.BeginDoc;
|
procedure TCairoPrinterCanvas.BeginDoc;
|
||||||
begin
|
begin
|
||||||
inherited BeginDoc;
|
inherited BeginDoc;
|
||||||
if assigned(printer) then
|
BeginPage;
|
||||||
FLazClipRect:=printer.PaperSize.PaperRect.WorkRect;
|
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TCairoPrinterCanvas.EndDoc;
|
procedure TCairoPrinterCanvas.EndDoc;
|
||||||
begin
|
begin
|
||||||
inherited EndDoc;
|
inherited EndDoc;
|
||||||
cairo_show_page(cr);
|
EndPage;
|
||||||
FLazClipRect := Rect(0, 0, 0, 0);
|
|
||||||
//if caller is printer, then at the end destroy cairo handles (flush output)
|
//if caller is printer, then at the end destroy cairo handles (flush output)
|
||||||
//and establishes CreateCairoHandle call on the next print
|
//and establishes CreateCairoHandle call on the next print
|
||||||
Handle := 0;
|
Handle := 0;
|
||||||
@ -365,8 +366,29 @@ end;
|
|||||||
|
|
||||||
procedure TCairoPrinterCanvas.NewPage;
|
procedure TCairoPrinterCanvas.NewPage;
|
||||||
begin
|
begin
|
||||||
inherited NewPage;
|
EndPage;
|
||||||
cairo_show_page(cr);
|
BeginPage;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure TCairoPrinterCanvas.BeginPage;
|
||||||
|
begin
|
||||||
|
if assigned(printer) then
|
||||||
|
begin
|
||||||
|
FLazClipRect:=printer.PaperSize.PaperRect.WorkRect;
|
||||||
|
if HandleAllocated then
|
||||||
|
UpdatePageSize;
|
||||||
|
end;
|
||||||
|
fPageBegun := true;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure TCairoPrinterCanvas.EndPage;
|
||||||
|
begin
|
||||||
|
if fPageBegun then
|
||||||
|
begin
|
||||||
|
cairo_show_page(cr);
|
||||||
|
FLazClipRect := Rect(0, 0, 0, 0);
|
||||||
|
fPageBegun := false;
|
||||||
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TCairoPrinterCanvas.CreateBrush;
|
procedure TCairoPrinterCanvas.CreateBrush;
|
||||||
@ -795,6 +817,10 @@ begin
|
|||||||
Changed;
|
Changed;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
procedure TCairoPrinterCanvas.UpdatePageSize;
|
||||||
|
begin
|
||||||
|
end;
|
||||||
|
|
||||||
procedure TCairoPrinterCanvas.Ellipse(X1, Y1, X2, Y2: Integer);
|
procedure TCairoPrinterCanvas.Ellipse(X1, Y1, X2, Y2: Integer);
|
||||||
begin
|
begin
|
||||||
Changing;
|
Changing;
|
||||||
@ -1470,10 +1496,6 @@ begin
|
|||||||
sf := nil;
|
sf := nil;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TCairoFileCanvas.UpdatePageSize;
|
|
||||||
begin
|
|
||||||
end;
|
|
||||||
|
|
||||||
{ TCairoPdfCanvas }
|
{ TCairoPdfCanvas }
|
||||||
|
|
||||||
function TCairoPdfCanvas.CreateCairoHandle: HDC;
|
function TCairoPdfCanvas.CreateCairoHandle: HDC;
|
||||||
|
@ -947,6 +947,12 @@ begin
|
|||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
procedure TCUPSPrinter.DoNewPage;
|
||||||
|
begin
|
||||||
|
// just to flag that we want the old 'newpage' pagination way
|
||||||
|
// instead of the new 'beginpage/endpage'
|
||||||
|
end;
|
||||||
|
|
||||||
procedure TCUPSPrinter.DoResetPrintersList;
|
procedure TCUPSPrinter.DoResetPrintersList;
|
||||||
begin
|
begin
|
||||||
if Assigned(fcupsPPD) then
|
if Assigned(fcupsPPD) then
|
||||||
|
@ -110,7 +110,7 @@ type
|
|||||||
protected
|
protected
|
||||||
procedure DoBeginDoc; override;
|
procedure DoBeginDoc; override;
|
||||||
procedure DoEndDoc(aAborted : Boolean); override;
|
procedure DoEndDoc(aAborted : Boolean); override;
|
||||||
|
procedure DoNewPage; override;
|
||||||
|
|
||||||
procedure DoResetPrintersList; override;
|
procedure DoResetPrintersList; override;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user