diff options
-rw-r--r-- | examples/gfx/imgtest/imgtest.lpi | 5 | ||||
-rw-r--r-- | gfx/gdi/gfx_gdi.pas | 2 | ||||
-rw-r--r-- | gfx/gfxbase.pas | 2 | ||||
-rw-r--r-- | gfx/template/gfx_xxx.pas | 490 | ||||
-rw-r--r-- | gfx/template/gfxinterface.pas | 43 | ||||
-rw-r--r-- | gfx/x11/gfx_x11.pas | 2 |
6 files changed, 128 insertions, 416 deletions
diff --git a/examples/gfx/imgtest/imgtest.lpi b/examples/gfx/imgtest/imgtest.lpi index c507609d..fefabc63 100644 --- a/examples/gfx/imgtest/imgtest.lpi +++ b/examples/gfx/imgtest/imgtest.lpi @@ -1,7 +1,7 @@ <?xml version="1.0"?> <CONFIG> <ProjectOptions> - <PathDelim Value="/"/> + <PathDelim Value="\"/> <Version Value="5"/> <General> <Flags> @@ -20,7 +20,7 @@ <RunParams> <local> <FormatVersion Value="1"/> - <LaunchingApplication PathPlusParams="/usr/X11R6/bin/xterm -T 'Lazarus Run Output' -e $(LazarusDir)/tools/runwait.sh $(TargetCmdLine)"/> + <LaunchingApplication PathPlusParams="\usr\X11R6\bin\xterm -T 'Lazarus Run Output' -e $(LazarusDir)\tools\runwait.sh $(TargetCmdLine)"/> </local> </RunParams> <RequiredPackages Count="1"> @@ -39,6 +39,7 @@ </ProjectOptions> <CompilerOptions> <Version Value="5"/> + <PathDelim Value="\"/> <CodeGeneration> <Generate Value="Faster"/> </CodeGeneration> diff --git a/gfx/gdi/gfx_gdi.pas b/gfx/gdi/gfx_gdi.pas index cd028c0f..6d3f858c 100644 --- a/gfx/gdi/gfx_gdi.pas +++ b/gfx/gdi/gfx_gdi.pas @@ -72,7 +72,6 @@ type TGDICanvas = class(TFCustomCanvas) private - FHandle: HDC; FColor, FBrushColor, FPenColor, FFontColor: TGfxPixel; FLineStyle, FPenLineStyle: TGfxLineStyle; FBrush, FOldBrush: HBRUSH; @@ -112,7 +111,6 @@ type procedure SetColor_(AColor: TGfxPixel); override; procedure SetFont(AFont: TFCustomFont); override; procedure SetLineStyle(ALineStyle: TGfxLineStyle); override; - property Handle: HDC read FHandle; end; diff --git a/gfx/gfxbase.pas b/gfx/gfxbase.pas index 080aa0a5..968c9c42 100644 --- a/gfx/gfxbase.pas +++ b/gfx/gfxbase.pas @@ -269,6 +269,7 @@ type protected FWidth: Integer; FHeight: Integer; + FHandle: Cardinal; FPixelFormat: TGfxPixelFormat; FColor: TGfxColor; function DoExcludeClipRect(const ARect: TRect): Boolean; virtual; abstract; @@ -341,6 +342,7 @@ type property Height: Integer read FHeight; property PixelFormat: TGfxPixelFormat read FPixelFormat; property Matrix: TGfxMatrix read FMatrix write FMatrix; + property Handle: Cardinal read FHandle; end; { TFCustomBitmap } diff --git a/gfx/template/gfx_xxx.pas b/gfx/template/gfx_xxx.pas index 904c929b..1084905c 100644 --- a/gfx/template/gfx_xxx.pas +++ b/gfx/template/gfx_xxx.pas @@ -1,435 +1,155 @@ { - fpGFX - Free Pascal Graphics Library - Copyright (C) 2000 by - Areca Systems GmbH / Sebastian Guenther, sg@freepascal.org - Copyright (C) 2006 by Graeme Geldenhuys - member of the fpGFX development team. + fpGUI - Free Pascal GUI Library - Template for new target implementations + GFX_xxx - Template for new targets - See the file COPYING.fpGFX, included in this distribution, - for details about the copyright. + Copyright (C) 2000 - 2006 See the file AUTHORS.txt, included in this + distribution, for details of the copyright. + + See the file COPYING.modifiedLGPL, included in this distribution, + for details about redistributing fpGUI. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. - - **********************************************************************} - - +} unit GFX_xxx; +{$ifdef fpc} + {$mode delphi}{$H+} +{$endif} + interface uses - SysUtils, Classes, // FPC units - // xxx (insert target dependent units here) - GfxBase; // fpGUI units + SysUtils, Classes, + GfxBase; + type ExxxError = class(EGfxError); - TxxxDrawable = class; - TxxxDisplay = class; + { TxxxFont } - TxxxFont = class(TGfxFont) + TxxxFont = class(TFCustomFont) public - constructor Create; - destructor Destroy; override; + class function GetDefaultFontName(const AFontClass: TGfxFontClass): String; override; + constructor Create(const Descriptor: String); + destructor Destroy; override; end; - PxxxDrawableState = ^TxxxDrawableState; - TxxxDrawableState = record - Prev: PxxxDrawableState; - Matrix: TGfxMatrix; - // xxx Region data etc. + + { TxxxCanvas } + + TxxxCanvas = class(TFCustomCanvas) + protected + function DoExcludeClipRect(const ARect: TRect): Boolean; override; + function DoIntersectClipRect(const ARect: TRect): Boolean; override; + function DoUnionClipRect(const ARect: TRect): Boolean; override; + function DoGetClipRect: TRect; override; + procedure DoDrawArc(const ARect: TRect; StartAngle, EndAngle: Single); override; + procedure DoDrawCircle(const ARect: TRect); override; + procedure DoDrawLine(const AFrom, ATo: TPoint); override; + procedure DoDrawPoint(const APoint: TPoint); override; + procedure DoFillRect(const ARect: TRect); override; + procedure DoTextOut(const APosition: TPoint; const AText: String); override; + procedure DoCopyRect(ASource: TFCustomCanvas; const ASourceRect: TRect; const ADestPos: TPoint); override; + procedure DoMaskedCopyRect(ASource, AMask: TFCustomCanvas; const ASourceRect: TRect; const AMaskPos, ADestPos: TPoint); override; + procedure DoDrawImageRect(AImage: TFCustomBitmap; ASourceRect: TRect; const ADestPos: TPoint); override; + public + constructor Create(AHandle: HDC); + destructor Destroy; override; + function MapColor(const AColor: TGfxColor): TGfxPixel; override; + function FontCellHeight: Integer; override; + function TextExtent(const AText: String): TSize; override; + procedure SaveState; override; + procedure RestoreState; override; + procedure EmptyClipRect; override; + procedure SetColor_(AColor: TGfxPixel); override; + procedure SetFont(AFont: TFCustomFont); override; + procedure SetLineStyle(ALineStyle: TGfxLineStyle); override; + property Handle: HDC read FHandle; end; - TxxxDrawable = class(TGfxDrawable) + + TxxxWindowCanvas = class(TxxxCanvas) private - FDisplay: TxxxDisplay; - FStateStackpointer: PxxxDrawableState; - procedure Resized(NewWidth, NewHeight: Integer); + FWnd: HWND; public - constructor Create(ADisplay: TxxxDisplay); // xxx And other arguments optionally + constructor Create(AWnd: HWND); destructor Destroy; override; - - function CreateMemoryDrawable(AWidth, AHeight: Cardinal; - const APixelFormat: TGfxPixelFormat; - AStride: LongWord; AData: Pointer): TGfxDrawable; override; - - procedure SaveState; override; - procedure RestoreState; override; - function ExcludeClipRect(const ARect: TRect): Boolean; override; - function IntersectClipRect(const ARect: TRect): Boolean; override; - function GetClipRect: TRect; override; - function MapColor(const AColor: TGfxColor): TGfxPixel; override; - procedure SetColor(AColor: TGfxPixel); override; - procedure SetFont(AFont: TGfxFont); override; - procedure SetLineStyle(ALineStyle: TGfxLineStyle); override; - - procedure DrawArc(const Rect: TRect; StartAngle, EndAngle: Single); override; - procedure DrawCircle(const Rect: TRect); override; - procedure DrawLine(x1, y1, x2, y2: Integer); override; - procedure FillRect(const Rect: TRect); override; - function FontCellHeight: Integer; override; - function TextWidth(const AText: String): Cardinal; override; - procedure TextOut(x, y: Integer; const AText: String); override; - - procedure CopyRect(ASource: TGfxDrawable; const ASourceRect: TRect; - ADestX, ADestY: Integer); override; - - - property Display: TxxxDisplay read FDisplay; end; - TxxxWindow = class; - - TxxxDisplay = class(TGfxDisplay) + TxxxBitmapCanvas = class(TxxxCanvas) public + constructor Create(ABitmap: HBITMAP; AWidth, AHeight: Integer); destructor Destroy; override; - function CreateFont(const Descriptor: String): TGfxFont; override; - function CreateWindow: TGfxWindow; override; - procedure Run; override; end; + { TxxxBitmap } - xxxSomeHandleType = Pointer; // !!!: Remove this in your implementation - - TxxxWindow = class(TGfxWindow) - private - FHandle: xxxSomeHandleType; - protected - function GetTitle: String; override; - procedure SetTitle(const ATitle: String); override; + TxxxBitmap = class(TFCustomBitmap) private - constructor Create(ADisplay: TxxxDisplay); + IsLocked: Boolean; public + constructor Create(AWidth, AHeight: Integer; APixelFormat: TGfxPixelFormat); override; destructor Destroy; override; + procedure Lock(var AData: Pointer; var AStride: LongWord); override; + procedure Unlock; override; + end; - procedure SetSize(AWidth, AHeight: Cardinal); override; - procedure SetMinMaxSize(AMinWidth, AMinHeight, - AMaxWidth, AMaxHeight: Cardinal); override; - procedure Show; override; - procedure Invalidate(const ARect: TRect); override; - procedure CaptureMouse; override; - procedure ReleaseMouse; override; + { TxxxScreen } - property Handle: xxxSomeHandleType read FHandle; + TxxxScreen = class(TFCustomScreen) + public + constructor Create; override; end; -// =================================================================== -// =================================================================== - -implementation + { TxxxApplication } + TxxxApplication = class(TFCustomApplication) + private + DoBreakRun: Boolean; + public + { default methods } + constructor Create; override; + destructor Destroy; override; + procedure AddWindow(AWindow: TFCustomWindow); override; + procedure Initialize(ADisplayName: String = ''); override; + procedure Run; override; + procedure Quit; override; + end; -// ------------------------------------------------------------------- -// TxxxFont -// ------------------------------------------------------------------- - -constructor TxxxFont.Create; -begin - inherited Create; - // !!!: Implement this -end; - -destructor TxxxFont.Destroy; -begin - // !!!: Implement this - inherited Destroy; -end; - - -// ------------------------------------------------------------------- -// TxxxDrawable -// ------------------------------------------------------------------- - - - -// ------------------------------------------------------------------- -// TxxxDrawable -// ------------------------------------------------------------------- - -constructor TxxxDrawable.Create(ADisplay: TxxxDisplay); -begin - inherited Create; - FDisplay := ADisplay; - // !!!: Create handle, init graphics state (line attributes, font etc.) -end; - -destructor TxxxDrawable.Destroy; -begin - // !!!: Implement this - inherited Destroy; -end; - -function TxxxDrawable.CreateMemoryDrawable(AWidth, AHeight: Cardinal; - const APixelFormat: TGfxPixelFormat; - AStride: LongWord; AData: Pointer): TGfxDrawable; -begin - // !!!: Implement this - raise EGfxError.Create(SUnsupportedPixelFormat); - Result := nil; -end; - -procedure TxxxDrawable.SaveState; -var - SavedState: PxxxDrawableState; -begin - New(SavedState); - SavedState^.Prev := FStateStackpointer; - SavedState^.Matrix := Matrix; - // !!!: Save additional state informations - FStateStackpointer := SavedState; -end; - -procedure TxxxDrawable.RestoreState; -var - SavedState: PxxxDrawableState; -begin - SavedState := FStateStackpointer; - FStateStackpointer := SavedState^.Prev; - Matrix := SavedState^.Matrix; - // !!!: Restore additional state informations - Dispose(SavedState); -end; - -function TxxxDrawable.ExcludeClipRect(const ARect: TRect): Boolean; -var - x1, y1, x2, y2: Integer; -begin - Transform(ARect.Left, ARect.Top, x1, y1); - Transform(ARect.Right, ARect.Bottom, x2, y2); - - if (x2 > x1) and (y2 > y1) then - begin - // !!!: Implement this - Result := True; // !!!: Return False if region is empty - end else - Result := False; -end; - -function TxxxDrawable.IntersectClipRect(const ARect: TRect): Boolean; -var - x1, y1, x2, y2: Integer; -begin - Transform(ARect.Left, ARect.Top, x1, y1); - Transform(ARect.Right, ARect.Bottom, x2, y2); - - if (x2 > x1) and (y2 > y1) then - begin - // !!!: Implement this - Result := True; // !!!: Return False if region is empty - end else - Result := False; -end; - -function TxxxDrawable.GetClipRect: TRect; -begin - // !!!: Implement this - Result.Left := 0; - Result.Top := 0; - Result.Right := 0; - Result.Bottom := 0; -end; - -function TxxxDrawable.MapColor(const AColor: TGfxColor): TGfxPixel; -begin - // !!!: Implement this - Result := 0; -end; - -procedure TxxxDrawable.SetColor(AColor: TGfxPixel); -begin - // !!!: Implement this -end; - -procedure TxxxDrawable.SetFont(AFont: TGfxFont); -begin - // !!!: Implement this -end; - -procedure TxxxDrawable.SetLineStyle(ALineStyle: TGfxLineStyle); -begin - // !!!: Implement this -end; - -procedure TxxxDrawable.DrawArc(const Rect: TRect; StartAngle, EndAngle: Single); -var - x1, y1, x2, y2: Integer; -begin - Transform(Rect.Left, Rect.Top, x1, y1); - Transform(Rect.Right, Rect.Bottom, x2, y2); - // !!!: Implement this -end; - -procedure TxxxDrawable.DrawCircle(const Rect: TRect); -var - x1, y1, x2, y2: Integer; -begin - Transform(Rect.Left, Rect.Top, x1, y1); - Transform(Rect.Right, Rect.Bottom, x2, y2); - // !!!: Implement this -end; - -procedure TxxxDrawable.DrawLine(x1, y1, x2, y2: Integer); -begin - Transform(x1, y1, x1, y1); - Transform(x2, y2, x2, y2); - // !!!: Implement this -end; - -procedure TxxxDrawable.FillRect(const Rect: TRect); -var - r: TRect; -begin - Transform(Rect.Left, Rect.Top, r.Left, r.Top); - Transform(Rect.Right, Rect.Bottom, r.Right, r.Bottom); - // !!!: Implement this -end; - -function TxxxDrawable.FontCellHeight: Integer; -begin - // !!!: Implement this - Result := 16; -end; - -function TxxxDrawable.TextWidth(const AText: String): Cardinal; -begin - // !!!: Implement this - Result := 16 * Length(AText); -end; - -procedure TxxxDrawable.TextOut(x, y: Integer; const AText: String); -begin - Transform(x, y, x, y); - // !!!: Implement this -end; - -procedure TxxxDrawable.CopyRect(ASource: TGfxDrawable; const ASourceRect: TRect; - DestX, DestY: Integer); -begin - Transform(DestX, DestY, DestX, DestY); - // !!!: Implement this -end; - -procedure TxxxDrawable.Resized(NewWidth, NewHeight: Integer); -begin - FWidth := NewWidth; - FHeight := NewHeight; -end; - - -// ------------------------------------------------------------------- -// TxxxDisplay -// ------------------------------------------------------------------- - -destructor TxxxDisplay.Destroy; -begin - // !!!: Implement this - inherited Destroy; -end; - -function TxxxDisplay.CreateFont(const Descriptor: String): TGfxFont; -begin - Result := TxxxFont.Create; -end; - -function TxxxDisplay.CreateWindow: TGfxWindow; -begin - Result := TxxxWindow.Create(Self); - // !!!: Implement this -end; - -procedure TxxxDisplay.Run; -begin - // !!!: Implement this -end; - - -// ------------------------------------------------------------------- -// TxxxWindow -// ------------------------------------------------------------------- - -function TxxxWindow.GetTitle: String; -begin - // !!!: Implement this - Result := inherited; -end; - -procedure TxxxWindow.SetTitle(const ATitle: String); -begin - // !!!: Implement this -end; - -constructor TxxxWindow.Create(ADisplay: TxxxDisplay); -begin - inherited Create; - FDisplay := ADisplay; - // !!!: Implement this - FDrawable := TxxxDrawable.Create(ADisplay); // !!!: Create a suitable drawable -end; - -destructor TxxxWindow.Destroy; -begin - if Assigned(OnClose) then - OnClose(Self); - - Drawable.Free; - - // !!!: Clean up - - inherited Destroy; -end; - -procedure TxxxWindow.SetSize(AWidth, AHeight: Cardinal); -begin - // !!!: Implement this -end; - -procedure TxxxWindow.SetMinMaxSize(AMinWidth, AMinHeight, - AMaxWidth, AMaxHeight: Cardinal); -begin - // !!!: Implement this -end; - -procedure TxxxWindow.Show; -begin - // !!!: Implement this -end; - -procedure TxxxWindow.Invalidate(const ARect: TRect); -begin - // !!!: Implement this -end; - -procedure TxxxWindow.CaptureMouse; -begin - // !!!: Implement this -end; - -procedure TxxxWindow.ReleaseMouse; -begin - // !!!: Implement this -end; - + { TxxxWindow } -end. + TxxxWindow = class(TFCustomWindow) + protected + function GetTitle: String; override; + procedure SetTitle(const ATitle: String); override; + procedure DoSetCursor; override; + public + constructor Create(AParent: TFCustomWindow; AWindowOptions: TGfxWindowOptions); override; + destructor Destroy; override; + procedure DefaultHandler(var Message); override; + procedure SetPosition(const APosition: TPoint); override; + procedure SetSize(const ASize: TSize); override; + procedure SetMinMaxSize(const AMinSize, AMaxSize: TSize); override; + procedure SetClientSize(const ASize: TSize); override; + procedure SetMinMaxClientSize(const AMinSize, AMaxSize: TSize); override; + procedure Show; override; + procedure Invalidate(const ARect: TRect); override; + procedure PaintInvalidRegion; override; + procedure CaptureMouse; override; + procedure ReleaseMouse; override; + end; -{ - $Log: gfx_xxx.pp,v $ - Revision 1.3 2000/12/23 23:07:24 sg - *** empty log message *** +implementation - Revision 1.2 2000/10/28 20:28:27 sg - * First version +uses fpgfx; - Revision 1.1 2000/08/04 21:05:53 sg - * First version in CVS +end. -} diff --git a/gfx/template/gfxinterface.pas b/gfx/template/gfxinterface.pas index 189b772c..0f5374b8 100644 --- a/gfx/template/gfxinterface.pas +++ b/gfx/template/gfxinterface.pas @@ -1,46 +1,39 @@ { - fpGFX - Free Pascal Graphics Library - Copyright (C) 2000 by - Areca Systems GmbH / Sebastian Guenther, sg@freepascal.org - Copyright (C) 2006 by Graeme Geldenhuys - member of the fpGFX development team. + fpGUI - Free Pascal GUI Library - Default target selection unit for template unit + GFXInterface - Default target selection unit - See the file COPYING.fpGFX, included in this distribution, - for details about the copyright. + Copyright (C) 2000 - 2006 See the file AUTHORS.txt, included in this + distribution, for details of the copyright. + + See the file COPYING.modifiedLGPL, included in this distribution, + for details about redistributing fpGUI. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. - - **********************************************************************} - - -unit GFXImpl; +} +unit GFXInterface; interface uses GFX_xxx; - type - TDefDisplay = TxxxDisplay; - TDefWindow = TxxxWindow; + TDefFont = TxxxFont; + TDefCanvas = TxxxCanvas; -implementation + TDefBitmap = TxxxBitmap; -end. + TDefScreen = TxxxScreen; + TDefApplication = TxxxApplication; -{ - $Log: gfximpl.pp,v $ - Revision 1.2 2000/10/28 20:28:27 sg - * First version + TDefWindow = TxxxWindow; - Revision 1.1 2000/08/04 21:05:53 sg - * First version in CVS +implementation + +end. -} diff --git a/gfx/x11/gfx_x11.pas b/gfx/x11/gfx_x11.pas index 0141326c..07083c8d 100644 --- a/gfx/x11/gfx_x11.pas +++ b/gfx/x11/gfx_x11.pas @@ -83,7 +83,6 @@ type TX11Canvas = class(TFCustomCanvas) private - FHandle: X.TDrawable; FGC: TGC; FVisual: PVisual; FRegion: TRegion; @@ -125,7 +124,6 @@ type procedure SetFont(AFont: TFCustomFont); override; procedure SetLineStyle(ALineStyle: TGfxLineStyle); override; procedure DrawPolyLine(const Coords: array of TPoint); override; - property Handle: X.TDrawable read FHandle; property GC: TGC read FGC; property Visual: PVisual read FVisual; property Colormap: TColormap read FColormap; |