summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
authorgraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2008-03-16 21:23:16 +0000
committergraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2008-03-16 21:23:16 +0000
commit9ff34b128f410e0c25e780f822e3e6983e743b3d (patch)
tree806581f6724bb6700d9598bf8a2794f0f181499a /src/gui
parent9eb1979d6c4f9cfc0b07223bbd02c1558c2742c3 (diff)
downloadfpGUI-9ff34b128f410e0c25e780f822e3e6983e743b3d.tar.xz
* I implement an improved positioning of dropdown window of Combobox and EditCombo when it runs out of screen space. It also handles resizing if the dropdown is bigger that the screen is high.
* Started refactoring the ComboBox and EditComboBox. There was just to much code duplication. I am still busy with it, but please test and let me know if I broke something.
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/gui_combobox.pas262
-rw-r--r--src/gui/gui_editcombo.pas152
2 files changed, 190 insertions, 224 deletions
diff --git a/src/gui/gui_combobox.pas b/src/gui/gui_combobox.pas
index 89400d90..5a1cf94e 100644
--- a/src/gui/gui_combobox.pas
+++ b/src/gui/gui_combobox.pas
@@ -58,29 +58,46 @@ uses
type
- { TfpgAbstractComboBox }
-
- TfpgAbstractComboBox = class(TfpgWidget)
+ TfpgBaseComboBox = class(TfpgWidget)
private
FDropDownCount: integer;
- FFocusItem: integer;
FFont: TfpgFont;
- FInternalBtnRect: TfpgRect;
- FItems: TStringList;
FOnChange: TNotifyEvent;
function GetFontDesc: string;
procedure SetDropDownCount(const AValue: integer);
- procedure InternalBtnClick(Sender: TObject);
- procedure DoOnChange;
procedure SetFocusItem(const AValue: integer);
procedure SetFontDesc(const AValue: string);
+ protected
+ FFocusItem: integer;
+ FItems: TStringList;
+ procedure HandleKeyPress(var keycode: word; var shiftstate: TShiftState; var consumed: boolean); override;
+ procedure DoOnChange;
+ procedure DoDropDown; virtual; abstract;
+ function GetDropDownPos(AParent, AComboBox, ADropDown: TfpgWidget): TfpgRect; virtual;
+ property DropDownCount: integer read FDropDownCount write SetDropDownCount default 8;
+ property FocusItem: integer read FFocusItem write SetFocusItem;
+ property FontDesc: string read GetFontDesc write SetFontDesc;
+ property Items: TStringList read FItems; {$Note Make this read/write }
+ property OnChange: TNotifyEvent read FOnChange write FOnChange;
+ public
+ constructor Create(AOwner: TComponent); override;
+ destructor Destroy; override;
+ property Font: TfpgFont read FFont;
+ end;
+
+
+ TfpgAbstractComboBox = class(TfpgBaseComboBox)
+ private
+ FInternalBtnRect: TfpgRect;
+ procedure InternalBtnClick(Sender: TObject);
+ procedure SetFocusItem(const AValue: integer);
procedure CalculateInternalButtonRect;
procedure MsgPopupClose(var msg: TfpgMessageRec); message FPGM_POPUPCLOSE;
protected
FMargin: integer;
FBtnPressed: Boolean;
FDropDown: TfpgPopupWindow;
- procedure DoDropDown; virtual;
+ procedure DoDropDown; override;
function GetText: string; virtual;
function HasText: boolean; virtual;
procedure SetText(const AValue: string); virtual;
@@ -92,18 +109,11 @@ type
procedure HandleResize(awidth, aheight: TfpgCoord); override;
procedure HandlePaint; override;
procedure PaintInternalButton; virtual;
- property DropDownCount: integer read FDropDownCount write SetDropDownCount default 8;
- property Items: TStringList read FItems; {$Note Make this read/write }
- // property is 1-based
- property FocusItem: integer read FFocusItem write SetFocusItem;
- property FontDesc: string read GetFontDesc write SetFontDesc;
- property OnChange: TNotifyEvent read FOnChange write FOnChange;
property Text: string read GetText write SetText;
public
constructor Create(AOwner: TComponent); override;
destructor Destroy; override;
procedure Update;
- property Font: TfpgFont read FFont;
end;
@@ -153,6 +163,130 @@ type
end;
+{ TfpgBaseComboBox }
+
+procedure TfpgBaseComboBox.SetDropDownCount(const AValue: integer);
+begin
+ if FDropDownCount = AValue then
+ Exit;
+ FDropDownCount := AValue;
+end;
+
+function TfpgBaseComboBox.GetFontDesc: string;
+begin
+ Result := FFont.FontDesc;
+end;
+
+{ Focusitem is 1 based and NOT 0 based like the Delphi ItemIndex property.
+ So at startup, FocusItem = 0 which means nothing is selected. If FocusItem = 1
+ it means the first item is selected etc. }
+procedure TfpgBaseComboBox.SetFocusItem(const AValue: integer);
+begin
+ if FFocusItem = AValue then
+ Exit; //==>
+ FFocusItem := AValue;
+
+ // do some limit check corrections
+ if FFocusItem < 0 then
+ FFocusItem := 0 // nothing is selected
+ else if FFocusItem > FItems.Count then
+ FFocusItem := FItems.Count;
+
+ RePaint;
+ DoOnChange;
+end;
+
+procedure TfpgBaseComboBox.SetFontDesc(const AValue: string);
+begin
+ FFont.Free;
+ FFont := fpgGetFont(AValue);
+ if Height < FFont.Height + 6 then
+ Height:= FFont.Height + 6;
+ RePaint;
+end;
+
+procedure TfpgBaseComboBox.HandleKeyPress(var keycode: word;
+ var shiftstate: TShiftState; var consumed: boolean);
+begin
+ inherited HandleKeyPress(keycode, shiftstate, consumed);
+ if not consumed then
+ begin
+ case keycode of
+ keyDown:
+ begin
+ if (shiftstate = [ssAlt]) then
+ DoDropDown
+ else
+ begin
+ FocusItem := FocusItem + 1;
+ consumed := True;
+ end;
+ end;
+
+ keyUp:
+ begin
+ FocusItem := FocusItem - 1;
+ consumed := True;
+ end;
+ end; { case }
+ end; { if }
+end;
+
+procedure TfpgBaseComboBox.DoOnChange;
+begin
+ if Assigned(OnChange) then
+ FOnChange(self);
+end;
+
+function TfpgBaseComboBox.GetDropDownPos(AParent, AComboBox, ADropDown: TfpgWidget): TfpgRect;
+var
+ pt: TPoint;
+begin
+ // translate ComboBox coordinates
+ pt := WindowToScreen(AParent, Point(AComboBox.Left, AComboBox.Bottom));
+
+ // dropdown will not fit below combobox so we place it above
+ if (pt.y + ADropDown.Height) > fpgApplication.ScreenHeight then
+ Result.Top := AComboBox.Top - ADropDown.Height
+ else
+ Result.Top := AComboBox.Bottom;
+
+ // dropdown height doesn't fit in screen height so shrink it
+ if (ADropDown.Height > fpgApplication.ScreenHeight) then
+ begin
+ // 50 is just some spacing for taskbars (top or bottom aligned)
+ Result.Top := AComboBox.Top - pt.y + 50;
+ Result.Height := fpgApplication.ScreenHeight - 50;
+ end
+ else
+ Result.Height := ADropDown.Height;
+
+ Result.Left := AComboBox.Left;
+ Result.Width := ADropDown.Width;
+
+// writeln('H:', fpgApplication.ScreenHeight, ' W:', fpgApplication.ScreenWidth);
+// writeln('Point x:', pt.x, ' y:', pt.y);
+// PrintRect(Result);
+end;
+
+constructor TfpgBaseComboBox.Create(AOwner: TComponent);
+begin
+ inherited Create(AOwner);
+ FDropDownCount := 8;
+ FFocusItem := 0; // nothing is selected
+ FItems := TStringList.Create;
+ FFont := fpgGetFont('#List');
+ FOnChange := nil;
+end;
+
+destructor TfpgBaseComboBox.Destroy;
+begin
+ FFont.Free;
+ FItems.Free;
+ inherited Destroy;
+end;
+
+
{ TComboboxDropdownWindow }
procedure TComboboxDropdownWindow.SetFirstItem;
@@ -197,6 +331,7 @@ end;
constructor TComboboxDropdownWindow.Create(AOwner: TComponent; ACallerWidget: TfpgAbstractComboBox);
begin
inherited Create(nil);
+ Name := '_ComboboxDropdownWindow';
if not Assigned(ACallerWidget) then
raise Exception.Create('ACallerWidget may not be <nil>');
FCallerWidget := ACallerWidget;
@@ -230,22 +365,10 @@ end;
{ TfpgAbstractComboBox }
-procedure TfpgAbstractComboBox.SetDropDownCount(const AValue: integer);
-begin
- if FDropDownCount = AValue then
- Exit;
- FDropDownCount := AValue;
-end;
-
-function TfpgAbstractComboBox.GetFontDesc: string;
-begin
- Result := FFont.FontDesc;
-end;
-
function TfpgAbstractComboBox.GetText: string;
begin
if (FocusItem > 0) and (FocusItem <= FItems.Count) then
- Result := FItems.Strings[FocusItem-1]
+ Result := Items.Strings[FocusItem-1]
else
Result := '';
end;
@@ -259,7 +382,9 @@ procedure TfpgAbstractComboBox.DoDropDown;
var
ddw: TComboboxDropdownWindow;
rowcount: integer;
+ r: TfpgRect;
begin
+ writeln('DoDropDown');
if (not Assigned(FDropDown)) or (not FDropDown.HasHandle) then
begin
FreeAndNil(FDropDown);
@@ -278,7 +403,9 @@ begin
ddw.Width := Width;
ddw.Height := (ddw.ListBox.RowHeight * rowcount) + 4;
ddw.DontCloseWidget := self; // now we can control when the popup window closes
- ddw.ShowAt(Parent, Left, Top + Height); // drop the box below the combo
+ r := GetDropDownPos(Parent, self, ddw);
+ ddw.Height := r.Height;
+ ddw.ShowAt(Parent, r.Left, r.Top);
end
else
begin
@@ -295,41 +422,9 @@ begin
DoDropDown;
end;
-procedure TfpgAbstractComboBox.DoOnChange;
-begin
- if Assigned(OnChange) then
- FOnChange(self);
-end;
-
-{ Focusitem is 1 based and NOT 0 based like the Delphi ItemIndex property.
- So at startup, FocusItem = 0 which means nothing is selected. If FocusItem = 1
- it means the first item is selected etc. }
procedure TfpgAbstractComboBox.SetFocusItem(const AValue: integer);
begin
- if FFocusItem = AValue then
- Exit; //==>
- FFocusItem := AValue;
-
- // do some limit check corrections
- if FFocusItem < 0 then
- FFocusItem := 0 // nothing is selected
- else if FFocusItem > FItems.Count then
- FFocusItem := FItems.Count;
- RePaint;
- DoOnChange;
-end;
-
-procedure TfpgAbstractComboBox.SetFontDesc(const AValue: string);
-begin
- FFont.Free;
- FFont := fpgGetFont(AValue);
- if Height < FFont.Height + 6 then
- begin
- Height:= FFont.Height + 6;
-// UpdateWindowPosition;
- end;
- RePaint;
end;
procedure TfpgAbstractComboBox.SetText(const AValue: string);
@@ -342,7 +437,7 @@ begin
begin
for i := 0 to FItems.Count - 1 do
begin
- if SameText(FItems.Strings[i], AValue) then
+ if SameText(Items.Strings[i], AValue) then
begin
SetFocusItem(i+1); // our FocusItem is 1-based. TStringList is 0-based.
Exit;
@@ -361,41 +456,10 @@ begin
end;
procedure TfpgAbstractComboBox.HandleKeyPress(var keycode: word; var shiftstate: TShiftState; var consumed: boolean);
-var
- hasChanged: boolean;
begin
inherited HandleKeyPress(keycode, shiftstate, consumed);
- hasChanged := False;
- consumed := True;
- case keycode of
-
- keyDown:
- begin
- if (shiftstate = [ssAlt]) then
- DoDropDown
- else
- begin
- FocusItem := FocusItem + 1;
- hasChanged := True;
- end;
- end;
-
- keyUp:
- begin
- FocusItem := FocusItem - 1;
- hasChanged := True;
- end;
- else
- Consumed := False;
- end;
-
if consumed then
RePaint
- else
- inherited;
-
- if hasChanged then
- DoOnChange;
end;
procedure TfpgAbstractComboBox.CalculateInternalButtonRect;
@@ -528,28 +592,20 @@ end;
constructor TfpgAbstractComboBox.Create(AOwner: TComponent);
begin
inherited Create(AOwner);
- FFont := fpgGetFont('#List');
FBackgroundColor := clBoxColor;
FTextColor := Parent.TextColor;
- FDropDownCount := 8;
FWidth := 120;
- FHeight := FFont.Height + 6;
- FFocusItem := 0; // nothing is selected
+ FHeight := Font.Height + 6;
FMargin := 3;
FFocusable := True;
FBtnPressed := False;
- FItems := TStringList.Create;
CalculateInternalButtonRect;
-
- FOnChange := nil;
end;
destructor TfpgAbstractComboBox.Destroy;
begin
FDropDown.Free;
- FItems.Free;
- FFont.Free;
inherited Destroy;
end;
diff --git a/src/gui/gui_editcombo.pas b/src/gui/gui_editcombo.pas
index a1d8a343..b6bfb6c3 100644
--- a/src/gui/gui_editcombo.pas
+++ b/src/gui/gui_editcombo.pas
@@ -57,34 +57,26 @@ uses
gfx_widget,
gfxbase,
fpgfx,
- gfx_popupwindow;
+ gfx_popupwindow,
+ gui_combobox;
type
TAllowNew = (anNo, anYes, anAsk);
- TfpgAbstractEditCombo = class(TfpgWidget)
+ TfpgAbstractEditCombo = class(TfpgBaseComboBox)
private
FAutoCompletion: Boolean;
FAutoDropDown: Boolean;
FAllowNew: TAllowNew;
- FDropDownCount: integer;
FText: string;
FSelectedItem: integer;
FMaxLength: integer;
- FFocusItem: integer;
- FFont: TfpgFont;
FInternalBtnRect: TfpgRect;
- FItems: TStringList;
- FOnChange: TNotifyEvent;
FNewItem: boolean;
- function GetFontDesc: string;
procedure SetAllowNew(const AValue: TAllowNew);
- procedure SetDropDownCount(const AValue: integer);
procedure InternalBtnClick(Sender: TObject);
procedure InternalListBoxSelect(Sender: TObject);
- procedure SetFocusItem(const AValue: integer);
- procedure SetFontDesc(const AValue: string);
procedure CalculateInternalButtonRect;
procedure MsgPopupClose(var msg: TfpgMessageRec); message FPGM_POPUPCLOSE;
protected
@@ -95,7 +87,7 @@ type
FSelStart: integer;
FSelOffset: integer;
FCursorPos: integer;
- procedure DoDropDown; virtual;
+ procedure DoDropDown; override;
function GetText: string; virtual;
function HasText: boolean; virtual;
procedure SetText(const AValue: string); virtual;
@@ -108,24 +100,16 @@ type
procedure HandleResize(awidth, aheight: TfpgCoord); override;
procedure HandlePaint; override;
procedure PaintInternalButton; virtual;
- property DropDownCount: integer read FDropDownCount write SetDropDownCount default 8;
- // property is 0-based
- property Items: TStringList read FItems; {$Note Make this read/write}
- // property is 1-based
- property FocusItem: integer read FFocusItem write SetFocusItem;
property AutoCompletion: Boolean read FAutocompletion write FAutoCompletion default False;
property AutoDropDown: Boolean read FAutoDropDown write FAutoDropDown default False;
property AllowNew: TAllowNew read FAllowNew write SetAllowNew default anNo;
property BackgroundColor: TfpgColor read FBackgroundColor write SetBackgroundColor default clBoxColor;
property TextColor: TfpgColor read FTextColor write SetTextColor default clText1;
- property FontDesc: string read GetFontDesc write SetFontDesc;
- property OnChange: TNotifyEvent read FOnChange write FOnChange;
property Text: string read GetText write SetText;
public
constructor Create(AOwner: TComponent); override;
destructor Destroy; override;
procedure Update;
- property Font: TfpgFont read FFont;
property NewText: boolean read FNewItem;
property OnKeyPress;
end;
@@ -255,8 +239,8 @@ begin
Result.Top := y;
Result.Width := w;
Result.Focusable := True;
- if h < TfpgEditCombo(Result).FFont.Height + 6 then
- Result.Height:= TfpgEditCombo(Result).FFont.Height + 6
+ if h < TfpgEditCombo(Result).Font.Height + 6 then
+ Result.Height:= TfpgEditCombo(Result).Font.Height + 6
else
Result.Height:= h;
@@ -266,24 +250,12 @@ end;
{ TfpgAbstractEditCombo }
-procedure TfpgAbstractEditCombo.SetDropDownCount(const AValue: integer);
-begin
- if FDropDownCount = AValue then
- Exit;
- FDropDownCount := AValue;
-end;
-
procedure TfpgAbstractEditCombo.SetAllowNew(const AValue: TAllowNew);
begin
if FAllowNew <> AValue then
FAllowNew:= AValue;
end;
-function TfpgAbstractEditCombo.GetFontDesc: string;
-begin
- Result := FFont.FontDesc;
-end;
-
function TfpgAbstractEditCombo.GetText: string;
var
i: integer;
@@ -351,8 +323,8 @@ end;
procedure TfpgAbstractEditCombo.DoDropDown;
var
ddw: TDropDownWindow;
- rowcount, i, t: integer;
- theparent: TfpgWidget;
+ rowcount, i: integer;
+ r: TfpgRect;
begin
if (not Assigned(FDropDown)) or (not FDropDown.HasHandle) then
begin
@@ -376,8 +348,8 @@ begin
// adjust the height of the dropdown
rowcount := ddw.ListBox.Items.Count;
- if rowcount > FDropDownCount then
- rowcount := FDropDownCount;
+ if rowcount > DropDownCount then
+ rowcount := DropDownCount;
if rowcount < 1 then
rowcount := 1;
ddw.Height := (ddw.ListBox.RowHeight * rowcount) + 4;
@@ -387,30 +359,9 @@ begin
ddw.ListBox.FocusItem := FFocusItem;
ddw.DontCloseWidget := self; // now we can control when the popup window closes
- theparent := Self;
- t:= 0;
- repeat
- t := t + theparent.Top;
- theparent:= theparent.Parent;
- until theparent is TfpgForm;
- if (t + Height + ddw.Height) > theparent.Height then
- if t > ddw.Height then
- ddw.ShowAt(Parent, Left, Top - ddw.Height) // drop the list above the combo
- else
- begin
- while (t + Height + ddw.Height) > theparent.Height do
- begin
- FDropDownCount:= FDropDownCount - 1;
- if rowcount > FDropDownCount then
- rowcount:= FDropDownCount;
- ddw.Height := (ddw.ListBox.RowHeight * rowcount) + 4;
- ddw.ListBox.Height := ddw.Height;
- end;
- ddw.ShowAt(Parent, Left, t + Height); // drop a reduced list below the combo
- end
- else
- ddw.ShowAt(Parent, Left, Top + Height); // drop the list below the combo
-// ddw.ListBox.SetFocus;
+ r := GetDropDownPos(Parent, self, ddw);
+ ddw.Height := r.Height;
+ ddw.ShowAt(Parent, r.Left, r.Top);
end
else
begin
@@ -435,7 +386,7 @@ begin
// Items is 0-based and FocusItem is 1-based
if Items[i]= TDropDownWindow(FDropDown).ListBox.Items[TDropDownWindow(FDropDown).ListBox.FocusItem-1] then
begin
- FFocusItem := i+1;
+ FocusItem := i+1;
Break;
end;
end;
@@ -443,35 +394,6 @@ begin
if HasHandle then
Repaint;
- if Assigned(FOnChange) then
- FOnChange(self);
-end;
-
-{ Focusitem is 1 based and NOT 0 based like the Delphi ItemIndex property.
- So at startup, FocusItem = 0 which means nothing is selected. If
- FocusItem = 1 it means the first item is selected etc. }
-procedure TfpgAbstractEditCombo.SetFocusItem(const AValue: integer);
-begin
- if FFocusItem = AValue then
- Exit; //==>
- FFocusItem := AValue;
-
- // do some limit check corrections
- if FFocusItem < 0 then
- FFocusItem := 0 // nothing is selected
- else if FFocusItem > FItems.Count then
- FFocusItem := FItems.Count;
-
- RePaint;
-end;
-
-procedure TfpgAbstractEditCombo.SetFontDesc(const AValue: string);
-begin
- FFont.Free;
- FFont := fpgGetFont(AValue);
- if Height < FFont.Height + 6 then
- Height := FFont.Height + 6;
- RePaint;
end;
procedure TfpgAbstractEditCombo.SetText(const AValue: string);
@@ -479,19 +401,19 @@ var
i: integer;
begin
if AValue = '' then
- SetFocusItem(0) // nothing selected
+ FocusItem := 0 // nothing selected
else
begin
- for i := 0 to FItems.Count - 1 do
+ for i := 0 to Items.Count - 1 do
begin
- if SameText(UTF8Copy(FItems.Strings[i], 1, UTF8Length(AVAlue)), AValue) then
+ if SameText(UTF8Copy(Items.Strings[i], 1, UTF8Length(AVAlue)), AValue) then
begin
- SetFocusItem(i+1); // our FocusItem is 1-based. TStringList is 0-based.
+ FocusItem := i+1; // our FocusItem is 1-based. TStringList is 0-based.
Exit;
end;
end;
// if we get here, we didn't find a match
- SetFocusItem(0);
+ FocusItem := 0;
end;
end;
@@ -544,8 +466,7 @@ begin
end;
if prevval <> FText then
- if Assigned(FOnChange) then
- FOnChange(self);
+ DoOnChange;
if consumed then
RePaint
@@ -566,7 +487,7 @@ begin
keyBackSpace:
begin
if HasText then
- FocusItem:= 0;
+ FocusItem := 0;
if FCursorPos > 0 then
begin
UTF8Delete(FText, FCursorPos, 1);
@@ -578,8 +499,8 @@ begin
keyDelete:
begin
if HasText then
- FocusItem:= 0;
- FSelectedItem:= -2; // detects delete has been pressed
+ FocusItem := 0;
+ FSelectedItem := -2; // detects delete has been pressed
hasChanged := True;
end;
@@ -608,12 +529,9 @@ begin
if consumed then
RePaint;
-// else
-// inherited;
if hasChanged then
- if Assigned(FOnChange) then
- FOnChange(self);
+ DoOnChange;
inherited HandleKeyPress(keycode, shiftstate, consumed);
end;
@@ -678,10 +596,10 @@ var
st := st + len;
len := -len;
end;
- tw := FFont.TextWidth(UTF8Copy(Items[FSelectedItem], 1, st));
- tw2 := FFont.TextWidth(UTF8Copy(Items[FSelectedItem], 1, st + len));
+ tw := Font.TextWidth(UTF8Copy(Items[FSelectedItem], 1, st));
+ tw2 := Font.TextWidth(UTF8Copy(Items[FSelectedItem], 1, st + len));
Canvas.XORFillRectangle(fpgColorToRGB(lcolor) xor $FFFFFF,
- -FDrawOffset + FMargin + tw, 3, tw2 - tw, FFont.Height);
+ -FDrawOffset + FMargin + tw, 3, tw2 - tw, Font.Height);
end;
begin
@@ -746,7 +664,7 @@ begin
if Texte <> '' then
if FSelectedItem > -1 then
begin
- FSelOffset:= FFont.TextWidth(UTF8Copy(Items[FSelectedItem], UTF8Length(FText) + 1,
+ FSelOffset:= Font.TextWidth(UTF8Copy(Items[FSelectedItem], UTF8Length(FText) + 1,
UTF8Length(Items[FSelectedItem]) - UTF8Length(FText)));
fpgStyle.DrawString(Canvas, FMargin+1, FMargin, FText + UTF8Copy(Items[FSelectedItem],
UTF8Length(FText) + 1, UTF8Length(Items[FSelectedItem]) - UTF8Length(FText)), Enabled);
@@ -766,8 +684,8 @@ begin
// drawing cursor
FCursorPos:= UTF8Length(FText);
- tw := FFont.TextWidth(UTF8Copy(FText, 1, FCursorPos));
- fpgCaret.SetCaret(Canvas, -FDrawOffset + FMargin + tw, 3, fpgCaret.Width, FFont.Height);
+ tw := Font.TextWidth(UTF8Copy(FText, 1, FCursorPos));
+ fpgCaret.SetCaret(Canvas, -FDrawOffset + FMargin + tw, 3, fpgCaret.Width, Font.Height);
end
else
fpgCaret.UnSetCaret(Canvas);
@@ -810,13 +728,10 @@ end;
constructor TfpgAbstractEditCombo.Create(AOwner: TComponent);
begin
inherited Create(AOwner);
- FFont := fpgGetFont('#List');
FBackgroundColor := clBoxColor;
FTextColor := Parent.TextColor;
- FDropDownCount := 8;
FWidth := 120;
- FHeight := FFont.Height + 6;
- FFocusItem := 0; // nothing is selected
+ FHeight := Font.Height + 6;
FMargin := 3;
FFocusable := True;
FBtnPressed := False;
@@ -831,17 +746,12 @@ begin
FSelectedItem := -1; // to allow typing if list is empty
FNewItem := False;
- FItems := TStringList.Create;
CalculateInternalButtonRect;
-
- FOnChange := nil;
end;
destructor TfpgAbstractEditCombo.Destroy;
begin
FDropDown.Free;
- FItems.Free;
- FFont.Free;
inherited Destroy;
end;