mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-11-30 13:27:22 +01:00
forgot to add the fie in r17799 #488a25bd42
git-svn-id: trunk@17800 -
This commit is contained in:
parent
488a25bd42
commit
305b5215ab
1
.gitattributes
vendored
1
.gitattributes
vendored
@ -1479,6 +1479,7 @@ components/tachart/demo/unit1.lrs svneol=native#text/plain
|
|||||||
components/tachart/demo/unit1.pas svneol=native#text/plain
|
components/tachart/demo/unit1.pas svneol=native#text/plain
|
||||||
components/tachart/tachartlazaruspkg.lpk svneol=native#text/plain
|
components/tachart/tachartlazaruspkg.lpk svneol=native#text/plain
|
||||||
components/tachart/tachartlazaruspkg.pas svneol=native#text/plain
|
components/tachart/tachartlazaruspkg.pas svneol=native#text/plain
|
||||||
|
components/tachart/tachartutils.pas svneol=native#text/plain
|
||||||
components/tachart/tagraph.lrs svneol=native#text/plain
|
components/tachart/tagraph.lrs svneol=native#text/plain
|
||||||
components/tachart/tagraph.pas svneol=native#text/plain
|
components/tachart/tagraph.pas svneol=native#text/plain
|
||||||
components/tachart/taseries.pas svneol=native#text/plain
|
components/tachart/taseries.pas svneol=native#text/plain
|
||||||
|
|||||||
669
components/tachart/tachartutils.pas
Normal file
669
components/tachart/tachartutils.pas
Normal file
@ -0,0 +1,669 @@
|
|||||||
|
{
|
||||||
|
/***************************************************************************
|
||||||
|
TAChartUtils.pas
|
||||||
|
----------------
|
||||||
|
Component Library Standard Graph Utiliity Functions
|
||||||
|
|
||||||
|
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
*****************************************************************************
|
||||||
|
* *
|
||||||
|
* See the file COPYING.modifiedLGPL.txt, included in this distribution, *
|
||||||
|
* for details about the copyright. *
|
||||||
|
* *
|
||||||
|
* 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. *
|
||||||
|
* *
|
||||||
|
*****************************************************************************
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
unit TAChartUtils;
|
||||||
|
|
||||||
|
{$IFDEF fpc}
|
||||||
|
{$MODE DELPHI}{$H+}
|
||||||
|
{$ENDIF}
|
||||||
|
|
||||||
|
interface
|
||||||
|
|
||||||
|
uses
|
||||||
|
Graphics;
|
||||||
|
|
||||||
|
const
|
||||||
|
MaxColor = 15;
|
||||||
|
Colors: array [1..MaxColor] of TColor = (
|
||||||
|
clRed, clGreen, clYellow, clBlue, clWhite, clGray, clFuchsia,
|
||||||
|
clTeal, clNavy, clMaroon, clLime, clOlive, clPurple, clSilver, clAqua);
|
||||||
|
|
||||||
|
type
|
||||||
|
TAxisScale = (asIncreasing, asDecreasing, asLogIncreasing, asLogDecreasing);
|
||||||
|
|
||||||
|
TPenBrushFont = set of (pbfPen, pbfBrush, pbfFont);
|
||||||
|
|
||||||
|
{ TPenBrushFontRecall }
|
||||||
|
|
||||||
|
TPenBrushFontRecall = class
|
||||||
|
private
|
||||||
|
FPen: TPen;
|
||||||
|
FBrush: TBrush;
|
||||||
|
FFont: TFont;
|
||||||
|
FCanvas: TCanvas;
|
||||||
|
public
|
||||||
|
constructor Create(ACanvas: TCanvas; AParams: TPenBrushFont);
|
||||||
|
destructor Destroy; override;
|
||||||
|
procedure Recall;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure CalculateIntervals(
|
||||||
|
AMin, AMax: Double; AxisScale: TAxisScale; out AStart, AStep: Double);
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Integer); overload;
|
||||||
|
procedure Exchange(var A, B: Double); overload;
|
||||||
|
|
||||||
|
procedure RotateLabel(
|
||||||
|
Canvas: TCanvas; x, y: Integer; const St: String; RotDegree: Integer);
|
||||||
|
|
||||||
|
implementation
|
||||||
|
|
||||||
|
uses
|
||||||
|
Math, SysUtils, LCLIntF, LCLType;
|
||||||
|
|
||||||
|
procedure CalculateIntervals(
|
||||||
|
AMin, AMax: Double; AxisScale: TAxisScale; out AStart, AStep: Double);
|
||||||
|
var
|
||||||
|
extent, extentTmp, stepCount, scale, maxStepCount, m: Double;
|
||||||
|
i: Integer;
|
||||||
|
const
|
||||||
|
GOOD_STEPS: array [1..3] of Double = (0.2, 0.5, 1.0);
|
||||||
|
begin
|
||||||
|
extent := AMax - AMin;
|
||||||
|
AStep := 1;
|
||||||
|
AStart := AMin;
|
||||||
|
if extent <= 0 then exit;
|
||||||
|
|
||||||
|
maxStepCount := 0;
|
||||||
|
scale := 1.0;
|
||||||
|
for i := Low(GOOD_STEPS) to High(GOOD_STEPS) do begin
|
||||||
|
extentTmp := extent / GOOD_STEPS[i];
|
||||||
|
m := power(10, Round(log10(extentTmp)));
|
||||||
|
while extentTmp * m > 10 do
|
||||||
|
m *= 0.1;
|
||||||
|
while extentTmp * m <= 1 do
|
||||||
|
m *= 10;
|
||||||
|
stepCount := extentTmp * m;
|
||||||
|
if stepCount > maxStepCount then begin
|
||||||
|
maxStepCount := stepCount;
|
||||||
|
scale := m;
|
||||||
|
AStep := GOOD_STEPS[i] / m;
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
case AxisScale of
|
||||||
|
asIncreasing: begin
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMin - AStep) * scale) / scale;
|
||||||
|
while AStart > AMin do AStart -= AStep;
|
||||||
|
end;
|
||||||
|
asDecreasing: begin
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMax + AStep) * scale) / scale;
|
||||||
|
while AStart < AMax do AStart += AStep;
|
||||||
|
end;
|
||||||
|
asLogIncreasing: begin
|
||||||
|
// FIXME: asLogIncreasing is still not implemented.
|
||||||
|
// The following is the same code for asIncreasing;
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMin - AStep) * scale) / scale;
|
||||||
|
while AStart > AMin do AStart -= AStep;
|
||||||
|
end;
|
||||||
|
asLogDecreasing: begin
|
||||||
|
// FIXME: asLogDecreasing is still not implemented.
|
||||||
|
// The following is the same code for asIncreasing;
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMax + AStep) * scale) / scale;
|
||||||
|
while AStart < AMax do AStart += AStep;
|
||||||
|
end;
|
||||||
|
end; {case AxisScale}
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Integer); overload;
|
||||||
|
var
|
||||||
|
t: Integer;
|
||||||
|
begin
|
||||||
|
t := A;
|
||||||
|
A := B;
|
||||||
|
B := t;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Double); overload;
|
||||||
|
var
|
||||||
|
t: Double;
|
||||||
|
begin
|
||||||
|
t := A;
|
||||||
|
A := B;
|
||||||
|
B := t;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure RotateLabel(
|
||||||
|
Canvas: TCanvas; x, y: Integer; const St: String; RotDegree: Integer);
|
||||||
|
var
|
||||||
|
OldFont, NewFont: HFONT;
|
||||||
|
LogRec: TLOGFONT;
|
||||||
|
DC: HDC;
|
||||||
|
begin
|
||||||
|
with Canvas do begin
|
||||||
|
Brush.Style := bsClear;
|
||||||
|
GetObject(Font.Handle, SizeOf(LogRec), @LogRec);
|
||||||
|
LogRec.lfEscapement := RotDegree * 10;
|
||||||
|
LogRec.lfOrientation := 0;
|
||||||
|
LogRec.lfOutPrecision := OUT_TT_ONLY_PRECIS;
|
||||||
|
NewFont := CreateFontIndirect(LogRec);
|
||||||
|
DC := Handle;
|
||||||
|
end;
|
||||||
|
OldFont := SelectObject(DC, NewFont);
|
||||||
|
TextOut(DC, X, Y, @St[1], Length(St));
|
||||||
|
DeleteObject(SelectObject(DC, OldFont));
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TPenBrushFontRecall }
|
||||||
|
|
||||||
|
constructor TPenBrushFontRecall.Create(ACanvas: TCanvas; AParams: TPenBrushFont);
|
||||||
|
begin
|
||||||
|
inherited Create;
|
||||||
|
FCanvas := ACanvas;
|
||||||
|
if pbfPen in AParams then begin
|
||||||
|
FPen := TPen.Create;
|
||||||
|
FPen.Assign(FCanvas.Pen);
|
||||||
|
end;
|
||||||
|
if pbfBrush in AParams then begin
|
||||||
|
FBrush := TBrush.Create;
|
||||||
|
FBrush.Assign(FCanvas.Brush);
|
||||||
|
end;
|
||||||
|
if pbfFont in AParams then begin
|
||||||
|
FFont := TFont.Create;
|
||||||
|
FFont.Assign(FCanvas.Font);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
destructor TPenBrushFontRecall.Destroy;
|
||||||
|
begin
|
||||||
|
Recall;
|
||||||
|
inherited;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure TPenBrushFontRecall.Recall;
|
||||||
|
begin
|
||||||
|
if FPen <> nil then begin
|
||||||
|
FCanvas.Pen.Assign(FPen);
|
||||||
|
FreeAndNil(FPen);
|
||||||
|
end;
|
||||||
|
if FBrush <> nil then begin
|
||||||
|
FCanvas.Brush.Assign(FBrush);
|
||||||
|
FreeAndNil(FBrush);
|
||||||
|
end;
|
||||||
|
if FFont <> nil then begin
|
||||||
|
FCanvas.Font.Assign(FFont);
|
||||||
|
FreeAndNil(FFont);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
end.
|
||||||
|
{
|
||||||
|
/***************************************************************************
|
||||||
|
TAChartUtils.pas
|
||||||
|
----------------
|
||||||
|
Component Library Standard Graph Utiliity Functions
|
||||||
|
|
||||||
|
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
*****************************************************************************
|
||||||
|
* *
|
||||||
|
* See the file COPYING.modifiedLGPL.txt, included in this distribution, *
|
||||||
|
* for details about the copyright. *
|
||||||
|
* *
|
||||||
|
* 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. *
|
||||||
|
* *
|
||||||
|
*****************************************************************************
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
unit TAChartUtils;
|
||||||
|
|
||||||
|
{$IFDEF fpc}
|
||||||
|
{$MODE DELPHI}{$H+}
|
||||||
|
{$ENDIF}
|
||||||
|
|
||||||
|
interface
|
||||||
|
|
||||||
|
uses
|
||||||
|
Graphics;
|
||||||
|
|
||||||
|
const
|
||||||
|
MaxColor = 15;
|
||||||
|
Colors: array [1..MaxColor] of TColor = (
|
||||||
|
clRed, clGreen, clYellow, clBlue, clWhite, clGray, clFuchsia,
|
||||||
|
clTeal, clNavy, clMaroon, clLime, clOlive, clPurple, clSilver, clAqua);
|
||||||
|
|
||||||
|
type
|
||||||
|
TAxisScale = (asIncreasing, asDecreasing, asLogIncreasing, asLogDecreasing);
|
||||||
|
|
||||||
|
TPenBrushFont = set of (pbfPen, pbfBrush, pbfFont);
|
||||||
|
|
||||||
|
{ TPenBrushFontRecall }
|
||||||
|
|
||||||
|
TPenBrushFontRecall = class
|
||||||
|
private
|
||||||
|
FPen: TPen;
|
||||||
|
FBrush: TBrush;
|
||||||
|
FFont: TFont;
|
||||||
|
FCanvas: TCanvas;
|
||||||
|
public
|
||||||
|
constructor Create(ACanvas: TCanvas; AParams: TPenBrushFont);
|
||||||
|
destructor Destroy; override;
|
||||||
|
procedure Recall;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure CalculateIntervals(
|
||||||
|
AMin, AMax: Double; AxisScale: TAxisScale; out AStart, AStep: Double);
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Integer); overload;
|
||||||
|
procedure Exchange(var A, B: Double); overload;
|
||||||
|
|
||||||
|
procedure RotateLabel(
|
||||||
|
Canvas: TCanvas; x, y: Integer; const St: String; RotDegree: Integer);
|
||||||
|
|
||||||
|
implementation
|
||||||
|
|
||||||
|
uses
|
||||||
|
Math, SysUtils, LCLIntF, LCLType;
|
||||||
|
|
||||||
|
procedure CalculateIntervals(
|
||||||
|
AMin, AMax: Double; AxisScale: TAxisScale; out AStart, AStep: Double);
|
||||||
|
var
|
||||||
|
extent, extentTmp, stepCount, scale, maxStepCount, m: Double;
|
||||||
|
i: Integer;
|
||||||
|
const
|
||||||
|
GOOD_STEPS: array [1..3] of Double = (0.2, 0.5, 1.0);
|
||||||
|
begin
|
||||||
|
extent := AMax - AMin;
|
||||||
|
AStep := 1;
|
||||||
|
AStart := AMin;
|
||||||
|
if extent <= 0 then exit;
|
||||||
|
|
||||||
|
maxStepCount := 0;
|
||||||
|
scale := 1.0;
|
||||||
|
for i := Low(GOOD_STEPS) to High(GOOD_STEPS) do begin
|
||||||
|
extentTmp := extent / GOOD_STEPS[i];
|
||||||
|
m := power(10, Round(log10(extentTmp)));
|
||||||
|
while extentTmp * m > 10 do
|
||||||
|
m *= 0.1;
|
||||||
|
while extentTmp * m <= 1 do
|
||||||
|
m *= 10;
|
||||||
|
stepCount := extentTmp * m;
|
||||||
|
if stepCount > maxStepCount then begin
|
||||||
|
maxStepCount := stepCount;
|
||||||
|
scale := m;
|
||||||
|
AStep := GOOD_STEPS[i] / m;
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
case AxisScale of
|
||||||
|
asIncreasing: begin
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMin - AStep) * scale) / scale;
|
||||||
|
while AStart > AMin do AStart := AStart - AStep;
|
||||||
|
end;
|
||||||
|
asDecreasing: begin
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMax + AStep) * scale) / scale;
|
||||||
|
while AStart < AMax do AStart := AStart + AStep;
|
||||||
|
end;
|
||||||
|
asLogIncreasing: begin
|
||||||
|
// FIXME: asLogIncreasing is still not implemented.
|
||||||
|
// The following is the same code for asIncreasing;
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMin - AStep) * scale) / scale;
|
||||||
|
while AStart > AMin do AStart := AStart - AStep;
|
||||||
|
end;
|
||||||
|
asLogDecreasing: begin
|
||||||
|
// FIXME: asLogDecreasing is still not implemented.
|
||||||
|
// The following is the same code for asIncreasing;
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMax + AStep) * scale) / scale;
|
||||||
|
while AStart < AMax do AStart := AStart + AStep;
|
||||||
|
end;
|
||||||
|
end; {case AxisScale}
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Integer); overload;
|
||||||
|
var
|
||||||
|
t: Integer;
|
||||||
|
begin
|
||||||
|
t := A;
|
||||||
|
A := B;
|
||||||
|
B := t;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Double); overload;
|
||||||
|
var
|
||||||
|
t: Double;
|
||||||
|
begin
|
||||||
|
t := A;
|
||||||
|
A := B;
|
||||||
|
B := t;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure RotateLabel(
|
||||||
|
Canvas: TCanvas; x, y: Integer; const St: String; RotDegree: Integer);
|
||||||
|
var
|
||||||
|
OldFont, NewFont: HFONT;
|
||||||
|
LogRec: TLOGFONT;
|
||||||
|
DC: HDC;
|
||||||
|
begin
|
||||||
|
with Canvas do begin
|
||||||
|
Brush.Style := bsClear;
|
||||||
|
GetObject(Font.Handle, SizeOf(LogRec), @LogRec);
|
||||||
|
LogRec.lfEscapement := RotDegree * 10;
|
||||||
|
LogRec.lfOrientation := 0;
|
||||||
|
LogRec.lfOutPrecision := OUT_TT_ONLY_PRECIS;
|
||||||
|
NewFont := CreateFontIndirect(LogRec);
|
||||||
|
DC := Handle;
|
||||||
|
end;
|
||||||
|
OldFont := SelectObject(DC, NewFont);
|
||||||
|
TextOut(DC, X, Y, @St[1], Length(St));
|
||||||
|
DeleteObject(SelectObject(DC, OldFont));
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TPenBrushFontRecall }
|
||||||
|
|
||||||
|
constructor TPenBrushFontRecall.Create(ACanvas: TCanvas; AParams: TPenBrushFont);
|
||||||
|
begin
|
||||||
|
inherited Create;
|
||||||
|
FCanvas := ACanvas;
|
||||||
|
if pbfPen in AParams then begin
|
||||||
|
FPen := TPen.Create;
|
||||||
|
FPen.Assign(FCanvas.Pen);
|
||||||
|
end;
|
||||||
|
if pbfBrush in AParams then begin
|
||||||
|
FBrush := TBrush.Create;
|
||||||
|
FBrush.Assign(FCanvas.Brush);
|
||||||
|
end;
|
||||||
|
if pbfFont in AParams then begin
|
||||||
|
FFont := TFont.Create;
|
||||||
|
FFont.Assign(FCanvas.Font);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
destructor TPenBrushFontRecall.Destroy;
|
||||||
|
begin
|
||||||
|
Recall;
|
||||||
|
inherited;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure TPenBrushFontRecall.Recall;
|
||||||
|
begin
|
||||||
|
if FPen <> nil then begin
|
||||||
|
FCanvas.Pen.Assign(FPen);
|
||||||
|
FreeAndNil(FPen);
|
||||||
|
end;
|
||||||
|
if FBrush <> nil then begin
|
||||||
|
FCanvas.Brush.Assign(FBrush);
|
||||||
|
FreeAndNil(FBrush);
|
||||||
|
end;
|
||||||
|
if FFont <> nil then begin
|
||||||
|
FCanvas.Font.Assign(FFont);
|
||||||
|
FreeAndNil(FFont);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
end.
|
||||||
|
{
|
||||||
|
/***************************************************************************
|
||||||
|
TAChartUtils.pas
|
||||||
|
----------------
|
||||||
|
Component Library Standard Graph Utiliity Functions
|
||||||
|
|
||||||
|
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
*****************************************************************************
|
||||||
|
* *
|
||||||
|
* See the file COPYING.modifiedLGPL.txt, included in this distribution, *
|
||||||
|
* for details about the copyright. *
|
||||||
|
* *
|
||||||
|
* 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. *
|
||||||
|
* *
|
||||||
|
*****************************************************************************
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
unit TAChartUtils;
|
||||||
|
|
||||||
|
{$IFDEF fpc}
|
||||||
|
{$MODE DELPHI}{$H+}
|
||||||
|
{$ENDIF}
|
||||||
|
|
||||||
|
interface
|
||||||
|
|
||||||
|
uses
|
||||||
|
Graphics;
|
||||||
|
|
||||||
|
const
|
||||||
|
MaxColor = 15;
|
||||||
|
Colors: array [1..MaxColor] of TColor = (
|
||||||
|
clRed, clGreen, clYellow, clBlue, clWhite, clGray, clFuchsia,
|
||||||
|
clTeal, clNavy, clMaroon, clLime, clOlive, clPurple, clSilver, clAqua);
|
||||||
|
|
||||||
|
type
|
||||||
|
TAxisScale = (asIncreasing, asDecreasing, asLogIncreasing, asLogDecreasing);
|
||||||
|
|
||||||
|
TPenBrushFont = set of (pbfPen, pbfBrush, pbfFont);
|
||||||
|
|
||||||
|
{ TPenBrushFontRecall }
|
||||||
|
|
||||||
|
TPenBrushFontRecall = class
|
||||||
|
private
|
||||||
|
FPen: TPen;
|
||||||
|
FBrush: TBrush;
|
||||||
|
FFont: TFont;
|
||||||
|
FCanvas: TCanvas;
|
||||||
|
public
|
||||||
|
constructor Create(ACanvas: TCanvas; AParams: TPenBrushFont);
|
||||||
|
destructor Destroy; override;
|
||||||
|
procedure Recall;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure CalculateIntervals(
|
||||||
|
AMin, AMax: Double; AxisScale: TAxisScale; out AStart, AStep: Double);
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Integer); overload;
|
||||||
|
procedure Exchange(var A, B: Double); overload;
|
||||||
|
|
||||||
|
procedure RotateLabel(
|
||||||
|
Canvas: TCanvas; x, y: Integer; const St: String; RotDegree: Integer);
|
||||||
|
|
||||||
|
implementation
|
||||||
|
|
||||||
|
uses
|
||||||
|
Math, SysUtils, LCLType, LCLIntF;
|
||||||
|
|
||||||
|
procedure CalculateIntervals(
|
||||||
|
AMin, AMax: Double; AxisScale: TAxisScale; out AStart, AStep: Double);
|
||||||
|
var
|
||||||
|
extent, extentTmp, stepCount, scale, maxStepCount, m: Double;
|
||||||
|
i: Integer;
|
||||||
|
const
|
||||||
|
GOOD_STEPS: array [1..3] of Double = (0.2, 0.5, 1.0);
|
||||||
|
begin
|
||||||
|
extent := AMax - AMin;
|
||||||
|
AStep := 1;
|
||||||
|
AStart := AMin;
|
||||||
|
if extent <= 0 then exit;
|
||||||
|
|
||||||
|
maxStepCount := 0;
|
||||||
|
scale := 1.0;
|
||||||
|
for i := Low(GOOD_STEPS) to High(GOOD_STEPS) do begin
|
||||||
|
extentTmp := extent / GOOD_STEPS[i];
|
||||||
|
m := power(10, Round(log10(extentTmp)));
|
||||||
|
while extentTmp * m > 10 do
|
||||||
|
m *= 0.1;
|
||||||
|
while extentTmp * m <= 1 do
|
||||||
|
m *= 10;
|
||||||
|
stepCount := extentTmp * m;
|
||||||
|
if stepCount > maxStepCount then begin
|
||||||
|
maxStepCount := stepCount;
|
||||||
|
scale := m;
|
||||||
|
AStep := GOOD_STEPS[i] / m;
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
case AxisScale of
|
||||||
|
asIncreasing: begin
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMin - AStep) * scale) / scale;
|
||||||
|
while AStart > AMin do AStart := AStart + AStep;
|
||||||
|
end;
|
||||||
|
asDecreasing: begin
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMax + AStep) * scale) / scale;
|
||||||
|
while AStart < AMax do AStart := AStart - AStep;
|
||||||
|
end;
|
||||||
|
asLogIncreasing: begin
|
||||||
|
// FIXME: asLogIncreasing is still not implemented.
|
||||||
|
// The following is the same code for asIncreasing;
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMin - AStep) * scale) / scale;
|
||||||
|
while AStart > AMin do AStart := AStart - AStep;
|
||||||
|
end;
|
||||||
|
asLogDecreasing: begin
|
||||||
|
// FIXME: asLogDecreasing is still not implemented.
|
||||||
|
// The following is the same code for asIncreasing;
|
||||||
|
// If 0 is in the interval, set it as a mark.
|
||||||
|
if InRange(0, AMin, AMax) then
|
||||||
|
AStart := 0
|
||||||
|
else
|
||||||
|
AStart := Round((AMax + AStep) * scale) / scale;
|
||||||
|
while AStart < AMax do AStart := AStart + AStep;
|
||||||
|
end;
|
||||||
|
end; {case AxisScale}
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Integer); overload;
|
||||||
|
var
|
||||||
|
t: Integer;
|
||||||
|
begin
|
||||||
|
t := A;
|
||||||
|
A := B;
|
||||||
|
B := t;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure Exchange(var A, B: Double); overload;
|
||||||
|
var
|
||||||
|
t: Double;
|
||||||
|
begin
|
||||||
|
t := A;
|
||||||
|
A := B;
|
||||||
|
B := t;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure RotateLabel(
|
||||||
|
Canvas: TCanvas; x, y: Integer; const St: String; RotDegree: Integer);
|
||||||
|
var
|
||||||
|
OldFont, NewFont: HFONT;
|
||||||
|
LogRec: TLOGFONT;
|
||||||
|
DC: HDC;
|
||||||
|
begin
|
||||||
|
with Canvas do begin
|
||||||
|
Brush.Style := bsClear;
|
||||||
|
GetObject(Font.Handle, SizeOf(LogRec), @LogRec);
|
||||||
|
LogRec.lfEscapement := RotDegree * 10;
|
||||||
|
LogRec.lfOrientation := 0;
|
||||||
|
LogRec.lfOutPrecision := OUT_TT_ONLY_PRECIS;
|
||||||
|
NewFont := CreateFontIndirect(LogRec);
|
||||||
|
DC := Handle;
|
||||||
|
end;
|
||||||
|
OldFont := SelectObject(DC, NewFont);
|
||||||
|
TextOut(DC, X, Y, @St[1], Length(St));
|
||||||
|
DeleteObject(SelectObject(DC, OldFont));
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TPenBrushFontRecall }
|
||||||
|
|
||||||
|
constructor TPenBrushFontRecall.Create(ACanvas: TCanvas; AParams: TPenBrushFont);
|
||||||
|
begin
|
||||||
|
inherited Create;
|
||||||
|
FCanvas := ACanvas;
|
||||||
|
if pbfPen in AParams then begin
|
||||||
|
FPen := TPen.Create;
|
||||||
|
FPen.Assign(FCanvas.Pen);
|
||||||
|
end;
|
||||||
|
if pbfBrush in AParams then begin
|
||||||
|
FBrush := TBrush.Create;
|
||||||
|
FBrush.Assign(FCanvas.Brush);
|
||||||
|
end;
|
||||||
|
if pbfFont in AParams then begin
|
||||||
|
FFont := TFont.Create;
|
||||||
|
FFont.Assign(FCanvas.Font);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
destructor TPenBrushFontRecall.Destroy;
|
||||||
|
begin
|
||||||
|
Recall;
|
||||||
|
inherited;
|
||||||
|
end;
|
||||||
|
|
||||||
|
procedure TPenBrushFontRecall.Recall;
|
||||||
|
begin
|
||||||
|
if FPen <> nil then begin
|
||||||
|
FCanvas.Pen.Assign(FPen);
|
||||||
|
FreeAndNil(FPen);
|
||||||
|
end;
|
||||||
|
if FBrush <> nil then begin
|
||||||
|
FCanvas.Brush.Assign(FBrush);
|
||||||
|
FreeAndNil(FBrush);
|
||||||
|
end;
|
||||||
|
if FFont <> nil then begin
|
||||||
|
FCanvas.Font.Assign(FFont);
|
||||||
|
FreeAndNil(FFont);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
end.
|
||||||
Loading…
Reference in New Issue
Block a user