diff options
author | graemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf> | 2007-07-19 12:58:07 +0000 |
---|---|---|
committer | graemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf> | 2007-07-19 12:58:07 +0000 |
commit | 305c7919280c57516e55a8df96bcad0e0d60dfb0 (patch) | |
tree | 30b6177e7600375fba9c3ac9f1403e234f897ade | |
parent | 8cc3714242ec4ece8675dd587ce4ccb820443bb8 (diff) | |
download | fpGUI-305c7919280c57516e55a8df96bcad0e0d60dfb0.tar.xz |
GFX: Implemented Font Underline support.
* The start of a theme test project. Proof of concept only.
-rw-r--r-- | prototypes/fpgui2/source/core/gfxbase.pas | 19 | ||||
-rw-r--r-- | prototypes/fpgui2/tests/themetest.lpi | 264 | ||||
-rw-r--r-- | prototypes/fpgui2/tests/themetest.lpr | 265 |
3 files changed, 548 insertions, 0 deletions
diff --git a/prototypes/fpgui2/source/core/gfxbase.pas b/prototypes/fpgui2/source/core/gfxbase.pas index a00730ac..5f76ee14 100644 --- a/prototypes/fpgui2/source/core/gfxbase.pas +++ b/prototypes/fpgui2/source/core/gfxbase.pas @@ -712,8 +712,27 @@ begin end; procedure TfpgCanvasBase.DrawString(x, y: TfpgCoord; const txt: string); +var + underline: integer; begin DoDrawString(x, y, txt); + + { What was not handled: underline } + if Pos('UNDERLINE', UpperCase(Font.FontDesc)) > 0 then + begin + underline := (Font.Descent div 2) + 1; + if underline = 0 then + underline := 1; + if underline >= Font.Descent then + underline := Font.Descent - 1; + +// if Pos('BOLD', UpperCase(Font.FontDesc)) = 0 then + DoSetLineStyle(1, lsSolid); +// else +// DoSetLineStyle(2, lsSolid); + DoSetColor(TextColor); + DoDrawLine(x, Font.Height-underline, x+Font.TextWidth(txt), Font.Height-underline); + end; end; procedure TfpgCanvasBase.FillRectangle(x, y, w, h: TfpgCoord); diff --git a/prototypes/fpgui2/tests/themetest.lpi b/prototypes/fpgui2/tests/themetest.lpi new file mode 100644 index 00000000..77427571 --- /dev/null +++ b/prototypes/fpgui2/tests/themetest.lpi @@ -0,0 +1,264 @@ +<?xml version="1.0"?> +<CONFIG> + <ProjectOptions> + <PathDelim Value="/"/> + <Version Value="5"/> + <General> + <MainUnit Value="0"/> + <TargetFileExt Value=""/> + <ActiveEditorIndexAtStart Value="6"/> + </General> + <VersionInfo> + <ProjectVersion Value=""/> + <Language Value=""/> + <CharSet 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="1"> + <Item1> + <PackageName Value="fpGFX2"/> + </Item1> + </RequiredPackages> + <Units Count="13"> + <Unit0> + <Filename Value="themetest.lpr"/> + <IsPartOfProject Value="True"/> + <UnitName Value="themetest"/> + <CursorPos X="41" Y="239"/> + <TopLine Value="233"/> + <EditorIndex Value="0"/> + <UsageCount Value="20"/> + <Loaded Value="True"/> + </Unit0> + <Unit1> + <Filename Value="edittest.dpr"/> + <UnitName Value="edittest"/> + <CursorPos X="1" Y="11"/> + <TopLine Value="1"/> + <EditorIndex Value="3"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit1> + <Unit2> + <Filename Value="../source/gui/gui_label.pas"/> + <UnitName Value="gui_label"/> + <CursorPos X="3" Y="118"/> + <TopLine Value="78"/> + <EditorIndex Value="2"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit2> + <Unit3> + <Filename Value="../../../../lptk/src/gfxbase.pas"/> + <UnitName Value="gfxbase"/> + <CursorPos X="21" Y="1915"/> + <TopLine Value="1940"/> + <UsageCount Value="10"/> + </Unit3> + <Unit4> + <Filename Value="../../../../fpgui/prototypes/fpgui2/source/core/gdi/gfx_gdi.pas"/> + <UnitName Value="gfx_gdi"/> + <CursorPos X="32" Y="1371"/> + <TopLine Value="1357"/> + <UsageCount Value="10"/> + </Unit4> + <Unit5> + <Filename Value="../../../../../../opt_backup/mseide/msegui/lib/common/kernel/msegraphics.pas"/> + <UnitName Value="msegraphics"/> + <CursorPos X="14" Y="2585"/> + <TopLine Value="2570"/> + <UsageCount Value="10"/> + </Unit5> + <Unit6> + <Filename Value="../../../../../../opt_backup/mseide/msegui/lib/common/kernel/msepostscriptprinter.pas"/> + <UnitName Value="msepostscriptprinter"/> + <CursorPos X="8" Y="1120"/> + <TopLine Value="1105"/> + <UsageCount Value="10"/> + </Unit6> + <Unit7> + <Filename Value="../../../../../../opt_backup/mseide/msegui/lib/common/kernel/i386-linux/mseguiintf.pas"/> + <UnitName Value="mseguiintf"/> + <CursorPos X="14" Y="3297"/> + <TopLine Value="3282"/> + <UsageCount Value="10"/> + </Unit7> + <Unit8> + <Filename Value="../../../../../../opt_backup/mseide/msegui/lib/common/kernel/msedrawtext.pas"/> + <UnitName Value="msedrawtext"/> + <CursorPos X="1" Y="842"/> + <TopLine Value="827"/> + <EditorIndex Value="7"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit8> + <Unit9> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <UnitName Value="gfx_x11"/> + <CursorPos X="1" Y="1337"/> + <TopLine Value="1330"/> + <EditorIndex Value="4"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit9> + <Unit10> + <Filename Value="../source/core/gfxbase.pas"/> + <UnitName Value="gfxbase"/> + <CursorPos X="1" Y="720"/> + <TopLine Value="714"/> + <EditorIndex Value="6"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit10> + <Unit11> + <Filename Value="../source/core/fpgfx.pas"/> + <UnitName Value="fpgfx"/> + <CursorPos X="17" Y="156"/> + <TopLine Value="136"/> + <EditorIndex Value="1"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit11> + <Unit12> + <Filename Value="../source/core/gdi/gfx_gdi.pas"/> + <UnitName Value="gfx_gdi"/> + <CursorPos X="1" Y="1100"/> + <TopLine Value="1073"/> + <EditorIndex Value="5"/> + <UsageCount Value="10"/> + <Loaded Value="True"/> + </Unit12> + </Units> + <JumpHistory Count="27" HistoryIndex="26"> + <Position1> + <Filename Value="themetest.lpr"/> + <Caret Line="18" Column="9" TopLine="9"/> + </Position1> + <Position2> + <Filename Value="themetest.lpr"/> + <Caret Line="50" Column="11" TopLine="34"/> + </Position2> + <Position3> + <Filename Value="themetest.lpr"/> + <Caret Line="49" Column="23" TopLine="36"/> + </Position3> + <Position4> + <Filename Value="themetest.lpr"/> + <Caret Line="233" Column="3" TopLine="231"/> + </Position4> + <Position5> + <Filename Value="edittest.dpr"/> + <Caret Line="300" Column="1" TopLine="288"/> + </Position5> + <Position6> + <Filename Value="themetest.lpr"/> + <Caret Line="215" Column="25" TopLine="201"/> + </Position6> + <Position7> + <Filename Value="themetest.lpr"/> + <Caret Line="15" Column="13" TopLine="1"/> + </Position7> + <Position8> + <Filename Value="themetest.lpr"/> + <Caret Line="216" Column="39" TopLine="202"/> + </Position8> + <Position9> + <Filename Value="themetest.lpr"/> + <Caret Line="240" Column="17" TopLine="233"/> + </Position9> + <Position10> + <Filename Value="../source/gui/gui_label.pas"/> + <Caret Line="35" Column="63" TopLine="21"/> + </Position10> + <Position11> + <Filename Value="themetest.lpr"/> + <Caret Line="240" Column="16" TopLine="233"/> + </Position11> + <Position12> + <Filename Value="../source/gui/gui_label.pas"/> + <Caret Line="34" Column="52" TopLine="21"/> + </Position12> + <Position13> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="14" Column="26" TopLine="1"/> + </Position13> + <Position14> + <Filename Value="../../../../../../opt_backup/mseide/msegui/lib/common/kernel/msedrawtext.pas"/> + <Caret Line="840" Column="14" TopLine="822"/> + </Position14> + <Position15> + <Filename Value="../../../../../../opt_backup/mseide/msegui/lib/common/kernel/msedrawtext.pas"/> + <Caret Line="841" Column="4" TopLine="844"/> + </Position15> + <Position16> + <Filename Value="../../../../../../opt_backup/mseide/msegui/lib/common/kernel/msedrawtext.pas"/> + <Caret Line="737" Column="12" TopLine="723"/> + </Position16> + <Position17> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="1349" Column="76" TopLine="1324"/> + </Position17> + <Position18> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="1347" Column="28" TopLine="1324"/> + </Position18> + <Position19> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="1349" Column="17" TopLine="1324"/> + </Position19> + <Position20> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="1351" Column="92" TopLine="1330"/> + </Position20> + <Position21> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="1352" Column="1" TopLine="1330"/> + </Position21> + <Position22> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="1343" Column="34" TopLine="1329"/> + </Position22> + <Position23> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="1352" Column="73" TopLine="1334"/> + </Position23> + <Position24> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="1347" Column="1" TopLine="1329"/> + </Position24> + <Position25> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="129" Column="19" TopLine="118"/> + </Position25> + <Position26> + <Filename Value="../source/core/x11/gfx_x11.pas"/> + <Caret Line="78" Column="36" TopLine="77"/> + </Position26> + <Position27> + <Filename Value="../source/core/gdi/gfx_gdi.pas"/> + <Caret Line="1" Column="1" TopLine="1"/> + </Position27> + </JumpHistory> + </ProjectOptions> + <CompilerOptions> + <Version Value="5"/> + <CodeGeneration> + <Generate Value="Faster"/> + </CodeGeneration> + <Other> + <CustomOptions Value="-FUunits"/> + <CompilerPath Value="$(CompPath)"/> + </Other> + </CompilerOptions> +</CONFIG> diff --git a/prototypes/fpgui2/tests/themetest.lpr b/prototypes/fpgui2/tests/themetest.lpr new file mode 100644 index 00000000..adb26616 --- /dev/null +++ b/prototypes/fpgui2/tests/themetest.lpr @@ -0,0 +1,265 @@ +program themetest; + +{$mode objfpc}{$H+} + +uses + {$IFDEF UNIX}{$IFDEF UseCThreads} + cthreads, + {$ENDIF}{$ENDIF} + Classes, + SysUtils, + fpgfx, + gfxbase, + gui_form, + gui_scrollbar, + gui_button, + gui_label, + gfx_imgfmt_bmp; + +type + { Concept theme button } + TThemeButton = class(TfpgButton) + private + State: integer; + // 0 - normal + // 1 - hover + // 2 - mouse down + // 3 - disabled + // 4 - got focus or default + image: TfpgImage; + procedure SetThemeImage(const AValue: TfpgImage); + protected + procedure HandlePaint; override; + procedure HandleLMouseDown(X, Y: integer; ShiftState: TShiftState); override; + procedure HandleLMouseUp(x, y: integer; shiftstate: TShiftState); override; + procedure HandleMouseExit; override; + procedure HandleMouseEnter; override; + public + constructor Create(AOwner: TComponent); override; + destructor Destroy; override; + { this property is only for demo purposes! } + property ThemeImage: TfpgImage read image write SetThemeImage; + end; + + + TThemeScrollbar = class(TfpgScrollBar) + end; + + + TMainForm = class(TfpgForm) + private + lblLuna: TfpgLabel; + lblSilver: TfpgLabel; + public + constructor Create(AOwner: TComponent); override; + end; + + + +{ TXPButton } + +procedure TThemeButton.SetThemeImage(const AValue: TfpgImage); +begin + if Assigned(image) then + image.Free; + image := AValue; + Repaint; +end; + +procedure TThemeButton.HandlePaint; +var + x, i: integer; + r: TfpgRect; + iy, y: integer; + w: integer; + pofs: integer; +begin + Canvas.BeginDraw; +// inherited HandlePaint; + Canvas.ClearClipRect; + Canvas.Clear(clButtonFace); + + if State <> 1 then + begin + if Down then + State := 2 + else if Focused then + State := 4 + else if not Enabled then + State := 3 + else + State := 0; + end; + + x := 0; + { left } + Canvas.DrawImagePart(x, 0, image, state*32, 0, 3, 21); + { body } + for i := (x+3) to (x+3+69) do + Canvas.DrawImagePart(i, 0, image, (state*32)+3, 0, 1, 21); + { right } + Canvas.DrawImagePart(i, 0, image, (state*32)+29, 0, 3, 21); + + if Focused and (not Embedded) then + begin + Canvas.SetColor(clText1); + Canvas.SetLineStyle(1, lsDot); + Canvas.DrawRectangle(3, 3, Width - 6, Height - 6); + end + else + begin + Canvas.SetTextColor(clText1); + Canvas.SetColor(clText1); + end; + + if not Enabled then + Canvas.SetTextColor(clShadow1); + + r.left := 2; + r.top := 2; + r.Width := Width - 4; + r.Height := Height - 4; + Canvas.SetClipRect(r); + + Canvas.SetFont(Font); + y := Height div 2 - FFont.Height div 2; + if y < 3 then + y := 3; + + // offset text and image + if Down then + pofs := 1 + else + pofs := 0; + + if (ShowImage) and (FImage <> nil) then + begin + iy := Height div 2 - FImage.Height div 2; + if ImageMargin = -1 then // centered + begin + w := FFont.TextWidth(FText) + FImage.Width; + if FImageSpacing > 0 then + Inc(w, FImageSpacing); + x := (Width div 2) - (w div 2); + if x < 3 then + x := 3; + end + else + begin + x := FImageMargin + 3; + end; + + Canvas.DrawImage(x + pofs, iy + pofs, FImage); + Inc(x, FImage.Width); + if FImageSpacing > 0 then + Inc(x, FImageSpacing); + + if (FImageSpacing = -1) and (FImageMargin >= 0) then + begin + w := (Width - 3 - x) div 2 - FFont.TextWidth(FText) div 2; + if w < 1 then + w := 1; // minimal spacing + x := x + w; + end; + end + else + x := (Width div 2) - (FFont.TextWidth(FText) div 2); + + if x < 3 then + x := 3; + + Canvas.DrawString(x + pofs, y + pofs, FText); + + Canvas.EndDraw; +end; + +procedure TThemeButton.HandleLMouseDown(X, Y: integer; ShiftState: TShiftState); +begin + State := 2; + Repaint; + inherited HandleLMouseDown(X, Y, ShiftState); +end; + +procedure TThemeButton.HandleLMouseUp(x, y: integer; shiftstate: TShiftState); +begin + State := 1; + Repaint; + inherited HandleLMouseUp(x, y, shiftstate); +end; + +procedure TThemeButton.HandleMouseExit; +begin + inherited HandleMouseExit; + if Enabled then + begin + State := 0; + Repaint; + end; +end; + +procedure TThemeButton.HandleMouseEnter; +begin + inherited HandleMouseEnter; + if Enabled then + begin + State := 1; + Repaint; + end; +end; + +constructor TThemeButton.Create(AOwner: TComponent); +begin + inherited Create(AOwner); + Width := 75; + Height := 21; + State := 0; + + image := LoadImage_BMP(SetDirSeparators('../images/themes/luna/button.bmp')); + image.CreateMaskFromSample(0, 0); + image.UpdateImage; + if not Assigned(image) then + writeln('Image is nil'); +end; + +destructor TThemeButton.Destroy; +begin + image.Free; + inherited Destroy; +end; + + +{ TMainForm } + +constructor TMainForm.Create(AOwner: TComponent); +begin + inherited Create(AOwner); + WindowTitle := 'Theme test'; + SetPosition(100, 100, 400, 300); + + lblLuna := CreateLabel(self, 100, 5, 'Luna'); + lblLuna.FontDesc := 'Sans-12:bold:underline'; + lblLuna.Height := lblLuna.Font.Height; + lblLuna.Width := lblLuna.Font.TextWidth(lblLuna.Text); + + lblSilver := CreateLabel(self, 250, 5, 'Silver'); + lblSilver.FontDesc := 'Sans-12:bold:underline'; + lblSilver.Height := lblSilver.Font.Height; + lblSilver.Width := lblSilver.Font.TextWidth(lblSilver.Text); +end; + + + +procedure MainProc; +var + frm: TMainForm; +begin + fpgApplication.Initialize; + frm := TMainForm.Create(nil); + frm.Show; + fpgApplication.Run; +end; + +begin + MainProc; +end. + |