summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2007-09-19 14:02:24 +0000
committergraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2007-09-19 14:02:24 +0000
commitc4c280141a787c832c5c9ad3a0f5e0efeb57e5a4 (patch)
tree5b6321ce2c70ba55a9dc8c258427f528672a4561
parente879ec3c3c1e91e6d99582cf26a7f2f0ebe45bfd (diff)
downloadfpGUI-c4c280141a787c832c5c9ad3a0f5e0efeb57e5a4.tar.xz
* GUI: All CustomGrid and StringGrid properties using a Column Index is now
1-based. So to access the first column the Index will be 1. * GUI Designer: Added a StringGrid Columns property editor. * GUI Designer: When saving files that are now also added to the MRU menu.
-rw-r--r--examples/apps/uidesigner/uidesigner.lpi7
-rw-r--r--examples/apps/uidesigner/uidesigner.lpr2
-rw-r--r--examples/apps/uidesigner/vfdmain.pas2
-rw-r--r--examples/apps/uidesigner/vfdpropeditgrid.pas521
-rw-r--r--examples/apps/uidesigner/vfdresizer.pas1
-rw-r--r--examples/apps/uidesigner/vfdwidgets.pas10
-rw-r--r--examples/gui/gridtest/gridtest.lpr4
-rw-r--r--src/gui/gui_customgrid.pas38
-rw-r--r--src/gui/gui_grid.pas20
9 files changed, 586 insertions, 19 deletions
diff --git a/examples/apps/uidesigner/uidesigner.lpi b/examples/apps/uidesigner/uidesigner.lpi
index 0e92e472..77fefe30 100644
--- a/examples/apps/uidesigner/uidesigner.lpi
+++ b/examples/apps/uidesigner/uidesigner.lpi
@@ -33,7 +33,7 @@
<MinVersion Minor="5" Valid="True"/>
</Item1>
</RequiredPackages>
- <Units Count="13">
+ <Units Count="14">
<Unit0>
<Filename Value="uidesigner.lpr"/>
<IsPartOfProject Value="True"/>
@@ -99,6 +99,11 @@
<IsPartOfProject Value="True"/>
<UnitName Value="vfdutils"/>
</Unit12>
+ <Unit13>
+ <Filename Value="vfdpropeditgrid.pas"/>
+ <IsPartOfProject Value="True"/>
+ <UnitName Value="vfdpropeditgrid"/>
+ </Unit13>
</Units>
</ProjectOptions>
<CompilerOptions>
diff --git a/examples/apps/uidesigner/uidesigner.lpr b/examples/apps/uidesigner/uidesigner.lpr
index fe3c980d..d39cac22 100644
--- a/examples/apps/uidesigner/uidesigner.lpr
+++ b/examples/apps/uidesigner/uidesigner.lpr
@@ -25,7 +25,7 @@ uses
{$ENDIF}{$ENDIF}
Classes, SysUtils, fpgfx, vfdmain, vfdresizer, vfdforms,
vfdfile, newformdesigner, vfdwidgets, vfdformparser, vfdeditors,
- vfdwidgetclass, vfdutils, vfdprops, vfddesigner;
+ vfdwidgetclass, vfdutils, vfdprops, vfddesigner, vfdpropeditgrid;
procedure MainProc;
diff --git a/examples/apps/uidesigner/vfdmain.pas b/examples/apps/uidesigner/vfdmain.pas
index 28c598d3..c26305cb 100644
--- a/examples/apps/uidesigner/vfdmain.pas
+++ b/examples/apps/uidesigner/vfdmain.pas
@@ -221,8 +221,8 @@ begin
finally
CloseFile(ff);
end;
-// frmMain.AddRecentFile(fname);
frmMain.WindowTitle := 'fpGUI Designer v' + program_version + ' - ' + fname;
+ frmMain.mru.AddItem(fname);
except
Writeln('Form save I/O failure.');
end;
diff --git a/examples/apps/uidesigner/vfdpropeditgrid.pas b/examples/apps/uidesigner/vfdpropeditgrid.pas
new file mode 100644
index 00000000..f123eba4
--- /dev/null
+++ b/examples/apps/uidesigner/vfdpropeditgrid.pas
@@ -0,0 +1,521 @@
+{
+ fpGUI - Free Pascal GUI Library
+
+ Copyright (C) 2006 - 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.
+
+ Description:
+ Property editor for grid columns.
+}
+
+unit vfdpropeditgrid;
+
+{$mode objfpc}{$H+}
+
+interface
+
+uses
+ Classes,
+ SysUtils,
+ gfxbase,
+ gfx_widget,
+ gui_form,
+ gui_label,
+ gui_edit,
+ gui_button,
+ gui_listbox,
+ gui_memo,
+ gui_combobox,
+ gui_customgrid,
+ gui_grid,
+ gui_checkbox,
+ vfdforms,
+ vfdwidgetclass,
+ vfdprops,
+ vfdformparser;
+
+type
+
+ TPropertyDBColumns = class(TVFDWidgetProperty)
+ public
+ function ParseSourceLine(wg: TfpgWidget; const line: string): boolean; override;
+ function GetPropertySource(wg: TfpgWidget; const ident: string): string; override;
+ function GetValueText(wg: TfpgWidget): string; override;
+ function CreateEditor(AOwner: TComponent): TVFDPropertyEditor; override;
+ procedure OnExternalEdit(wg: TfpgWidget); override;
+ end;
+
+
+ TColumnsGrid = class(TfpgCustomGrid)
+ protected
+ function GetRowCount: integer; override;
+ procedure DrawCell(ARow, ACol: integer; ARect: TfpgRect; AFlags: integer); override;
+ public
+ dbgrid: TfpgStringGrid;
+ constructor Create(AOwner: TComponent); override;
+ end;
+
+
+ TColumnEditForm = class(TfpgForm)
+ private
+ procedure GridRowChange(Sender: TObject; row: integer);
+ procedure EditChange(Sender: TObject);
+ procedure NewButtonClick(Sender: TObject);
+ procedure DeleteButtonClick(Sender: TObject);
+ procedure CloseButtonClick(Sender: TObject);
+ procedure UpDownButtonClick(Sender: TObject);
+ procedure SaveColumn(row: integer);
+ public
+ {@VFD_HEAD_BEGIN: ColumnEditForm}
+ lbLabel1: TfpgLabel;
+ grid: TColumnsGrid;
+ lbLabel2: TfpgLabel;
+ lbLabel3: TfpgLabel;
+ lbLabel6: TfpgLabel;
+ lbLabel5: TfpgLabel;
+ lbCOLNO: TfpgLabel;
+ edTITLE: TfpgEdit;
+ edCOLWIDTH: TfpgEdit;
+ chlALIGN: TfpgComboBox;
+ btnNew: TfpgButton;
+ btnDelete: TfpgButton;
+ btnUP: TfpgButton;
+ btnDOWN: TfpgButton;
+ btnClose: TfpgButton;
+ {@VFD_HEAD_END: ColumnEditForm}
+
+ dbgrid: TfpgStringGrid;
+ procedure AfterCreate; override;
+ end;
+
+
+implementation
+
+
+procedure EditStringGridColumns(agrid: TfpgStringGrid);
+var
+ frm: TColumnEditForm;
+begin
+ frm := TColumnEditForm.Create(nil);
+ frm.dbgrid := agrid;
+ frm.grid.dbgrid := agrid;
+ frm.ShowModal;
+ frm.Free;
+end;
+
+{ TColumnEditForm }
+
+procedure TColumnEditForm.AfterCreate;
+begin
+ {@VFD_BODY_BEGIN: ColumnEditForm}
+ Name := 'ColumnEditForm';
+ SetPosition(270, 267, 511, 269);
+ WindowTitle := 'Column editor';
+ Sizeable := False;
+
+ lbLabel1 := TfpgLabel.Create(self);
+ with lbLabel1 do
+ begin
+ Name := 'lbLabel1';
+ SetPosition(8, 4, 110, 16);
+ Text := 'String Grid columns:';
+ FontDesc := '#Label1';
+ end;
+
+ grid := TColumnsGrid.Create(self);
+ with grid do
+ begin
+ Name := 'grid';
+ SetPosition(8, 24, 328, 204);
+ OnRowChange := @GridRowChange;
+ end;
+
+ lbLabel2 := TfpgLabel.Create(self);
+ with lbLabel2 do
+ begin
+ Name := 'lbLabel2';
+ SetPosition(344, 24, 56, 16);
+ Text := 'Column:';
+ FontDesc := '#Label1';
+ end;
+
+ lbLabel3 := TfpgLabel.Create(self);
+ with lbLabel3 do
+ begin
+ Name := 'lbLabel3';
+ SetPosition(344, 56, 34, 16);
+ Text := 'Title:';
+ FontDesc := '#Label1';
+ end;
+
+ lbLabel6 := TfpgLabel.Create(self);
+ with lbLabel6 do
+ begin
+ Name := 'lbLabel6';
+ SetPosition(344, 100, 88, 16);
+ Text := 'Column width:';
+ FontDesc := '#Label1';
+ end;
+
+ lbLabel5 := TfpgLabel.Create(self);
+ with lbLabel5 do
+ begin
+ Name := 'lbLabel5';
+ SetPosition(344, 144, 83, 16);
+ Text := 'Alignment:';
+ FontDesc := '#Label1';
+ end;
+
+ lbCOLNO := TfpgLabel.Create(self);
+ with lbCOLNO do
+ begin
+ Name := 'lbCOLNO';
+ SetPosition(404, 24, 54, 16);
+ Text := '--';
+ FontDesc := '#Label1';
+ end;
+
+ edTITLE := TfpgEdit.Create(self);
+ with edTITLE do
+ begin
+ Name := 'edTITLE';
+ SetPosition(344, 72, 160, 22);
+ Text := '';
+ FontDesc := '#Edit1';
+ OnChange := @EditChange;
+ end;
+
+ edCOLWIDTH := TfpgEdit.Create(self);
+ with edCOLWIDTH do
+ begin
+ Name := 'edCOLWIDTH';
+ SetPosition(344, 116, 160, 22);
+ Text := '';
+ FontDesc := '#Edit1';
+ OnChange := @EditChange;
+ end;
+
+ chlALIGN := TfpgComboBox.Create(self);
+ with chlALIGN do
+ begin
+ Name := 'chlALIGN';
+ SetPosition(344, 162, 160, 22);
+ Items.Add('Left');
+ Items.Add('Right');
+ Items.Add('Center');
+ FontDesc := '#List';
+ OnChange := @EditChange;
+ end;
+
+ btnNew := TfpgButton.Create(self);
+ with btnNew do
+ begin
+ Name := 'btnNew';
+ SetPosition(8, 236, 75, 24);
+ Text := 'New';
+ FontDesc := '#Label1';
+ ImageName := '';
+ ModalResult := 0;
+ OnClick := @NewButtonClick;
+ end;
+
+ btnDelete := TfpgButton.Create(self);
+ with btnDelete do
+ begin
+ Name := 'btnDelete';
+ SetPosition(86, 236, 75, 24);
+ Text := 'Delete';
+ FontDesc := '#Label1';
+ ImageName := '';
+ ModalResult := 0;
+ OnClick := @DeleteButtonClick;
+ end;
+
+ btnUP := TfpgButton.Create(self);
+ with btnUP do
+ begin
+ Name := 'btnUP';
+ SetPosition(182, 236, 75, 24);
+ Text := 'UP';
+ FontDesc := '#Label1';
+ ImageName := '';
+ ModalResult := 0;
+ OnClick := @UpDownButtonClick;
+ end;
+
+ btnDOWN := TfpgButton.Create(self);
+ with btnDOWN do
+ begin
+ Name := 'btnDOWN';
+ SetPosition(260, 236, 75, 24);
+ Text := 'DOWN';
+ FontDesc := '#Label1';
+ ImageName := '';
+ ModalResult := 0;
+ OnClick := @UpDownButtonClick;
+ end;
+
+ btnClose := TfpgButton.Create(self);
+ with btnClose do
+ begin
+ Name := 'btnClose';
+ SetPosition(428, 236, 75, 24);
+ Text := 'Close';
+ FontDesc := '#Label1';
+ ImageName := 'stdimg.close';
+ ModalResult := 0;
+ OnClick := @CloseButtonClick;
+ end;
+
+ {@VFD_BODY_END: ColumnEditForm}
+end;
+
+procedure TColumnEditForm.GridRowChange(Sender: TObject; row: integer);
+var
+ i: integer;
+ c: TfpgStringColumn;
+begin
+ c := dbgrid.Columns[row{ - 1}];
+ if c = nil then
+ Exit;
+
+ lbCOLNO.Text := IntToStr(row);
+ edTITLE.Text := c.Title;
+ edCOLWIDTH.Text := IntToStr(c.Width);
+ case c.Alignment of
+ taRightJustify:
+ i := 2;
+ taCenter:
+ i := 3
+ else
+ i := 1;
+ end;
+ chlALIGN.FocusItem := i;
+end;
+
+procedure TColumnEditForm.SaveColumn(row: integer);
+var
+ c: TfpgStringColumn;
+begin
+ c := dbgrid.Columns[row{ - 1}];
+ if c = nil then
+ Exit;
+
+ c.Title := edTITLE.Text;
+ c.Width := StrToIntDef(edCOLWIDTH.Text, 30);
+ case chlALIGN.FocusItem of
+ 2: c.Alignment := taRightJustify;
+ 3: c.Alignment := taCenter;
+ else
+ c.Alignment := taLeftJustify;
+ end;
+
+ grid.RePaint;
+ dbgrid.Update;
+end;
+
+procedure TColumnEditForm.EditChange(Sender: TObject);
+begin
+ if grid.FocusRow < 1 then
+ Exit;
+
+ SaveColumn(grid.FocusRow);
+end;
+
+procedure TColumnEditForm.NewButtonClick(Sender: TObject);
+begin
+ dbgrid.AddColumn('New', 50, taLeftJustify);
+ grid.FocusRow := grid.RowCount;
+ grid.Update;
+ GridRowChange(Sender, grid.FocusRow);
+end;
+
+procedure TColumnEditForm.DeleteButtonClick(Sender: TObject);
+begin
+ dbgrid.DeleteColumn(grid.FocusRow);
+ grid.Update;
+end;
+
+procedure TColumnEditForm.CloseButtonClick(Sender: TObject);
+begin
+ Close;
+end;
+
+procedure TColumnEditForm.UpDownButtonClick(Sender: TObject);
+begin
+ if Sender = btnUP then
+ begin
+ if grid.FocusRow > 1 then
+ begin
+ dbgrid.MoveColumn(grid.FocusRow - 1, grid.FocusRow - 2);
+ grid.FocusRow := grid.FocusRow - 1;
+ grid.Update;
+ end;
+ end
+ else if grid.FocusRow < grid.RowCount then
+ begin
+ dbgrid.MoveColumn(grid.FocusRow - 1, grid.FocusRow);
+ grid.FocusRow := grid.FocusRow + 1;
+ grid.Update;
+ end;
+end;
+
+
+{ TColumnsGrid }
+
+function TColumnsGrid.GetRowCount: integer;
+begin
+ try
+ Result := dbgrid.ColumnCount;
+ except
+ Result := inherited GetRowCount;
+ end;
+end;
+
+procedure TColumnsGrid.DrawCell(ARow, ACol: integer; ARect: TfpgRect; AFlags: integer);
+var
+ s: string;
+ x: integer;
+ c: TfpgStringColumn;
+begin
+// writeln('ARow=', ARow, ' ACol=', ACol);
+ c := dbgrid.Columns[ARow{ - 1}];
+ if c = nil then
+ begin
+// writeln(' TColumnsGrid.DrawCell -> exit early because c = nil');
+ Exit;
+ end;
+// writeln(' ... we passed the nil test');
+ x := ARect.Left + 1;
+
+ case ACol of
+ 1: s := IntToStr(ARow);
+ 2: s := c.Title;
+ 3: s := IntToStr(c.Width);
+ 4: case c.Alignment of
+ taRightJustify:
+ s := 'Right';
+ taCenter:
+ s := 'Center';
+ else
+ s := 'Left';
+ end;
+ else
+ s := '?';
+ end;
+
+ Canvas.DrawString(x, ARect.Top + 1, s);
+end;
+
+constructor TColumnsGrid.Create(AOwner: TComponent);
+begin
+ inherited Create(AOwner);
+ RowSelect := True;
+ ColumnCount := 0;
+ RowCount := 0;
+ AddColumn('Col.', 30);
+ AddColumn('Title', 80);
+ AddColumn('Width', 40);
+ AddColumn('Align', 50);
+end;
+
+{ TPropertyDBColumns }
+
+function TPropertyDBColumns.CreateEditor(AOwner: TComponent): TVFDPropertyEditor;
+begin
+ Result := TExternalPropertyEditor.Create(AOwner, self);
+end;
+
+function TPropertyDBColumns.GetValueText(wg: TfpgWidget): string;
+begin
+ with TfpgStringGrid(wg) do
+ Result := '[' + IntToStr(ColumnCount) + ' columns]';
+end;
+
+procedure TPropertyDBColumns.OnExternalEdit(wg: TfpgWidget);
+begin
+ if not Assigned(wg) then
+ raise Exception.Create('TPropertyDBColumns.OnExternalEdit(wg) - wg widget may not be nil.');
+ if not (wg is TfpgStringGrid) then
+ raise Exception.Create('TPropertyDBColumns.OnExternalEdit(wg) - wg widget is not a TfpgStringGrid.');
+ EditStringGridColumns(TfpgStringGrid(wg));
+end;
+
+function TPropertyDBColumns.ParseSourceLine(wg: TfpgWidget; const line: string): boolean;
+var
+ c: TfpgStringColumn;
+ s: string;
+ sval: string;
+begin
+ s := line;
+ Result := False;
+ if UpperCase(GetIdentifier(s)) <> UpperCase('ADDCOLUMN') then
+ Exit;
+
+ c := TfpgStringColumn.Create;
+
+ Result := CheckSymbol(s, '(');
+
+ if Result then
+ c.Title := GetStringValue(s);
+ Result := Result and CheckSymbol(s, ',');
+ if Result then
+ c.Width := GetIntValue(s);
+ Result := Result and CheckSymbol(s, ',');
+ if Result then
+ begin
+ sval := UpperCase(GetIdentifier(s));
+ if sval = 'TARIGHTJUSTIFY' then
+ c.Alignment := taRightJustify
+ else if sval = 'TACENTER' then
+ c.Alignment := taCenter
+ else
+ c.Alignment := taLeftJustify;
+ end;
+
+ Result := Result and CheckSymbol(s, ')');
+ Result := Result and CheckSymbol(s, ';');
+
+ if Result then
+ TfpgStringGrid(wg).AddColumn(c.Title, c.Width, c.Alignment);
+
+ c.Free;
+end;
+
+function TPropertyDBColumns.GetPropertySource(wg: TfpgWidget; const ident: string): string;
+var
+ f: integer;
+ c: TfpgStringColumn;
+ alstr: string;
+begin
+ Result := '';
+ with TfpgStringGrid(wg) do
+ begin
+ for f := 1 to ColumnCount do
+ begin
+ c := Columns[f];
+ case c.Alignment of
+ taRightJustify:
+ alstr := 'taRightJustify';
+ taCenter:
+ alstr := 'taCenter';
+ else
+ alstr := 'taLeftJustify';
+ end;
+ Result := Result + ident
+ + 'AddColumn(' + QuotedStr(c.Title) + ', '
+ + IntToStr(c.Width) + ', '
+ + alstr + ');' + LineEnding;
+ end; { for }
+ end; { with }
+end;
+
+end.
+
diff --git a/examples/apps/uidesigner/vfdresizer.pas b/examples/apps/uidesigner/vfdresizer.pas
index 2faccfe8..a599b89f 100644
--- a/examples/apps/uidesigner/vfdresizer.pas
+++ b/examples/apps/uidesigner/vfdresizer.pas
@@ -49,7 +49,6 @@ implementation
uses
vfddesigner,
- vfdforms,
vfdmain;
{ TwgResizer }
diff --git a/examples/apps/uidesigner/vfdwidgets.pas b/examples/apps/uidesigner/vfdwidgets.pas
index 75d44741..7a2af304 100644
--- a/examples/apps/uidesigner/vfdwidgets.pas
+++ b/examples/apps/uidesigner/vfdwidgets.pas
@@ -58,7 +58,8 @@ uses
gui_trackbar,
gui_menu,
gui_progressbar,
- gui_tab;
+ gui_tab,
+ vfdpropeditgrid;
var
FVFDFormWidget: TVFDWidgetClass;
@@ -289,9 +290,10 @@ begin
// StringGrid
wc := TVFDWidgetClass.Create(TfpgStringGrid);
wc.NameBase := 'grdName';
-// wc.AddProperty('Columns',TPropertyDBColumns,'');
- wc.AddProperty('FontDesc',TPropertyString,'');
- wc.AddProperty('HeaderFontDesc',TPropertyString,'');
+ wc.AddProperty('Columns', TPropertyDBColumns, '');
+ wc.AddProperty('FontDesc', TPropertyString, '');
+ wc.AddProperty('HeaderFontDesc', TPropertyString, '');
+ wc.AddProperty('RowCount', TPropertyInteger, '');
wc.WidgetIconName := 'vfd.stringgrid';
RegisterVFDWidget(wc);
diff --git a/examples/gui/gridtest/gridtest.lpr b/examples/gui/gridtest/gridtest.lpr
index 88bc77f1..d85bad61 100644
--- a/examples/gui/gridtest/gridtest.lpr
+++ b/examples/gui/gridtest/gridtest.lpr
@@ -107,11 +107,11 @@ begin
tsTab2 := pagecontrol.AppendTabSheet('String Grid');
stringgrid := TfpgStringGrid.Create(tsTab2);
stringgrid.SetPosition(10, 10, Width-50, 250);
- // change row and column count to something different that the default
+ // change row and column count to something different than the default
stringgrid.ColumnCount := 2;
stringgrid.RowCount := 3;
// add and change a column
- stringgrid.AddColumn('Extra', 100);
+ stringgrid.AddColumn('Extra (col3)', 100);
stringgrid.ColumnWidth[3] := 150;
// changes header text in different ways
stringgrid.ColumnTitle[1] := 'Column 1';
diff --git a/src/gui/gui_customgrid.pas b/src/gui/gui_customgrid.pas
index 47cd2e9f..be589e7c 100644
--- a/src/gui/gui_customgrid.pas
+++ b/src/gui/gui_customgrid.pas
@@ -15,7 +15,6 @@ interface
uses
Classes,
SysUtils,
- gfxbase,
fpgfx,
gui_basegrid;
@@ -52,12 +51,16 @@ type
function GetHeaderText(ACol: integer): string; override;
property RowCount: integer read GetRowCount write SetRowCount;
property ColumnCount: integer read GetColumnCount write SetColumnCount;
+ { Columns AIndex is 1-based. }
property Columns[AIndex: integer]: TfpgGridColumn read GetColumns;
// property AlternateColor: TColor read FAlternateColor write SetAlternateColor stored IsAltColorStored;
public
constructor Create(AOwner: TComponent); override;
destructor Destroy; override;
function AddColumn(ATitle: string; AWidth: integer): TfpgGridColumn; virtual;
+ { AIndex is 1-based. }
+ procedure DeleteColumn(AIndex: integer); virtual;
+ procedure MoveColumn(oldindex, newindex: integer); virtual;
end;
@@ -67,9 +70,9 @@ implementation
constructor TfpgGridColumn.Create;
begin
- Width := 64;
+ Width := 65;
Title := '';
- Alignment := taCenter;
+ Alignment := taLeftJustify;
end;
{ TfpgCustomGrid }
@@ -81,10 +84,10 @@ end;
function TfpgCustomGrid.GetColumns(AIndex: integer): TfpgGridColumn;
begin
- if (AIndex < 0) or (AIndex > FColumns.Count-1) then
+ if (AIndex < 1) or (AIndex > FColumns.Count) then
Result := nil
else
- Result := TfpgGridColumn(FColumns[AIndex]);
+ Result := TfpgGridColumn(FColumns[AIndex-1]);
end;
procedure TfpgCustomGrid.DoDeleteColumn(ACol: integer);
@@ -182,8 +185,8 @@ end;
constructor TfpgCustomGrid.Create(AOwner: TComponent);
begin
- inherited Create(AOwner);
FColumns := TList.Create;
+ inherited Create(AOwner);
ColumnCount := 5;
RowCount := 5;
end;
@@ -207,9 +210,32 @@ begin
Result.Width := AWidth;
FColumns.Add(Result);
+ if csUpdating in ComponentState then
+ Exit; //==>
+
UpdateScrollBars;
RePaint;
end;
+procedure TfpgCustomGrid.DeleteColumn(AIndex: integer);
+var
+ c: TfpgGridColumn;
+begin
+ c := Columns[AIndex];
+ if c <> nil then
+ begin
+ DoDeleteColumn(AIndex);
+ if HasHandle then
+ Update;
+ end;
+end;
+
+procedure TfpgCustomGrid.MoveColumn(oldindex, newindex: integer);
+begin
+ FColumns.Move(oldindex, newindex);
+ if HasHandle then
+ Update;
+end;
+
end.
diff --git a/src/gui/gui_grid.pas b/src/gui/gui_grid.pas
index c57b3c38..be619194 100644
--- a/src/gui/gui_grid.pas
+++ b/src/gui/gui_grid.pas
@@ -151,9 +151,12 @@ type
procedure DoSetRowCount(AValue: integer); override;
function DoCreateColumnClass: TfpgStringColumn; reintroduce; override;
procedure DrawCell(ARow, ACol: integer; ARect: TfpgRect; AFlags: integer); override;
+ { AIndex is 1-based. }
property Columns[AIndex: integer]: TfpgStringColumn read GetColumns;
public
- function AddColumn(ATitle: string; AWidth: integer): TfpgStringColumn; reintroduce; override;
+ constructor Create(AOwner: TComponent); override;
+ function AddColumn(ATitle: string; AWidth: integer; AAlignment: TAlignment = taLeftJustify): TfpgStringColumn; overload;
+ { ACol and ARow is 1-based. }
property Cells[ACol, ARow: LongWord]: string read GetCell write SetCell;
// property Objects[ACol, ARow: Integer]: TObject read GetObjects write SetObjects;
property ColumnTitle[ACol: integer]: string read GetColumnTitle write SetColumnTitle;
@@ -592,7 +595,7 @@ begin
RowCount := 0;
FFixedFont := fpgGetFont('Courier New-9');
- {$Note Abstract this! No IFDEF's allowed!!! }
+ {$Note No IFDEF's allowed!!! But how the hell to we get around this? }
{$ifdef MSWINDOWS}
AddColumn('Name', 320);
{$else}
@@ -745,13 +748,24 @@ begin
end;
end;
-function TfpgCustomStringGrid.AddColumn(ATitle: string; AWidth: integer): TfpgStringColumn;
+constructor TfpgCustomStringGrid.Create(AOwner: TComponent);
+begin
+ inherited Create(AOwner);
+ ColumnCount := 0;
+ RowCount := 0;
+end;
+
+function TfpgCustomStringGrid.AddColumn(ATitle: string; AWidth: integer;
+ AAlignment: TAlignment): TfpgStringColumn;
var
r: integer;
begin
+ Include(ComponentState, csUpdating);
Result := TfpgStringColumn(inherited AddColumn(ATitle, AWidth));
+ Result.Alignment := AAlignment;
for r := 1 to RowCount do
Result.Cells.Append('');
+ Exclude(ComponentState, csUpdating);
end;
end.