summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/fpg_edit.pas266
-rw-r--r--src/gui/fpg_spinedit.pas29
2 files changed, 237 insertions, 58 deletions
diff --git a/src/gui/fpg_edit.pas b/src/gui/fpg_edit.pas
index dce1fda8..f66a5859 100644
--- a/src/gui/fpg_edit.pas
+++ b/src/gui/fpg_edit.pas
@@ -242,9 +242,15 @@ type
TfpgEditInteger = class(TfpgBaseNumericEdit)
+ private
+ FLimit: Boolean;
+ FMaxValue: integer;
+ FMinValue: integer;
protected
function GetValue: integer; virtual;
procedure SetValue(const AValue: integer); virtual;
+ procedure SetMaxValue(const AValue: integer); virtual;
+ procedure SetMinValue(const AValue: integer); virtual;
procedure HandleKeyChar(var AText: TfpgChar; var shiftstate: TShiftState; var consumed: Boolean); override;
procedure HandleSetFocus; override;
procedure HandleKillFocus; override;
@@ -258,6 +264,8 @@ type
property CustomThousandSeparator;
property Enabled;
property Hint;
+ property MaxValue: integer read FMaxValue write SetMaxValue;
+ property MinValue: integer read FMinValue write SetMinValue;
property NegativeColor;
property ParentShowHint;
property ReadOnly;
@@ -279,12 +287,17 @@ type
TfpgEditFloat = class(TfpgBaseNumericEdit)
private
- FFixedDecimals: boolean;
+ FFixedDecimals: integer;
+ FLimit: Boolean;
+ FMaxValue: extended;
+ FMinValue: extended;
protected
function GetValue: extended; virtual;
procedure SetValue(const AValue: extended); virtual;
+ procedure SetMaxValue(const AValue: extended); virtual;
+ procedure SetMinValue(const AValue: extended); virtual;
procedure SetDecimals(const AValue: integer);
- procedure SetFixedDecimals(const AValue: boolean);
+ procedure SetFixedDecimals(const AValue: integer);
procedure HandleKeyChar(var AText: TfpgChar; var shiftstate: TShiftState; var consumed: Boolean); override;
procedure HandleSetFocus; override;
procedure HandleKillFocus; override;
@@ -298,9 +311,11 @@ type
property CustomDecimalSeparator;
property CustomThousandSeparator;
property Decimals: integer read FDecimals write SetDecimals default -1;
+ property FixedDecimals: integer read FFixedDecimals write SetFixedDecimals default -1;
property Enabled;
- property FixedDecimals: boolean read FFixedDecimals write SetFixedDecimals default False;
property Hint;
+ property MaxValue: extended read FMaxValue write SetMaxValue;
+ property MinValue: extended read FMinValue write SetMinValue;
property NegativeColor;
property ParentShowHint;
property ReadOnly;
@@ -321,9 +336,15 @@ type
TfpgEditCurrency = class(TfpgBaseNumericEdit)
+ private
+ FLimit: Boolean;
+ FMaxValue: Currency;
+ FMinValue: Currency;
protected
function GetValue: Currency; virtual;
procedure SetValue(const AValue: Currency); virtual;
+ procedure SetMaxValue(const AValue: Currency); virtual;
+ procedure SetMinValue(const AValue: Currency); virtual;
procedure SetDecimals(AValue: integer);
procedure HandleKeyChar(var AText: TfpgChar; var shiftstate: TShiftState; var consumed: Boolean); override;
procedure HandleKeyPress(var keycode: word; var shiftstate: TShiftState; var consumed: Boolean); override;
@@ -341,6 +362,8 @@ type
property Decimals: integer read FDecimals write SetDecimals default 2;
property Enabled;
property Hint;
+ property MaxValue: Currency read FMaxValue write SetMaxValue;
+ property MinValue: Currency read FMinValue write SetMinValue;
property NegativeColor;
property ParentShowHint;
property ReadOnly;
@@ -365,7 +388,7 @@ function CreateEditInteger(AOwner: TComponent; x, y, w, h: TfpgCoord;
AShowThousand: boolean= True): TfpgEditInteger;
function CreateEditFloat(AOwner: TComponent; x, y, w, h: TfpgCoord;
- AShowThousand: boolean= True; ADecimals: Integer= -1; AFixedDecimals: boolean= False): TfpgEditFloat;
+ AShowThousand: boolean= True; ADecimals: Integer= -1; AFixedDecimals: integer= -1): TfpgEditFloat;
function CreateEditCurrency(AOwner: TComponent; x, y, w, h: TfpgCoord;
AShowThousand: boolean= True; ADecimals: Integer= 2): TfpgEditCurrency;
@@ -388,7 +411,6 @@ const
cPasswordChar = #$E2#$97#$8F; // U+25CF BLACK CIRCLE
-
function CreateEdit(AOwner: TComponent; x, y, w, h: TfpgCoord): TfpgEdit;
begin
Result := TfpgEdit.Create(AOwner);
@@ -418,7 +440,7 @@ begin
end;
function CreateEditFloat(AOwner: TComponent; x, y, w, h: TfpgCoord; AShowThousand: boolean= True;
- ADecimals: Integer= -1; AFixedDecimals: boolean= False): TfpgEditFloat;
+ ADecimals: Integer= -1; AFixedDecimals: integer= -1): TfpgEditFloat;
begin
Result := TfpgEditFloat.Create(AOwner);
Result.Left := x;
@@ -426,7 +448,7 @@ begin
Result.Width := w;
Result.ShowThousand:= AShowThousand;
Result.Decimals := ADecimals;
- Result.FFixedDecimals:= AFixedDecimals;
+ Result.FixedDecimals := AFixedDecimals;
if h < TfpgEditFloat(Result).FFont.Height + 4 + (Result.FHeightMargin * 2) then
Result.Height := TfpgEditFloat(Result).FFont.Height + 4 + (Result.FHeightMargin * 2)
else
@@ -1880,6 +1902,19 @@ begin
begin
try
Result := StrToInt(fText);
+ if FLimit then
+ begin
+ if Result> FMaxValue then
+ begin
+ SetValue(FMaxValue);
+ Result:= FMaxValue;
+ end;
+ if Result< FMinValue then
+ begin
+ SetValue(FMinValue);
+ Result:= FMinValue;
+ end;
+ end;
except
on E: EConvertError do
begin
@@ -1896,13 +1931,43 @@ end;
procedure TfpgEditInteger.SetValue(const AValue: integer);
begin
- try
- Text := IntToStr(AValue);
- FormatEdit;
- except
- on E: EConvertError do
- Text := '';
- end;
+ if FLimit then
+ if (AValue <= FMaxValue) and (AValue >= FMinValue) then
+ try
+ Text := IntToStr(AValue);
+ FormatEdit;
+ except
+ on E: EConvertError do
+ Text := '';
+ end
+ else
+ Exit
+ else
+ try
+ Text := IntToStr(AValue);
+ FormatEdit;
+ except
+ on E: EConvertError do
+ Text := '';
+ end;
+end;
+
+procedure TfpgEditInteger.SetMaxValue(const AValue: integer);
+begin
+ if AValue > FMinValue then
+ FMaxValue:= AValue
+ else
+ FMaxValue := FMinValue;
+ FLimit:= True;
+end;
+
+procedure TfpgEditInteger.SetMinValue(const AValue: integer);
+begin
+ if AValue < FMaxValue then
+ FMinValue:= AValue
+ else
+ FMinValue := FMaxValue;
+ FLimit:= True;
end;
procedure TfpgEditInteger.HandleKeyChar(var AText: TfpgChar;
@@ -1960,6 +2025,7 @@ begin
inherited Create(AOwner);
FShowThousand := True;
FDecimals := 0;
+ FLimit := False;
end;
{ TfpgEditFloat }
@@ -1978,6 +2044,10 @@ begin
if FDecimals = 0 then
if UTF8Pos(FDecimalSeparator, fText) > 0 then
fText := UTF8Copy(fText, 1, UTF8Length(fText) - 1);
+ if FFixedDecimals > -1 then
+ if UTF8Pos(FDecimalSeparator, fText) > 0 then
+ if UTF8Length(fText)-UTF8Pos(FDecimalSeparator, fText) > FFixedDecimals then
+ fText := UTF8Copy(fText, 1, UTF8Length(fText) - 1);
if ShowThousand then
begin
@@ -2005,7 +2075,20 @@ begin
begin
try
Result := StrToFloat(fText);
- except
+ if FLimit then
+ begin
+ if Result> FMaxValue then
+ begin
+ SetValue(FMaxValue);
+ Result:= FMaxvalue;
+ end;
+ if Result< FMinValue then
+ begin
+ SetValue(FMinValue);
+ Result:= FMinValue;
+ end;
+ end;
+ except
on E: EConvertError do
begin
Result := 0;
@@ -2021,16 +2104,51 @@ end;
procedure TfpgEditFloat.SetValue(const AValue: extended);
begin
- try
- if FFixedDecimals then
- Text := FloatToStrF(AValue, ffFixed, 18, FDecimals)
+ if FLimit then
+ if (AValue <= FMaxValue) and (AValue >= FMinValue) then
+ try
+ Text := FloatToStr(AValue);
+ if FFixedDecimals > -1 then
+ if UTF8Pos(FDecimalSeparator, Text) > 0 then
+ while UTF8Length(Text)-UTF8Pos(FDecimalSeparator, Text) < FFixedDecimals do
+ Text := Text + '0';
+ FormatEdit;
+ except
+ on E: EConvertError do
+ Text := '';
+ end
else
+ Exit
+ else
+ try
Text := FloatToStr(AValue);
- FormatEdit;
- except
- on E: EConvertError do
- Text := '';
- end;
+ if FFixedDecimals > -1 then
+ if UTF8Pos(FDecimalSeparator, Text) > 0 then
+ while UTF8Length(Text)-UTF8Pos(FDecimalSeparator, Text) < FFixedDecimals do
+ Text := Text + '0';
+ FormatEdit;
+ except
+ on E: EConvertError do
+ Text := '';
+ end;
+end;
+
+procedure TfpgEditFloat.SetMaxValue(const AValue: extended);
+begin
+ if AValue > FMinValue then
+ FMaxValue:= AValue
+ else
+ FMaxValue := FMinValue;
+ FLimit:= True;
+end;
+
+procedure TfpgEditFloat.SetMinValue(const AValue: extended);
+begin
+ if AValue < FMaxValue then
+ FMinValue:= AValue
+ else
+ FMinValue := FMaxValue;
+ FLimit:= True;
end;
procedure TfpgEditFloat.SetDecimals(const AValue: integer);
@@ -2038,13 +2156,21 @@ begin
if AValue < -1 then
Exit; // =>
if FDecimals <> AValue then
- FDecimals := AValue
+ begin
+ FDecimals := AValue;
+ FFixedDecimals := -1;
+ end;
end;
-procedure TfpgEditFloat.SetFixedDecimals(const AValue: boolean);
+procedure TfpgEditFloat.SetFixedDecimals(const AValue: integer);
begin
+ if AValue < -1 then
+ Exit; // =>
if FFixedDecimals <> AValue then
+ begin
FFixedDecimals := AValue;
+ FDecimals := -1;
+ end;
end;
procedure TfpgEditFloat.HandleKeyChar(var AText: TfpgChar;
@@ -2065,17 +2191,21 @@ procedure TfpgEditFloat.HandleSetFocus;
begin
try
if GetValue = 0 then
- Text := ''
+ fText := ''
else
begin
- if FFixedDecimals then
- Text := FloatToStrF(GetValue, ffFixed, 18, FDecimals)
- else
- Text := FloatToStr(GetValue);
+ fText := FloatToStr(GetValue);
+ if FFixedDecimals > -1 then
+ begin
+ if UTF8Pos(FDecimalSeparator, fText) = 0 then
+ fText := fText + FDecimalSeparator;
+ while (UTF8Length(fText) - (UTF8Pos(FDecimalSeparator, fText)) < FFixedDecimals) do
+ fText := fText +'0';
+ end;
end;
except
on E: EConvertError do
- Text := '';
+ fText := '';
end;
inherited HandleSetFocus;
end;
@@ -2083,14 +2213,18 @@ end;
procedure TfpgEditFloat.HandleKillFocus;
begin
try
- if FFixedDecimals then
- Text := FloatToStrF(GetValue, ffFixed, 18, FDecimals)
- else
- Text := FloatToStr(GetValue);
+ fText := FloatToStr(GetValue);
+ if FFixedDecimals > -1 then
+ begin
+ if UTF8Pos(FDecimalSeparator, fText) = 0 then
+ fText := fText + FDecimalSeparator;
+ while (UTF8Length(fText) - (UTF8Pos(FDecimalSeparator, fText)) < FFixedDecimals) do
+ fText := fText +'0';
+ end;
FormatEdit;
except
on E: EConvertError do
- Text := '';
+ fText := '';
end;
inherited HandleKillFocus;
end;
@@ -2110,8 +2244,8 @@ constructor TfpgEditFloat.Create(AOwner: TComponent);
begin
inherited Create(AOwner);
FDecimals := -1;
- FFixedDecimals := False;
FShowThousand := True;
+ FLimit := False;
end;
{ TfpgEditCurrency }
@@ -2147,6 +2281,19 @@ begin
if fText > '' then
try
Result := StrToCurr(fText);
+ if FLimit then
+ begin
+ if Result> FMaxValue then
+ begin
+ SetValue(FMaxValue);
+ Result:= FMaxvalue;
+ end;
+ if Result< FMinValue then
+ begin
+ SetValue(FMinValue);
+ Result:= FMinValue;
+ end;
+ end;
except
on E: EConvertError do
begin
@@ -2161,13 +2308,43 @@ end;
procedure TfpgEditCurrency.SetValue(const AValue: Currency);
begin
- try
- Text := FloatToStrF(AValue, ffFixed, -1, FDecimals);
- FormatEdit;
- except
- on E: EConvertError do
- Text := '';
- end;
+ if FLimit then
+ if (AValue <= FMaxValue) and (AValue >= FMinValue) then
+ try
+ Text := FloatToStrF(AValue, ffFixed, -1, FDecimals);
+ FormatEdit;
+ except
+ on E: EConvertError do
+ Text := '';
+ end
+ else
+ Exit
+ else
+ try
+ Text := FloatToStrF(AValue, ffFixed, -1, FDecimals);
+ FormatEdit;
+ except
+ on E: EConvertError do
+ Text := '';
+ end;
+end;
+
+procedure TfpgEditCurrency.SetMaxValue(const AValue: Currency);
+begin
+ if AValue > FMinValue then
+ FMaxValue:= AValue
+ else
+ FMaxValue := FMinValue;
+ FLimit:= True;
+end;
+
+procedure TfpgEditCurrency.SetMinValue(const AValue: Currency);
+begin
+ if AValue < FMaxValue then
+ FMinValue:= AValue
+ else
+ FMinValue := FMaxValue;
+ FLimit:= True;
end;
procedure TfpgEditCurrency.SetDecimals(AValue: integer);
@@ -2256,6 +2433,7 @@ begin
inherited Create(AOwner);
FDecimals := 2;
FShowThousand := True;
+ FLimit := False;
end;
diff --git a/src/gui/fpg_spinedit.pas b/src/gui/fpg_spinedit.pas
index 5c00c91b..444fa2c0 100644
--- a/src/gui/fpg_spinedit.pas
+++ b/src/gui/fpg_spinedit.pas
@@ -107,7 +107,7 @@ type
function GetNegativeColor: TfpgColor;
function GetFontDesc: string;
function GetDecimals: integer;
- function GetFixedDecimals: Boolean;
+ function GetFixedDecimals: integer;
procedure ResizeChildren; override;
procedure SetEditBackgroundColor(const AValue: Tfpgcolor);
procedure SetTextColor(const AValue: Tfpgcolor); override;
@@ -119,7 +119,7 @@ type
procedure SetLargeIncrement(const AValue: extended);
procedure SetValue(const AValue: extended);
procedure SetDecimals(const AValue: integer);
- procedure SetFixedDecimals(const AValue: Boolean);
+ procedure SetFixedDecimals(const AValue: integer);
procedure SetHint(const AValue: TfpgString); override;
procedure ButtonUpClick(Sender: TObject);
procedure ButtonDownClick(Sender: TObject);
@@ -150,7 +150,7 @@ type
property LargeIncrement: extended read FLargeIncrement write SetLargeIncrement;
property Value: extended read FValue write SetValue;
property Decimals: integer read GetDecimals write SetDecimals;
- property FixedDecimals: Boolean read GetFixedDecimals write SetFixedDecimals;
+ property FixedDecimals: integer read GetFixedDecimals write SetFixedDecimals;
property Hint;
property TabOrder;
property OnChange;
@@ -235,7 +235,7 @@ type
function CreateSpinEditFloat(AOwner: TComponent; x, y, w, h: TfpgCoord;
AMinValue: extended = 0; AMaxValue: extended = 100; AIncrement: extended = 1; ALargeIncrement: extended = 10.0;
- ADecimals: integer = 1; AValue: extended = 0; AFixedDecimals: boolean= False): TfpgSpinEditFloat;
+ AFixedDecimals: integer = 1; AValue: extended = 0; ADecimals: integer = -1): TfpgSpinEditFloat;
function CreateSpinEdit(AOwner: TComponent; x, y, w, h: TfpgCoord; AMinValue: integer = 0;
AMaxValue: integer = 100; AIncrement: integer = 1; ALargeIncrement: integer = 10;
AValue: integer = 0): TfpgSpinEdit;
@@ -244,12 +244,14 @@ function CreateSpinEdit(AOwner: TComponent; x, y, w, h: TfpgCoord; AMinValue: in
implementation
uses
- fpg_extgraphics, math;
+ fpg_extgraphics,
+ fpg_stringutils,
+ math;
function CreateSpinEditFloat(AOwner: TComponent; x, y, w, h: TfpgCoord;
AMinValue: extended = 0; AMaxValue: extended = 100; AIncrement: extended = 1; ALargeIncrement: extended = 10.0;
- ADecimals: integer = 1; AValue: extended = 0; AFixedDecimals: boolean= False): TfpgSpinEditFloat;
+ AFixedDecimals: integer = 1; AValue: extended = 0; ADecimals: integer = -1): TfpgSpinEditFloat;
var
newh: TfpgCoord;
begin
@@ -267,8 +269,8 @@ begin
end;
Result.Increment := AIncrement;
Result.LargeIncrement := ALargeIncrement;
- Result.FEdit.Decimals := ADecimals;
Result.FEdit.FixedDecimals := AFixedDecimals;
+ Result.FEdit.Decimals := ADecimals;
if (AValue <= Result.MaxValue) and (AValue >= Result.MinValue) then
Result.Value := AValue;
end;
@@ -502,7 +504,7 @@ begin
Result := FEdit.Decimals;
end;
-function TfpgSpinEditFloat.GetFixedDecimals: Boolean;
+function TfpgSpinEditFloat.GetFixedDecimals: integer;
begin
Result := FEdit.FixedDecimals;
end;
@@ -607,13 +609,12 @@ begin
FEdit.Decimals := AValue;
end;
-procedure TfpgSpinEditFloat.SetFixedDecimals(const AValue: Boolean);
+procedure TfpgSpinEditFloat.SetFixedDecimals(const AValue: integer);
begin
+ if AValue < 0 then
+ Exit; // =>
if FEdit.FixedDecimals <> AValue then
- begin
FEdit.FixedDecimals := AValue;
- FEdit.Text:= FloatToStrF(FEdit.Value, ffFixed, 18, FEdit.Decimals);
- end;
end;
procedure TfpgSpinEditFloat.SetHint(const AValue: TfpgString);
@@ -878,9 +879,9 @@ begin
FUp := False;
FDown := False;
- FEdit.Decimals := 1;
+ FEdit.Decimals := -1;
+ FEdit.FixedDecimals := 1;
FEdit.Value := FValue;
- FEdit.FixedDecimals := False;
FButtonUp.OnClick := @ButtonUpClick;
FButtonDown.OnClick := @ButtonDownClick;