summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGraeme Geldenhuys <graeme@mastermaths.co.za>2010-10-15 11:10:27 +0200
committerGraeme Geldenhuys <graeme@mastermaths.co.za>2010-10-15 11:10:27 +0200
commit59f9a7513fe58a046b789caf881e432b6f3abdea (patch)
treebb73191ab1b1ed44e9916644e3fc1a2e9ad09e0b /src
parentecc152d7debac7cd78e3239c148fc873910d21f1 (diff)
downloadfpGUI-59f9a7513fe58a046b789caf881e432b6f3abdea.tar.xz
TfpgMemo now has BeginUpdate and EndUpdate methods
This allows you to add/delete many lines and the memo only repaints once.
Diffstat (limited to 'src')
-rw-r--r--src/corelib/fpg_widget.pas2
-rw-r--r--src/gui/fpg_memo.pas50
2 files changed, 35 insertions, 17 deletions
diff --git a/src/corelib/fpg_widget.pas b/src/corelib/fpg_widget.pas
index f2d220db..f0c7f514 100644
--- a/src/corelib/fpg_widget.pas
+++ b/src/corelib/fpg_widget.pas
@@ -137,7 +137,7 @@ type
procedure InternalHandleShow; virtual;
procedure HandleHide; virtual;
procedure MoveAndResize(ALeft, ATop, AWidth, AHeight: TfpgCoord);
- procedure RePaint;
+ procedure RePaint; virtual;
{ property events }
property OnClick: TNotifyEvent read FOnClick write FOnClick;
property OnDoubleClick: TMouseButtonEvent read FOnDoubleClick write FOnDoubleClick;
diff --git a/src/gui/fpg_memo.pas b/src/gui/fpg_memo.pas
index dccc5f55..308a37a5 100644
--- a/src/gui/fpg_memo.pas
+++ b/src/gui/fpg_memo.pas
@@ -62,6 +62,7 @@ type
FPopupMenu: TfpgPopupMenu;
FDefaultPopupMenu: TfpgPopupMenu;
FReadOnly: Boolean;
+ FUpdateCount: integer;
function GetFontDesc: string;
procedure SetFontDesc(const AValue: string);
procedure RecalcLongestLine;
@@ -106,6 +107,7 @@ type
procedure HandleMouseEnter; override;
procedure HandleMouseExit; override;
procedure HandleHide; override;
+ procedure RePaint; override;
public
constructor Create(AOwner: TComponent); override;
destructor Destroy; override;
@@ -115,6 +117,8 @@ type
procedure CutToClipboard;
procedure PasteFromClipboard;
procedure Clear;
+ procedure BeginUpdate;
+ procedure EndUpdate;
property CursorLine: integer read FCursorLine write SetCursorLine;
property Font: TfpgFont read FFont;
property LineHeight: integer read FLineHeight;
@@ -168,7 +172,6 @@ type
TfpgMemoStrings = class(TStringList)
protected
Memo: TfpgMemo;
- procedure RefreshMemo;
public
constructor Create(AMemo: TfpgMemo); reintroduce;
destructor Destroy; override;
@@ -180,15 +183,6 @@ type
{ 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;
@@ -203,28 +197,30 @@ end;
function TfpgMemoStrings.Add(const s: String): Integer;
begin
+ Memo.BeginUpdate;
Result := inherited Add(s);
- RefreshMemo;
+ Memo.EndUpdate;
end;
procedure TfpgMemoStrings.Delete(Index: Integer);
begin
-// writeln('Delete''s Index = ', Index);
+ Memo.BeginUpdate;
inherited Delete(Index);
- RefreshMemo;
+ Memo.EndUpdate;
end;
procedure TfpgMemoStrings.Insert(Index: Integer; const S: string);
begin
-// writeln('Insert''s Index = ', Index);
+ Memo.BeginUpdate;
inherited Insert(Index, S);
- RefreshMemo;
+ Memo.EndUpdate;
end;
procedure TfpgMemoStrings.Clear;
begin
+ Memo.BeginUpdate;
inherited Clear;
- RefreshMemo;
+ Memo.EndUpdate;
end;
@@ -447,6 +443,7 @@ begin
FPopupMenu := nil;
FDefaultPopupMenu := nil;
FReadOnly := False;
+ FUpdateCount := 0;
FLines := TfpgMemoStrings.Create(self);
FFirstLine := 0;
@@ -854,6 +851,12 @@ begin
inherited;
end;
+procedure TfpgMemo.RePaint;
+begin
+ if FUpdateCount <= 0 then
+ inherited RePaint;
+end;
+
procedure TfpgMemo.VScrollBarMove(Sender: TObject; position: integer);
begin
if FFirstLine <> position then
@@ -1602,6 +1605,21 @@ begin
Repaint;
end;
+procedure TfpgMemo.BeginUpdate;
+begin
+ Inc(FUpdateCount);
+end;
+
+procedure TfpgMemo.EndUpdate;
+begin
+ Dec(FUpdateCount);
+ if FUpdateCount <= 0 then
+ begin
+ Invalidate;
+ UpdateScrollBars;
+ end;
+end;
+
function TfpgMemo.GetText: TfpgString;
var
n: integer;