diff options
author | graemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf> | 2008-06-27 12:45:47 +0000 |
---|---|---|
committer | graemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf> | 2008-06-27 12:45:47 +0000 |
commit | eb703bcee1956bcf075a64eaae2756eb7d48ed42 (patch) | |
tree | 856c1aa072a1d243c638bbff163da66bc94e4e2f /src | |
parent | 328be13f54585df2851894ef8f81358fdc27c5cb (diff) | |
download | fpGUI-eb703bcee1956bcf075a64eaae2756eb7d48ed42.tar.xz |
* Introduced a new property to TfpgWidget, called IsContainer for all
components that act like containers (Panel, Form, etc). This optimizes
the Component Alignment calls.
* All resizing calls now get routed through DoUpdateWindowPosition() so
they have a more consistent execution path.
* OnResize now get fired when components get resized, and not just for
Forms.
* HandleAlignments() is now only called when needed.
* Fixed the bug where Alignment didn't work when components are resized
at runtime.
* Removed compiler warnings form gui_mru.pas unit.
* Memo's scrollbar now gets adjusted correctly when it's text
is modified via code.
* Minor bug fix when deleting line in a Memo component. The 'Index out of
Bounds' error still occurs though. That will be fixed shortly.
Diffstat (limited to 'src')
-rw-r--r-- | src/corelib/fpgfx.pas | 4 | ||||
-rw-r--r-- | src/corelib/gdi/fpgui_toolkit.lpk | 328 | ||||
-rw-r--r-- | src/corelib/gdi/fpgui_toolkit.pas | 23 | ||||
-rw-r--r-- | src/corelib/gfx_popupwindow.pas | 1 | ||||
-rw-r--r-- | src/corelib/gfx_widget.pas | 101 | ||||
-rw-r--r-- | src/corelib/gfxbase.pas | 34 | ||||
-rw-r--r-- | src/corelib/x11/fpgui_toolkit.lpk | 328 | ||||
-rw-r--r-- | src/corelib/x11/fpgui_toolkit.pas | 23 | ||||
-rw-r--r-- | src/gui/gui_form.pas | 17 | ||||
-rw-r--r-- | src/gui/gui_memo.pas | 33 | ||||
-rw-r--r-- | src/gui/gui_mru.pas | 12 | ||||
-rw-r--r-- | src/gui/gui_panel.pas | 1 | ||||
-rw-r--r-- | src/gui/gui_tab.pas | 2 |
13 files changed, 849 insertions, 58 deletions
diff --git a/src/corelib/fpgfx.pas b/src/corelib/fpgfx.pas index bc2fb866..13ed1eaa 100644 --- a/src/corelib/fpgfx.pas +++ b/src/corelib/fpgfx.pas @@ -43,10 +43,10 @@ const TextFlagsDflt = [txtLeft, txtTop, txtEnabled]; // Used for the internal message queue - cMessageQueueSize = 512; + cMessageQueueSize = 1024; // version and name constants - fpGUIVersion = '0.6.1'; + fpGUIVersion = '0.6.2'; fpGUIName = 'fpGUI Toolkit'; diff --git a/src/corelib/gdi/fpgui_toolkit.lpk b/src/corelib/gdi/fpgui_toolkit.lpk new file mode 100644 index 00000000..243f958f --- /dev/null +++ b/src/corelib/gdi/fpgui_toolkit.lpk @@ -0,0 +1,328 @@ +<?xml version="1.0"?> +<CONFIG> + <Package Version="3"> + <Name Value="fpgui_toolkit"/> + <Author Value="Graeme Geldenhuys"/> + <CompilerOptions> + <Version Value="5"/> + <SearchPaths> + <OtherUnitFiles Value="../;../../gui/;../../gui/db/"/> + <UnitOutputDirectory Value="../../../lib"/> + </SearchPaths> + <Parsing> + <SyntaxOptions> + <CStyleOperator Value="False"/> + <AllowLabel Value="False"/> + <CPPInline Value="False"/> + </SyntaxOptions> + </Parsing> + <CodeGeneration> + <Generate Value="Faster"/> + </CodeGeneration> + <Other> + <CompilerPath Value="$(CompPath)"/> + </Other> + </CompilerOptions> + <Description Value="fpGUI Toolkit +"/> + <License Value="Modified LGPL +"/> + <Version Minor="6" Release="2"/> + <Files Count="70"> + <Item1> + <Filename Value="../stdimages.inc"/> + <Type Value="Include"/> + </Item1> + <Item2> + <Filename Value="../fpgfx.pas"/> + <UnitName Value="fpgfx"/> + </Item2> + <Item3> + <Filename Value="../gfxbase.pas"/> + <UnitName Value="gfxbase"/> + </Item3> + <Item4> + <Filename Value="../gfx_cmdlineparams.pas"/> + <UnitName Value="gfx_cmdlineparams"/> + </Item4> + <Item5> + <Filename Value="../gfx_command_intf.pas"/> + <UnitName Value="gfx_command_intf"/> + </Item5> + <Item6> + <Filename Value="../gfx_constants.pas"/> + <UnitName Value="gfx_constants"/> + </Item6> + <Item7> + <Filename Value="../gfx_extinterpolation.pas"/> + <UnitName Value="gfx_extinterpolation"/> + </Item7> + <Item8> + <Filename Value="../gfx_imagelist.pas"/> + <UnitName Value="gfx_imagelist"/> + </Item8> + <Item9> + <Filename Value="../gfx_imgfmt_bmp.pas"/> + <UnitName Value="gfx_imgfmt_bmp"/> + </Item9> + <Item10> + <Filename Value="../gfx_msgqueue.inc"/> + <Type Value="Include"/> + </Item10> + <Item11> + <Filename Value="../gfx_pofiles.pas"/> + <UnitName Value="gfx_pofiles"/> + </Item11> + <Item12> + <Filename Value="../gfx_popupwindow.pas"/> + <UnitName Value="gfx_popupwindow"/> + </Item12> + <Item13> + <Filename Value="../gfx_stdimages.pas"/> + <UnitName Value="gfx_stdimages"/> + </Item13> + <Item14> + <Filename Value="../gfx_stringhashlist.pas"/> + <UnitName Value="gfx_stringhashlist"/> + </Item14> + <Item15> + <Filename Value="../gfx_translations.pas"/> + <UnitName Value="gfx_translations"/> + </Item15> + <Item16> + <Filename Value="../gfx_utf8utils.pas"/> + <UnitName Value="gfx_UTF8utils"/> + </Item16> + <Item17> + <Filename Value="../gfx_utils.pas"/> + <UnitName Value="gfx_utils"/> + </Item17> + <Item18> + <Filename Value="../gfx_widget.pas"/> + <UnitName Value="gfx_widget"/> + </Item18> + <Item19> + <Filename Value="../gfx_wuline.pas"/> + <UnitName Value="gfx_wuline"/> + </Item19> + <Item20> + <Filename Value="../keys.inc"/> + <Type Value="Include"/> + </Item20> + <Item21> + <Filename Value="../lang_afrikaans.inc"/> + <Type Value="Include"/> + </Item21> + <Item22> + <Filename Value="../lang_english.inc"/> + <Type Value="Include"/> + </Item22> + <Item23> + <Filename Value="../lang_french.inc"/> + <Type Value="Include"/> + </Item23> + <Item24> + <Filename Value="../lang_german.inc"/> + <Type Value="Include"/> + </Item24> + <Item25> + <Filename Value="../lang_italian.inc"/> + <Type Value="Include"/> + </Item25> + <Item26> + <Filename Value="../lang_portuguese.inc"/> + <Type Value="Include"/> + </Item26> + <Item27> + <Filename Value="../lang_russian.inc"/> + <Type Value="Include"/> + </Item27> + <Item28> + <Filename Value="../lang_spanish.inc"/> + <Type Value="Include"/> + </Item28> + <Item29> + <Filename Value="../predefinedcolors.inc"/> + <Type Value="Include"/> + </Item29> + <Item30> + <Filename Value="gfx_impl.pas"/> + <UnitName Value="gfx_impl"/> + </Item30> + <Item31> + <Filename Value="gfx_utils_impl.inc"/> + <Type Value="Include"/> + </Item31> + <Item32> + <Filename Value="gfx_x11.pas"/> + <UnitName Value="gfx_x11"/> + </Item32> + <Item33> + <Filename Value="_netlayer.pas"/> + <UnitName Value="_netlayer"/> + </Item33> + <Item34> + <Filename Value="x11_keyconv.pas"/> + <UnitName Value="x11_keyconv"/> + </Item34> + <Item35> + <Filename Value="x11_xft.pas"/> + <UnitName Value="x11_xft"/> + </Item35> + <Item36> + <Filename Value="../../gui/promptuserdialog.inc"/> + <Type Value="Include"/> + </Item36> + <Item37> + <Filename Value="../../gui/gui_animation.pas"/> + <UnitName Value="gui_animation"/> + </Item37> + <Item38> + <Filename Value="../../gui/gui_basegrid.pas"/> + <UnitName Value="gui_basegrid"/> + </Item38> + <Item39> + <Filename Value="../../gui/gui_bevel.pas"/> + <UnitName Value="gui_bevel"/> + </Item39> + <Item40> + <Filename Value="../../gui/gui_button.pas"/> + <UnitName Value="gui_button"/> + </Item40> + <Item41> + <Filename Value="../../gui/gui_checkbox.pas"/> + <UnitName Value="gui_checkbox"/> + </Item41> + <Item42> + <Filename Value="../../gui/gui_combobox.pas"/> + <UnitName Value="gui_combobox"/> + </Item42> + <Item43> + <Filename Value="../../gui/gui_customgrid.pas"/> + <UnitName Value="gui_customgrid"/> + </Item43> + <Item44> + <Filename Value="../../gui/gui_dialogs.pas"/> + <UnitName Value="gui_dialogs"/> + </Item44> + <Item45> + <Filename Value="../../gui/gui_editcombo.pas"/> + <UnitName Value="gui_editcombo"/> + </Item45> + <Item46> + <Filename Value="../../gui/gui_edit.pas"/> + <UnitName Value="gui_edit"/> + </Item46> + <Item47> + <Filename Value="../../gui/gui_form.pas"/> + <UnitName Value="gui_form"/> + </Item47> + <Item48> + <Filename Value="../../gui/gui_gauge.pas"/> + <UnitName Value="gui_gauge"/> + </Item48> + <Item49> + <Filename Value="../../gui/gui_grid.pas"/> + <UnitName Value="gui_grid"/> + </Item49> + <Item50> + <Filename Value="../../gui/gui_hyperlink.pas"/> + <UnitName Value="gui_hyperlink"/> + </Item50> + <Item51> + <Filename Value="../../gui/gui_iniutils.pas"/> + <UnitName Value="gui_iniutils"/> + </Item51> + <Item52> + <Filename Value="../../gui/gui_label.pas"/> + <UnitName Value="gui_label"/> + </Item52> + <Item53> + <Filename Value="../../gui/gui_listbox.pas"/> + <UnitName Value="gui_listbox"/> + </Item53> + <Item54> + <Filename Value="../../gui/gui_listview.pas"/> + <UnitName Value="gui_listview"/> + </Item54> + <Item55> + <Filename Value="../../gui/gui_memo.pas"/> + <UnitName Value="gui_memo"/> + </Item55> + <Item56> + <Filename Value="../../gui/gui_menu.pas"/> + <UnitName Value="gui_menu"/> + </Item56> + <Item57> + <Filename Value="../../gui/gui_mru.pas"/> + <UnitName Value="gui_mru"/> + </Item57> + <Item58> + <Filename Value="../../gui/gui_panel.pas"/> + <UnitName Value="gui_panel"/> + </Item58> + <Item59> + <Filename Value="../../gui/gui_popupcalendar.pas"/> + <UnitName Value="gui_popupcalendar"/> + </Item59> + <Item60> + <Filename Value="../../gui/gui_progressbar.pas"/> + <UnitName Value="gui_progressbar"/> + </Item60> + <Item61> + <Filename Value="../../gui/gui_radiobutton.pas"/> + <UnitName Value="gui_radiobutton"/> + </Item61> + <Item62> + <Filename Value="../../gui/gui_scrollbar.pas"/> + <UnitName Value="gui_scrollbar"/> + </Item62> + <Item63> + <Filename Value="../../gui/gui_style.pas"/> + <UnitName Value="gui_style"/> + </Item63> + <Item64> + <Filename Value="../../gui/gui_tab.pas"/> + <UnitName Value="gui_tab"/> + </Item64> + <Item65> + <Filename Value="../../gui/gui_trackbar.pas"/> + <UnitName Value="gui_trackbar"/> + </Item65> + <Item66> + <Filename Value="../../gui/gui_tree.pas"/> + <UnitName Value="gui_tree"/> + </Item66> + <Item67> + <Filename Value="../../gui/logo.inc"/> + <Type Value="Include"/> + </Item67> + <Item68> + <Filename Value="../../gui/messagedialog.inc"/> + <Type Value="Include"/> + </Item68> + <Item69> + <Filename Value="../../gui/newdirdialog.inc"/> + <Type Value="Include"/> + </Item69> + <Item70> + <Filename Value="../../gui/db/fpgui_db.pas"/> + <UnitName Value="fpgui_db"/> + </Item70> + </Files> + <LazDoc Paths="../../../docs/xml/corelib/;../../../docs/xml/corelib/x11/;../../../docs/xml/corelib/gdi/;../../../docs/xml/gui/"/> + <RequiredPkgs Count="1"> + <Item1> + <PackageName Value="FCL"/> + <MinVersion Major="1" Valid="True"/> + </Item1> + </RequiredPkgs> + <UsageOptions> + <UnitPath Value="$(PkgOutDir)/"/> + </UsageOptions> + <PublishOptions> + <Version Value="2"/> + <IgnoreBinaries Value="False"/> + </PublishOptions> + </Package> +</CONFIG> diff --git a/src/corelib/gdi/fpgui_toolkit.pas b/src/corelib/gdi/fpgui_toolkit.pas new file mode 100644 index 00000000..85c6b743 --- /dev/null +++ b/src/corelib/gdi/fpgui_toolkit.pas @@ -0,0 +1,23 @@ +{ This file was automatically created by Lazarus. Do not edit! +This source is only used to compile and install the package. + } + +unit fpgui_toolkit; + +interface + +uses + fpgfx, gfxbase, gfx_cmdlineparams, gfx_command_intf, gfx_constants, + gfx_extinterpolation, gfx_imagelist, gfx_imgfmt_bmp, gfx_pofiles, + gfx_popupwindow, gfx_stdimages, gfx_stringhashlist, gfx_translations, + gfx_UTF8utils, gfx_utils, gfx_widget, gfx_wuline, gfx_impl, gfx_x11, + _netlayer, x11_keyconv, x11_xft, gui_animation, gui_basegrid, gui_bevel, + gui_button, gui_checkbox, gui_combobox, gui_customgrid, gui_dialogs, + gui_editcombo, gui_edit, gui_form, gui_gauge, gui_grid, gui_hyperlink, + gui_iniutils, gui_label, gui_listbox, gui_listview, gui_memo, gui_menu, + gui_mru, gui_panel, gui_popupcalendar, gui_progressbar, gui_radiobutton, + gui_scrollbar, gui_style, gui_tab, gui_trackbar, gui_tree, fpgui_db; + +implementation + +end. diff --git a/src/corelib/gfx_popupwindow.pas b/src/corelib/gfx_popupwindow.pas index e19b8642..8fb37b2c 100644 --- a/src/corelib/gfx_popupwindow.pas +++ b/src/corelib/gfx_popupwindow.pas @@ -284,6 +284,7 @@ begin FDontCloseWidget := nil; Parent := nil; FPopupFrame := False; + FIsContainer := True; end; procedure TfpgPopupWindow.ShowAt(AWidget: TfpgWidget; x, y: TfpgCoord); diff --git a/src/corelib/gfx_widget.pas b/src/corelib/gfx_widget.pas index 85bf059b..03df3577 100644 --- a/src/corelib/gfx_widget.pas +++ b/src/corelib/gfx_widget.pas @@ -60,6 +60,7 @@ type FHint: string; FBackgroundColor: TfpgColor; FTextColor: TfpgColor; + FIsContainer: Boolean; procedure SetBackgroundColor(const AValue: TfpgColor); virtual; procedure SetTextColor(const AValue: TfpgColor); virtual; function GetClientBounds: TfpgRect; virtual; @@ -67,9 +68,11 @@ type procedure SetParent(const AValue: TfpgWidget); reintroduce; procedure SetEnabled(const AValue: boolean); virtual; procedure SetVisible(const AValue: boolean); virtual; - procedure DoAlign(aalign: TAlign); + procedure DoUpdateWindowPosition(aleft, atop, awidth, aheight: TfpgCoord); override; + procedure DoAlign(AAlign: TAlign); + procedure DoResize; procedure HandlePaint; virtual; - procedure HandleResize(awidth, aheight: TfpgCoord); virtual; + procedure HandleResize(AWidth, AHeight: TfpgCoord); virtual; procedure HandleMove(x, y: TfpgCoord); virtual; procedure HandleKeyChar(var AText: TfpgChar; var shiftstate: TShiftState; var consumed: boolean); virtual; procedure HandleKeyPress(var keycode: word; var shiftstate: TShiftState; var consumed: boolean); virtual; @@ -116,6 +119,7 @@ type property FormDesigner: TObject read FFormDesigner write FFormDesigner; property Parent: TfpgWidget read GetParent write SetParent; property ActiveWidget: TfpgWidget read FActiveWidget write SetActiveWidget; + property IsContainer: Boolean read FIsContainer; property Visible: boolean read FVisible write SetVisible default True; property Enabled: boolean read FEnabled write SetEnabled default True; property TabOrder: integer read FTabOrder write FTabOrder; @@ -200,6 +204,24 @@ begin end; end; +procedure TfpgWidget.DoUpdateWindowPosition(aleft, atop, awidth, aheight: TfpgCoord); +var + dw: integer; + dh: integer; +begin +// writeln('DoUpdateWindowPosition - ', Classname); + dw := FWidth - FPrevWidth; + dh := FHeight - FPrevHeight; + + if IsContainer and FDirty then + HandleAlignments(dw, dh); + + inherited DoUpdateWindowPosition(aleft, atop, awidth, aheight); + if FDirty and ((dw <> 0) or (dh <> 0)) then + DoResize; + FDirty := False; +end; + procedure TfpgWidget.SetBackgroundColor(const AValue: TfpgColor); begin if FBackgroundColor <> AValue then @@ -241,16 +263,17 @@ begin Loading; {$endif} - FOnScreen := False; - FVisible := True; - FActiveWidget := nil; - FEnabled := True; - FFocusable := False; - FFocused := False; - FTabOrder := 0; - FAnchors := [anLeft, anTop]; - FAlign := alNone; - FHint := ''; + FIsContainer := False; + FOnScreen := False; + FVisible := True; + FActiveWidget := nil; + FEnabled := True; + FFocusable := False; + FFocused := False; + FTabOrder := 0; + FAnchors := [anLeft, anTop]; + FAlign := alNone; + FHint := ''; FBackgroundColor := clWindowBackground; FTextColor := clText1; @@ -868,25 +891,13 @@ end; procedure TfpgWidget.MsgResize(var msg: TfpgMessageRec); begin +// writeln('MsgResize - ', Classname); HandleResize(msg.Params.rect.Width, msg.Params.rect.Height); if FFormDesigner <> nil then begin FFormDesigner.Dispatch(msg); end; - if Assigned(FOnResize) then - FOnResize(Self); -end; - -procedure TfpgWidget.HandleResize(awidth, aheight: TfpgCoord); -var - dw: integer; - dh: integer; -begin - dw := awidth - FWidth; - dh := aheight - FHeight; - FWidth := Max(awidth, FMinWidth); - FHeight := Max(aheight, FMinHeight); - HandleAlignments(dw, dh); + DoResize; end; procedure TfpgWidget.MsgMove(var msg: TfpgMessageRec); @@ -898,10 +909,17 @@ begin end; end; +procedure TfpgWidget.HandleResize(AWidth, AHeight: TfpgCoord); +begin +// writeln('HandleResize - ', Classname); + Width := Max(awidth, FMinWidth); + Height := Max(aheight, FMinHeight); +end; + procedure TfpgWidget.HandleMove(x, y: TfpgCoord); begin - FLeft := x; - FTop := y; + Left := x; + Top := y; end; procedure TfpgWidget.HandleAlignments(dwidth, dheight: TfpgCoord); @@ -915,6 +933,7 @@ var begin if (csLoading in ComponentState) then Exit; //==> +// writeln('HandleAlignments - ', Classname); FAlignRect := GetClientBounds; DoAlign(alTop); @@ -958,19 +977,19 @@ procedure TfpgWidget.MoveAndResize(ALeft, ATop, AWidth, AHeight: TfpgCoord); begin if HasHandle then begin - if (aleft <> FLeft) or (atop <> FTop) then - HandleMove(aleft, atop); - if (awidth <> FWidth) or (aheight <> FHeight) then - HandleResize(awidth, aheight); + if (ALeft <> FLeft) or (ATop <> FTop) then + HandleMove(ALeft, ATop); + if (AWidth <> FWidth) or (AHeight <> FHeight) then + HandleResize(AWidth, AHeight); UpdateWindowPosition; end else begin // When the widget is created, it's position will be applied - FLeft := ALeft; - FTop := ATop; - FWidth := AWidth; - FHeight := AHeight; + Left := ALeft; + Top := ATop; + Width := AWidth; + Height := AHeight; end; end; @@ -1008,7 +1027,7 @@ begin end; end; -procedure TfpgWidget.DoAlign(aalign: TAlign); +procedure TfpgWidget.DoAlign(AAlign: TAlign); var alist: TList; w: TfpgWidget; @@ -1019,7 +1038,7 @@ begin if Components[n] is TfpgWidget then begin w := TfpgWidget(Components[n]); - if w.Align = aalign then + if w.Align = AAlign then alist.Add(w); end; @@ -1064,6 +1083,12 @@ begin alist.Free; end; +procedure TfpgWidget.DoResize; +begin + if Assigned(FOnResize) then + FOnResize(Self); +end; + procedure TfpgWidget.SetPosition(aleft, atop, awidth, aheight: TfpgCoord); begin MoveAndResize(aleft, atop, awidth, aheight); diff --git a/src/corelib/gfxbase.pas b/src/corelib/gfxbase.pas index 8757deda..b249d486 100644 --- a/src/corelib/gfxbase.pas +++ b/src/corelib/gfxbase.pas @@ -358,9 +358,14 @@ type FLeft: TfpgCoord; FWidth: TfpgCoord; FHeight: TfpgCoord; + FPrevTop: TfpgCoord; + FPrevLeft: TfpgCoord; + FPrevWidth: TfpgCoord; + FPrevHeight: TfpgCoord; FMinWidth: TfpgCoord; FMinHeight: TfpgCoord; FCanvas: TfpgCanvasBase; + FDirty: Boolean; function HandleIsValid: boolean; virtual; abstract; procedure DoUpdateWindowPosition(aleft, atop, awidth, aheight: TfpgCoord); virtual; abstract; procedure DoAllocateWindowHandle(AParent: TfpgWindowBase); virtual; abstract; @@ -377,6 +382,8 @@ type procedure AllocateWindowHandle; procedure ReleaseWindowHandle; procedure SetWindowTitle(const ATitle: string); virtual; + procedure SetTop(const AValue: TfpgCoord); virtual; + procedure SetLeft(const AValue: TfpgCoord); virtual; procedure SetHeight(const AValue: TfpgCoord); virtual; procedure SetWidth(const AValue: TfpgCoord); virtual; public @@ -400,8 +407,8 @@ type property HasHandle: boolean read HandleIsValid; property WindowType: TWindowType read FWindowType write FWindowType; property WindowAttributes: TWindowAttributes read FWindowAttributes write FWindowAttributes; - property Left: TfpgCoord read FLeft write FLeft; - property Top: TfpgCoord read FTop write FTop; + property Left: TfpgCoord read FLeft write SetLeft; + property Top: TfpgCoord read FTop write SetTop; property Width: TfpgCoord read FWidth write SetWidth; property Height: TfpgCoord read FHeight write SetHeight; property MinWidth: TfpgCoord read FMinWidth write FMinWidth; @@ -947,24 +954,47 @@ begin DoSetWindowTitle(ATitle); end; +procedure TfpgWindowBase.SetTop(const AValue: TfpgCoord); +begin + if FTop = AValue then + Exit; + FPrevTop := FTop; + FTop := AValue; + FDirty := True; +end; + +procedure TfpgWindowBase.SetLeft(const AValue: TfpgCoord); +begin + if FLeft = AValue then + Exit; + FPrevLeft := FHeight; + FLeft := AValue; + FDirty := True; +end; + procedure TfpgWindowBase.SetHeight(const AValue: TfpgCoord); begin if FHeight = AValue then Exit; + FPrevHeight := FHeight; FHeight := AValue; + FDirty := True; end; procedure TfpgWindowBase.SetWidth(const AValue: TfpgCoord); begin if FWidth = AValue then Exit; + FPrevWidth := FWidth; FWidth := AValue; + FDirty := True; end; constructor TfpgWindowBase.Create(AOwner: TComponent); begin inherited Create(AOwner); FMouseCursor := mcDefault; + FDirty := True; end; procedure TfpgWindowBase.AfterConstruction; diff --git a/src/corelib/x11/fpgui_toolkit.lpk b/src/corelib/x11/fpgui_toolkit.lpk new file mode 100644 index 00000000..243f958f --- /dev/null +++ b/src/corelib/x11/fpgui_toolkit.lpk @@ -0,0 +1,328 @@ +<?xml version="1.0"?> +<CONFIG> + <Package Version="3"> + <Name Value="fpgui_toolkit"/> + <Author Value="Graeme Geldenhuys"/> + <CompilerOptions> + <Version Value="5"/> + <SearchPaths> + <OtherUnitFiles Value="../;../../gui/;../../gui/db/"/> + <UnitOutputDirectory Value="../../../lib"/> + </SearchPaths> + <Parsing> + <SyntaxOptions> + <CStyleOperator Value="False"/> + <AllowLabel Value="False"/> + <CPPInline Value="False"/> + </SyntaxOptions> + </Parsing> + <CodeGeneration> + <Generate Value="Faster"/> + </CodeGeneration> + <Other> + <CompilerPath Value="$(CompPath)"/> + </Other> + </CompilerOptions> + <Description Value="fpGUI Toolkit +"/> + <License Value="Modified LGPL +"/> + <Version Minor="6" Release="2"/> + <Files Count="70"> + <Item1> + <Filename Value="../stdimages.inc"/> + <Type Value="Include"/> + </Item1> + <Item2> + <Filename Value="../fpgfx.pas"/> + <UnitName Value="fpgfx"/> + </Item2> + <Item3> + <Filename Value="../gfxbase.pas"/> + <UnitName Value="gfxbase"/> + </Item3> + <Item4> + <Filename Value="../gfx_cmdlineparams.pas"/> + <UnitName Value="gfx_cmdlineparams"/> + </Item4> + <Item5> + <Filename Value="../gfx_command_intf.pas"/> + <UnitName Value="gfx_command_intf"/> + </Item5> + <Item6> + <Filename Value="../gfx_constants.pas"/> + <UnitName Value="gfx_constants"/> + </Item6> + <Item7> + <Filename Value="../gfx_extinterpolation.pas"/> + <UnitName Value="gfx_extinterpolation"/> + </Item7> + <Item8> + <Filename Value="../gfx_imagelist.pas"/> + <UnitName Value="gfx_imagelist"/> + </Item8> + <Item9> + <Filename Value="../gfx_imgfmt_bmp.pas"/> + <UnitName Value="gfx_imgfmt_bmp"/> + </Item9> + <Item10> + <Filename Value="../gfx_msgqueue.inc"/> + <Type Value="Include"/> + </Item10> + <Item11> + <Filename Value="../gfx_pofiles.pas"/> + <UnitName Value="gfx_pofiles"/> + </Item11> + <Item12> + <Filename Value="../gfx_popupwindow.pas"/> + <UnitName Value="gfx_popupwindow"/> + </Item12> + <Item13> + <Filename Value="../gfx_stdimages.pas"/> + <UnitName Value="gfx_stdimages"/> + </Item13> + <Item14> + <Filename Value="../gfx_stringhashlist.pas"/> + <UnitName Value="gfx_stringhashlist"/> + </Item14> + <Item15> + <Filename Value="../gfx_translations.pas"/> + <UnitName Value="gfx_translations"/> + </Item15> + <Item16> + <Filename Value="../gfx_utf8utils.pas"/> + <UnitName Value="gfx_UTF8utils"/> + </Item16> + <Item17> + <Filename Value="../gfx_utils.pas"/> + <UnitName Value="gfx_utils"/> + </Item17> + <Item18> + <Filename Value="../gfx_widget.pas"/> + <UnitName Value="gfx_widget"/> + </Item18> + <Item19> + <Filename Value="../gfx_wuline.pas"/> + <UnitName Value="gfx_wuline"/> + </Item19> + <Item20> + <Filename Value="../keys.inc"/> + <Type Value="Include"/> + </Item20> + <Item21> + <Filename Value="../lang_afrikaans.inc"/> + <Type Value="Include"/> + </Item21> + <Item22> + <Filename Value="../lang_english.inc"/> + <Type Value="Include"/> + </Item22> + <Item23> + <Filename Value="../lang_french.inc"/> + <Type Value="Include"/> + </Item23> + <Item24> + <Filename Value="../lang_german.inc"/> + <Type Value="Include"/> + </Item24> + <Item25> + <Filename Value="../lang_italian.inc"/> + <Type Value="Include"/> + </Item25> + <Item26> + <Filename Value="../lang_portuguese.inc"/> + <Type Value="Include"/> + </Item26> + <Item27> + <Filename Value="../lang_russian.inc"/> + <Type Value="Include"/> + </Item27> + <Item28> + <Filename Value="../lang_spanish.inc"/> + <Type Value="Include"/> + </Item28> + <Item29> + <Filename Value="../predefinedcolors.inc"/> + <Type Value="Include"/> + </Item29> + <Item30> + <Filename Value="gfx_impl.pas"/> + <UnitName Value="gfx_impl"/> + </Item30> + <Item31> + <Filename Value="gfx_utils_impl.inc"/> + <Type Value="Include"/> + </Item31> + <Item32> + <Filename Value="gfx_x11.pas"/> + <UnitName Value="gfx_x11"/> + </Item32> + <Item33> + <Filename Value="_netlayer.pas"/> + <UnitName Value="_netlayer"/> + </Item33> + <Item34> + <Filename Value="x11_keyconv.pas"/> + <UnitName Value="x11_keyconv"/> + </Item34> + <Item35> + <Filename Value="x11_xft.pas"/> + <UnitName Value="x11_xft"/> + </Item35> + <Item36> + <Filename Value="../../gui/promptuserdialog.inc"/> + <Type Value="Include"/> + </Item36> + <Item37> + <Filename Value="../../gui/gui_animation.pas"/> + <UnitName Value="gui_animation"/> + </Item37> + <Item38> + <Filename Value="../../gui/gui_basegrid.pas"/> + <UnitName Value="gui_basegrid"/> + </Item38> + <Item39> + <Filename Value="../../gui/gui_bevel.pas"/> + <UnitName Value="gui_bevel"/> + </Item39> + <Item40> + <Filename Value="../../gui/gui_button.pas"/> + <UnitName Value="gui_button"/> + </Item40> + <Item41> + <Filename Value="../../gui/gui_checkbox.pas"/> + <UnitName Value="gui_checkbox"/> + </Item41> + <Item42> + <Filename Value="../../gui/gui_combobox.pas"/> + <UnitName Value="gui_combobox"/> + </Item42> + <Item43> + <Filename Value="../../gui/gui_customgrid.pas"/> + <UnitName Value="gui_customgrid"/> + </Item43> + <Item44> + <Filename Value="../../gui/gui_dialogs.pas"/> + <UnitName Value="gui_dialogs"/> + </Item44> + <Item45> + <Filename Value="../../gui/gui_editcombo.pas"/> + <UnitName Value="gui_editcombo"/> + </Item45> + <Item46> + <Filename Value="../../gui/gui_edit.pas"/> + <UnitName Value="gui_edit"/> + </Item46> + <Item47> + <Filename Value="../../gui/gui_form.pas"/> + <UnitName Value="gui_form"/> + </Item47> + <Item48> + <Filename Value="../../gui/gui_gauge.pas"/> + <UnitName Value="gui_gauge"/> + </Item48> + <Item49> + <Filename Value="../../gui/gui_grid.pas"/> + <UnitName Value="gui_grid"/> + </Item49> + <Item50> + <Filename Value="../../gui/gui_hyperlink.pas"/> + <UnitName Value="gui_hyperlink"/> + </Item50> + <Item51> + <Filename Value="../../gui/gui_iniutils.pas"/> + <UnitName Value="gui_iniutils"/> + </Item51> + <Item52> + <Filename Value="../../gui/gui_label.pas"/> + <UnitName Value="gui_label"/> + </Item52> + <Item53> + <Filename Value="../../gui/gui_listbox.pas"/> + <UnitName Value="gui_listbox"/> + </Item53> + <Item54> + <Filename Value="../../gui/gui_listview.pas"/> + <UnitName Value="gui_listview"/> + </Item54> + <Item55> + <Filename Value="../../gui/gui_memo.pas"/> + <UnitName Value="gui_memo"/> + </Item55> + <Item56> + <Filename Value="../../gui/gui_menu.pas"/> + <UnitName Value="gui_menu"/> + </Item56> + <Item57> + <Filename Value="../../gui/gui_mru.pas"/> + <UnitName Value="gui_mru"/> + </Item57> + <Item58> + <Filename Value="../../gui/gui_panel.pas"/> + <UnitName Value="gui_panel"/> + </Item58> + <Item59> + <Filename Value="../../gui/gui_popupcalendar.pas"/> + <UnitName Value="gui_popupcalendar"/> + </Item59> + <Item60> + <Filename Value="../../gui/gui_progressbar.pas"/> + <UnitName Value="gui_progressbar"/> + </Item60> + <Item61> + <Filename Value="../../gui/gui_radiobutton.pas"/> + <UnitName Value="gui_radiobutton"/> + </Item61> + <Item62> + <Filename Value="../../gui/gui_scrollbar.pas"/> + <UnitName Value="gui_scrollbar"/> + </Item62> + <Item63> + <Filename Value="../../gui/gui_style.pas"/> + <UnitName Value="gui_style"/> + </Item63> + <Item64> + <Filename Value="../../gui/gui_tab.pas"/> + <UnitName Value="gui_tab"/> + </Item64> + <Item65> + <Filename Value="../../gui/gui_trackbar.pas"/> + <UnitName Value="gui_trackbar"/> + </Item65> + <Item66> + <Filename Value="../../gui/gui_tree.pas"/> + <UnitName Value="gui_tree"/> + </Item66> + <Item67> + <Filename Value="../../gui/logo.inc"/> + <Type Value="Include"/> + </Item67> + <Item68> + <Filename Value="../../gui/messagedialog.inc"/> + <Type Value="Include"/> + </Item68> + <Item69> + <Filename Value="../../gui/newdirdialog.inc"/> + <Type Value="Include"/> + </Item69> + <Item70> + <Filename Value="../../gui/db/fpgui_db.pas"/> + <UnitName Value="fpgui_db"/> + </Item70> + </Files> + <LazDoc Paths="../../../docs/xml/corelib/;../../../docs/xml/corelib/x11/;../../../docs/xml/corelib/gdi/;../../../docs/xml/gui/"/> + <RequiredPkgs Count="1"> + <Item1> + <PackageName Value="FCL"/> + <MinVersion Major="1" Valid="True"/> + </Item1> + </RequiredPkgs> + <UsageOptions> + <UnitPath Value="$(PkgOutDir)/"/> + </UsageOptions> + <PublishOptions> + <Version Value="2"/> + <IgnoreBinaries Value="False"/> + </PublishOptions> + </Package> +</CONFIG> diff --git a/src/corelib/x11/fpgui_toolkit.pas b/src/corelib/x11/fpgui_toolkit.pas new file mode 100644 index 00000000..85c6b743 --- /dev/null +++ b/src/corelib/x11/fpgui_toolkit.pas @@ -0,0 +1,23 @@ +{ This file was automatically created by Lazarus. Do not edit! +This source is only used to compile and install the package. + } + +unit fpgui_toolkit; + +interface + +uses + fpgfx, gfxbase, gfx_cmdlineparams, gfx_command_intf, gfx_constants, + gfx_extinterpolation, gfx_imagelist, gfx_imgfmt_bmp, gfx_pofiles, + gfx_popupwindow, gfx_stdimages, gfx_stringhashlist, gfx_translations, + gfx_UTF8utils, gfx_utils, gfx_widget, gfx_wuline, gfx_impl, gfx_x11, + _netlayer, x11_keyconv, x11_xft, gui_animation, gui_basegrid, gui_bevel, + gui_button, gui_checkbox, gui_combobox, gui_customgrid, gui_dialogs, + gui_editcombo, gui_edit, gui_form, gui_gauge, gui_grid, gui_hyperlink, + gui_iniutils, gui_label, gui_listbox, gui_listview, gui_memo, gui_menu, + gui_mru, gui_panel, gui_popupcalendar, gui_progressbar, gui_radiobutton, + gui_scrollbar, gui_style, gui_tab, gui_trackbar, gui_tree, fpgui_db; + +implementation + +end. diff --git a/src/gui/gui_form.pas b/src/gui/gui_form.pas index 18cd1960..b75a5638 100644 --- a/src/gui/gui_form.pas +++ b/src/gui/gui_form.pas @@ -55,6 +55,8 @@ type procedure AdjustWindowStyle; override; procedure SetWindowParameters; override; procedure SetWindowTitle(const ATitle: string); override; + procedure SetHeight(const AValue: TfpgCoord); override; + procedure SetWidth(const AValue: TfpgCoord); override; procedure MsgActivate(var msg: TfpgMessageRec); message FPGM_ACTIVATE; procedure MsgDeActivate(var msg: TfpgMessageRec); message FPGM_DEACTIVATE; procedure MsgClose(var msg: TfpgMessageRec); message FPGM_CLOSE; @@ -66,7 +68,7 @@ type procedure HandleResize(awidth, aheight: TfpgCoord); override; procedure HandleKeyPress(var keycode: word; var shiftstate: TShiftState; var consumed: boolean); override; procedure DoOnClose(var CloseAction: TCloseAction); virtual; - + // properties property Sizeable: boolean read FSizeable write FSizeable; property ModalResult: integer read FModalResult write FModalResult; property FullScreen: boolean read FFullScreen write FFullScreen default False; @@ -157,6 +159,18 @@ begin inherited SetWindowTitle(ATitle); end; +procedure TfpgBaseForm.SetHeight(const AValue: TfpgCoord); +begin + if Sizeable then + inherited SetHeight(AValue); +end; + +procedure TfpgBaseForm.SetWidth(const AValue: TfpgCoord); +begin + if Sizeable then + inherited SetWidth(AValue); +end; + procedure TfpgBaseForm.MsgActivate(var msg: TfpgMessageRec); begin if (fpgApplication.TopModalForm = nil) or (fpgApplication.TopModalForm = self) then @@ -239,6 +253,7 @@ begin FMinHeight := 32; FModalResult := 0; FFullScreen := False; + FIsContainer := True; end; procedure TfpgBaseForm.AfterCreate; diff --git a/src/gui/gui_memo.pas b/src/gui/gui_memo.pas index fc4a0f86..34e4cef9 100644 --- a/src/gui/gui_memo.pas +++ b/src/gui/gui_memo.pas @@ -126,16 +126,27 @@ type TfpgMemoStrings = class(TStringList) protected Memo: TfpgMemo; + procedure RefreshMemo; public constructor Create(AMemo: TfpgMemo); reintroduce; destructor Destroy; override; function Add(const s: String): Integer; override; - procedure Delete(Index: Integer); override; procedure Clear; override; + procedure Delete(Index: Integer); override; + procedure Insert(Index: Integer; const S: string); override; end; { TfpgMemoStrings } +procedure TfpgMemoStrings.RefreshMemo; +begin + if Assigned(Memo) and (Memo.HasHandle) then + begin + Memo.Invalidate; + Memo.UpdateScrollBars; + end; +end; + constructor TfpgMemoStrings.Create(AMemo: TfpgMemo); begin inherited Create; @@ -151,22 +162,27 @@ end; function TfpgMemoStrings.Add(const s: String): Integer; begin Result := inherited Add(s); - if Assigned(Memo) and (Memo.HasHandle) then - Memo.Invalidate; + RefreshMemo; end; procedure TfpgMemoStrings.Delete(Index: Integer); begin +// writeln('Delete''s Index = ', Index); inherited Delete(Index); - if Assigned(Memo) and (Memo.HasHandle) then - Memo.Invalidate; + RefreshMemo; +end; + +procedure TfpgMemoStrings.Insert(Index: Integer; const S: string); +begin +// writeln('Insert''s Index = ', Index); + inherited Insert(Index, S); + RefreshMemo; end; procedure TfpgMemoStrings.Clear; begin inherited Clear; - if Assigned(Memo) and (Memo.HasHandle) then - Memo.Invalidate; + RefreshMemo; end; @@ -349,7 +365,6 @@ begin selep := FSelStartPos; selsl := FSelEndLine; selsp := FSelEndPos; - end; for n := selsl to selel do @@ -376,7 +391,7 @@ begin SetLineText(selsl, ls); end; - for n := selsl + 1 to selel do + for n := selsl to selel do FLines.Delete(n); FCursorPos := selsp; diff --git a/src/gui/gui_mru.pas b/src/gui/gui_mru.pas index 1c97dc58..4e4d9e9e 100644 --- a/src/gui/gui_mru.pas +++ b/src/gui/gui_mru.pas @@ -32,12 +32,12 @@ type TfpgMRU = class(TComponent) private FItems: TStringList; - FMaxItems: Word; + FMaxItems: Integer; FShowFullPath: boolean; FParentMenuItem: TfpgPopupMenu; // FIniFilePath: string; FOnClick: TMRUClickEvent; - procedure SetMaxItems(const AValue: Word); + procedure SetMaxItems(const AValue: Integer); // procedure SetIniFilePath(const AValue: string); procedure SetParentMenuItem(const AValue: TfpgPopupMenu); procedure SetShowFullPath(const AValue: boolean); @@ -56,7 +56,7 @@ type function RemoveItem(const FileName : string) : boolean; procedure LoadMRU; published - property MaxItems: Word read FMaxItems write SetMaxItems default 4; + property MaxItems: Integer read FMaxItems write SetMaxItems default 4; // property IniFilePath: string read FIniFilePath write SetIniFilePath; property ShowFullPath: boolean read FShowFullPath write SetShowFullPath default True; property ParentMenuItem: TfpgPopupMenu read FParentMenuItem write SetParentMenuItem; @@ -76,7 +76,7 @@ type { TfpgMRU } -procedure TfpgMRU.SetMaxItems(const AValue: Word); +procedure TfpgMRU.SetMaxItems(const AValue: Integer); begin if AValue <> FMaxItems then begin @@ -84,8 +84,8 @@ begin FMaxItems := 1 else begin - if AValue > MaxInt then - FMaxItems := High(Word) - 1 + if AValue > High(Word) then // 65535 should be enough + FMaxItems := High(Word) else begin FMaxItems := AValue; diff --git a/src/gui/gui_panel.pas b/src/gui/gui_panel.pas index 2e4280c5..fc9df44d 100644 --- a/src/gui/gui_panel.pas +++ b/src/gui/gui_panel.pas @@ -241,6 +241,7 @@ begin FHeight := 80; FFocusable := True; // otherwise children can't get focus FBackgroundColor := Parent.BackgroundColor; + FIsContainer := True; end; {TfpgBevel} diff --git a/src/gui/gui_tab.pas b/src/gui/gui_tab.pas index adda9f58..29d3c5dc 100644 --- a/src/gui/gui_tab.pas +++ b/src/gui/gui_tab.pas @@ -200,6 +200,7 @@ begin FFocusable := True; FBackgroundColor := Parent.BackgroundColor; FTextColor := Parent.TextColor; + FIsContainer := True; end; destructor TfpgTabSheet.Destroy; @@ -784,6 +785,7 @@ begin FPages := TList.Create; FWidth := 150; FHeight := 100; + FIsContainer := True; FTextColor := Parent.TextColor; FBackgroundColor := Parent.BackgroundColor; |