summaryrefslogtreecommitdiff
path: root/examples/img
diff options
context:
space:
mode:
authorgraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2007-05-28 12:53:58 +0000
committergraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2007-05-28 12:53:58 +0000
commit6c6aa999c078adae842ec37b44a7deafb27b7134 (patch)
tree6c406207a5643baa62fd5a09935e44fcbdc815ed /examples/img
parent10b66d63a8763ed62019d7789635b84372f4e463 (diff)
downloadfpGUI-6c6aa999c078adae842ec37b44a7deafb27b7134.tar.xz
Updated the img/masktest example to compile with latest GFX changes.
Diffstat (limited to 'examples/img')
-rw-r--r--examples/img/disp_bmp/disp_bmp.pas10
-rw-r--r--examples/img/disp_bmp/test24.bmp (renamed from examples/img/disp_bmp/test.bmp)bin196662 -> 196662 bytes
-rw-r--r--examples/img/masktest/masktest.lpi105
-rw-r--r--examples/img/masktest/masktest.pas89
4 files changed, 98 insertions, 106 deletions
diff --git a/examples/img/disp_bmp/disp_bmp.pas b/examples/img/disp_bmp/disp_bmp.pas
index 880340c0..5f581195 100644
--- a/examples/img/disp_bmp/disp_bmp.pas
+++ b/examples/img/disp_bmp/disp_bmp.pas
@@ -57,11 +57,9 @@ end;
procedure TMainForm.Paint(Sender: TObject; const Rect: TRect);
begin
// debug only
-{
Canvas.SetColor(colRed);
Canvas.FillRect(Rect);
Canvas.SetColor(colYellow);
-}
// paint image
Canvas.DrawImage(Image, Point(0, 0));
end;
@@ -77,11 +75,7 @@ begin
GFApplication.Initialize;
MainForm := TMainForm.Create;
- try
- MainForm.Show;
- GFApplication.Run;
- finally
- MainForm.Free;
- end;
+ MainForm.Show;
+ GFApplication.Run;
end.
diff --git a/examples/img/disp_bmp/test.bmp b/examples/img/disp_bmp/test24.bmp
index bda7377d..bda7377d 100644
--- a/examples/img/disp_bmp/test.bmp
+++ b/examples/img/disp_bmp/test24.bmp
Binary files differ
diff --git a/examples/img/masktest/masktest.lpi b/examples/img/masktest/masktest.lpi
index 6c574c2d..dda2a998 100644
--- a/examples/img/masktest/masktest.lpi
+++ b/examples/img/masktest/masktest.lpi
@@ -1,53 +1,52 @@
-<?xml version="1.0"?>
-<CONFIG>
- <ProjectOptions>
- <PathDelim Value="\"/>
- <Version Value="5"/>
- <General>
- <SessionStorage Value="InProjectDir"/>
- <MainUnit Value="0"/>
- <IconPath Value="./"/>
- <TargetFileExt Value=".exe"/>
- </General>
- <VersionInfo>
- <ProjectVersion Value=""/>
- </VersionInfo>
- <PublishOptions>
- <Version Value="2"/>
- <IgnoreBinaries Value="False"/>
- <IncludeFileFilter Value="*.(pas|pp|inc|lfm|lpr|lrs|lpi|lpk|sh|xml)"/>
- <ExcludeFileFilter Value="*.(bak|ppu|ppw|o|so);*~;backup"/>
- </PublishOptions>
- <RunParams>
- <local>
- <FormatVersion Value="1"/>
- <LaunchingApplication PathPlusParams="/usr/X11R6/bin/xterm -T 'Lazarus Run Output' -e $(LazarusDir)/tools/runwait.sh $(TargetCmdLine)"/>
- </local>
- </RunParams>
- <RequiredPackages Count="2">
- <Item1>
- <PackageName Value="fpimgpackage"/>
- </Item1>
- <Item2>
- <PackageName Value="fpGFXPackage"/>
- </Item2>
- </RequiredPackages>
- <Units Count="1">
- <Unit0>
- <Filename Value="masktest.pas"/>
- <IsPartOfProject Value="True"/>
- <UnitName Value="MaskTest"/>
- </Unit0>
- </Units>
- </ProjectOptions>
- <CompilerOptions>
- <Version Value="5"/>
- <PathDelim Value="\"/>
- <CodeGeneration>
- <Generate Value="Faster"/>
- </CodeGeneration>
- <Other>
- <CompilerPath Value="$(CompPath)"/>
- </Other>
- </CompilerOptions>
-</CONFIG>
+<?xml version="1.0"?>
+<CONFIG>
+ <ProjectOptions>
+ <PathDelim Value="/"/>
+ <Version Value="5"/>
+ <General>
+ <SessionStorage Value="InProjectDir"/>
+ <MainUnit Value="0"/>
+ <IconPath Value="./"/>
+ <TargetFileExt Value=".exe"/>
+ </General>
+ <VersionInfo>
+ <ProjectVersion Value=""/>
+ </VersionInfo>
+ <PublishOptions>
+ <Version Value="2"/>
+ <IgnoreBinaries Value="False"/>
+ <IncludeFileFilter Value="*.(pas|pp|inc|lfm|lpr|lrs|lpi|lpk|sh|xml)"/>
+ <ExcludeFileFilter Value="*.(bak|ppu|ppw|o|so);*~;backup"/>
+ </PublishOptions>
+ <RunParams>
+ <local>
+ <FormatVersion Value="1"/>
+ <LaunchingApplication PathPlusParams="/usr/X11R6/bin/xterm -T 'Lazarus Run Output' -e $(LazarusDir)/tools/runwait.sh $(TargetCmdLine)"/>
+ </local>
+ </RunParams>
+ <RequiredPackages Count="2">
+ <Item1>
+ <PackageName Value="fpimgpackage"/>
+ </Item1>
+ <Item2>
+ <PackageName Value="fpGFXPackage"/>
+ </Item2>
+ </RequiredPackages>
+ <Units Count="1">
+ <Unit0>
+ <Filename Value="masktest.pas"/>
+ <IsPartOfProject Value="True"/>
+ <UnitName Value="MaskTest"/>
+ </Unit0>
+ </Units>
+ </ProjectOptions>
+ <CompilerOptions>
+ <Version Value="5"/>
+ <CodeGeneration>
+ <Generate Value="Faster"/>
+ </CodeGeneration>
+ <Other>
+ <CompilerPath Value="$(CompPath)"/>
+ </Other>
+ </CompilerOptions>
+</CONFIG>
diff --git a/examples/img/masktest/masktest.pas b/examples/img/masktest/masktest.pas
index b469dbd5..d9db3e6a 100644
--- a/examples/img/masktest/masktest.pas
+++ b/examples/img/masktest/masktest.pas
@@ -1,72 +1,71 @@
{
- $Id: masktest.pp,v 1.3 2001/02/14 23:08:59 sg Exp $
-
- fpImg - Free Pascal Imaging Library
- Copyright (C) 2000 - 2001 by
- Areca Systems GmbH / Sebastian Guenther, sg@freepascal.org
+ fpGUI - Free Pascal GUI Library
Example: Display BMP file with monochrome mask
- See the file COPYING, included in this distribution,
- for details about the copyright.
+ Copyright (C) 2000 - 2007 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.
}
-
program MaskTest;
-uses Classes, GFXBase, fpGFX, fpImg, BMPReader;
+{$ifdef fpc}
+ {$mode objfpc}{$H+}
+{$endif}
+
+uses
+ Classes, GFXBase, fpGFX, fpImg, BMPReader;
type
- TMainWindow = class
- procedure Paint(Sender: TObject; const ARect: TRect);
+ TMainWindow = class(TFWindow)
private
- Window: TFWindow;
Image2, Image4, Image8, Image24, Mask: TFBitmap;
Image2Canvas, Image4Canvas, Image8Canvas,
Image24Canvas, MaskCanvas: TFCanvas;
+ protected
+ procedure Paint(Sender: TObject; const ARect: TRect);
public
- constructor Create;
- destructor Destroy; override;
+ constructor Create; overload;
+ destructor Destroy; override;
end;
constructor TMainWindow.Create;
begin
- inherited Create;
+ inherited Create(nil, [woWindow]);
// Load and prepare the images
Image2 := CreateImageFromFile(GFScreen, TBMPReader, 'image2.bmp');
- Image2Canvas := TFBitmap.Create(Image2.Width, Image2.Height);
+ Image2Canvas := TFCanvas(GFScreen.CreateBitmapCanvas(Image2.Width, Image2.Height));
Image2Canvas.DrawImage(Image2, Point(0, 0));
Image4 := CreateImageFromFile(GFScreen, TBMPReader, 'image4.bmp');
- Image4Canvas :=
- GFScreen.CreateBitmap(Image4.Width, Image4.Height);
+ Image4Canvas := TFCanvas(GFScreen.CreateBitmapCanvas(Image4.Width, Image4.Height));
Image4Canvas.DrawImage(Image4, Point(0, 0));
Image8 := CreateImageFromFile(GFScreen, TBMPReader, 'image8.bmp');
- Image8Canvas :=
- Display.DefaultScreen.CreateBitmap(Image8.Width, Image8.Height);
+ Image8Canvas := TFCanvas(GFScreen.CreateBitmapCanvas(Image8.Width, Image8.Height));
Image8Canvas.DrawImage(Image8, Point(0, 0));
Image24 := CreateImageFromFile(GFScreen, TBMPReader, 'image24.bmp');
- Image24Canvas :=
- Display.DefaultScreen.CreateBitmap(Image24.Width, Image24.Height);
+ Image24Canvas := TFCanvas(GFScreen.CreateBitmapCanvas(Image24.Width, Image24.Height));
Image24Canvas.DrawImage(Image24, Point(0, 0));
// Load and prepare the image mask
Mask := CreateImageFromFile(GFScreen, TBMPReader, 'mask.bmp');
- MaskCanvas := Display.DefaultScreen.CreateMonoBitmap(Mask.Width, Mask.Height);
+ MaskCanvas := TFCanvas(GFScreen.CreateMonoBitmapCanvas(Mask.Width, Mask.Height));
+// MaskCanvas := Display.DefaultScreen.CreateMonoBitmap(Mask.Width, Mask.Height);
MaskCanvas.DrawImage(Mask, Point(0, 0));
- Window := ADisplay.DefaultScreen.CreateWindow;
- Window.Title := 'fpImg Blitting Mask Test';
- Window.OnPaint := @Paint;
- Window.SetClientSize(Size(Image2.Width * 2 + 64, Image2.Height * 2 + 64));
- Window.Show;
+ Title := 'fpImg Blitting Mask Test';
+ OnPaint := @Paint;
+ SetClientSize(Size(Image2.Width * 2 + 64, Image2.Height * 2 + 64));
end;
destructor TMainWindow.Destroy;
@@ -97,27 +96,28 @@ begin
r.Right := ARect.Right;
for i := ARect.Top to ARect.Bottom - 1 do
begin
- Color.Blue := $ffff - (i * $ffff) div Window.Height;
+ Color.Blue := $ffff - (i * $ffff) div Height;
Color.Red := Color.Blue shr 1;
- Window.Canvas.SetColor(Color);
+ Canvas.SetColor(Color);
r.Top := i;
r.Bottom := i + 1;
- Window.Canvas.FillRect(r);
+ Canvas.FillRect(r);
end;
- x1 := Window.ClientWidth div 4 - Image2.Width div 2;
- y1 := Window.ClientHeight div 4 - Image2.Height div 2;
- x2 := x1 + Window.ClientWidth div 2;
- y2 := y1 + Window.ClientHeight div 2;
-
- Window.Canvas.MaskedCopy(Image2Canvas, MaskCanvas, Point(x1, y1));
- Window.Canvas.TextOut(Point(x1, y1 + Image2.Height), 'monochrome');
- Window.Canvas.MaskedCopy(Image4Canvas, MaskCanvas, Point(x2, y1));
- Window.Canvas.TextOut(Point(x2, y1 + Image2.Height), '4bpp palettized');
- Window.Canvas.MaskedCopy(Image8Canvas, MaskCanvas, Point(x1, y2));
- Window.Canvas.TextOut(Point(x1, y2 + Image2.Height), '8bpp palettized');
- Window.Canvas.MaskedCopy(Image24Canvas, MaskCanvas, Point(x2, y2));
- Window.Canvas.TextOut(Point(x2, y2 + Image2.Height), '24bpp true color');
+ x1 := ClientWidth div 4 - Image2.Width div 2;
+ y1 := ClientHeight div 4 - Image2.Height div 2;
+ x2 := x1 + ClientWidth div 2;
+ y2 := y1 + ClientHeight div 2;
+
+ Canvas.SetColor(colWhite);
+ Canvas.MaskedCopy(Image2Canvas, MaskCanvas, Point(x1, y1));
+ Canvas.TextOut(Point(x1, y1 + Image2.Height), 'monochrome');
+ Canvas.MaskedCopy(Image4Canvas, MaskCanvas, Point(x2, y1));
+ Canvas.TextOut(Point(x2, y1 + Image2.Height), '4bpp palettized');
+ Canvas.MaskedCopy(Image8Canvas, MaskCanvas, Point(x1, y2));
+ Canvas.TextOut(Point(x1, y2 + Image2.Height), '8bpp palettized');
+ Canvas.MaskedCopy(Image24Canvas, MaskCanvas, Point(x2, y2));
+ Canvas.TextOut(Point(x2, y2 + Image2.Height), '24bpp true color');
end;
var
@@ -125,7 +125,6 @@ var
begin
GFApplication.Initialize;
MainWindow := TMainWindow.Create;
- GFApplication.AddWindow(MainWindow);
MainWindow.Show;
GFApplication.Run;
end.