Printers, Fix printing regression under linux, issue #34680

git-svn-id: trunk@59823 -
This commit is contained in:
jesus 2018-12-14 02:25:32 +00:00
parent 75136b6580
commit 8965b70a28
3 changed files with 40 additions and 12 deletions

View File

@ -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;

View File

@ -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

View File

@ -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;