lazarus/components/tachart/demo/func/main.pas
2010-10-17 07:50:02 +00:00

104 lines
2.4 KiB
ObjectPascal

unit main;
{$mode objfpc}{$H+}
interface
uses
Classes, ComCtrls, StdCtrls, Forms, Graphics, TAFuncSeries, TAGraph, TASeries,
TASources, TATools;
type
{ TForm1 }
TForm1 = class(TForm)
cbDomain: TCheckBox;
Chart1: TChart;
Chart1BarSeries1: TBarSeries;
Chart1FuncSeries1: TFuncSeries;
Chart1UserDrawnSeries1: TUserDrawnSeries;
Chart1XAxis: TConstantLine;
Chart1YAxis: TConstantLine;
ChartColorMap: TChart;
ChartColorMapColorMapSeries1: TColorMapSeries;
ChartToolset1: TChartToolset;
ChartToolset1PanDragTool1: TPanDragTool;
ChartToolset1ZoomDragTool1: TZoomDragTool;
ListChartSource1: TListChartSource;
PageControl1: TPageControl;
tsDomain: TTabSheet;
tsColorMap: TTabSheet;
UserDefinedChartSource1: TUserDefinedChartSource;
procedure cbDomainChange(Sender: TObject);
procedure Chart1FuncSeries1Calculate(const AX: Double; out AY: Double);
procedure Chart1UserDrawnSeries1Draw(ACanvas: TCanvas; const ARect: TRect);
procedure ChartColorMapColorMapSeries1Calculate(const AX, AY: Double; out
AZ: Double);
procedure UserDefinedChartSource1GetChartDataItem(
ASource: TUserDefinedChartSource; AIndex: Integer;
var AItem: TChartDataItem);
end;
var
Form1: TForm1;
implementation
uses
TAChartUtils;
{$R *.lfm}
{ TForm1 }
procedure TForm1.cbDomainChange(Sender: TObject);
var
i: Integer;
begin
with Chart1FuncSeries1.DomainExclusions do begin
Clear;
Epsilon := 1e-7;
if cbDomain.Checked then
for i := -10 to 10 do
AddPoint(i * Pi);
end;
end;
procedure TForm1.Chart1FuncSeries1Calculate(const AX: Double; out AY: Double);
begin
AY := 1 / Sin(AX);
end;
procedure TForm1.Chart1UserDrawnSeries1Draw(
ACanvas: TCanvas; const ARect: TRect);
var
a: TDoublePoint = (X: -1; Y: -1);
b: TDoublePoint = (X: 1; Y: 1);
r: TRect;
begin
r.TopLeft := Chart1.GraphToImage(a);
r.BottomRight := Chart1.GraphToImage(b);
ACanvas.Pen.Mode := pmCopy;
ACanvas.Pen.Color := clRed;
ACanvas.Pen.Style := psDash;
ACanvas.Brush.Style := bsClear;
ACanvas.Ellipse(r);
end;
procedure TForm1.ChartColorMapColorMapSeries1Calculate(
const AX, AY: Double; out AZ: Double);
begin
AZ := Sin(10 * Sqr(AX) + 17 * Sqr(AY));
end;
procedure TForm1.UserDefinedChartSource1GetChartDataItem(
ASource: TUserDefinedChartSource; AIndex: Integer; var AItem: TChartDataItem);
begin
AItem.X := AIndex - ASource.PointsNumber / 2;
AItem.Y := Cos(AItem.X);
end;
end.