grid_cartesian.dart
3.5 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/*
* Copyright (C) 2017, David PHAM-VAN <dev.nfet.net@gmail.com>
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// ignore_for_file: omit_local_variable_types
part of widget;
class CartesianGrid extends ChartGrid {
CartesianGrid({
@required GridAxis xAxis,
@required GridAxis yAxis,
}) : _xAxis = xAxis..direction = Axis.horizontal,
_yAxis = yAxis..direction = Axis.vertical;
final GridAxis _xAxis;
final GridAxis _yAxis;
PdfRect gridBox;
@override
void layout(Context context, BoxConstraints constraints,
{bool parentUsesSize = false}) {
assert(Chart.of(context) != null,
'$runtimeType cannot be used without a Chart widget');
super.layout(context, constraints, parentUsesSize: parentUsesSize);
final List<Dataset> datasets = Chart.of(context).datasets;
final PdfPoint size = constraints.biggest;
// In simple conditions, this loop will run only 2 times.
int count = 5;
while (count-- > 0) {
_xAxis._crossAxisPosition = _yAxis.axisPosition;
_xAxis.axisPosition =
math.max(_xAxis.axisPosition, _yAxis._crossAxisPosition);
_xAxis.layout(context, constraints);
assert(_xAxis.box != null);
_yAxis._crossAxisPosition = _xAxis.axisPosition;
_yAxis.axisPosition =
math.max(_yAxis.axisPosition, _xAxis._crossAxisPosition);
_yAxis.layout(context, constraints);
assert(_yAxis.box != null);
if (_yAxis._crossAxisPosition == _xAxis.axisPosition &&
_xAxis._crossAxisPosition == _yAxis.axisPosition) {
break;
}
}
final double width = _yAxis.axisPosition;
final double height = _xAxis.axisPosition;
gridBox = PdfRect(width, height, size.x - width, size.y - height);
for (final Dataset dataset in datasets) {
dataset.layout(context, BoxConstraints.tight(gridBox.size));
dataset.box =
PdfRect.fromPoints(PdfPoint(width, height), dataset.box.size);
}
}
@override
PdfPoint toChart(PdfPoint p) {
return PdfPoint(
_xAxis.toChart(p.x),
_yAxis.toChart(p.y),
);
}
double get xAxisOffset => _xAxis.axisPosition;
double get yAxisOffset => _yAxis.axisPosition;
void paintBackground(Context context) {
_xAxis.paintBackground(context);
_yAxis.paintBackground(context);
}
void clip(Context context, PdfPoint size) {
context.canvas
..saveContext()
..drawRect(
gridBox.left,
gridBox.bottom,
gridBox.width,
gridBox.height,
)
..clipPath();
}
@override
void paint(Context context) {
super.paint(context);
final List<Dataset> datasets = Chart.of(context).datasets;
clip(context, box.size);
for (Dataset dataSet in datasets) {
dataSet.paintBackground(context);
}
context.canvas.restoreContext();
paintBackground(context);
clip(context, box.size);
for (Dataset dataSet in datasets) {
dataSet.paint(context);
}
context.canvas.restoreContext();
_xAxis.paint(context);
_yAxis.paint(context);
}
}