Commit 868b11a8 authored by Igor.Zotov's avatar Igor.Zotov Committed by Alexander.Trofimov

орисовка линейной диаграммы по разрывному диапазону

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@55613 954022d7-b5bf-4e40-9824-e11837661b57
parent 9377757b
...@@ -3061,6 +3061,8 @@ CChartsDrawer.prototype = ...@@ -3061,6 +3061,8 @@ CChartsDrawer.prototype =
/* /*
var SYMBOL_PICTURE = 5;*/ var SYMBOL_PICTURE = 5;*/
path.moveTo(x * pathW, y * pathW);
switch ( symbol ) switch ( symbol )
{ {
case SYMBOL_DASH: case SYMBOL_DASH:
...@@ -4066,123 +4068,100 @@ drawLineChart.prototype = ...@@ -4066,123 +4068,100 @@ drawLineChart.prototype =
//соответствует подписям оси значений(OY) //соответствует подписям оси значений(OY)
var yPoints = this.cChartSpace.chart.plotArea.valAx.yPoints; var yPoints = this.cChartSpace.chart.plotArea.valAx.yPoints;
var isSplineLine = false; var points;
var y, y1, y2, y3, x, x1, x2, x3, val, nextVal, tempVal, seria, dataSeries, compiledMarkerSize, compiledMarkerSymbol; var y, y1, y2, y3, x, x1, x2, x3, val, nextVal, tempVal, seria, dataSeries, compiledMarkerSize, compiledMarkerSymbol, idx, numCache;
for (var i = 0; i < this.chartProp.series.length; i++) { for (var i = 0; i < this.chartProp.series.length; i++) {
seria = this.chartProp.series[i]; seria = this.chartProp.series[i];
isSplineLine = seria.smooth; numCache = seria.val.numRef ? seria.val.numRef.numCache : seria.val.numLit;
dataSeries = numCache.pts;
dataSeries = seria.val.numRef ? seria.val.numRef.numCache.pts : seria.val.numLit.pts;
if(dataSeries.length == 1) for(var n = 0; n < numCache.ptCount; n++)
{ {
var n = 0; idx = dataSeries[n] && dataSeries[n].idx != null ? dataSeries[n].idx : n;
//рассчитываем значения //рассчитываем значения
val = this._getYVal(n, i); val = this._getYVal(n, i);
if(this.cChartSpace.chart.plotArea.valAx && this.cChartSpace.chart.plotArea.valAx.scaling.logBase)
val = this.cChartDrawer.getLogarithmicValue(val, this.cChartSpace.chart.plotArea.valAx.scaling.logBase, yPoints);
y = this.cChartDrawer.getYPosition(val, yPoints);
x = xPoints[n].pos; x = xPoints[n].pos;
y = this.cChartDrawer.getYPosition(val, yPoints);
if(!this.paths.points) if(!this.paths.points)
this.paths.points = []; this.paths.points = [];
if(!this.paths.points[i]) if(!this.paths.points[i])
this.paths.points[i] = []; this.paths.points[i] = [];
compiledMarkerSize = dataSeries[n].compiledMarker && dataSeries[n].compiledMarker.size ? dataSeries[n].compiledMarker.size : null; if(!points)
compiledMarkerSymbol = dataSeries[n].compiledMarker && dataSeries[n].compiledMarker.symbol ? dataSeries[n].compiledMarker.symbol : null; points = [];
if(!points[i])
points[i] = [];
compiledMarkerSize = dataSeries[n] && dataSeries[n].compiledMarker && dataSeries[n].compiledMarker.size ? dataSeries[n].compiledMarker.size : null;
compiledMarkerSymbol = dataSeries[n] && dataSeries[n].compiledMarker && dataSeries[n].compiledMarker.symbol ? dataSeries[n].compiledMarker.symbol : null;
if(val != null)
{
this.paths.points[i][n] = this.cChartDrawer.calculatePoint(x, y, compiledMarkerSize, compiledMarkerSymbol); this.paths.points[i][n] = this.cChartDrawer.calculatePoint(x, y, compiledMarkerSize, compiledMarkerSymbol);
points[i][n] = {x: x, y: y};
} }
else else
{ {
for(var n = 0; n < dataSeries.length - 1; n++) this.paths.points[i][n] = null;
points[i][n] = null;
}
}
};
this._calculateAllLines(points);
},
_calculateAllLines: function(points)
{ {
//рассчитываем значения var startPoint, endPoint;
val = this._getYVal(n, i); //соответствует подписям оси категорий(OX)
if(this.cChartSpace.chart.plotArea.valAx && this.cChartSpace.chart.plotArea.valAx.scaling.logBase) var xPoints = this.cChartSpace.chart.plotArea.catAx.xPoints;
val = this.cChartDrawer.getLogarithmicValue(val, this.cChartSpace.chart.plotArea.valAx.scaling.logBase, yPoints); //соответствует подписям оси значений(OY)
var yPoints = this.cChartSpace.chart.plotArea.valAx.yPoints;
nextVal = this._getYVal(n + 1, i); var x, y, x1, y1, x2, y2, x3, y3, isSplineLine;
if(this.cChartSpace.chart.plotArea.valAx && this.cChartSpace.chart.plotArea.valAx.scaling.logBase)
nextVal = this.cChartDrawer.getLogarithmicValue(nextVal, this.cChartSpace.chart.plotArea.valAx.scaling.logBase, yPoints);
//точки находятся внутри диапазона for(var i = 0; i < points.length; i++)
{
isSplineLine = this.chartProp.series[i].smooth;
for(var n = 0; n < points[i].length; n++)
{
if(!this.paths.series) if(!this.paths.series)
this.paths.series = []; this.paths.series = [];
if(!this.paths.series[i]) if(!this.paths.series[i])
this.paths.series[i] = []; this.paths.series[i] = [];
if(points[i][n] != null && points[i][n + 1] != null)
{
if(isSplineLine) if(isSplineLine)
{ {
x = n - 1 >= 0 ? n - 1 : 0; x = points[i][n - 1] ? n - 1 : 0;
y = this._getYVal(x, i); y = this._getYVal(x, i);
x1 = n; x1 = n;
y1 = val; y1 = this._getYVal(x1, i);
x2 = n + 1 <= dataSeries.length - 1 ? n + 1 : dataSeries.length - 1; x2 = points[i][n + 1] ? n + 1 : n;
y2 = this._getYVal(x2, i); y2 = this._getYVal(x2, i);
x3 = n + 2 <= dataSeries.length - 1 ? n + 2 : dataSeries.length - 1; x3 = points[i][n + 2] ? n + 2 : points[i][n + 1] ? n + 1 : n;
y3 = this._getYVal(x3, i); y3 = this._getYVal(x3, i);
this.paths.series[i][n] = this._calculateSplineLine(x, y, x1, y1, x2, y2, x3, y3, xPoints, yPoints); this.paths.series[i][n] = this._calculateSplineLine(x, y, x1, y1, x2, y2, x3, y3, xPoints, yPoints);
y = this.cChartDrawer.getYPosition(val, yPoints);
y1 = this.cChartDrawer.getYPosition(nextVal, yPoints);
x = xPoints[n].pos;
x1 = xPoints[n + 1].pos;
} }
else else
{ this.paths.series[i][n] = this._calculateLine(points[i][n].x, points[i][n].y, points[i][n + 1].x, points[i][n + 1].y);
y = this.cChartDrawer.getYPosition(val, yPoints);
y1 = this.cChartDrawer.getYPosition(nextVal, yPoints);
x = xPoints[n].pos;
x1 = xPoints[n + 1].pos;
if(!this.paths.series)
this.paths.series = [];
if(!this.paths.series[i])
this.paths.series[i] = []
this.paths.series[i][n] = this._calculateLine(x, y, x1, y1);
}
if(!this.paths.points)
this.paths.points = [];
if(!this.paths.points[i])
this.paths.points[i] = [];
if(n == 0)
{
compiledMarkerSize = dataSeries[n].compiledMarker && dataSeries[n].compiledMarker.size ? dataSeries[n].compiledMarker.size : null;
compiledMarkerSymbol = dataSeries[n].compiledMarker && dataSeries[n].compiledMarker.symbol ? dataSeries[n].compiledMarker.symbol : null;
this.paths.points[i][n] = this.cChartDrawer.calculatePoint(x, y, compiledMarkerSize, compiledMarkerSymbol);
compiledMarkerSize = dataSeries[n + 1].compiledMarker && dataSeries[n + 1].compiledMarker.size ? dataSeries[n + 1].compiledMarker.size : null;
compiledMarkerSymbol = dataSeries[n + 1].compiledMarker && dataSeries[n + 1].compiledMarker.symbol ? dataSeries[n + 1].compiledMarker.symbol : null;
this.paths.points[i][n + 1] = this.cChartDrawer.calculatePoint(x1, y1, compiledMarkerSize, compiledMarkerSymbol);
}
else
{
compiledMarkerSize = dataSeries[n + 1].compiledMarker && dataSeries[n + 1].compiledMarker.size ? dataSeries[n + 1].compiledMarker.size : null;
compiledMarkerSymbol = dataSeries[n + 1].compiledMarker && dataSeries[n + 1].compiledMarker.symbol ? dataSeries[n + 1].compiledMarker.symbol : null;
this.paths.points[i][n + 1] = this.cChartDrawer.calculatePoint(x1, y1, compiledMarkerSize, compiledMarkerSymbol);
}
}
} }
} }
};
}, },
_getYPosition: function(val, yPoints) _getYPosition: function(val, yPoints)
...@@ -4226,32 +4205,16 @@ drawLineChart.prototype = ...@@ -4226,32 +4205,16 @@ drawLineChart.prototype =
_calculateDLbl: function(chartSpace, ser, val) _calculateDLbl: function(chartSpace, ser, val)
{ {
var numCache = this.chartProp.series[ser].val.numRef ? this.chartProp.series[ser].val.numRef.numCache : this.chartProp.series[ser].val.numLit; var numCache = this.chartProp.series[ser].val.numRef ? this.chartProp.series[ser].val.numRef.numCache : this.chartProp.series[ser].val.numLit;
var point = numCache.pts[val]; var point = this.cChartDrawer.getIdxPoint(this.chartProp.series[ser], val);
var path; var path;
var isSplineLine = false;
if(this.paths.series)
{
if(val == numCache.pts.length - 1)
path = this.paths.series[ser][val - 1].ArrPathCommand[1];
else
path = this.paths.series[ser][val].ArrPathCommand[0];
}
else if(this.paths.points)
{
path = this.paths.points[ser][val].path.ArrPathCommand[0]; path = this.paths.points[ser][val].path.ArrPathCommand[0];
}
if(!path) if(!path)
return; return;
var x = path.X; var x = path.X;
var y = path.Y; var y = path.Y;
if(val == numCache.pts.length - 1 && isSplineLine == true)
{
x = path.X2;
y = path.Y2;
}
var pxToMm = this.chartProp.pxToMM; var pxToMm = this.chartProp.pxToMM;
var constMargin = 5 / pxToMm; var constMargin = 5 / pxToMm;
...@@ -4313,18 +4276,18 @@ drawLineChart.prototype = ...@@ -4313,18 +4276,18 @@ drawLineChart.prototype =
this.cShapeDrawer.Graphics.SaveGrState(); this.cShapeDrawer.Graphics.SaveGrState();
this.cShapeDrawer.Graphics.AddClipRect(this.chartProp.chartGutter._left / this.chartProp.pxToMM, this.chartProp.chartGutter._top / this.chartProp.pxToMM, this.chartProp.trueWidth / this.chartProp.pxToMM, this.chartProp.trueHeight / this.chartProp.pxToMM); this.cShapeDrawer.Graphics.AddClipRect(this.chartProp.chartGutter._left / this.chartProp.pxToMM, this.chartProp.chartGutter._top / this.chartProp.pxToMM, this.chartProp.trueWidth / this.chartProp.pxToMM, this.chartProp.trueHeight / this.chartProp.pxToMM);
for (var i = 0; i < this.chartProp.series.length; i++) { for (var i = 0; i < this.paths.series.length; i++) {
seria = this.chartProp.series[i]; seria = this.chartProp.series[i];
brush = seria.brush; brush = seria.brush;
pen = seria.pen; pen = seria.pen;
numCache = seria.val.numRef ? seria.val.numRef.numCache : seria.val.numLit; numCache = seria.val.numRef ? seria.val.numRef.numCache : seria.val.numLit;
dataSeries = numCache.pts; dataSeries = this.paths.series[i];
for(var n = 0; n < dataSeries.length - 1; n++) for(var n = 0; n < dataSeries.length; n++)
{ {
if(numCache.pts[n].pen) if(numCache.pts[n] && numCache.pts[n].pen)
pen = numCache.pts[n].pen; pen = numCache.pts[n].pen;
if(numCache.pts[n].brush) if(numCache.pts[n] && numCache.pts[n].brush)
brush = numCache.pts[n].brush; brush = numCache.pts[n].brush;
this.cChartDrawer.drawPath(this.paths.series[i][n], pen, brush); this.cChartDrawer.drawPath(this.paths.series[i][n], pen, brush);
...@@ -4332,14 +4295,18 @@ drawLineChart.prototype = ...@@ -4332,14 +4295,18 @@ drawLineChart.prototype =
//draw point //draw point
for(var k = 0; k < this.paths.points[i].length; k++) for(var k = 0; k < this.paths.points[i].length; k++)
{
if(numCache.pts[k])
{ {
markerBrush = numCache.pts[k].compiledMarker ? numCache.pts[k].compiledMarker.brush : null; markerBrush = numCache.pts[k].compiledMarker ? numCache.pts[k].compiledMarker.brush : null;
markerPen = numCache.pts[k].compiledMarker ? numCache.pts[k].compiledMarker.pen : null; markerPen = numCache.pts[k].compiledMarker ? numCache.pts[k].compiledMarker.pen : null;
};
//frame of point //frame of point
if(this.paths.points[i][0].framePaths) if(this.paths.points[i][0] && this.paths.points[i][0].framePaths)
this.cChartDrawer.drawPath(this.paths.points[i][k].framePaths, markerPen, markerBrush, false); this.cChartDrawer.drawPath(this.paths.points[i][k].framePaths, markerPen, markerBrush, false);
//point //point
if(this.paths.points[i][k])
this.cChartDrawer.drawPath(this.paths.points[i][k].path, markerPen, markerBrush, true); this.cChartDrawer.drawPath(this.paths.points[i][k].path, markerPen, markerBrush, true);
} }
} }
...@@ -4351,12 +4318,15 @@ drawLineChart.prototype = ...@@ -4351,12 +4318,15 @@ drawLineChart.prototype =
var tempVal; var tempVal;
var val = 0; var val = 0;
var numCache; var numCache;
var idxPoint;
if(this.chartProp.subType == "stacked") if(this.chartProp.subType == "stacked")
{ {
for(var k = 0; k <= i; k++) for(var k = 0; k <= i; k++)
{ {
numCache = this.chartProp.series[k].val.numRef ? this.chartProp.series[k].val.numRef.numCache : this.chartProp.series[k].val.numLit; numCache = this.chartProp.series[k].val.numRef ? this.chartProp.series[k].val.numRef.numCache : this.chartProp.series[k].val.numLit;
tempVal = parseFloat(numCache.pts[n].val); idxPoint = this.cChartDrawer.getIdxPoint(this.chartProp.series[k], n);
tempVal = idxPoint ? parseFloat(idxPoint.val) : 0;
if(tempVal) if(tempVal)
val += tempVal; val += tempVal;
} }
...@@ -4367,7 +4337,8 @@ drawLineChart.prototype = ...@@ -4367,7 +4337,8 @@ drawLineChart.prototype =
for(var k = 0; k < this.chartProp.series.length; k++) for(var k = 0; k < this.chartProp.series.length; k++)
{ {
numCache = this.chartProp.series[k].val.numRef ? this.chartProp.series[k].val.numRef.numCache : this.chartProp.series[k].val.numLit; numCache = this.chartProp.series[k].val.numRef ? this.chartProp.series[k].val.numRef.numCache : this.chartProp.series[k].val.numLit;
tempVal = parseFloat(numCache.pts[n].val); idxPoint = this.cChartDrawer.getIdxPoint(this.chartProp.series[k], n);
tempVal = idxPoint ? parseFloat(idxPoint.val) : 0;
if(tempVal) if(tempVal)
{ {
if(k <= i) if(k <= i)
...@@ -4380,7 +4351,8 @@ drawLineChart.prototype = ...@@ -4380,7 +4351,8 @@ drawLineChart.prototype =
else else
{ {
numCache = this.chartProp.series[i].val.numRef ? this.chartProp.series[i].val.numRef.numCache : this.chartProp.series[i].val.numLit; numCache = this.chartProp.series[i].val.numRef ? this.chartProp.series[i].val.numRef.numCache : this.chartProp.series[i].val.numLit;
val = parseFloat(numCache.pts[n].val); idxPoint = this.cChartDrawer.getIdxPoint(this.chartProp.series[i], n);
val = idxPoint ? parseFloat(idxPoint.val) : null;
} }
return val; return val;
}, },
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment