diff options
author | graemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf> | 2007-09-19 14:02:24 +0000 |
---|---|---|
committer | graemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf> | 2007-09-19 14:02:24 +0000 |
commit | c4c280141a787c832c5c9ad3a0f5e0efeb57e5a4 (patch) | |
tree | 5b6321ce2c70ba55a9dc8c258427f528672a4561 | |
parent | e879ec3c3c1e91e6d99582cf26a7f2f0ebe45bfd (diff) | |
download | fpGUI-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.lpi | 7 | ||||
-rw-r--r-- | examples/apps/uidesigner/uidesigner.lpr | 2 | ||||
-rw-r--r-- | examples/apps/uidesigner/vfdmain.pas | 2 | ||||
-rw-r--r-- | examples/apps/uidesigner/vfdpropeditgrid.pas | 521 | ||||
-rw-r--r-- | examples/apps/uidesigner/vfdresizer.pas | 1 | ||||
-rw-r--r-- | examples/apps/uidesigner/vfdwidgets.pas | 10 | ||||
-rw-r--r-- | examples/gui/gridtest/gridtest.lpr | 4 | ||||
-rw-r--r-- | src/gui/gui_customgrid.pas | 38 | ||||
-rw-r--r-- | src/gui/gui_grid.pas | 20 |
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. |