Commit 4162cd86 authored by GoshaZotov's avatar GoshaZotov

add changes from SVN branch

parent e654f092
/* /*
* *
* (c) Copyright Ascensio System Limited 2010-2016 * (c) Copyright Ascensio System Limited 2010-2016
* *
* This program is freeware. You can redistribute it and/or modify it under the terms of the GNU * This program is freeware. You can redistribute it and/or modify it under the terms of the GNU
* General Public License (GPL) version 3 as published by the Free Software Foundation (https://www.gnu.org/copyleft/gpl.html). * General Public License (GPL) version 3 as published by the Free Software Foundation (https://www.gnu.org/copyleft/gpl.html).
* In accordance with Section 7(a) of the GNU GPL its Section 15 shall be amended to the effect that * In accordance with Section 7(a) of the GNU GPL its Section 15 shall be amended to the effect that
* Ascensio System SIA expressly excludes the warranty of non-infringement of any third-party rights. * Ascensio System SIA expressly excludes the warranty of non-infringement of any third-party rights.
* *
* THIS PROGRAM IS DISTRIBUTED WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR * THIS PROGRAM IS DISTRIBUTED WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR
* FITNESS FOR A PARTICULAR PURPOSE. For more details, see GNU GPL at https://www.gnu.org/copyleft/gpl.html * FITNESS FOR A PARTICULAR PURPOSE. For more details, see GNU GPL at https://www.gnu.org/copyleft/gpl.html
* *
* You can contact Ascensio System SIA by email at sales@onlyoffice.com * You can contact Ascensio System SIA by email at sales@onlyoffice.com
* *
* The interactive user interfaces in modified source and object code versions of ONLYOFFICE must display * The interactive user interfaces in modified source and object code versions of ONLYOFFICE must display
* Appropriate Legal Notices, as required under Section 5 of the GNU GPL version 3. * Appropriate Legal Notices, as required under Section 5 of the GNU GPL version 3.
* *
* Pursuant to Section 7  3(b) of the GNU GPL you must retain the original ONLYOFFICE logo which contains * Pursuant to Section 7  3(b) of the GNU GPL you must retain the original ONLYOFFICE logo which contains
* relevant author attributions when distributing the software. If the display of the logo in its graphic * relevant author attributions when distributing the software. If the display of the logo in its graphic
* form is not reasonably feasible for technical reasons, you must include the words "Powered by ONLYOFFICE" * form is not reasonably feasible for technical reasons, you must include the words "Powered by ONLYOFFICE"
* in every copy of the program you distribute. * in every copy of the program you distribute.
* Pursuant to Section 7  3(e) we decline to grant you any rights under trademark law for use of our trademarks. * Pursuant to Section 7  3(e) we decline to grant you any rights under trademark law for use of our trademarks.
* *
*/ */
/** @constructor */ /** @constructor */
function Processor3D(width, height, left, right, bottom, top, chartSpace, chartsDrawer) { function Processor3D(width, height, left, right, bottom, top, chartSpace, chartsDrawer) {
this.widthCanvas = width; this.widthCanvas = width;
...@@ -76,7 +76,7 @@ Processor3D.prototype.calaculate3DProperties = function(baseDepth, gapDepth, isT ...@@ -76,7 +76,7 @@ Processor3D.prototype.calaculate3DProperties = function(baseDepth, gapDepth, isT
//this._calcSpecialStandardScaleX(); //this._calcSpecialStandardScaleX();
//глубина //глубина
this.depthPerspective = this.view3D.rAngAx ? this._calculateDepth() : this._calculateDepthPerspective();; this.depthPerspective = this.view3D.rAngAx ? this._calculateDepth() : this._calculateDepthPerspective();
//угол перспективы //угол перспективы
this._calculatePerspective(this.view3D); this._calculatePerspective(this.view3D);
...@@ -116,18 +116,21 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function() ...@@ -116,18 +116,21 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function()
{ {
var widthLine = this.widthCanvas - (this.left + this.right); var widthLine = this.widthCanvas - (this.left + this.right);
var heightLine = this.heightCanvas - (this.top + this.bottom); var heightLine = this.heightCanvas - (this.top + this.bottom);
var widthCanvas = this.widthCanvas;
//todo оптимальную ширину нужно пересмотреть
//оптимальная ширина - ширина при которой не происходит масштабирования по ширине
var optimalWidth = heightLine * 10;
var subType = this.chartsDrawer.calcProp.subType; var subType = this.chartsDrawer.calcProp.subType;
var isStandardType = subType === "standard" || this.chartsDrawer.calcProp.type === "Line" || this.chartsDrawer.calcProp.type === "Area" && subType === "normal" ? true : false; var isStandardType = !!(subType === "standard" || this.chartsDrawer.calcProp.type === "Line" || this.chartsDrawer.calcProp.type === "Area" && subType === "normal");
if(!isStandardType)
var optimalWidthLine, kF;
if(!isStandardType)
{ {
var optimalWidth = heightLine * 10;
var widthCanvas = this.widthCanvas;
this.widthCanvas = optimalWidth + (this.left + this.right); this.widthCanvas = optimalWidth + (this.left + this.right);
this._calculateScaleNStandard(); this._calculateScaleNStandard();
var optimalWidthLine = this.depthPerspective * Math.sin(-this.angleOy) + ((this.widthCanvas - (this.left + this.right)) / this.aspectRatioX) / this.scaleX; optimalWidthLine = this.depthPerspective * Math.sin(-this.angleOy) + ((this.widthCanvas - (this.left + this.right)) / this.aspectRatioX) / this.scaleX;
var kF = optimalWidthLine / widthLine; kF = optimalWidthLine / widthLine;
if(optimalWidthLine < widthLine) if(optimalWidthLine < widthLine)
{ {
...@@ -152,17 +155,12 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function() ...@@ -152,17 +155,12 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function()
{ {
if(this.depthPerspective * Math.sin(-this.angleOy) + ((this.widthCanvas - (this.left + this.right)) / this.aspectRatioX) / this.scaleX <= widthLine) if(this.depthPerspective * Math.sin(-this.angleOy) + ((this.widthCanvas - (this.left + this.right)) / this.aspectRatioX) / this.scaleX <= widthLine)
return; return;
//todo оптимальную ширину нужно пересмотреть
//оптимальная ширина - ширина при которой не происходит масштабирования по ширине
var optimalWidth = heightLine * 10;
var widthCanvas = this.widthCanvas;
//рассчитываем параметры диаграммы при оптимальной ширине //рассчитываем параметры диаграммы при оптимальной ширине
this.widthCanvas = optimalWidth + (this.left + this.right); this.widthCanvas = optimalWidth + (this.left + this.right);
this.calaculate3DProperties(null, null, true); this.calaculate3DProperties(null, null, true);
var optimalWidthLine = this.depthPerspective * Math.sin(-this.angleOy) + ((this.widthCanvas - (this.left + this.right)) / this.aspectRatioX) / this.scaleX; optimalWidthLine = this.depthPerspective * Math.sin(-this.angleOy) + ((this.widthCanvas - (this.left + this.right)) / this.aspectRatioX) / this.scaleX;
var kF = optimalWidthLine / widthLine; kF = optimalWidthLine / widthLine;
this.aspectRatioX = widthLine / ((optimalWidthLine - this.depthPerspective*Math.sin(-this.angleOy))/kF); this.aspectRatioX = widthLine / ((optimalWidthLine - this.depthPerspective*Math.sin(-this.angleOy))/kF);
this.scaleY = this.scaleY * kF; this.scaleY = this.scaleY * kF;
...@@ -174,11 +172,6 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function() ...@@ -174,11 +172,6 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function()
} }
else else
{ {
//todo оптимальную ширину нужно пересмотреть
//оптимальная ширина - ширина при которой не происходит масштабирования по ширине
var optimalWidth = heightLine * 10;
var widthCanvas = this.widthCanvas;
//рассчитываем параметры диаграммы при оптимальной ширине //рассчитываем параметры диаграммы при оптимальной ширине
this.widthCanvas = optimalWidth + (this.left + this.right); this.widthCanvas = optimalWidth + (this.left + this.right);
var scaleX = this.scaleX; var scaleX = this.scaleX;
...@@ -190,7 +183,7 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function() ...@@ -190,7 +183,7 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function()
var aspectRatioZ = this.aspectRatioZ; var aspectRatioZ = this.aspectRatioZ;
this.calaculate3DProperties(null, null, true); this.calaculate3DProperties(null, null, true);
var optimalWidthLine = this.depthPerspective * Math.sin(-this.angleOy) + ((this.widthCanvas - (this.left + this.right)) / this.aspectRatioX) / this.scaleX; optimalWidthLine = this.depthPerspective * Math.sin(-this.angleOy) + ((this.widthCanvas - (this.left + this.right)) / this.aspectRatioX) / this.scaleX;
if(optimalWidthLine < widthLine) if(optimalWidthLine < widthLine)
...@@ -208,7 +201,7 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function() ...@@ -208,7 +201,7 @@ Processor3D.prototype._recalculateScaleWithMaxWidth = function()
} }
var kF = optimalWidthLine / widthLine; kF = optimalWidthLine / widthLine;
this.aspectRatioX = widthLine / ((optimalWidthLine - this.depthPerspective*Math.sin(-this.angleOy))/kF); this.aspectRatioX = widthLine / ((optimalWidthLine - this.depthPerspective*Math.sin(-this.angleOy))/kF);
this.scaleY = this.scaleY * kF; this.scaleY = this.scaleY * kF;
this.scaleZ = this.scaleZ * kF; this.scaleZ = this.scaleZ * kF;
...@@ -314,12 +307,29 @@ Processor3D.prototype.calculateZPositionCatAxis = function() ...@@ -314,12 +307,29 @@ Processor3D.prototype.calculateZPositionCatAxis = function()
return result; return result;
}; };
//***functions for complete transformation point***
Processor3D.prototype.convertAndTurnPoint = function(x, y, z, cameraDiffZ) Processor3D.prototype.convertAndTurnPoint = function(x, y, z, cameraDiffZ)
{
var res = null;
if(this.view3D.rAngAx)
{
res = this.convertAndTurnPointRAngAx(x, y, z, cameraDiffZ);
}
else
{
res = this.convertAndTurnPointPerspective(x, y, z, cameraDiffZ);
}
return res;
};
Processor3D.prototype.convertAndTurnPointRAngAx = function(x, y, z)
{ {
var heightChart = this.heightCanvas - this.top - this.bottom; var heightChart = this.heightCanvas - this.top - this.bottom;
var widthOriginalChart = this.widthCanvas - this.left - this.right; var widthOriginalChart = this.widthCanvas - this.left - this.right;
var heightOriginalChart = heightChart;
var widthChart = heightChart;
//aspectRatio //aspectRatio
if(this.view3D.rAngAx) if(this.view3D.rAngAx)
...@@ -329,7 +339,7 @@ Processor3D.prototype.convertAndTurnPoint = function(x, y, z, cameraDiffZ) ...@@ -329,7 +339,7 @@ Processor3D.prototype.convertAndTurnPoint = function(x, y, z, cameraDiffZ)
} }
else else
{ {
var aspectRatio = (widthOriginalChart) / (heightOriginalChart); var aspectRatio = (widthOriginalChart) / (heightChart);
x = x / aspectRatio; x = x / aspectRatio;
} }
...@@ -341,7 +351,7 @@ Processor3D.prototype.convertAndTurnPoint = function(x, y, z, cameraDiffZ) ...@@ -341,7 +351,7 @@ Processor3D.prototype.convertAndTurnPoint = function(x, y, z, cameraDiffZ)
var point3D = new Point3D(x, y, z, this); var point3D = new Point3D(x, y, z, this);
//diff //diff
var centerXDiff = widthChart / 2 + this.left / 2; var centerXDiff = heightChart / 2 + this.left / 2;
var centerYDiff = heightChart / 2 + this.top; var centerYDiff = heightChart / 2 + this.top;
var centerZDiff = this.depthPerspective / 2; var centerZDiff = this.depthPerspective / 2;
...@@ -375,12 +385,132 @@ Processor3D.prototype.convertAndTurnPoint = function(x, y, z, cameraDiffZ) ...@@ -375,12 +385,132 @@ Processor3D.prototype.convertAndTurnPoint = function(x, y, z, cameraDiffZ)
return {x: projectionPoint.x, y: projectionPoint.y}; return {x: projectionPoint.x, y: projectionPoint.y};
}; };
Processor3D.prototype.convertAndTurnPointPerspective = function(x, y, z)
{
//aspectRatio
x = x / this.aspectRatioX;
y = y / this.aspectRatioY;
x = x / this.scaleX;
y = y / this.scaleY;
z = z / this.scaleZ;
var point3D = new Point3D(x, y, z, this);
//diff
var centerZDiff = this.depthPerspective / 2;
point3D.offset((-this.widthCanvas / 2) / this.aspectRatioX, (-this.heightCanvas / 2) / this.aspectRatioY /** aspectRatio*/, 0);
//rotate
var matrixRotateAllAxis;
if(!this.view3D.rAngAx)
matrixRotateAllAxis = this._getMatrixRotateAllAxis();
else
matrixRotateAllAxis = this._shearXY();
point3D.multiplyPointOnMatrix1(matrixRotateAllAxis);
// diff camera for charts write into rect
point3D.offset(this.cameraDiffX, this.cameraDiffY, this.cameraDiffZ);
//project
var projectionPoint = point3D;
if(!this.view3D.rAngAx)
{
var projectiveMatrix = this._getPerspectiveProjectionMatrix(1 / (this.rPerspective));
projectionPoint = point3D.project(projectiveMatrix);
}
//undiff
var specialReverseDiffX = this.widthCanvas / 2 + (this.left - this.right) / 2;
var specialReverseDiffY = this.heightCanvas / 2 + (this.top - this.bottom) / 2;
projectionPoint.offset(specialReverseDiffX, specialReverseDiffY, centerZDiff);
return {x: projectionPoint.x, y: projectionPoint.y};
};
//functions for step transformation point
Processor3D.prototype.calculatePointManual = function(x, y, z, diffX, diffY, diffZ)
{
diffX = diffX !== undefined ? diffX : this.cameraDiffX;
diffY = diffY !== undefined ? diffY : this.cameraDiffY;
diffZ = diffZ !== undefined ? diffZ : this.cameraDiffZ;
var diffAndScalePoints = this.diffAndScale(x, y, z);
var x11 = diffAndScalePoints.x;
var y11 = diffAndScalePoints.y;
var z11 = diffAndScalePoints.z;
var rotatePoints = this.rotate(x11, y11, z11);
var x111 = rotatePoints.x;
var y111 = rotatePoints.y;
var z111 = rotatePoints.z;
var x1111 = x111 + diffX;
var y1111 = y111 + diffY;
var z1111 = z111 + diffZ;
var projectPoints = this.project(x1111, y1111, z1111);
var x11111 = projectPoints.x;
var y11111 = projectPoints.y;
return {x: x11111, y: y11111};
};
Processor3D.prototype.diffAndScale = function(x, y, z)
{
var aRX = this.aspectRatioX;
var aRY = this.aspectRatioY;
var w = this.widthCanvas;
var h = this.heightCanvas;
var x1 = x / aRX;
var x11 = x1 - (w / 2) / aRX;
var z1 = z;
var z11 = z1;
var y1 = y / aRY;
var y11 = y1 - (h / 2) / aRY;
return {x: x11, y: y11, z: z11};
};
Processor3D.prototype.rotate = function(x11, y11, z11)
{
var sinOY = Math.sin(-this.angleOy);
var cosOY = Math.cos(-this.angleOy);
var sinOX = Math.sin(-this.angleOx);
var cosOX = Math.cos(-this.angleOx);
var x111 = z11 * sinOY + x11 * cosOY;
var y111 = x11 * sinOX * sinOY + y11 * cosOX - z11 * sinOX * cosOY;
var z111 = -x11 * sinOY * cosOX + y11 * sinOX + z11 * (cosOY * cosOX);
return {x: x111, y: y111, z: z111};
};
Processor3D.prototype.project = function(x1111, y1111, z1111)
{
var fov = 1 / this.rPerspective;
var w = this.widthCanvas;
var h = this.heightCanvas;
var x11111 = (fov * x1111) / (z1111 + fov) + w / 2;
var y11111 = (fov * y1111) / (z1111 + fov) + h / 2;
return {x: x11111, y: y11111};
};
//exception for pie charts
Processor3D.prototype.convertAndTurnPointForPie = function(x, y, z, cameraDiffZ) Processor3D.prototype.convertAndTurnPointForPie = function(x, y, z, cameraDiffZ)
{ {
var heightChart = this.heightCanvas - this.top - this.bottom; var heightChart = this.heightCanvas - this.top - this.bottom;
var widthOriginalChart = this.widthCanvas - this.left - this.right;
var heightOriginalChart = heightChart;
var widthChart = heightChart;
//aspectRatio //aspectRatio
/*x = x / this.aspectRatioX; /*x = x / this.aspectRatioX;
...@@ -393,7 +523,7 @@ Processor3D.prototype.convertAndTurnPointForPie = function(x, y, z, cameraDiffZ) ...@@ -393,7 +523,7 @@ Processor3D.prototype.convertAndTurnPointForPie = function(x, y, z, cameraDiffZ)
var point3D = new Point3D(x, y, z, this); var point3D = new Point3D(x, y, z, this);
//diff //diff
var centerXDiff = widthChart / 2 + this.left / 2; var centerXDiff = heightChart / 2 + this.left / 2;
var centerYDiff = heightChart / 2 + this.top; var centerYDiff = heightChart / 2 + this.top;
var centerZDiff = this.depthPerspective / 2; var centerZDiff = this.depthPerspective / 2;
...@@ -451,6 +581,9 @@ Processor3D.prototype.calculatePropertiesForPieCharts = function() ...@@ -451,6 +581,9 @@ Processor3D.prototype.calculatePropertiesForPieCharts = function()
return {radius1: radius1, radius2: radius2, depth: depth}; return {radius1: radius1, radius2: radius2, depth: depth};
}; };
//***functions for matrix transformation***
Processor3D.prototype._shearXY = function() Processor3D.prototype._shearXY = function()
{ {
//TODO матрица перевёрнута //TODO матрица перевёрнута
...@@ -462,6 +595,14 @@ Processor3D.prototype._getMatrixRotateAllAxis = function() ...@@ -462,6 +595,14 @@ Processor3D.prototype._getMatrixRotateAllAxis = function()
var matrixRotateOY = this._getMatrixRotateOy(); var matrixRotateOY = this._getMatrixRotateOy();
var matrixRotateOX = this._getMatrixRotateOx(); var matrixRotateOX = this._getMatrixRotateOx();
/*итоговая матрица
|cosOy 0 sinOy 0|
|sinOx * sinOy cosOx -sinOx * cosOy 0|
|-sinOy * cosOx sinOx cosOy * cosOx 0|
|-sinOy 0 (cosOy + 1) 1|*/
return Point3D.prototype.multiplyMatrix(matrixRotateOY, matrixRotateOX); return Point3D.prototype.multiplyMatrix(matrixRotateOY, matrixRotateOX);
}; };
...@@ -480,6 +621,18 @@ Processor3D.prototype._getMatrixRotateOz = function() ...@@ -480,6 +621,18 @@ Processor3D.prototype._getMatrixRotateOz = function()
return [[1, 0, 0, 0], [0, 1, 0, 0], [0, 0, 0, 1], [0, 0, 0, 1]]; return [[1, 0, 0, 0], [0, 1, 0, 0], [0, 0, 0, 1], [0, 0, 0, 1]];
}; };
Processor3D.prototype._getPerspectiveProjectionMatrix = function(fov)
{
/*var zf = this.rPerspective + this.depthPerspective;
var zn = this.rPerspective;
var q = zf / (zf - zn);
return [[1 / Math.tan(this.rPerspective / 2), 0, 0, 0], [0, 1 / Math.tan(this.rPerspective / 2), 0, 0], [0, 0, q, 1], [0, 0, -q * zn, 0]];*/
return [[1, 0, 0, 0], [0, 1, 0, 0], [0, 0, 0, 1 / fov], [0, 0, 0, 1]];
};
Processor3D.prototype.correctPointsPosition = function(chartSpace) Processor3D.prototype.correctPointsPosition = function(chartSpace)
{ {
if(this.chartsDrawer.calcProp.type === "Pie") if(this.chartsDrawer.calcProp.type === "Pie")
...@@ -563,19 +716,15 @@ Processor3D.prototype.correctPointsPosition = function(chartSpace) ...@@ -563,19 +716,15 @@ Processor3D.prototype.correctPointsPosition = function(chartSpace)
{ {
widthText = 0; widthText = 0;
} }
if(t.view3D.rAngAx) var diffXText = 0;
diffXText = 0;
else
diffXText = 15;
var angleOyAbs = Math.abs(t.angleOy); var angleOyAbs = Math.abs(t.angleOy);
if(!t.view3D.rAngAx && (angleOyAbs >= Math.PI / 2 && angleOyAbs < 3 * Math.PI/2)) if(!t.view3D.rAngAx && (angleOyAbs >= Math.PI / 2 && angleOyAbs < 3 * Math.PI/2))
diffXText = - diffXText; diffXText = - diffXText;
valCatAx.transformYPoints[i] = {x: (point.x - (diffXText + widthText)) / pxToMM, y: point.y / pxToMM}; valCatAx.transformYPoints[i] = {x: (point.x - (diffXText + widthText)) / pxToMM, y: point.y / pxToMM};
} }
} };
var correctPointsOyHBar = function() var correctPointsOyHBar = function()
{ {
...@@ -604,7 +753,7 @@ Processor3D.prototype.correctPointsPosition = function(chartSpace) ...@@ -604,7 +753,7 @@ Processor3D.prototype.correctPointsPosition = function(chartSpace)
valCatAx.transformYPoints[i] = {x: (point.x - widthText) / pxToMM, y: point.y / pxToMM}; valCatAx.transformYPoints[i] = {x: (point.x - widthText) / pxToMM, y: point.y / pxToMM};
} }
} };
if(xPoints) if(xPoints)
...@@ -624,39 +773,8 @@ Processor3D.prototype.correctPointsPosition = function(chartSpace) ...@@ -624,39 +773,8 @@ Processor3D.prototype.correctPointsPosition = function(chartSpace)
} }
}; };
Processor3D.prototype._getIsometricProjectionMatrix = function()
{
var far = this.depthPerspective;
var near = 0;
var right = this.widthCanvas + this.left;
var left = this.left;
var bottom = this.heightCanvas + this.top;
var top = this.top;
var m11 = 2 / (right - left);
var m41 = (right + left) / (right - left);
var m22 = 2 / (top - bottom);
var m42 = (top + bottom) / (top - bottom);
var m33 = -2 / (far - near);
var m34 = (far + near) / (far - near);
return [[m11, 0, 0, m41], [0, m22, 0, m42], [0, 0, m33, m34], [0, 0, 0, 1]];
};
Processor3D.prototype._getPerspectiveProjectionMatrix = function(fov)
{
/*var zf = this.rPerspective + this.depthPerspective;
var zn = this.rPerspective;
var q = zf / (zf - zn);
return [[1 / Math.tan(this.rPerspective / 2), 0, 0, 0], [0, 1 / Math.tan(this.rPerspective / 2), 0, 0], [0, 0, q, 1], [0, 0, -q * zn, 0]];*/
return [[1, 0, 0, 0], [0, 1, 0, 0], [0, 0, 0, 1 / fov], [0, 0, 0, 1]];
};
Processor3D.prototype._calculatePerspective = function(view3D) Processor3D.prototype._calculatePerspective = function(view3D)
{ {
var widthLine = this.widthCanvas - (this.left + this.right);
var heightLine = this.heightCanvas - (this.top + this.bottom); var heightLine = this.heightCanvas - (this.top + this.bottom);
var perspective = view3D && view3D.perspective ? view3D.perspective : global3DPersperctive; var perspective = view3D && view3D.perspective ? view3D.perspective : global3DPersperctive;
...@@ -672,75 +790,6 @@ Processor3D.prototype._calculatePerspective = function(view3D) ...@@ -672,75 +790,6 @@ Processor3D.prototype._calculatePerspective = function(view3D)
this.rPerspective = rPerspective; this.rPerspective = rPerspective;
}; };
Processor3D.prototype._calculateDepthClassic = function()
{
var widthOriginalChart = this.widthCanvas - (this.left + this.right);
var heightOriginalChart = this.heightCanvas - (this.top + this.bottom);
var subType = this.chartsDrawer.calcProp.subType;
var type = this.chartsDrawer.calcProp.type;
var defaultOverlap = (subType == "stacked" || subType == "stackedPer" || subType == "standard" || type == "Line" || type == "Area") ? 100 : 0;
var overlap = this.chartSpace.chart.plotArea.chart.overlap ? (this.chartSpace.chart.plotArea.chart.overlap / 100) : (defaultOverlap / 100);
var gapWidth = this.chartSpace.chart.plotArea.chart.gapWidth != null ? (this.chartSpace.chart.plotArea.chart.gapWidth / 100) : (150 / 100);
var gapDepth = this.chartSpace.chart.plotArea.chart.gapDepth != null ? (this.chartSpace.chart.plotArea.chart.gapDepth / 100) : (150 / 100);
var basePercent = this.view3D && this.view3D.depthPercent ? this.view3D.depthPercent / 100 : globalBasePercent / 100;//процент от базовой глубины
var seriesCount = this.chartsDrawer.calcProp.seriesCount;
var ptCount = this.chartsDrawer.calcProp.ptCount;
var sinOx = Math.sin(-this.angleOx);
var hPercent = this.view3D.hPercent !== null ? this.view3D.hPercent / 100 : heightOriginalChart / widthOriginalChart;
var t = this;
var depth = 0;
//STANDARD TYPE
var calculateDepthForStandardCharts = function()
{
var angleOxKf = sinOx === 0 ? 0 : sinOx;
depth = (1 / (angleOxKf + ((ptCount + (Math.floor((seriesCount - ptCount) / 2))) / seriesCount * hPercent))) * (heightOriginalChart);
return depth;
};
var calculateDepthForAnotherCharts = function()
{
//TODO глубина с некоторыми графиками имеет различия, пересчитать!
var widthChart = (widthOriginalChart / t.aspectRatioX) / t.specialStandardScaleX;
var width = widthChart / t.chartsDrawer.calcProp.ptCount;
var baseDepth = width / (seriesCount - (seriesCount - 1) * overlap + gapWidth);
if(subType == "standard" || type == "Line")
baseDepth = (width / (seriesCount - (seriesCount - 1) * overlap + gapWidth)) * seriesCount;
var depth;
if(t.view3D.rAngAx && t.aspectRatioY === 1)
{
var b = (seriesCount - (seriesCount - 1) * overlap + gapWidth);
if(subType == "standard" || type == "Line" || type == "Area")
b = b / seriesCount;
var sinOx = Math.sin(-t.angleOx);
var angleOxKf = sinOx === 0 ? 1 : sinOx;
var a = basePercent / (t.chartsDrawer.calcProp.ptCount * b);
depth = (widthChart * a + gapDepth * widthChart * a) / (1 / angleOxKf + (gapDepth) * a + a);
depth = depth / angleOxKf;
}
else
{
depth = baseDepth * basePercent;
depth = depth + depth * gapDepth;
}
return depth;
};
depth = subType === "standard" || this.chartsDrawer.calcProp.type === "Line" ? calculateDepthForStandardCharts() : calculateDepthForAnotherCharts();
return depth;
};
Processor3D.prototype._calculateDepth = function() Processor3D.prototype._calculateDepth = function()
{ {
var widthOriginalChart = this.widthCanvas - (this.left + this.right); var widthOriginalChart = this.widthCanvas - (this.left + this.right);
...@@ -770,18 +819,21 @@ Processor3D.prototype._calculateDepth = function() ...@@ -770,18 +819,21 @@ Processor3D.prototype._calculateDepth = function()
standardType = true; standardType = true;
var heightHPercent = heightOriginalChart / hPercent; var heightHPercent = heightOriginalChart / hPercent;
var angleOxKf;
if(!standardType) if(!standardType)
{ {
if(this.angleOx === 0 && this.angleOy === 0)//withoutAngleNoAuto + withoutAngleAuto var widthOneBar = ((heightHPercent / seriesCount) / (ptCount - (ptCount - 1) * (overlap) + gapWidth)) * sinOy;
var a, b;
if(this.angleOx === 0 && this.angleOy === 0)//withoutAngleNoAuto + withoutAngleAuto
{ {
var widthOneBar = ((heightHPercent / seriesCount) / (ptCount - (ptCount - 1) * (overlap) + gapWidth)) * sinOy;//0
chartWidth = widthOneBar + heightHPercent; chartWidth = widthOneBar + heightHPercent;
} }
else if(this.angleOx !== 0/* && this.angleOy !== 0*/)//AngleOYNoAut + AngleOYNoAutPerHeight + (ANGLEOX+ANGLEOY) + AngleOYOXNoAut + ANGLEOXANGLEOYHPerDPer(ANGLEOX+ANGLEOY HPercent) else if(this.angleOx !== 0/* && this.angleOy !== 0*/)//AngleOYNoAut + AngleOYNoAutPerHeight + (ANGLEOX+ANGLEOY) + AngleOYOXNoAut + ANGLEOXANGLEOYHPerDPer(ANGLEOX+ANGLEOY HPercent)
{ {
//если выставить ширину 255 будет так же, как и в документе с расчётами //если выставить ширину 255 будет так же, как и в документе с расчётами
var b = (seriesCount - (seriesCount - 1) * overlap + gapWidth); b = (seriesCount - (seriesCount - 1) * overlap + gapWidth);
var a = (depthPercent / (ptCount * b)) / hPercent; a = (depthPercent / (ptCount * b)) / hPercent;
var width = heightOriginalChart * areaStackedKf; var width = heightOriginalChart * areaStackedKf;
depth = (width * a + gapDepth * width * a) / (1 / sinOx + (gapDepth) * a + a); depth = (width * a + gapDepth * width * a) / (1 / sinOx + (gapDepth) * a + a);
...@@ -790,21 +842,15 @@ Processor3D.prototype._calculateDepth = function() ...@@ -790,21 +842,15 @@ Processor3D.prototype._calculateDepth = function()
else if(this.angleOy !== 0)//angleOxNoAuto else if(this.angleOy !== 0)//angleOxNoAuto
{ {
//если выставить ширину = 321.25 будет так же, как и в документе с расчётам //если выставить ширину = 321.25 будет так же, как и в документе с расчётам
var widthOneBar = ((heightHPercent / seriesCount) / (ptCount - (ptCount - 1) * (overlap) + gapWidth)) * sinOy;
chartWidth = widthOneBar + heightHPercent;
//TODO глубина с некоторыми графиками имеет различия, пересчитать! //TODO глубина с некоторыми графиками имеет различия, пересчитать!
var widthChart = (widthOriginalChart / t.aspectRatioX) / t.specialStandardScaleX; var widthChart = (widthOriginalChart / t.aspectRatioX) / t.specialStandardScaleX;
var b = (seriesCount - (seriesCount - 1) * overlap + gapWidth); b = (seriesCount - (seriesCount - 1) * overlap + gapWidth);
if(subType == "standard" || type == "Line" || type == "Area") if(subType == "standard" || type == "Line" || type == "Area")
b = b / seriesCount; b = b / seriesCount;
var sinOx = Math.sin(-t.angleOx); angleOxKf = sinOx === 0 ? 1 : sinOx;
var angleOxKf = sinOx === 0 ? 1 : sinOx; a = basePercent / (t.chartsDrawer.calcProp.ptCount * b);
var a = basePercent / (t.chartsDrawer.calcProp.ptCount * b);
depth = (widthChart * a + gapDepth * widthChart * a) / (1 / angleOxKf + (gapDepth) * a + a); depth = (widthChart * a + gapDepth * widthChart * a) / (1 / angleOxKf + (gapDepth) * a + a);
depth = depth / angleOxKf; depth = depth / angleOxKf;
...@@ -812,12 +858,12 @@ Processor3D.prototype._calculateDepth = function() ...@@ -812,12 +858,12 @@ Processor3D.prototype._calculateDepth = function()
} }
else//allStandardDepth else//allStandardDepth
{ {
var angleOxKf = sinOx === 0 ? 0 : sinOx; angleOxKf = sinOx === 0 ? 0 : sinOx;
if(type == "Area") if(type == "Area")
depth = (1*depthPercent / (angleOxKf*depthPercent + ((ptCount + (Math.floor((seriesCount - ptCount) / 2 - 0.5))) / seriesCount * hPercent))) * (heightOriginalChart); depth = (depthPercent / (angleOxKf*depthPercent + ((ptCount + (Math.floor((seriesCount - ptCount) / 2 - 0.5))) / seriesCount * hPercent))) * (heightOriginalChart);
else else
depth = (1*depthPercent / (angleOxKf*depthPercent + ((ptCount + (Math.floor((seriesCount - ptCount) / 2))) / seriesCount * hPercent))) * (heightOriginalChart); depth = (depthPercent / (angleOxKf*depthPercent + ((ptCount + (Math.floor((seriesCount - ptCount) / 2))) / seriesCount * hPercent))) * (heightOriginalChart);
if((this.angleOx !== 0)) if((this.angleOx !== 0))
depth = depth * Math.sin(-this.angleOx); depth = depth * Math.sin(-this.angleOx);
...@@ -826,18 +872,14 @@ Processor3D.prototype._calculateDepth = function() ...@@ -826,18 +872,14 @@ Processor3D.prototype._calculateDepth = function()
return sinOx !== 0 ? depth / Math.sin(-this.angleOx) : depth; return sinOx !== 0 ? depth / Math.sin(-this.angleOx) : depth;
}; };
Processor3D.prototype._calculateDepthPerspective = function() Processor3D.prototype._calculateDepthPerspective = function()
{ {
var widthCanvas = this.widthCanvas; var widthCanvas = this.widthCanvas;
var heightCanvas = this.heightCanvas; var widthOriginalChart = widthCanvas - (this.left + this.right);
var widthOriginalChart = heightCanvas - (this.left + this.right);
var heightOriginalChart = heightCanvas - (this.top + this.bottom);
var aspectRatio = (widthOriginalChart) / (heightOriginalChart); var aspectRatio = this.aspectRatioX / (this.specialStandardScaleX);
var widthChart = widthOriginalChart / aspectRatio; var widthChart = widthOriginalChart / aspectRatio;
widthChart = widthChart / this.scaleX;
var widthChart = widthChart / this.scaleX;
var seriesCount = this.chartsDrawer.calcProp.seriesCount; var seriesCount = this.chartsDrawer.calcProp.seriesCount;
...@@ -859,16 +901,15 @@ Processor3D.prototype._calculateDepthPerspective = function() ...@@ -859,16 +901,15 @@ Processor3D.prototype._calculateDepthPerspective = function()
depth = depth + depth * gapDepth; depth = depth + depth * gapDepth;
if(this.view3D.rAngAx) //TODO глубина в некоторых случаях отличается(тип Standard)
if(this.chartsDrawer.calcProp.subType === "standard" || this.chartsDrawer.calcProp.type === "Line")
{ {
var b = (seriesCount - (seriesCount - 1) * overlap + gapWidth); var b = 1 / seriesCount;
if(this.chartsDrawer.calcProp.subType == "standard" || this.chartsDrawer.calcProp.type == "Line" || this.chartsDrawer.calcProp.type == "Area")
b = b / seriesCount;
var sinOx = Math.sin(-this.angleOx); var sinOx = Math.sin(-this.angleOx);
var angleOxKf = sinOx === 0 ? 1 : sinOx; var angleOxKf = 1;
var a = basePercent / (this.chartsDrawer.calcProp.ptCount * b); var a = basePercent / (this.chartsDrawer.calcProp.ptCount * b);
depth = (widthChart * a + gapDepth * widthChart * a) / (1 / angleOxKf + (gapDepth) * a + a); depth = (widthChart * a + widthChart * a) / (1 / angleOxKf + a);
depth = depth / angleOxKf; depth = depth / angleOxKf;
} }
...@@ -893,9 +934,6 @@ Processor3D.prototype._calculateScaleFromDepth = function (/*isSkip*/) ...@@ -893,9 +934,6 @@ Processor3D.prototype._calculateScaleFromDepth = function (/*isSkip*/)
//***Calculate scaleY*** //***Calculate scaleY***
if(this.view3D.rAngAx && this.aspectRatioY === 1) if(this.view3D.rAngAx && this.aspectRatioY === 1)
{ {
var widthCanvas = this.widthCanvas;
var originalWidthChart = widthCanvas - this.left - this.right;
var heightCanvas = this.heightCanvas; var heightCanvas = this.heightCanvas;
var heightChart = heightCanvas - this.top - this.bottom; var heightChart = heightCanvas - this.top - this.bottom;
...@@ -906,21 +944,12 @@ Processor3D.prototype._calculateScaleFromDepth = function (/*isSkip*/) ...@@ -906,21 +944,12 @@ Processor3D.prototype._calculateScaleFromDepth = function (/*isSkip*/)
//this.scaleX += parseInt((this.chartsDrawer.calcProp.seriesCount + 1) / 2) - 1; //this.scaleX += parseInt((this.chartsDrawer.calcProp.seriesCount + 1) / 2) - 1;
var subType = this.chartsDrawer.calcProp.subType; var subType = this.chartsDrawer.calcProp.subType;
if(subType == "standard" || this.chartsDrawer.calcProp.type === "Line" || (this.chartsDrawer.calcProp.type === "Area" && subType == "normal")) var newDepth, newWidth;
if(!(subType == "standard" || this.chartsDrawer.calcProp.type === "Line" || (this.chartsDrawer.calcProp.type === "Area" && subType == "normal")))
{ {
var widthStandard = heightChart / this.specialStandardScaleX; newDepth = this.depthPerspective * Math.sin(-this.angleOx);
if(widthStandard > originalWidthChart) newWidth = heightChart - newDepth;
widthStandard = originalWidthChart; this.scaleX = heightChart / newWidth;
var newDepth = this.depthPerspective * Math.sin(-this.angleOx);
var newWidth = widthStandard - newDepth;
//this.scaleX = heightChart / newWidth;
}
else
{
var newDepth = this.depthPerspective * Math.sin(-this.angleOx);
var newWidth = heightChart - newDepth;
this.scaleX = heightChart / newWidth;
} }
} }
}; };
...@@ -936,8 +965,6 @@ Processor3D.prototype._calculateCameraDiff = function (/*isSkip*/) ...@@ -936,8 +965,6 @@ Processor3D.prototype._calculateCameraDiff = function (/*isSkip*/)
var heightCanvas = this.heightCanvas; var heightCanvas = this.heightCanvas;
var heightChart = heightCanvas - this.top - this.bottom; var heightChart = heightCanvas - this.top - this.bottom;
var perspectiveDepth = this.depthPerspective;
//add test points for parallelepiped rect //add test points for parallelepiped rect
var points = []; var points = [];
var faces = []; var faces = [];
...@@ -960,75 +987,949 @@ Processor3D.prototype._calculateCameraDiff = function (/*isSkip*/) ...@@ -960,75 +987,949 @@ Processor3D.prototype._calculateCameraDiff = function (/*isSkip*/)
//***Calculate cameraDiffZ*** //***Calculate cameraDiffZ***
if(!this.view3D.rAngAx) if(!this.view3D.rAngAx)
this._calculateCameraDiffZ(points, faces); {
//медленная функция поиска сдвигов камеры(все сдвиги корректны)
//this._calculateCameraDiffZ(points, faces);
//быстрая функция поиска сдвигов камеры
console.time("sdf");
this._calculateCameraDiffZX(points, faces);
console.timeEnd("sdf");
}
//***Calculate cameraDiffX*** //***Calculate cameraDiffX***
if(this.view3D.rAngAx) if(this.view3D.rAngAx)
{ {
var minMaxOx = this._getMinMaxOx(points, faces); var minMaxOx = this._getMinMaxOx(points, faces);
this._calculateCameraDiffX(minMaxOx); this._calculateCameraDiffX(minMaxOx);
//***Calculate cameraDiffY***
var minMaxOy = this._getMinMaxOy(points, faces);
this._calculateCameraDiffY(minMaxOy.top, minMaxOy.bottom);
} }
//***Calculate cameraDiffY***
var minMaxOy = this._getMinMaxOy(points, faces);
this._calculateCameraDiffY(minMaxOy.top, minMaxOy.bottom);
}; };
Processor3D.prototype._calculateCameraDiffZ = function (points, faces) Processor3D.prototype._calculateCameraDiffZX = function (newPoints)
{ {
var widthCanvas = this.widthCanvas; var heightChart = this.heightCanvas - this.top - this.bottom;
var originalWidthChart = widthCanvas - this.left - this.right; var widthOriginalChart = this.widthCanvas - this.left - this.right;
var heightOriginalChart = heightChart;
var heightCanvas = this.heightCanvas; var minX = null;
var heightChart = heightCanvas - this.top - this.bottom; var maxX = null;
var minZ = null;
var widthChart = originalWidthChart; var aspectRatio = (widthOriginalChart) / (heightOriginalChart);
var depthChart = this.depthPerspective;
var minMaxOx = this._getMinMaxOx(points, faces);
var point1 = this.convertAndTurnPoint(minMaxOx.mostLeftPointX.x, minMaxOx.mostLeftPointX.y, minMaxOx.mostLeftPointX.z, true);
var point2 = this.convertAndTurnPoint(minMaxOx.mostRightPointX.x, minMaxOx.mostRightPointX.y, minMaxOx.mostRightPointX.z, true);
var x1 = point1.x;
var x2 = point2.x;
var y1 = point1.y;
var y2 = point2.y;
var diffX = Math.abs(x1 - x2);
var diffY = Math.abs(y1 - y2);
//TODO медленная функция, рассчитать сдвиги!
while(diffX > widthChart || diffY > heightChart)
{
var minMaxOx = this._getMinMaxOx(points, faces);
var point1 = this.convertAndTurnPoint(minMaxOx.mostLeftPointX.x, minMaxOx.mostLeftPointX.y, minMaxOx.mostLeftPointX.z, true);
var point2 = this.convertAndTurnPoint(minMaxOx.mostRightPointX.x, minMaxOx.mostRightPointX.y, minMaxOx.mostRightPointX.z, true);
var x1 = point1.x; for(var i = 0; i < newPoints.length; i++)
var x2 = point2.x; {
var y1 = point1.y; var point3D = new Point3D(newPoints[i].x, newPoints[i].y, newPoints[i].z, this);
var y2 = point2.y;
var leftMargin = this.left - x1; point3D.scale(aspectRatio, 1, 1);
var rightMargin = x2 - (this.left + originalWidthChart); point3D.offset((-this.widthCanvas / 2) / aspectRatio, (-this.heightCanvas / 2) , 0);
var topMargin = this.top - y1; //rotate
var bottomMargin = y2 - (this.top + heightChart); var matrixRotateAllAxis = this._getMatrixRotateAllAxis();
point3D.multiplyPointOnMatrix1(matrixRotateAllAxis);
if(leftMargin > rightMargin)
{
this.cameraDiffX++;
}
else
{
this.cameraDiffX--;
}
var diffX = Math.abs(x1 - x2);
var diffY = Math.abs(y1 - y2); if(minZ === null || point3D.z < minZ)
minZ = point3D.z;
this.cameraDiffZ++;
if(minX === null || point3D.x < minX)
minX = point3D.x;
if(maxX === null || point3D.x > maxX)
maxX = point3D.x;
} }
var minMaxOy = this._getMinMaxOy(points, faces); //get min and max point's and diffX
/*if(-t.angleOx === 0)
{
var minMaxOx = this._getMinMaxOxPoints(newPoints, minZ);
this.cameraDiffZ = - minZ;
this.cameraDiffX = - minMaxOx.diffX;
var x111 = this.convertAndTurnPoint(minMaxOx.tempX1, minMaxOx.tempY1, minMaxOx.tempZ1);
var x222 = this.convertAndTurnPoint(minMaxOx.tempX2, minMaxOx.tempY2, minMaxOx.tempZ2);
if(Math.abs(x222.x - x111.x) > widthOriginalChart)
{
var correctOffset;
if(x222.x > x111.x)
{
correctOffset = this._correctZPosition4(minMaxOx.tempX1, minMaxOx.tempX2, minMaxOx.tempZ1, minMaxOx.tempZ2, minZ, minMaxOx.tempY1, minMaxOx.tempY2);
}
else
{
correctOffset = this._correctZPosition4(minMaxOx.tempX1, minMaxOx.tempX2, minMaxOx.tempZ1, minMaxOx.tempZ2, minZ, minMaxOx.tempY1, minMaxOx.tempY2);
}
this.cameraDiffZ = Math.abs(correctOffset.minZ);
this.cameraDiffX = correctOffset.diffX;
}
}
else if(-t.angleOy === 0 && -t.angleOx !== 0)
{
var minMaxOy = this._getMinMaxOyPoints(newPoints, minZ);
this.cameraDiffZ = - minZ;
this.cameraDiffY = -minMaxOy.diffY;
var y111 = this.convertAndTurnPoint(minMaxOy.tempX1, minMaxOy.tempY1, minMaxOy.tempZ1);
var y222 = this.convertAndTurnPoint(minMaxOy.tempX2, minMaxOy.tempY2, minMaxOy.tempZ2);
if(Math.abs(y111.y - y222.y) < heightOriginalChart)
{
var minMaxOx = this._getMinMaxOxPoints(newPoints, minZ);
var x111 = this.convertAndTurnPoint(minMaxOx.tempX1, minMaxOx.tempY1, minMaxOx.tempZ1);
var x222 = this.convertAndTurnPoint(minMaxOx.tempX2, minMaxOx.tempY2, minMaxOx.tempZ2);
var correctOffset;
if(x222.x > x111.x)
{
correctOffset = this._correctZPosition4(minMaxOx.tempX1, minMaxOx.tempX2, minMaxOx.tempZ1, minMaxOx.tempZ2, minZ, minMaxOx.tempY1, minMaxOx.tempY2);
}
else
{
correctOffset = this._correctZPosition4(minMaxOx.tempX1, minMaxOx.tempX2, minMaxOx.tempZ1, minMaxOx.tempZ2, minZ, minMaxOx.tempY1, minMaxOx.tempY2);
}
this.cameraDiffZ = Math.abs(correctOffset.minZ);
this.cameraDiffX = correctOffset.diffX;
var minMaxOy = this._getMinMaxOyPoints(newPoints, 0);
//this.cameraDiffZ = - minZ;
this.cameraDiffY = -minMaxOy.diffY;
}
}*/
/*else if(-t.angleOy !== 0 && -t.angleOx !== 0)
{
var minMaxOx = this._getMinMaxOxPoints(newPoints, minZ);
var x111 = this.convertAndTurnPoint(minMaxOx.tempX1, minMaxOx.tempY1, minMaxOx.tempZ1);
var x222 = this.convertAndTurnPoint(minMaxOx.tempX2, minMaxOx.tempY2, minMaxOx.tempZ2);
var correctOffset;
if(x222.x > x111.x)
{
correctOffset = this._correctZPosition4(minMaxOx.tempX1, minMaxOx.tempX2, minMaxOx.tempZ1, minMaxOx.tempZ2, minZ, minMaxOx.tempY1, minMaxOx.tempY2);
}
else
{
correctOffset = this._correctZPosition4(minMaxOx.tempX2, minMaxOx.tempX1, minMaxOx.tempZ2, minMaxOx.tempZ1, minZ, minMaxOx.tempY2, minMaxOx.tempY1);
}
this.cameraDiffZ = correctOffset.minZ;
this.cameraDiffX = correctOffset.diffX;
var minMaxOy = this._getMinMaxOyPoints2(newPoints, this.cameraDiffZ);
this.cameraDiffY = minMaxOy.diffY;
console.log(" tempX1: " + minMaxOy.tempX1 + " tempX2: " + minMaxOy.tempX2 + " tempY1: " + minMaxOy.tempY1 + " tempY2: " + minMaxOy.tempY2 + " tempZ1: " + minMaxOy.tempZ1 + " tempZ2: " + minMaxOy.tempZ2);
var y111 = this.convertAndTurnPoint(minMaxOy.tempX1, minMaxOy.tempY1, minMaxOy.tempZ1);
var y222 = this.convertAndTurnPoint(minMaxOy.tempX2, minMaxOy.tempY2, minMaxOy.tempZ2);
if(y111.y < this.top || y222.y > this.top + heightOriginalChart)
{
//correctOffset = this._correctZPositionOY(minMaxOy.tempX1, minMaxOy.tempX2, minMaxOy.tempZ1, minMaxOy.tempZ2, minZ, minMaxOy.tempY1, minMaxOy.tempY2);
this.cameraDiffZ = minMaxOy.diffZ;
//this.cameraDiffY = minMaxOy.diffY;
var minMaxOx = this._getMinMaxOxPoints(newPoints, -this.cameraDiffZ);
//correctOffset = this._correctZPosition4(minMaxOx.tempX1, minMaxOx.tempX2, minMaxOx.tempZ1, minMaxOx.tempZ2, -this.cameraDiffZ, minMaxOx.tempY1, minMaxOx.tempY2);
this.cameraDiffX = -minMaxOx.diffX;
}
//TODO пока включаю для поворотов по OX + по OY checkOutSideArea(медленная функция), затем нужно переделать, используя закомментированный код сверху
this.cameraDiffZ = -minZ;
//this.cameraDiffX = -minMaxOx.diffX;
this.checkOutSideArea(newPoints);
}*/
//TODO пока включаю для ВСЕГО checkOutSideArea(медленная функция), затем нужно переделать, используя закомментированный код сверху
this.cameraDiffZ = -minZ;
this.checkOutSideArea(newPoints);
};
Processor3D.prototype.checkOutSideArea = function(newPoints)
{
var i = 0;
var maxI = 1000;
var t = this;
var heightChart = this.heightCanvas - this.top - this.bottom;
var widthChart = this.widthCanvas - this.left - this.right;
var calculateZ = function(step)
{
var minMaxOx = t._getMinMaxOxPoints(newPoints, -t.cameraDiffZ);
t.cameraDiffX = -minMaxOx.diffX;
var x111 = t.convertAndTurnPoint(minMaxOx.tempX1, minMaxOx.tempY1, minMaxOx.tempZ1);
var x222 = t.convertAndTurnPoint(minMaxOx.tempX2, minMaxOx.tempY2, minMaxOx.tempZ2);
var diffX = Math.abs(x222.x - x111.x);
var minMaxOy = t._getMinMaxOyPoints(newPoints, t.cameraDiffZ);
t.cameraDiffY = -minMaxOy.diffY;
var y111 = t.convertAndTurnPoint(minMaxOy.tempX1, minMaxOy.tempY1, minMaxOy.tempZ1);
var y222 = t.convertAndTurnPoint(minMaxOy.tempX2, minMaxOy.tempY2, minMaxOy.tempZ2);
var diffY = Math.abs(y222.y - y111.y);
if(diffX < widthChart && diffY < heightChart)//if size less then width or height
{
while(diffX < widthChart && diffY < heightChart)
{
t.cameraDiffZ -= step;
i++;
minMaxOx = t._getMinMaxOxPoints(newPoints, -t.cameraDiffZ);
t.cameraDiffX = -minMaxOx.diffX;
x111 = t.convertAndTurnPoint(minMaxOx.tempX1, minMaxOx.tempY1, minMaxOx.tempZ1);
x222 = t.convertAndTurnPoint(minMaxOx.tempX2, minMaxOx.tempY2, minMaxOx.tempZ2);
diffX = Math.abs(x222.x - x111.x);
minMaxOy = t._getMinMaxOyPoints(newPoints, t.cameraDiffZ);
t.cameraDiffY = -minMaxOy.diffY;
y111 = t.convertAndTurnPoint(minMaxOy.tempX1, minMaxOy.tempY1, minMaxOy.tempZ1);
y222 = t.convertAndTurnPoint(minMaxOy.tempX2, minMaxOy.tempY2, minMaxOy.tempZ2);
diffY = Math.abs(y222.y - y111.y);
if(i > maxI)
break;
}
}
else if(diffX > widthChart || diffY > heightChart)//if size more then width or height
{
while(diffX > widthChart || diffY > heightChart)
{
t.cameraDiffZ += step;
i++;
minMaxOx = t._getMinMaxOxPoints(newPoints, -t.cameraDiffZ);
t.cameraDiffX = -minMaxOx.diffX;
x111 = t.convertAndTurnPoint(minMaxOx.tempX1, minMaxOx.tempY1, minMaxOx.tempZ1);
x222 = t.convertAndTurnPoint(minMaxOx.tempX2, minMaxOx.tempY2, minMaxOx.tempZ2);
diffX = Math.abs(x222.x - x111.x);
minMaxOy = t._getMinMaxOyPoints(newPoints, t.cameraDiffZ);
t.cameraDiffY = -minMaxOy.diffY;
y111 = t.convertAndTurnPoint(minMaxOy.tempX1, minMaxOy.tempY1, minMaxOy.tempZ1);
y222 = t.convertAndTurnPoint(minMaxOy.tempX2, minMaxOy.tempY2, minMaxOy.tempZ2);
diffY = Math.abs(y222.y - y111.y);
if(i > maxI)
break;
}
}
};
calculateZ(10);
calculateZ(1);
};
Processor3D.prototype._getMinMaxOxPoints = function(points, minZ)
{
var fov = 1 / this.rPerspective;
var t = this;
var aspectRatioX = this.aspectRatioX;
var aspectRatioY = this.aspectRatioY;
var diffAndRotatePoint = function(point)
{
var point3D = new Point3D(point.x, point.y, point.z, t);
point3D.scale(aspectRatioX, aspectRatioY, 1);
point3D.offset((-t.widthCanvas / 2) / aspectRatioX, (-t.heightCanvas / 2) / aspectRatioY /** aspectRatio*/, 0);
//rotate
var matrixRotateAllAxis = t._getMatrixRotateAllAxis();
point3D.multiplyPointOnMatrix1(matrixRotateAllAxis);
return point3D;
};
var calculateDiffX = function (x1, x2, z1, z2, minZ, y1, y2)
{
var diffAndScalePoints1 = t.diffAndScale(x1, y1, z1);
x1 = diffAndScalePoints1.x;
y1 = diffAndScalePoints1.y;
z1 = diffAndScalePoints1.z;
var rotatePoints1 = t.rotate(x1, y1, z1);
var a1 = rotatePoints1.x;
//var x1S = a1 - diffX;
var z1S = rotatePoints1.z - minZ;
//var x1SS = (fov * x1S / (z1S + fov)) + w / 2;
var diffAndScalePoints2 = t.diffAndScale(x2, y2, z2);
x2 = diffAndScalePoints2.x;
y2 = diffAndScalePoints2.y;
z2 = diffAndScalePoints2.z;
var rotatePoints2 = t.rotate(x2, y2, z2);
var a2 = rotatePoints2.x;
//var x2S = a2 - diffX;
var z2S = rotatePoints2.z - minZ;
//var x2SS = (fov * x2S / (z2S + fov)) + w / 2;
var diffX = (-a1 * z2S - a1 * fov - a2 * z1S -a2 * fov) / ( -z2S - fov - z1S - fov);
return diffX;
};
var w = t.widthCanvas;
var tempArray = this._getArrayAllVergeCube(points);
var x11, x22, y11, y22, z11, z22;
var tempX1, tempY1, tempZ1, tempX2, tempY2, tempZ2, start, end;
for(var i = 0; i < tempArray.length - 1; i++)
{
start = i;
end = i + 1;
x11 = tempArray[start].x - (t.widthCanvas / 2);
x22 = tempArray[end].x - (t.widthCanvas / 2);
y11 = tempArray[start].y - (t.heightCanvas / 2);
y22 = tempArray[end].y - (t.heightCanvas / 2);
z11 = tempArray[start].z;
z22 = tempArray[end].z;
tempX1 = tempArray[start].x;
tempY1 = tempArray[start].y;
tempZ1 = tempArray[start].z;
tempX2 = tempArray[end].x;
tempY2 = tempArray[end].y;
tempZ2 = tempArray[end].z;
if(x11 > x22)
{
start = i + 1;
end = i;
x11 = tempArray[start].x - (t.widthCanvas / 2);
x22 = tempArray[end].x - (t.widthCanvas / 2);
y11 = tempArray[start].y - (t.heightCanvas / 2);
y22 = tempArray[end].y - (t.heightCanvas / 2);
z11 = tempArray[start].z;
z22 = tempArray[end].z;
tempX1 = tempArray[start].x;
tempY1 = tempArray[start].y;
tempZ1 = tempArray[start].z;
tempX2 = tempArray[end].x;
tempY2 = tempArray[end].y;
tempZ2 = tempArray[end].z;
}
var diffX = calculateDiffX(tempX1, tempX2, tempZ1, tempZ2, minZ, tempY1, tempY2);
var projectiveMatrix = t._getPerspectiveProjectionMatrix(1 / (t.rPerspective));
var rotatePoint1 = diffAndRotatePoint(tempArray[start]);
rotatePoint1.offset(-diffX, 0, -minZ);
rotatePoint1 = rotatePoint1.project(projectiveMatrix);
var x1 = Math.floor(rotatePoint1.x + t.widthCanvas / 2);
var rotatePoint2 = diffAndRotatePoint(tempArray[end]);
rotatePoint2.offset(-diffX, 0, -minZ);
rotatePoint2 = rotatePoint2.project(projectiveMatrix);
var x2 = Math.floor(rotatePoint2.x + t.widthCanvas / 2);
var leftMargin = x1;
var rightMargin = Math.floor(w - x2);
if(!((leftMargin >= rightMargin - 1) && (leftMargin <= rightMargin + 1)))
continue;
var isTrue = true;
for(var l = 0; l < tempArray.length - 1; l++)
{
var rotatePoint = diffAndRotatePoint(tempArray[l]);
rotatePoint.offset(-diffX, 0, -minZ);
rotatePoint = rotatePoint.project(projectiveMatrix);
var tempX11 = Math.floor(rotatePoint.x + t.widthCanvas / 2);
if(x1 < x2)
{
if(tempX11 < x1 || tempX11 > x2)
{
isTrue = false;
break;
}
}
else
{
if(tempX11 > x1 || tempX11 < x2)
{
isTrue = false;
break;
}
}
}
if(isTrue)
break;
}
return {diffX: diffX, tempX1: tempX1, tempY1: tempY1, tempZ1: tempZ1, tempX2: tempX2, tempY2: tempY2, tempZ2: tempZ2, x11: x11, z11: z11, x22: x22, z22: z22, y11: y11, y22: y22};
};
Processor3D.prototype._getMinMaxOyPoints = function(points, minZ)
{
var fov = 1 / this.rPerspective;
var t = this;
var h = t.heightCanvas;
var w = t.widthCanvas;
var calculateDiffY = function (x1, x2, y1, y2, z1, z2, minZ)
{
//var cos1 = Math.cos(-t.angleOy);
//var sin1 = Math.sin(-t.angleOy);
var diffY = 0;
var diffAndScalePoints = t.diffAndScale(x1, y1, z1);
var x1 = diffAndScalePoints.x;
var y1 = diffAndScalePoints.y;
var z1 = diffAndScalePoints.z;
var rotatePoints = t.rotate(x1, y1, z1);
var a1 = rotatePoints.y;
//var y1S = (a1 - diffY);
var z1S = rotatePoints.z + minZ;
//var x1SS = (fov * y1S / (z1S + fov)) + h / 2;
diffAndScalePoints = t.diffAndScale(x2, y2, z2);
x2 = diffAndScalePoints.x;
y2 = diffAndScalePoints.y;
z2 = diffAndScalePoints.z;
rotatePoints = t.rotate(x2, y2, z2);
var a2 = rotatePoints.y;
//var y2S = (a2 - diffY);
var z2S = rotatePoints.z + minZ;
//var x2SS = (fov * y2S / (z2S + fov)) + h / 2;
//var topMargin = (fov * y1S / (z1S + fov)) + h / 2;
//var bottomMargin = h - ((fov * y2S / (z2S + fov)) + h / 2);
//((a1 - diffY) / (z1S + fov)) = - (((a2 - diffY) / (z2S + fov)))
/*(a1 - diffY) * (z2S + fov) = -(z1S + fov) * (a2 - diffY)
a1 * z2S + a1 * fov - diffY * z2S - diffY * fov = -z1S * a2 + z1S * diffY - fov * a2 + fov * diffY
a1 * z2S + a1 * fov + fov * a2 + z1S * a2= diffY * z2S + diffY * fov + z1S * diffY + fov * diffY*/
diffY = (a1 * z2S + a1 * fov + fov * a2 + z1S * a2) / (z2S + fov + z1S + fov);
//var diffY = (-a1 * z2S - a1 * fov - a2 * z1S -a2 * fov) / ( -z2S - fov - z1S - fov);
return diffY;
};
var tempArray = this._getArrayAllVergeCube(points);
var tempX1, tempY1, tempZ1, tempX2, tempY2, tempZ2;
for(var i = 0; i < tempArray.length - 1; i++)
{
var start = i;
var end = i + 1;
tempX1 = tempArray[start].x;
tempY1 = tempArray[start].y;
tempZ1 = tempArray[start].z;
tempX2 = tempArray[end].x;
tempY2 = tempArray[end].y;
tempZ2 = tempArray[end].z;
if(tempY1 > tempY2)
{
start = i + 1;
end = i;
tempX1 = tempArray[start].x;
tempY1 = tempArray[start].y;
tempZ1 = tempArray[start].z;
tempX2 = tempArray[end].x;
tempY2 = tempArray[end].y;
tempZ2 = tempArray[end].z;
}
var diffY = calculateDiffY(tempX1, tempX2, tempY1, tempY2, tempZ1, tempZ2, minZ);
var rotatePoint1 = this.calculatePointManual(tempX1, tempY1, tempZ1, this.cameraDiffX, -diffY, minZ);
var y1 = rotatePoint1.y;
var rotatePoint2 = this.calculatePointManual(tempX2, tempY2, tempZ2, this.cameraDiffX, -diffY, minZ);
var y2 = rotatePoint2.y;
var topMargin = y1;
var bottomMargin = Math.floor(h - y2);
if(!((topMargin >= bottomMargin - 1) && (topMargin <= bottomMargin + 1)))
continue;
var isTrue = true;
for(var l = 0; l < tempArray.length - 1; l++)
{
var rotatePoint = this.calculatePointManual(tempArray[l].x, tempArray[l].y, tempArray[l].z, this.cameraDiffX, -diffY, minZ);
var tempY11 = rotatePoint.y;
if(y1 < y2)
{
if(tempY11 < y1 || tempY11 > y2)
{
isTrue = false;
break;
}
}
else
{
if(tempY11 > y1 || tempY11 < y2)
{
isTrue = false;
break;
}
}
}
if(isTrue)
break;
}
return {diffY: diffY, tempX1: tempX1, tempY1: tempY1, tempZ1: tempZ1, tempX2: tempX2, tempY2: tempY2, tempZ2: tempZ2};
};
Processor3D.prototype._getArrayAllVergeCube = function(points)
{
var res = [];
res[0] = points[0];
res[1] = points[1];
res[2] = points[2];
res[3] = points[3];
res[4] = points[0];
res[5] = points[4];
res[6] = points[7];
res[7] = points[6];
res[8] = points[5];
res[9] = points[2];
res[10] = points[6];
res[11] = points[1];
res[12] = points[7];
res[13] = points[0];
res[14] = points[5];
res[15] = points[1];
res[16] = points[4];
res[17] = points[3];
res[18] = points[6];
res[19] = points[0];
res[20] = points[2];
res[21] = points[7];
res[22] = points[3];
res[23] = points[5];
res[24] = points[7];
res[25] = points[4];
res[26] = points[2];
res[27] = points[3];
res[28] = points[1];
res[29] = points[4];
res[30] = points[5];
res[31] = points[6];
res[32] = points[4];
/*for(var i = 0; i < points.length; i++)
{
for(var j = 0; j < points.length; j++)
{
res.push(points[i]);
res.push(points[j]);
}
}*/
return res;
};
Processor3D.prototype._getMinMaxOyPoints2 = function(points, minZ)
{
var t = this;
var h = t.heightCanvas;
var tempArray = [];
tempArray[0] = points[0];//leftNear
tempArray[1] = points[1];//leftFar
tempArray[2] = points[2];//rightFar
tempArray[3] = points[3];//rightNear
tempArray[4] = points[4];//leftNear
tempArray[5] = points[5];//leftFar
tempArray[6] = points[6];//leftFar
tempArray[7] = points[7];//leftFar
tempArray[8] = points[4];//leftFar
tempArray[9] = points[1];//leftFar
tempArray[10] = points[3];//leftFar
tempArray[11] = points[0];//leftFar
tempArray[12] = points[7];//leftFar
tempArray[13] = points[2];//leftFar
tempArray[14] = points[0];//leftFar
tempArray[15] = points[6];//leftFar
tempArray[16] = points[5];//leftFar
tempArray[17] = points[0];//leftFar
tempArray[18] = points[4];//leftFar
var tempX1, tempY1, tempZ1, tempX2, tempY2, tempZ2;
for(var i = 0; i < tempArray.length - 1; i++)
{
var start = i;
var end = i + 1;
tempX1 = tempArray[start].x;
tempY1 = tempArray[start].y;
tempZ1 = tempArray[start].z;
tempX2 = tempArray[end].x;
tempY2 = tempArray[end].y;
tempZ2 = tempArray[end].z;
if(tempY1 > tempY2)
{
start = i + 1;
end = i;
tempX1 = tempArray[start].x;
tempY1 = tempArray[start].y;
tempZ1 = tempArray[start].z;
tempX2 = tempArray[end].x;
tempY2 = tempArray[end].y;
tempZ2 = tempArray[end].z;
}
//var diffY = calculateDiffY(tempX1, tempX2, tempY1, tempY2, tempZ1, tempZ2, minZ);
var correctOffset = this._correctZPositionOY(tempX1, tempX2, tempZ1, tempZ2, minZ, tempY1, tempY2);
var diffZ = correctOffset.minZ;
var diffY = correctOffset.diffY;
var rotatePoint1 = this.calculatePointManual(tempX1, tempY1, tempZ1, this.cameraDiffX, diffY, diffZ);
var y1 = rotatePoint1.y;
var rotatePoint2 = this.calculatePointManual(tempX2, tempY2, tempZ2, this.cameraDiffX, diffY, diffZ);
var y2 = rotatePoint2.y;
var topMargin = y1;
var bottomMargin = Math.floor(h - y2);
if(!((topMargin >= bottomMargin - 1) && (topMargin <= bottomMargin + 1)))
continue;
var isTrue = true;
for(var l = 0; l < tempArray.length - 1; l++)
{
var rotatePoint = this.calculatePointManual(tempArray[l].x, tempArray[l].y, tempArray[l].z, this.cameraDiffX, diffY, diffZ);
var tempY11 = rotatePoint.y;
if(y1 < y2)
{
if(tempY11 < y1 || tempY11 > y2)
{
isTrue = false;
break;
}
}
else
{
if(tempY11 > y1 || tempY11 < y2)
{
isTrue = false;
break;
}
}
}
if(isTrue)
break;
}
return {diffY: diffY, tempX1: tempX1, tempY1: tempY1, tempZ1: tempZ1, tempX2: tempX2, tempY2: tempY2, tempZ2: tempZ2, diffZ: diffZ};
};
Processor3D.prototype._correctZPosition4 = function(x1, x2, z1, z2, minZ, y1, y2)
{
var t = this;
var getDiffXZ3 = function(x1, x2, z1, z2, y1, y2)
{
var w = t.widthCanvas;
var fov = 1 / t.rPerspective;
var diffAndScalePoints = t.diffAndScale(x1, y1, z1);
var x11 = diffAndScalePoints.x;
var y11 = diffAndScalePoints.y;
var z11 = diffAndScalePoints.z;
var rotatePoints = t.rotate(x11, y11, z11);
var x111 = rotatePoints.x;
var z111 = rotatePoints.z;
/*var x1111 = x111 + diffX;
var y1111 = y111 + diffY;
var z1111 = z111 + diffZ;
var x11111 = (fov * x1111) / (z1111 + fov) + w / 2;
var y11111 = (fov * y1111) / (z1111 + fov) + h / 2;*/
//(fov * x1111) / (z1111 + fov) + w / 2 = t.left
//(fov * (x111 + diffX)) / ((z111 + diffZ) + fov) + w / 2 = t.left
var wL = t.left - w / 2;
//fov * (x111 + diffX) = wL * ((z111 + diffZ) + fov)
//fov * x111 + fov * diffX = wL * z111 + wL * diffZ + wL * fov
diffAndScalePoints = t.diffAndScale(x2, y2, z2);
var x22 = diffAndScalePoints.x;
var y22 = diffAndScalePoints.y;
var z22 = diffAndScalePoints.z;
rotatePoints = t.rotate(x22, y22, z22);
var x222 = rotatePoints.x;
var z222 = rotatePoints.z;
/*var x1111 = x111 + diffX;
var y1111 = y111 + diffY;
var z1111 = z111 + diffZ;
var x11111 = (fov * x1111) / (z1111 + fov) + w / 2;
var y11111 = (fov * y1111) / (z1111 + fov) + h / 2;*/
var wR = w / 2 - t.left;
//fov * (x222 + diffX) = wR * ((z222 + diffZ) + fov)
//fov * x222 + fov * diffX = wR * z222 + wR * diffZ + wR * fov
//итого
//fov * x111 + fov * diffX = wL * z111 + wL * diffZ + wL * fov
//fov * x222 + fov * diffX = wR * z222 + wR * diffZ + wR * fov
/*diffX = (wL * z111 + wL * diffZ + wL * fov - fov * x111) / fov;
fov * x222 + wL * z111 + wL * diffZ + wL * fov - fov * x111 = wR * z222 + wR * diffZ + wR * fov
fov * x222 + wL * z111 + wL * fov - fov * x111 - wR * z222 - wR * fov = wR * diffZ - wL * diffZ*/
var diffZ = (fov * x222 + wL * z111 + wL * fov - fov * x111 - wR * z222 - wR * fov) / (wR - wL);
var diffX = (wL * z111 + wL * diffZ + wL * fov - fov * x111) / fov;
return {minZ: diffZ, diffX: diffX};
};
var diffXZ3 = getDiffXZ3(x1, x2, z1, z2, y1, y2);
return {minZ: diffXZ3.minZ, diffX: diffXZ3.diffX};
};
Processor3D.prototype._correctZPositionOY = function(x1, x2, z1, z2, minZ, y1, y2)
{
var t = this;
var getDiffXZ3 = function(x1, x2, z1, z2, y1, y2)
{
var h = t.heightCanvas;
var fov = 1 / t.rPerspective;
var diffAndScalePoints = t.diffAndScale(x1, y1, z1);
var x11 = diffAndScalePoints.x;
var y11 = diffAndScalePoints.y;
var z11 = diffAndScalePoints.z;
var rotatePoints = t.rotate(x11, y11, z11);
var y111 = rotatePoints.y;
var z111 = rotatePoints.z;
/*var x1111 = x111 + diffX;
var y1111 = y111 + diffY;
var z1111 = z111 + diffZ;
var x11111 = (fov * x1111) / (z1111 + fov) + w / 2;
var y11111 = (fov * y1111) / (z1111 + fov) + h / 2;*/
//(fov * x1111) / (z1111 + fov) + w / 2 = t.left
//(fov * (x111 + diffX)) / ((z111 + diffZ) + fov) + w / 2 = t.left
//var wL = t.left - w / 2;
//fov * (x111 + diffX) = wL * ((z111 + diffZ) + fov)
//fov * x111 + fov * diffX = wL * z111 + wL * diffZ + wL * fov
diffAndScalePoints = t.diffAndScale(x2, y2, z2);
var x22 = diffAndScalePoints.x;
var y22 = diffAndScalePoints.y;
var z22 = diffAndScalePoints.z;
rotatePoints = t.rotate(x22, y22, z22);
var y222 = rotatePoints.y;
var z222 = rotatePoints.z;
/*var x1111 = x111 + diffX;
var y1111 = y111 + diffY;
var z1111 = z111 + diffZ;
var x11111 = (fov * x1111) / (z1111 + fov) + w / 2;
var y11111 = (fov * y1111) / (z1111 + fov) + h / 2;*/
//(fov * (y111 + diffY)) / ((z111 + diffZ) + fov) + h / 2 = t.top
//(fov * (y222 + diffY)) / ((z222 + diffZ) + fov) + h / 2 = h - t.bottom
var wL = t.top - h / 2;
var wR = h / 2 - t.bottom;
/*(fov * (y111 + diffY)) / ((z111 + diffZ) + fov) = wL
(fov * (y222 + diffY)) / ((z222 + diffZ) + fov) = wR
fov * (y111 + diffY) = wL * ((z111 + diffZ) + fov)
fov * y111 + fov * diffY = wL * z111 + wL * diffZ + wL * fov
fov * y222 + fov * diffY = wR * z222 + wR * diffZ + wR * fov
diffY = (wR * z222 + wR * diffZ + wR * fov - fov * y222) / fov
fov * y111 + wR * z222 + wR * diffZ + wR * fov - fov * y222 = wL * z111 + wL * diffZ + wL * fov
fov * y111 + wR * z222 + wR * fov - fov * y222 - wL * z111 - wL * fov = wL * diffZ - wR * diffZ*/
var diffZ = (fov * y111 + wR * z222 + wR * fov - fov * y222 - wL * z111 - wL * fov) / (wL - wR);
var diffY = (wR * z222 + wR * diffZ + wR * fov - fov * y222) / fov;
//var diffZ = (fov * x222 + wL * z111 + wL * fov - fov * x111 - wR * z222 - wR * fov) / (wR - wL);
//var diffX = (wL * z111 + wL * diffZ + wL * fov - fov * x111) / fov;
return {minZ: diffZ, diffY: diffY};
};
var diffXZ3 = getDiffXZ3(x1, x2, z1, z2, y1, y2);
return {minZ: diffXZ3.minZ, diffY: diffXZ3.diffY};
};
Processor3D.prototype._calculateCameraDiffZ = function (points, faces)
{
var widthCanvas = this.widthCanvas;
var originalWidthChart = widthCanvas - this.left - this.right;
var heightCanvas = this.heightCanvas;
var heightChart = heightCanvas - this.top - this.bottom;
var widthChart = originalWidthChart;
var depthChart = this.depthPerspective;
var minMaxOx = this._getMinMaxOx(points, faces);
var point1 = this.convertAndTurnPoint(minMaxOx.mostLeftPointX.x, minMaxOx.mostLeftPointX.y, minMaxOx.mostLeftPointX.z, true);
var point2 = this.convertAndTurnPoint(minMaxOx.mostRightPointX.x, minMaxOx.mostRightPointX.y, minMaxOx.mostRightPointX.z, true);
var x1 = point1.x;
var x2 = point2.x;
var y1 = point1.y;
var y2 = point2.y;
var diffX = Math.abs(x1 - x2);
var diffY = Math.abs(y1 - y2);
//TODO медленная функция, рассчитать сдвиги!
while(diffX > widthChart || diffY > heightChart)
{
var minMaxOx = this._getMinMaxOx(points, faces);
var point1 = this.convertAndTurnPoint(minMaxOx.mostLeftPointX.x, minMaxOx.mostLeftPointX.y, minMaxOx.mostLeftPointX.z, true);
var point2 = this.convertAndTurnPoint(minMaxOx.mostRightPointX.x, minMaxOx.mostRightPointX.y, minMaxOx.mostRightPointX.z, true);
var x1 = point1.x;
var x2 = point2.x;
var y1 = point1.y;
var y2 = point2.y;
var leftMargin = this.left - x1;
var rightMargin = x2 - (this.left + originalWidthChart);
var topMargin = this.top - y1;
var bottomMargin = y2 - (this.top + heightChart);
if(leftMargin > rightMargin)
{
this.cameraDiffX++;
}
else
{
this.cameraDiffX--;
}
var diffX = Math.abs(x1 - x2);
var diffY = Math.abs(y1 - y2);
this.cameraDiffZ++;
}
var minMaxOy = this._getMinMaxOy(points, faces);
var point1 = this.convertAndTurnPoint(minMaxOy.mostTopPointY.x, minMaxOy.mostTopPointY.y, minMaxOy.mostTopPointY.z, true); var point1 = this.convertAndTurnPoint(minMaxOy.mostTopPointY.x, minMaxOy.mostTopPointY.y, minMaxOy.mostTopPointY.z, true);
var point2 = this.convertAndTurnPoint(minMaxOy.mostBottomPointY.x, minMaxOy.mostBottomPointY.y, minMaxOy.mostBottomPointY.z, true); var point2 = this.convertAndTurnPoint(minMaxOy.mostBottomPointY.x, minMaxOy.mostBottomPointY.y, minMaxOy.mostBottomPointY.z, true);
var y1 = point1.y; var y1 = point1.y;
...@@ -1130,8 +2031,6 @@ Processor3D.prototype._calculateCameraDiffX = function (minMaxOx) ...@@ -1130,8 +2031,6 @@ Processor3D.prototype._calculateCameraDiffX = function (minMaxOx)
//так ближе к тому, как смещает excel //так ближе к тому, как смещает excel
var left = this.left;
var right = this.right;
var widthCanvas = this.widthCanvas; var widthCanvas = this.widthCanvas;
var originalWidthChart = widthCanvas - this.left - this.right; var originalWidthChart = widthCanvas - this.left - this.right;
...@@ -1259,8 +2158,6 @@ Processor3D.prototype._getMinMaxOy = function (points, faces) ...@@ -1259,8 +2158,6 @@ Processor3D.prototype._getMinMaxOy = function (points, faces)
var point1 = this.convertAndTurnPoint(points[faces[i][k]].x, points[faces[i][k]].y, points[faces[i][k]].z, true); var point1 = this.convertAndTurnPoint(points[faces[i][k]].x, points[faces[i][k]].y, points[faces[i][k]].z, true);
var point2 = this.convertAndTurnPoint(points[faces[i][k + 1]].x, points[faces[i][k + 1]].y, points[faces[i][k + 1]].z, true); var point2 = this.convertAndTurnPoint(points[faces[i][k + 1]].x, points[faces[i][k + 1]].y, points[faces[i][k + 1]].z, true);
var x1 = point1.x;
var x2 = point2.x;
var y1 = point1.y; var y1 = point1.y;
var y2 = point2.y; var y2 = point2.y;
...@@ -1307,11 +2204,14 @@ Processor3D.prototype._calcAspectRatio = function() ...@@ -1307,11 +2204,14 @@ Processor3D.prototype._calcAspectRatio = function()
var aspectRatioX = 1; var aspectRatioX = 1;
var aspectRatioY = 1; var aspectRatioY = 1;
var sinOx = Math.sin(-this.angleOx);
var sinOy = Math.sin(-this.angleOy);
var subType = this.chartsDrawer.calcProp.subType; var subType = this.chartsDrawer.calcProp.subType;
if(subType === "standard" || this.chartsDrawer.calcProp.type === "Line" || (this.chartsDrawer.calcProp.type === "Area" && subType == "normal")) if((subType === "standard" || this.chartsDrawer.calcProp.type === "Line") && !this.view3D.rAngAx)
{
this._calcSpecialStandardScaleX();
aspectRatioX = (widthOriginalChart / (heightOriginalChart / hPercent)) * this.specialStandardScaleX;
}
else if(subType === "standard" || this.chartsDrawer.calcProp.type === "Line" || (this.chartsDrawer.calcProp.type === "Area" && subType == "normal"))
{ {
var seriesCount = this.chartsDrawer.calcProp.seriesCount; var seriesCount = this.chartsDrawer.calcProp.seriesCount;
var ptCount = this.chartsDrawer.calcProp.ptCount; var ptCount = this.chartsDrawer.calcProp.ptCount;
...@@ -1324,7 +2224,7 @@ Processor3D.prototype._calcAspectRatio = function() ...@@ -1324,7 +2224,7 @@ Processor3D.prototype._calcAspectRatio = function()
else if(hPercent !== null)//auto scale height else if(hPercent !== null)//auto scale height
aspectRatioX = widthOriginalChart / (heightOriginalChart / hPercent); aspectRatioX = widthOriginalChart / (heightOriginalChart / hPercent);
if(aspectRatioX < 1) if(aspectRatioX < 1 && this.view3D.rAngAx)
{ {
aspectRatioY = 1 / aspectRatioX; aspectRatioY = 1 / aspectRatioX;
aspectRatioX = 1; aspectRatioX = 1;
...@@ -1437,13 +2337,19 @@ Point3D.prototype = ...@@ -1437,13 +2337,19 @@ Point3D.prototype =
for (var i = 0; i < rowsA; i++) C[i] = []; for (var i = 0; i < rowsA; i++) C[i] = [];
for (var k = 0; k < colsB; k++) for (var k = 0; k < colsB; k++)
{ for (var i = 0; i < rowsA; i++) {
{ var temp = 0; for (var i = 0; i < rowsA; i++)
for (var j = 0; j < rowsB; j++) temp += A[i][j]*B[j][k]; {
C[i][k] = temp; var temp = 0;
for (var j = 0; j < rowsB; j++)
{
temp += A[i][j]*B[j][k];
}
C[i][k] = temp;
} }
} }
return C; return C;
} }
} };
\ No newline at end of file
/* /*
* *
* (c) Copyright Ascensio System Limited 2010-2016 * (c) Copyright Ascensio System Limited 2010-2016
* *
* This program is freeware. You can redistribute it and/or modify it under the terms of the GNU * This program is freeware. You can redistribute it and/or modify it under the terms of the GNU
* General Public License (GPL) version 3 as published by the Free Software Foundation (https://www.gnu.org/copyleft/gpl.html). * General Public License (GPL) version 3 as published by the Free Software Foundation (https://www.gnu.org/copyleft/gpl.html).
* In accordance with Section 7(a) of the GNU GPL its Section 15 shall be amended to the effect that * In accordance with Section 7(a) of the GNU GPL its Section 15 shall be amended to the effect that
* Ascensio System SIA expressly excludes the warranty of non-infringement of any third-party rights. * Ascensio System SIA expressly excludes the warranty of non-infringement of any third-party rights.
* *
* THIS PROGRAM IS DISTRIBUTED WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR * THIS PROGRAM IS DISTRIBUTED WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR
* FITNESS FOR A PARTICULAR PURPOSE. For more details, see GNU GPL at https://www.gnu.org/copyleft/gpl.html * FITNESS FOR A PARTICULAR PURPOSE. For more details, see GNU GPL at https://www.gnu.org/copyleft/gpl.html
* *
* You can contact Ascensio System SIA by email at sales@onlyoffice.com * You can contact Ascensio System SIA by email at sales@onlyoffice.com
* *
* The interactive user interfaces in modified source and object code versions of ONLYOFFICE must display * The interactive user interfaces in modified source and object code versions of ONLYOFFICE must display
* Appropriate Legal Notices, as required under Section 5 of the GNU GPL version 3. * Appropriate Legal Notices, as required under Section 5 of the GNU GPL version 3.
* *
* Pursuant to Section 7  3(b) of the GNU GPL you must retain the original ONLYOFFICE logo which contains * Pursuant to Section 7  3(b) of the GNU GPL you must retain the original ONLYOFFICE logo which contains
* relevant author attributions when distributing the software. If the display of the logo in its graphic * relevant author attributions when distributing the software. If the display of the logo in its graphic
* form is not reasonably feasible for technical reasons, you must include the words "Powered by ONLYOFFICE" * form is not reasonably feasible for technical reasons, you must include the words "Powered by ONLYOFFICE"
* in every copy of the program you distribute. * in every copy of the program you distribute.
* Pursuant to Section 7  3(e) we decline to grant you any rights under trademark law for use of our trademarks. * Pursuant to Section 7  3(e) we decline to grant you any rights under trademark law for use of our trademarks.
* *
*/ */
"use strict"; "use strict";
var global3DPersperctive = 30; var global3DPersperctive = 30;
...@@ -217,6 +217,13 @@ CChartsDrawer.prototype = ...@@ -217,6 +217,13 @@ CChartsDrawer.prototype =
this.gridChart.draw(this); this.gridChart.draw(this);
} }
if(this.nDimensionCount === 3)
{
this.cShapeDrawer.bIsNoSmartAttack = true;
this.chart.draw(this);
this.cShapeDrawer.bIsNoSmartAttack = false;
}
if(this.calcProp.type != "Pie" && this.calcProp.type != "DoughnutChart") if(this.calcProp.type != "Pie" && this.calcProp.type != "DoughnutChart")
{ {
this.catAxisChart.draw(this); this.catAxisChart.draw(this);
...@@ -224,9 +231,12 @@ CChartsDrawer.prototype = ...@@ -224,9 +231,12 @@ CChartsDrawer.prototype =
this.serAxisChart.draw(this); this.serAxisChart.draw(this);
} }
this.cShapeDrawer.bIsNoSmartAttack = true; if(this.nDimensionCount !== 3)
this.chart.draw(this); {
this.cShapeDrawer.bIsNoSmartAttack = false; this.cShapeDrawer.bIsNoSmartAttack = true;
this.chart.draw(this);
this.cShapeDrawer.bIsNoSmartAttack = false;
}
} }
}, },
...@@ -693,10 +703,12 @@ CChartsDrawer.prototype = ...@@ -693,10 +703,12 @@ CChartsDrawer.prototype =
var valAx = chartSpace.chart.plotArea.valAx; var valAx = chartSpace.chart.plotArea.valAx;
var catAx = chartSpace.chart.plotArea.catAx; var catAx = chartSpace.chart.plotArea.catAx;
var orientationValAx = valAx && valAx.scaling.orientation === ORIENTATION_MIN_MAX ? true : false;
var orientationCatAx = catAx && catAx.scaling.orientation === ORIENTATION_MIN_MAX ? true : false;
if(isHBar === 'HBar' && catAx && valAx && catAx.yPoints && valAx.xPoints) if(isHBar === 'HBar' && catAx && valAx && catAx.yPoints && valAx.xPoints)
{ {
if(catAx.scaling.orientation == ORIENTATION_MIN_MAX) if(orientationCatAx)
{ {
if(valAx.crossBetween == CROSS_BETWEEN_BETWEEN) if(valAx.crossBetween == CROSS_BETWEEN_BETWEEN)
leftDownPointY = catAx.yPoints[0].pos + Math.abs((catAx.interval) / 2); leftDownPointY = catAx.yPoints[0].pos + Math.abs((catAx.interval) / 2);
...@@ -712,14 +724,14 @@ CChartsDrawer.prototype = ...@@ -712,14 +724,14 @@ CChartsDrawer.prototype =
} }
if(valAx.scaling.orientation == ORIENTATION_MIN_MAX) if(orientationValAx)
leftDownPointX = valAx.xPoints[0].pos; leftDownPointX = valAx.xPoints[0].pos;
else else
leftDownPointX = valAx.xPoints[valAx.xPoints.length - 1].pos; leftDownPointX = valAx.xPoints[valAx.xPoints.length - 1].pos;
if(catAx.scaling.orientation == ORIENTATION_MIN_MAX) if(orientationCatAx)
{ {
if(valAx.crossBetween == CROSS_BETWEEN_BETWEEN) if(valAx.crossBetween == CROSS_BETWEEN_BETWEEN)
rightUpPointY = catAx.yPoints[catAx.yPoints.length - 1].pos - Math.abs((catAx.interval) / 2); rightUpPointY = catAx.yPoints[catAx.yPoints.length - 1].pos - Math.abs((catAx.interval) / 2);
...@@ -735,7 +747,7 @@ CChartsDrawer.prototype = ...@@ -735,7 +747,7 @@ CChartsDrawer.prototype =
} }
if(valAx.scaling.orientation == ORIENTATION_MIN_MAX) if(orientationValAx)
rightUpPointX = valAx.xPoints[valAx.xPoints.length - 1].pos; rightUpPointX = valAx.xPoints[valAx.xPoints.length - 1].pos;
else else
rightUpPointX = valAx.xPoints[0].pos; rightUpPointX = valAx.xPoints[0].pos;
...@@ -771,10 +783,10 @@ CChartsDrawer.prototype = ...@@ -771,10 +783,10 @@ CChartsDrawer.prototype =
else if(isHBar === 'Scatter' && catAx && valAx && catAx.xPoints && valAx.yPoints) else if(isHBar === 'Scatter' && catAx && valAx && catAx.xPoints && valAx.yPoints)
{ {
leftDownPointX = catAx.xPoints[0].pos; leftDownPointX = catAx.xPoints[0].pos;
leftDownPointY = valAx.scaling.orientation == ORIENTATION_MIN_MAX ? valAx.yPoints[0].pos : valAx.yPoints[valAx.yPoints.length - 1].pos; leftDownPointY = orientationValAx ? valAx.yPoints[0].pos : valAx.yPoints[valAx.yPoints.length - 1].pos;
rightUpPointX = catAx.xPoints[catAx.xPoints.length - 1].pos; rightUpPointX = catAx.xPoints[catAx.xPoints.length - 1].pos;
rightUpPointY = valAx.scaling.orientation == ORIENTATION_MIN_MAX ? valAx.yPoints[valAx.yPoints.length - 1].pos : valAx.yPoints[0].pos; rightUpPointY = orientationValAx ? valAx.yPoints[valAx.yPoints.length - 1].pos : valAx.yPoints[0].pos;
if(valAx.labels && !valAx.bDelete) if(valAx.labels && !valAx.bDelete)
{ {
...@@ -805,7 +817,7 @@ CChartsDrawer.prototype = ...@@ -805,7 +817,7 @@ CChartsDrawer.prototype =
} }
else if(isHBar !== undefined && valAx && catAx && catAx.xPoints && valAx.yPoints) else if(isHBar !== undefined && valAx && catAx && catAx.xPoints && valAx.yPoints)
{ {
if(catAx.scaling.orientation != ORIENTATION_MIN_MAX) if(!orientationCatAx)
{ {
leftDownPointX = catAx.xPoints[catAx.xPoints.length - 1].pos - Math.abs((catAx.interval) / 2); leftDownPointX = catAx.xPoints[catAx.xPoints.length - 1].pos - Math.abs((catAx.interval) / 2);
} }
...@@ -817,13 +829,13 @@ CChartsDrawer.prototype = ...@@ -817,13 +829,13 @@ CChartsDrawer.prototype =
leftDownPointX = catAx.xPoints[0].pos; leftDownPointX = catAx.xPoints[0].pos;
} }
if(valAx.scaling.orientation == ORIENTATION_MIN_MAX) if(orientationValAx)
leftDownPointY = valAx.yPoints[0].pos; leftDownPointY = valAx.yPoints[0].pos;
else else
leftDownPointY = valAx.yPoints[valAx.yPoints.length - 1].pos; leftDownPointY = valAx.yPoints[valAx.yPoints.length - 1].pos;
if(catAx.scaling.orientation != ORIENTATION_MIN_MAX) if(!orientationCatAx)
{ {
rightUpPointX = catAx.xPoints[0].pos; rightUpPointX = catAx.xPoints[0].pos;
} }
...@@ -836,7 +848,7 @@ CChartsDrawer.prototype = ...@@ -836,7 +848,7 @@ CChartsDrawer.prototype =
} }
if(valAx.scaling.orientation == ORIENTATION_MIN_MAX) if(orientationValAx)
rightUpPointY = valAx.yPoints[valAx.yPoints.length - 1].pos; rightUpPointY = valAx.yPoints[valAx.yPoints.length - 1].pos;
else else
rightUpPointY = valAx.yPoints[0].pos; rightUpPointY = valAx.yPoints[0].pos;
...@@ -2080,7 +2092,25 @@ CChartsDrawer.prototype = ...@@ -2080,7 +2092,25 @@ CChartsDrawer.prototype =
{ {
return this.processor3D.convertAndTurnPoint(x, y, z); return this.processor3D.convertAndTurnPoint(x, y, z);
}, },
//position of catAx labels(left or right) - returns false(left of axis)/true(right of axis) or null(standard position)
calculatePositionLabelsCatAxFromAngle: function(chartSpace)
{
var res = null;
var angleOy = chartSpace.chart.view3D && chartSpace.chart.view3D.rotY ? (- chartSpace.chart.view3D.rotY / 360) * (Math.PI * 2) : 0;
if(chartSpace.chart.view3D && !chartSpace.chart.view3D.rAngAx && angleOy !== 0)
{
var angleOy = Math.abs(angleOy);
if(angleOy >= Math.PI / 2 && angleOy < 3 * Math.PI / 2)
res = true;
else
res = false;
}
return res;
},
//****accessory functions**** //****accessory functions****
...@@ -2525,7 +2555,7 @@ CChartsDrawer.prototype = ...@@ -2525,7 +2555,7 @@ CChartsDrawer.prototype =
var chart = chartSpace && chartSpace.chart ? chartSpace.chart.plotArea.chart: null; var chart = chartSpace && chartSpace.chart ? chartSpace.chart.plotArea.chart: null;
var typeChart = chart ? chart.getObjectType() : null; var typeChart = chart ? chart.getObjectType() : null;
if(isTurnOn3DCharts && chartSpace && chartSpace.chart.view3D && chartSpace.chart.view3D.rAngAx && ((typeChart === historyitem_type_BarChart && chart && chart.barDir !== BAR_DIR_BAR) || (typeChart === historyitem_type_LineChart) || (typeChart === historyitem_type_BarChart && chart.barDir === BAR_DIR_BAR) /*|| (typeChart === historyitem_type_AreaChart)*/ || (typeChart === historyitem_type_PieChart))) if(isTurnOn3DCharts && chartSpace && chartSpace.chart.view3D /*&& chartSpace.chart.view3D.rAngAx*/ && ((typeChart === historyitem_type_BarChart && chart && chart.barDir !== BAR_DIR_BAR) || (typeChart === historyitem_type_LineChart) || (typeChart === historyitem_type_BarChart && chart.barDir === BAR_DIR_BAR) /*|| (typeChart === historyitem_type_AreaChart)*/ || (typeChart === historyitem_type_PieChart)))
{ {
res = true; res = true;
} }
...@@ -2928,109 +2958,411 @@ drawBarChart.prototype = ...@@ -2928,109 +2958,411 @@ drawBarChart.prototype =
_DrawBars3D: function() _DrawBars3D: function()
{ {
var t = this; var t = this;
var draw = function(onlyLessNull) var processor3D = this.cChartDrawer.processor3D;
var directionDraw =
{
onPoints: 0,
reversePointsOnPoints: 1,
reverseSeriesOnPoints: 2,
reverseSeriesPointsOnPoints: 3,
onSeries: 4,
reversePointsOnSeries: 5,
reverseSeriesOnSeries: 6,
reversePointsSeriesOnSeries: 7
};
var verges =
{
front: 0,
down: 1,
left: 2,
right: 3,
up: 4,
unfront: 5
};
var drawVerges = function(j, i, onlyLessNull, start, stop)
{ {
var brush, pen, options; var brush, pen, options;
for (var i = 0; i < t.chartProp.ptCount; i++) options = t._getOptionsForDrawing(j, i, onlyLessNull);
if(options !== null)
{ {
if(!t.paths.series) pen = options.pen;
return; brush = options.brush;
for (var j = 0; j < t.paths.series.length; ++j) for(var k = start; k <= stop; k++)
{ {
options = t._getOptionsForDrawing(j, i, onlyLessNull); t._drawBar3D(t.paths.series[j][i][k], pen, brush, k);
if(options !== null) }
}
};
//рисуем по точкам
var onPoints = function(onlyLessNull)
{
var drawNeedVerge = function(start, stop)
{
for (var i = 0; i < t.chartProp.ptCount; i++)
{
if(!t.paths.series)
return;
for (var j = 0; j < t.paths.series.length; ++j)
{ {
pen = options.pen; drawVerges(j, i, onlyLessNull, start, stop);
brush = options.brush;
} }
else }
continue; };
var angleOx = Math.abs(processor3D.angleOx);
var angleOy = Math.abs(processor3D.angleOy);
if(angleOx === 0)//тестировал все повороты вокруг OY, без обратных осей
{
drawNeedVerge(verges.down, verges.up);
drawNeedVerge(verges.unfront, verges.unfront);
drawNeedVerge(verges.front, verges.front);
}
else if(angleOx !== 0 && angleOy === 0)
{
drawNeedVerge(verges.right, verges.right);
drawNeedVerge(verges.left, verges.left);
drawNeedVerge(verges.unfront, verges.unfront);
drawNeedVerge(verges.up, verges.up);
drawNeedVerge(verges.down, verges.down);
drawNeedVerge(verges.front, verges.front);
}
else
{
drawNeedVerge(verges.down, verges.up);
drawNeedVerge(verges.unfront, verges.unfront);
drawNeedVerge(verges.front, verges.front);
}
};
var reverseSeriesOnPoints = function(onlyLessNull)
{
var drawNeedVerge = function(start, stop)
{
for (var i = 0; i < t.chartProp.ptCount; i++)
{
if(!t.paths.series)
return;
for(var k = 0; k < t.paths.series[j][i].length; k++) for (var j = t.paths.series.length - 1; j >= 0; --j)
{ {
t._drawBar3D(t.paths.series[j][i][k], pen, brush, k); drawVerges(j, i, onlyLessNull, start, stop);
} }
} }
} };
drawNeedVerge(verges.front, verges.unfront);
}; };
var drawReverse = function(onlyLessNull) var reverseSeriesPointsOnPoints = function(onlyLessNull)
{ {
var brush, pen, options; var drawNeedVerge = function(start, stop)
for (var i = 0; i < t.chartProp.ptCount; i++)
{ {
if(!t.paths.series) for (var i = t.chartProp.ptCount - 1; i >= 0; --i)
return;
for (var j = t.paths.series.length - 1; j >= 0; --j)
{ {
options = t._getOptionsForDrawing(j, i, onlyLessNull); if(!t.paths.series)
if(options !== null) return;
for (var j = t.paths.series.length - 1; j >= 0; --j)
{ {
pen = options.pen; drawVerges(j, i, onlyLessNull, start, stop);
brush = options.brush;
} }
else }
continue; };
drawNeedVerge(verges.down, verges.unfront);
drawNeedVerge(verges.front, verges.front);
};
var reversePointsOnPoints = function(onlyLessNull)
{
var drawNeedVerge = function(start, stop)
{
for (var i = t.chartProp.ptCount - 1; i >= 0; --i)
{
if(!t.paths.series)
return;
for(var k = 0; k < t.paths.series[j][i].length; k++) for (var j = 0; j < t.paths.series.length; j++)
{ {
t._drawBar3D(t.paths.series[j][i][k], pen, brush, k); drawVerges(j, i, onlyLessNull, start, stop);
} }
} }
} };
drawNeedVerge(verges.front, verges.unfront);
}; };
if(this.chartProp.subType === "standard")
//рисуем по сериям
var onSeries = function(onlyLessNull)
{ {
//вторую половину с конца рисуем var drawNeedVerge = function(start, stop)
var brush, pen, options; {
for (var j = 0; j < t.paths.series.length; j++)
{
if(!t.paths.series)
return;
for (var i = 0; i < t.chartProp.ptCount; i++)
{
drawVerges(j, i, onlyLessNull, start, stop);
}
}
};
if(!this.paths.series) drawNeedVerge(verges.front, verges.unfront);
return; };
var reversePointsOnSeries = function(onlyLessNull)
{
var drawNeedVerge = function(start, stop)
{
for (var j = 0; j < t.paths.series.length; j++)
{
if(!t.paths.series)
return;
for (var i = t.chartProp.ptCount - 1; i >= 0; i--)
{
drawVerges(j, i, onlyLessNull, start, stop);
}
}
};
for (var i = this.paths.series.length - 1; i >= 0; i--) { drawNeedVerge(verges.front, verges.unfront);
for (var j = this.chartProp.ptCount - 1; j >= 0; j--) { };
var reverseSeriesOnSeries = function(onlyLessNull)
{
var drawNeedVerge = function(start, stop)
{
for (var j = t.paths.series.length - 1; j >= 0; j--)
{
if(!t.paths.series)
return;
options = t._getOptionsForDrawing(i, j); for (var i = 0; i < t.chartProp.ptCount; i++)
if(options !== null)
{ {
pen = options.pen; drawVerges(j, i, onlyLessNull, start, stop);
brush = options.brush;
} }
else }
continue; };
drawNeedVerge(verges.front, verges.unfront);
};
var reversePointsSeriesOnSeries = function(onlyLessNull)
{
var drawNeedVerge = function(start, stop)
{
for (var j = t.paths.series.length - 1; j >= 0; j--)
{
if(!t.paths.series)
return;
for(var k = 0; k < this.paths.series[i][j].length; k++) for (var i = t.chartProp.ptCount - 1; i >= 0; i--)
{ {
this._drawBar3D(this.paths.series[i][j][k], pen, brush, k); drawVerges(j, i, onlyLessNull, start, stop);
} }
} }
};
drawNeedVerge(verges.front, verges.unfront);
};
var direction = this._calculateDirectionDraw3D(directionDraw);
for(var n = 0; n < direction.length; n++)
{
switch (direction[n].res)
{
case directionDraw.onPoints:
{
onPoints(direction[n].isLess);
break;
}
case directionDraw.reversePointsOnPoints:
{
reversePointsOnPoints(direction[n].isLess);
break;
}
case directionDraw.reverseSeriesOnPoints:
{
reverseSeriesOnPoints(direction[n].isLess);
break;
}
case directionDraw.reverseSeriesPointsOnPoints:
{
reverseSeriesPointsOnPoints(direction[n].isLess);
break;
}
case directionDraw.onSeries:
{
onSeries(direction[n].isLess);
break;
}
case directionDraw.reversePointsOnSeries:
{
reversePointsOnSeries(direction[n].isLess);
break;
}
case directionDraw.reverseSeriesOnSeries:
{
reverseSeriesOnSeries(direction[n].isLess);
break;
}
case directionDraw.reversePointsSeriesOnSeries:
{
reversePointsSeriesOnSeries(direction[n].isLess);
break;
}
} }
} }
else if(this.chartProp.subType == "stacked" || this.chartProp.subType == "stackedPer")
},
_calculateDirectionDraw3D: function(directionDraw)
{
var res = [];
var processor3D = this.cChartDrawer.processor3D;
var t = this;
//NOT PERSPECTIVE
var calculateDirectionNoPerspective = function()
{ {
if(this.cChartSpace.chart.plotArea.valAx.scaling.orientation === ORIENTATION_MIN_MAX) if(t.cChartSpace.chart.view3D.rAngAx)
{ {
drawReverse(true); if(t.chartProp.subType === "standard")
draw(false); {
res.push({res: directionDraw.reversePointsSeriesOnSeries, isLess: false});
}
else if(t.chartProp.subType == "stacked" || t.chartProp.subType == "stackedPer")
{
if(t.cChartSpace.chart.plotArea.valAx.scaling.orientation === ORIENTATION_MIN_MAX)
{
res.push({res: directionDraw.reverseSeriesOnPoints, isLess: true});
res.push({res: directionDraw.onPoints, isLess: false});
}
else
{
res.push({res: directionDraw.reverseSeriesOnPoints, isLess: false});
res.push({res: directionDraw.onPoints, isLess: true});
}
}
else
{
if(t.cChartSpace.chart.plotArea.catAx.scaling.orientation === ORIENTATION_MIN_MAX)
{
res.push({res: directionDraw.onPoints, isLess: false});
}
else
{
res.push({res: directionDraw.reverseSeriesOnPoints, isLess: false});
}
}
}
};
//PERSPECTIVE
var calculateDirectionPerspective = function()
{
if(t.chartProp.subType === "standard")
{
var angle = Math.abs(processor3D.angleOy);
if(angle <= Math.PI / 2)
{
res.push({res: directionDraw.reverseSeriesOnSeries, isLess: true});
res.push({res: directionDraw.reverseSeriesOnSeries, isLess: false});
}
else if(angle <= Math.PI)
{
res.push({res: directionDraw.onSeries, isLess: true});
res.push({res: directionDraw.onSeries, isLess: false});
}
else if(angle <= (3/2) * Math.PI)
{
res.push({res: directionDraw.reversePointsOnSeries, isLess: true});
res.push({res: directionDraw.reversePointsOnSeries, isLess: false});
}
else
{
res.push({res: directionDraw.reversePointsSeriesOnSeries, isLess: true});
res.push({res: directionDraw.reversePointsSeriesOnSeries, isLess: false});
}
}
else if(t.chartProp.subType == "stacked" || t.chartProp.subType == "stackedPer")
{
if(Math.abs(processor3D.angleOy) > Math.PI)
{
if(t.cChartSpace.chart.plotArea.valAx.scaling.orientation === ORIENTATION_MIN_MAX)
{
res.push({res: directionDraw.reversePointsOnPoints, isLess: false});
}
else
{
res.push({res: directionDraw.reverseSeriesOnPoints, isLess: false});
res.push({res: directionDraw.onPoints, isLess: true});
}
}
else
{
if(t.cChartSpace.chart.plotArea.valAx.scaling.orientation === ORIENTATION_MIN_MAX)
{
res.push({res: directionDraw.reverseSeriesOnPoints, isLess: true});
res.push({res: directionDraw.onPoints, isLess: false});
}
else
{
res.push({res: directionDraw.reverseSeriesOnPoints, isLess: false});
res.push({res: directionDraw.onPoints, isLess: true});
}
}
} }
else else
{ {
drawReverse(false); if(t.cChartSpace.chart.plotArea.catAx.scaling.orientation === ORIENTATION_MIN_MAX)
draw(true); {
if(Math.abs(processor3D.angleOy) > Math.PI)
{
res.push({res: directionDraw.reverseSeriesPointsOnPoints, isLess: false});
res.push({res: directionDraw.reverseSeriesPointsOnPoints, isLess: true});
}
else
{
res.push({res: directionDraw.onPoints, isLess: true});
res.push({res: directionDraw.onPoints, isLess: false});
}
}
else
{
res.push({res: directionDraw.reverseSeriesOnPoints, isLess: false});
res.push({res: directionDraw.reverseSeriesOnPoints, isLess: true});
}
} }
};
if(t.cChartSpace.chart.view3D.rAngAx)
{
calculateDirectionNoPerspective();
} }
else else
{ {
if(this.cChartSpace.chart.plotArea.catAx.scaling.orientation === ORIENTATION_MIN_MAX) calculateDirectionPerspective();
draw();
else
drawReverse();
} }
return res;
}, },
_getOptionsForDrawing: function(ser, point, onlyLessNull) _getOptionsForDrawing: function(ser, point, onlyLessNull)
...@@ -3547,27 +3879,80 @@ drawLineChart.prototype = ...@@ -3547,27 +3879,80 @@ drawLineChart.prototype =
_drawLines3D: function() _drawLines3D: function()
{ {
//вторую половину с конца рисуем var t = this;
var brush, pen, seria;
for (var i = this.paths.series.length - 1; i >= 0; i--) { var drawVerges = function(j, i, onlyLessNull)
for (var j = 0; j < this.chartProp.ptCount; j++) { {
seria = this.chartProp.series[i]; var brush, pen, seria;
brush = seria.brush;
pen = seria.pen; seria = t.chartProp.series[j];
brush = seria.brush;
if(!this.paths.series[i] || !this.paths.series[i][j] || !seria.val.numRef.numCache.pts[j]) pen = seria.pen;
continue;
if(!(!t.paths.series[j] || !t.paths.series[j][i] || !seria.val.numRef.numCache.pts[i]))
if(seria.val.numRef.numCache.pts[j].pen) {
pen = seria.val.numRef.numCache.pts[j].pen; if(seria.val.numRef.numCache.pts[i].pen)
if(seria.val.numRef.numCache.pts[j].brush) pen = seria.val.numRef.numCache.pts[i].pen;
brush = seria.val.numRef.numCache.pts[j].brush; if(seria.val.numRef.numCache.pts[i].brush)
brush = seria.val.numRef.numCache.pts[i].brush;
for(var k = 0; k < this.paths.series[i][j].length; k++)
{ for(var k = 0; k < t.paths.series[j][i].length; k++)
this._drawLine3D(this.paths.series[i][j][k], pen, brush, k); {
} t._drawLine3D(t.paths.series[j][i][k], pen, brush, k);
} }
}
};
//рисуем по сериям
var onSeries = function(onlyLessNull)
{
var drawNeedVerge = function()
{
for (var j = 0; j < t.paths.series.length; j++)
{
for (var i = 0; i < t.chartProp.ptCount; i++)
{
drawVerges(j, i, onlyLessNull);
}
}
};
drawNeedVerge();
};
var reverseSeriesOnSeries = function(onlyLessNull)
{
var drawNeedVerge = function()
{
for (var j = t.paths.series.length - 1; j >= 0; j--)
{
if(!t.paths.series)
return;
for (var i = 0; i < t.chartProp.ptCount; i++)
{
drawVerges(j, i, onlyLessNull);
}
}
};
drawNeedVerge();
};
if(!this.cChartDrawer.processor3D.view3D.rAngAx)
{
var angle = Math.abs(this.cChartDrawer.processor3D.angleOy);
if(angle > Math.PI / 2 && angle < 3 * Math.PI / 2)
onSeries();
else
reverseSeriesOnSeries();
}
else
{
reverseSeriesOnSeries();
} }
}, },
...@@ -9004,6 +9389,9 @@ gridChart.prototype = ...@@ -9004,6 +9389,9 @@ gridChart.prototype =
} }
} }
//для того, чтобы отрисовывался один параллелепипед. необходимо верхний FOR закомментировать и раскомментировать то, что внизу. + убрать отрисовку самого chart'a
//this.paths.horisontalLines = [];
//this.paths.horisontalLines.push(this._calculate3DParallalepiped());
}, },
_calculateVerticalLines: function() _calculateVerticalLines: function()
...@@ -9177,6 +9565,91 @@ gridChart.prototype = ...@@ -9177,6 +9565,91 @@ gridChart.prototype =
return path; return path;
}, },
_calculate3DParallalepiped: function()
{
var path = new Path();
var pathH = this.chartProp.pathH;
var pathW = this.chartProp.pathW;
var gdLst = [];
path.pathH = pathH;
path.pathW = pathW;
gdLst["w"] = 1;
gdLst["h"] = 1;
var perspectiveDepth = this.cChartDrawer.processor3D.depthPerspective;
var left = this.chartProp.chartGutter._left;
var right = this.chartProp.chartGutter._right;
var top = this.chartProp.chartGutter._top;
var bottom = this.chartProp.chartGutter._bottom;
var height = this.chartProp.heightCanvas - (top + bottom);
var width = this.chartProp.widthCanvas - (left + right);
var point0 = this.cChartDrawer._convertAndTurnPoint(left, top, perspectiveDepth);
var x0 = point0.x;
var y0 = point0.y;
var point1 = this.cChartDrawer._convertAndTurnPoint(left, top + height, perspectiveDepth);
var x1 = point1.x;
var y1 = point1.y;
var point2 = this.cChartDrawer._convertAndTurnPoint(left + width, top + height, perspectiveDepth);
var x2 = point2.x;
var y2 = point2.y;
var point3 = this.cChartDrawer._convertAndTurnPoint(left + width, top, perspectiveDepth);
var x3 = point3.x;
var y3 = point3.y;
var point4 = this.cChartDrawer._convertAndTurnPoint(left + width, top, 0);
var x4 = point4.x;
var y4 = point4.y;
var point5 = this.cChartDrawer._convertAndTurnPoint(left + width, top + height, 0);
var x5 = point5.x;
var y5 = point5.y;
var point6 = this.cChartDrawer._convertAndTurnPoint(left, top + height, 0);
var x6 = point6.x;
var y6 = point6.y;
var point7 = this.cChartDrawer._convertAndTurnPoint(left, top, 0);
var x7 = point7.x;
var y7 = point7.y;
path.stroke = true;
var pxToMm = this.chartProp.pxToMM;
path.moveTo(x0 / pxToMm * pathW, y0 / pxToMm * pathH);
path.lnTo(x1 / pxToMm * pathW, y1 / pxToMm * pathH);
path.lnTo(x2 / pxToMm * pathW, y2 / pxToMm * pathH);
path.lnTo(x3 / pxToMm * pathW, y3 / pxToMm * pathH);
path.lnTo(x4 / pxToMm * pathW, y4 / pxToMm * pathH);
path.lnTo(x5 / pxToMm * pathW, y5 / pxToMm * pathH);
path.lnTo(x6 / pxToMm * pathW, y6 / pxToMm * pathH);
path.lnTo(x7 / pxToMm * pathW, y7 / pxToMm * pathH);
path.lnTo(x0 / pxToMm * pathW, y0 / pxToMm * pathH);
path.lnTo(x1 / pxToMm * pathW, y1 / pxToMm * pathH);
path.lnTo(x6 / pxToMm * pathW, y6 / pxToMm * pathH);
path.lnTo(x5 / pxToMm * pathW, y5 / pxToMm * pathH);
path.lnTo(x2 / pxToMm * pathW, y2 / pxToMm * pathH);
path.lnTo(x3 / pxToMm * pathW, y3 / pxToMm * pathH);
path.lnTo(x0 / pxToMm * pathW, y0 / pxToMm * pathH);
path.lnTo(x7 / pxToMm * pathW, y7 / pxToMm * pathH);
path.lnTo(x4 / pxToMm * pathW, y4 / pxToMm * pathH);
path.recalculate(gdLst);
return path;
},
_drawHorisontalLines: function() _drawHorisontalLines: function()
{ {
var pen; var pen;
......
/* /*
* *
* (c) Copyright Ascensio System Limited 2010-2016 * (c) Copyright Ascensio System Limited 2010-2016
* *
* This program is freeware. You can redistribute it and/or modify it under the terms of the GNU * This program is freeware. You can redistribute it and/or modify it under the terms of the GNU
* General Public License (GPL) version 3 as published by the Free Software Foundation (https://www.gnu.org/copyleft/gpl.html). * General Public License (GPL) version 3 as published by the Free Software Foundation (https://www.gnu.org/copyleft/gpl.html).
* In accordance with Section 7(a) of the GNU GPL its Section 15 shall be amended to the effect that * In accordance with Section 7(a) of the GNU GPL its Section 15 shall be amended to the effect that
* Ascensio System SIA expressly excludes the warranty of non-infringement of any third-party rights. * Ascensio System SIA expressly excludes the warranty of non-infringement of any third-party rights.
* *
* THIS PROGRAM IS DISTRIBUTED WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR * THIS PROGRAM IS DISTRIBUTED WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR
* FITNESS FOR A PARTICULAR PURPOSE. For more details, see GNU GPL at https://www.gnu.org/copyleft/gpl.html * FITNESS FOR A PARTICULAR PURPOSE. For more details, see GNU GPL at https://www.gnu.org/copyleft/gpl.html
* *
* You can contact Ascensio System SIA by email at sales@onlyoffice.com * You can contact Ascensio System SIA by email at sales@onlyoffice.com
* *
* The interactive user interfaces in modified source and object code versions of ONLYOFFICE must display * The interactive user interfaces in modified source and object code versions of ONLYOFFICE must display
* Appropriate Legal Notices, as required under Section 5 of the GNU GPL version 3. * Appropriate Legal Notices, as required under Section 5 of the GNU GPL version 3.
* *
* Pursuant to Section 7  3(b) of the GNU GPL you must retain the original ONLYOFFICE logo which contains * Pursuant to Section 7  3(b) of the GNU GPL you must retain the original ONLYOFFICE logo which contains
* relevant author attributions when distributing the software. If the display of the logo in its graphic * relevant author attributions when distributing the software. If the display of the logo in its graphic
* form is not reasonably feasible for technical reasons, you must include the words "Powered by ONLYOFFICE" * form is not reasonably feasible for technical reasons, you must include the words "Powered by ONLYOFFICE"
* in every copy of the program you distribute. * in every copy of the program you distribute.
* Pursuant to Section 7  3(e) we decline to grant you any rights under trademark law for use of our trademarks. * Pursuant to Section 7  3(e) we decline to grant you any rights under trademark law for use of our trademarks.
* *
*/ */
"use strict"; "use strict";
var EFFECT_NONE = 0; var EFFECT_NONE = 0;
...@@ -2632,6 +2632,15 @@ CChartSpace.prototype = ...@@ -2632,6 +2632,15 @@ CChartSpace.prototype =
return true; return true;
}, },
getNeedReflect: function()
{
if(!this.chartObj)
{
this.chartObj = new CChartsDrawer();
}
return this.chartObj.calculatePositionLabelsCatAxFromAngle(this);
},
recalculateAxis: function() recalculateAxis: function()
{ {
if(this.chart && this.chart.plotArea && this.chart.plotArea.chart) if(this.chart && this.chart.plotArea && this.chart.plotArea.chart)
...@@ -2718,6 +2727,8 @@ CChartSpace.prototype = ...@@ -2718,6 +2727,8 @@ CChartSpace.prototype =
} }
return; return;
} }
var bNeedReflect = this.getNeedReflect();
if(chart_type === historyitem_type_ScatterChart) if(chart_type === historyitem_type_ScatterChart)
{ {
var x_ax, y_ax; var x_ax, y_ax;
...@@ -2890,7 +2901,14 @@ CChartSpace.prototype = ...@@ -2890,7 +2901,14 @@ CChartSpace.prototype =
{ {
left_align_labels = false; left_align_labels = false;
right_gap = Math.max(last_hor_label_half_width, y_ax.labels.extX); if(bNeedReflect)
{
right_gap = Math.max(last_hor_label_half_width, 0);
}
else
{
right_gap = Math.max(last_hor_label_half_width, y_ax.labels.extX);
}
hor_interval_width = checkFiniteNumber((rect.w - right_gap - first_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0])); hor_interval_width = checkFiniteNumber((rect.w - right_gap - first_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0]));
for(i = 0; i < arr_x_val.length; ++i) for(i = 0; i < arr_x_val.length; ++i)
{ {
...@@ -2902,7 +2920,14 @@ CChartSpace.prototype = ...@@ -2902,7 +2920,14 @@ CChartSpace.prototype =
} }
case TICK_LABEL_POSITION_LOW: case TICK_LABEL_POSITION_LOW:
{ {
left_gap = Math.max(first_hor_label_half_width, y_ax.labels.extX); if(bNeedReflect)
{
left_gap = Math.max(first_hor_label_half_width, 0);
}
else
{
left_gap = Math.max(first_hor_label_half_width, y_ax.labels.extX);
}
hor_interval_width = checkFiniteNumber((rect.w-left_gap - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0])); hor_interval_width = checkFiniteNumber((rect.w-left_gap - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0]));
for(i = 0; i < arr_x_val.length; ++i) for(i = 0; i < arr_x_val.length; ++i)
{ {
...@@ -2928,7 +2953,14 @@ CChartSpace.prototype = ...@@ -2928,7 +2953,14 @@ CChartSpace.prototype =
if(y_ax.crosses === CROSSES_MAX) if(y_ax.crosses === CROSSES_MAX)
{ {
left_align_labels = false; left_align_labels = false;
right_gap = Math.max(right_gap, y_ax.labels.extX); if(bNeedReflect)
{
right_gap = Math.max(right_gap, 0);
}
else
{
right_gap = Math.max(right_gap, y_ax.labels.extX);
}
y_ax.labels.x = rect.x + rect.w - right_gap; y_ax.labels.x = rect.x + rect.w - right_gap;
y_ax.xPos = rect.x + rect.w - right_gap; y_ax.xPos = rect.x + rect.w - right_gap;
...@@ -2941,7 +2973,7 @@ CChartSpace.prototype = ...@@ -2941,7 +2973,7 @@ CChartSpace.prototype =
else else
{ {
hor_interval_width = checkFiniteNumber((rect.w - first_hor_label_half_width - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0])); hor_interval_width = checkFiniteNumber((rect.w - first_hor_label_half_width - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0]));
if(first_hor_label_half_width + (crosses-arr_x_val[0])*hor_interval_width < y_ax.labels.extX) if(!bNeedReflect && first_hor_label_half_width + (crosses-arr_x_val[0])*hor_interval_width < y_ax.labels.extX)
{ {
hor_interval_width = checkFiniteNumber((rect.w - y_ax.labels.extX - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - crosses)); hor_interval_width = checkFiniteNumber((rect.w - y_ax.labels.extX - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - crosses));
} }
...@@ -2962,7 +2994,14 @@ CChartSpace.prototype = ...@@ -2962,7 +2994,14 @@ CChartSpace.prototype =
{ {
case TICK_LABEL_POSITION_HIGH: case TICK_LABEL_POSITION_HIGH:
{ {
left_gap = Math.max(y_ax.labels.extX, last_hor_label_half_width); if(bNeedReflect)
{
left_gap = Math.max(0, last_hor_label_half_width);
}
else
{
left_gap = Math.max(y_ax.labels.extX, last_hor_label_half_width);
}
hor_interval_width = checkFiniteNumber((rect.w - left_gap - first_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0])); hor_interval_width = checkFiniteNumber((rect.w - left_gap - first_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0]));
y_ax.xPos = rect.x + rect.w - (crosses - arr_x_val[0])*hor_interval_width - first_hor_label_half_width; y_ax.xPos = rect.x + rect.w - (crosses - arr_x_val[0])*hor_interval_width - first_hor_label_half_width;
...@@ -2977,7 +3016,14 @@ CChartSpace.prototype = ...@@ -2977,7 +3016,14 @@ CChartSpace.prototype =
{ {
left_align_labels = false; left_align_labels = false;
right_gap = Math.max(y_ax.labels.extX, first_hor_label_half_width); if(bNeedReflect)
{
right_gap = Math.max(0, first_hor_label_half_width);
}
else
{
right_gap = Math.max(y_ax.labels.extX, first_hor_label_half_width);
}
hor_interval_width = checkFiniteNumber((rect.w - right_gap - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0])); hor_interval_width = checkFiniteNumber((rect.w - right_gap - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0]));
y_ax.xPos = rect.x + rect.w - right_gap - (crosses - arr_x_val[0])*hor_interval_width; y_ax.xPos = rect.x + rect.w - right_gap - (crosses - arr_x_val[0])*hor_interval_width;
for(i = 0; i < arr_x_val.length; ++i) for(i = 0; i < arr_x_val.length; ++i)
...@@ -3003,7 +3049,14 @@ CChartSpace.prototype = ...@@ -3003,7 +3049,14 @@ CChartSpace.prototype =
if(y_ax.crosses === CROSSES_MAX) if(y_ax.crosses === CROSSES_MAX)
{ {
left_gap = Math.max(y_ax.labels.extX, last_hor_label_half_width); if(bNeedReflect)
{
left_gap = Math.max(0, last_hor_label_half_width);
}
else
{
left_gap = Math.max(y_ax.labels.extX, last_hor_label_half_width);
}
hor_interval_width = checkFiniteNumber((rect.w - left_gap - first_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0])); hor_interval_width = checkFiniteNumber((rect.w - left_gap - first_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0]));
y_ax.xPos = rect.x + rect.w - first_hor_label_half_width - (crosses-arr_x_val[0])*hor_interval_width; y_ax.xPos = rect.x + rect.w - first_hor_label_half_width - (crosses-arr_x_val[0])*hor_interval_width;
y_ax.labels.x = y_ax.xPos - ((arr_x_val[arr_x_val.length-1] - crosses)*hor_interval_width) - y_ax.labels.extX; y_ax.labels.x = y_ax.xPos - ((arr_x_val[arr_x_val.length-1] - crosses)*hor_interval_width) - y_ax.labels.extX;
...@@ -3012,7 +3065,7 @@ CChartSpace.prototype = ...@@ -3012,7 +3065,7 @@ CChartSpace.prototype =
{ {
left_align_labels = false; left_align_labels = false;
hor_interval_width = checkFiniteNumber((rect.w - first_hor_label_half_width - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0])); hor_interval_width = checkFiniteNumber((rect.w - first_hor_label_half_width - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - arr_x_val[0]));
if(first_hor_label_half_width + (crosses-arr_x_val[0])*hor_interval_width < y_ax.labels.extX) if(!bNeedReflect && first_hor_label_half_width + (crosses-arr_x_val[0])*hor_interval_width < y_ax.labels.extX)
{ {
hor_interval_width = checkFiniteNumber((rect.w - y_ax.labels.extX - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - crosses)); hor_interval_width = checkFiniteNumber((rect.w - y_ax.labels.extX - last_hor_label_half_width)/(arr_x_val[arr_x_val.length-1] - crosses));
} }
...@@ -3263,6 +3316,7 @@ CChartSpace.prototype = ...@@ -3263,6 +3316,7 @@ CChartSpace.prototype =
if(x_ax.labels) if(x_ax.labels)
{ {
arr_labels = x_ax.labels.arrLabels; arr_labels = x_ax.labels.arrLabels;
x_ax.labels.align = bottom_align_labels;
if(bottom_align_labels) if(bottom_align_labels)
{ {
var top_line = x_ax.labels.y + vert_gap; var top_line = x_ax.labels.y + vert_gap;
...@@ -3309,6 +3363,20 @@ CChartSpace.prototype = ...@@ -3309,6 +3363,20 @@ CChartSpace.prototype =
if(y_ax.labels) if(y_ax.labels)
{ {
if(bNeedReflect)
{
if(left_align_labels)
{
left_align_labels = false;
y_ax.labels.x += y_ax.labels.extX;
}
else
{
left_align_labels = true;
y_ax.labels.x -= y_ax.labels.extX;
}
}
y_ax.labels.align = left_align_labels;
arr_labels = y_ax.labels.arrLabels; arr_labels = y_ax.labels.arrLabels;
if(left_align_labels) if(left_align_labels)
{ {
...@@ -3436,7 +3504,7 @@ CChartSpace.prototype = ...@@ -3436,7 +3504,7 @@ CChartSpace.prototype =
/*если у нас шкала логарифмическая то будем вместо полученных значений использовать логарифм*/ /*если у нас шкала логарифмическая то будем вместо полученных значений использовать логарифм*/
val_ax.labels = new CValAxisLabels(this); val_ax.labels = new CValAxisLabels(this, val_ax);
var max_width = 0; var max_width = 0;
val_ax.yPoints = []; val_ax.yPoints = [];
...@@ -3625,7 +3693,14 @@ CChartSpace.prototype = ...@@ -3625,7 +3693,14 @@ CChartSpace.prototype =
{ {
left_val_ax_labels_align = false; left_val_ax_labels_align = false;
val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX; val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX;
point_interval = (rect.w - val_ax.labels.extX)/intervals_count; if(!bNeedReflect)
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
}
else
{
point_interval = rect.w/intervals_count;
}
val_ax.posX = val_ax.labels.x; val_ax.posX = val_ax.labels.x;
if(cross_between === CROSS_BETWEEN_MID_CAT) if(cross_between === CROSS_BETWEEN_MID_CAT)
{ {
...@@ -3641,7 +3716,7 @@ CChartSpace.prototype = ...@@ -3641,7 +3716,7 @@ CChartSpace.prototype =
else else
{ {
left_points_width = point_interval*(crosses-1);//общая ширина левых точек если считать что точки занимают все пространство left_points_width = point_interval*(crosses-1);//общая ширина левых точек если считать что точки занимают все пространство
if(left_points_width < val_ax.labels.extX)//подписи верт. оси выходят за пределы области построения if(!bNeedReflect && left_points_width < val_ax.labels.extX)//подписи верт. оси выходят за пределы области построения
{ {
var right_intervals_count = intervals_count - (crosses-1);//количесво интервалов правее вертикальной оси var right_intervals_count = intervals_count - (crosses-1);//количесво интервалов правее вертикальной оси
//скорректируем point_interval, поделив расстояние, которое осталось справа от подписей осей на количество интервалов справа //скорректируем point_interval, поделив расстояние, которое осталось справа от подписей осей на количество интервалов справа
...@@ -3679,23 +3754,54 @@ CChartSpace.prototype = ...@@ -3679,23 +3754,54 @@ CChartSpace.prototype =
} }
else if(labels_pos === TICK_LABEL_POSITION_LOW)//подписи слева от области построения else if(labels_pos === TICK_LABEL_POSITION_LOW)//подписи слева от области построения
{ {
point_interval = (rect.w - val_ax.labels.extX)/intervals_count; if(!bNeedReflect)
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
}
else
{
point_interval = rect.w/intervals_count;
}
val_ax.labels.x = rect.x; val_ax.labels.x = rect.x;
if(cross_between === CROSS_BETWEEN_MID_CAT) if(cross_between === CROSS_BETWEEN_MID_CAT)
{ {
for(i = 0; i < string_pts.length; ++i) if(!bNeedReflect)
arr_cat_labels_points[i] = rect.x + val_ax.labels.extX + point_interval*i; {
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + val_ax.labels.extX + point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + point_interval*i;
}
} }
else else
{ {
for(i = 0; i < string_pts.length; ++i) if(!bNeedReflect)
arr_cat_labels_points[i] = rect.x + val_ax.labels.extX + point_interval/2 + point_interval*i; {
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + val_ax.labels.extX + point_interval/2 + point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + point_interval/2 + point_interval*i;
}
} }
val_ax.posX = val_ax.labels.x + val_ax.labels.extX + point_interval*(crosses-1); val_ax.posX = val_ax.labels.x + val_ax.labels.extX + point_interval*(crosses-1);
} }
else if(labels_pos === TICK_LABEL_POSITION_HIGH)//подписи справа от области построения else if(labels_pos === TICK_LABEL_POSITION_HIGH)//подписи справа от области построения
{ {
point_interval = (rect.w - val_ax.labels.extX)/intervals_count; if(!bNeedReflect)
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
}
else
{
point_interval = rect.w/intervals_count;
}
val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX; val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX;
left_val_ax_labels_align = false; left_val_ax_labels_align = false;
if(cross_between === CROSS_BETWEEN_MID_CAT) if(cross_between === CROSS_BETWEEN_MID_CAT)
...@@ -3733,7 +3839,14 @@ CChartSpace.prototype = ...@@ -3733,7 +3839,14 @@ CChartSpace.prototype =
if(val_ax.crosses === CROSSES_MAX) if(val_ax.crosses === CROSSES_MAX)
{ {
val_ax.labels.x = rect.x; val_ax.labels.x = rect.x;
point_interval = (rect.w - val_ax.labels.extX)/intervals_count; if(!bNeedReflect)
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
}
else
{
point_interval = rect.w/intervals_count;
}
if(cross_between === CROSS_BETWEEN_MID_CAT) if(cross_between === CROSS_BETWEEN_MID_CAT)
{ {
for(i = 0; i < string_pts.length; ++i) for(i = 0; i < string_pts.length; ++i)
...@@ -3744,13 +3857,21 @@ CChartSpace.prototype = ...@@ -3744,13 +3857,21 @@ CChartSpace.prototype =
for(i = 0; i < string_pts.length; ++i) for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + rect.w - point_interval/2 - point_interval*i; arr_cat_labels_points[i] = rect.x + rect.w - point_interval/2 - point_interval*i;
} }
val_ax.posX = val_ax.labels.x + val_ax.labels.extX; if(!bNeedReflect)
{
val_ax.posX = val_ax.labels.x + val_ax.labels.extX;
}
else
{
val_ax.posX = val_ax.labels.x;
}
} }
else else
{ {
left_val_ax_labels_align = false; left_val_ax_labels_align = false;
right_point_width = point_interval*(crosses-1); right_point_width = point_interval*(crosses-1);
if(right_point_width < val_ax.labels.extX) if(!bNeedReflect && right_point_width < val_ax.labels.extX)
{ {
val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX; val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX;
var left_points_interval_count = intervals_count - (crosses - 1); var left_points_interval_count = intervals_count - (crosses - 1);
...@@ -3787,7 +3908,14 @@ CChartSpace.prototype = ...@@ -3787,7 +3908,14 @@ CChartSpace.prototype =
else if(labels_pos === TICK_LABEL_POSITION_LOW)//подписи справа от области построения else if(labels_pos === TICK_LABEL_POSITION_LOW)//подписи справа от области построения
{ {
left_val_ax_labels_align = false; left_val_ax_labels_align = false;
point_interval = (rect.w - val_ax.labels.extX)/intervals_count; if(!bNeedReflect)
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
}
else
{
point_interval = rect.w/intervals_count;
}
val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX; val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX;
if(cross_between === CROSS_BETWEEN_MID_CAT) if(cross_between === CROSS_BETWEEN_MID_CAT)
...@@ -3800,11 +3928,26 @@ CChartSpace.prototype = ...@@ -3800,11 +3928,26 @@ CChartSpace.prototype =
for(i = 0; i < string_pts.length; ++i) for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = val_ax.labels.x - point_interval/2 - point_interval*i; arr_cat_labels_points[i] = val_ax.labels.x - point_interval/2 - point_interval*i;
} }
val_ax.posX = rect.x + rect.w - point_interval*(crosses-1) - val_ax.labels.extX; if(!bNeedReflect)
{
val_ax.posX = rect.x + rect.w - point_interval*(crosses-1) - val_ax.labels.extX;
}
else
{
val_ax.posX = rect.x + rect.w - point_interval*(crosses-1);
}
} }
else if(labels_pos === TICK_LABEL_POSITION_HIGH)//подписи слева от области построения else if(labels_pos === TICK_LABEL_POSITION_HIGH)//подписи слева от области построения
{ {
point_interval = (rect.w - val_ax.labels.extX)/intervals_count; if(!bNeedReflect)
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
}
else
{
point_interval = rect.w/intervals_count;
}
val_ax.labels.x = rect.x; val_ax.labels.x = rect.x;
if(cross_between === CROSS_BETWEEN_MID_CAT) if(cross_between === CROSS_BETWEEN_MID_CAT)
...@@ -4271,6 +4414,20 @@ CChartSpace.prototype = ...@@ -4271,6 +4414,20 @@ CChartSpace.prototype =
var arr_labels, transform_text, local_text_transform; var arr_labels, transform_text, local_text_transform;
if(val_ax.labels) if(val_ax.labels)
{ {
if(bNeedReflect)
{
if(left_val_ax_labels_align)
{
left_val_ax_labels_align = false;
val_ax.labels.x += val_ax.labels.extX;
}
else
{
left_val_ax_labels_align = true;
val_ax.labels.x -= val_ax.labels.extX;
}
}
val_ax.labels.align = left_val_ax_labels_align;
val_ax.labels.y = Math.min.apply(Math, arr_val_labels_points) - max_val_labels_text_height/2; val_ax.labels.y = Math.min.apply(Math, arr_val_labels_points) - max_val_labels_text_height/2;
val_ax.labels.extY = Math.max.apply(Math, arr_val_labels_points) - Math.min.apply(Math, arr_val_labels_points) + max_val_labels_text_height; val_ax.labels.extY = Math.max.apply(Math, arr_val_labels_points) - Math.min.apply(Math, arr_val_labels_points) + max_val_labels_text_height;
arr_labels = val_ax.labels.arrLabels; arr_labels = val_ax.labels.arrLabels;
...@@ -4333,6 +4490,7 @@ CChartSpace.prototype = ...@@ -4333,6 +4490,7 @@ CChartSpace.prototype =
} }
cat_ax.labels.extX = arr_cat_labels_points[arr_cat_labels_points.length-1] + max_cat_label_width/2 - cat_ax.labels.x; cat_ax.labels.extX = arr_cat_labels_points[arr_cat_labels_points.length-1] + max_cat_label_width/2 - cat_ax.labels.x;
cat_ax.labels.align = cat_labels_align_bottom;
if(cat_labels_align_bottom) if(cat_labels_align_bottom)
{ {
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i) for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
...@@ -5077,7 +5235,14 @@ CChartSpace.prototype = ...@@ -5077,7 +5235,14 @@ CChartSpace.prototype =
{ {
if(cat_ax.crosses === CROSSES_MAX) if(cat_ax.crosses === CROSSES_MAX)
{ {
right_gap = Math.max(last_val_lbl_half_width, cat_ax_ext_x); if(!bNeedReflect)
{
right_gap = Math.max(last_val_lbl_half_width, cat_ax_ext_x);
}
else
{
right_gap = Math.max(last_val_lbl_half_width, 0);
}
cat_labels_align_left = false;//в данном случае подписи будут выравниваться по верхнему краю блока с подписями cat_labels_align_left = false;//в данном случае подписи будут выравниваться по верхнему краю блока с подписями
if(cat_ax.labels) if(cat_ax.labels)
cat_ax.labels.x = rect.x + rect.w - right_gap; cat_ax.labels.x = rect.x + rect.w - right_gap;
...@@ -5086,7 +5251,7 @@ CChartSpace.prototype = ...@@ -5086,7 +5251,7 @@ CChartSpace.prototype =
} }
else else
{ {
if((crosses_val_ax - arr_val[0])*unit_width + first_val_lbl_half_width < cat_ax_ext_x) if(!bNeedReflect && (crosses_val_ax - arr_val[0])*unit_width + first_val_lbl_half_width < cat_ax_ext_x)
{ {
unit_width = checkFiniteNumber((rect.w - cat_ax_ext_x - last_val_lbl_half_width)/(arr_val[arr_val.length-1] - crosses_val_ax)); unit_width = checkFiniteNumber((rect.w - cat_ax_ext_x - last_val_lbl_half_width)/(arr_val[arr_val.length-1] - crosses_val_ax));
} }
...@@ -5099,7 +5264,15 @@ CChartSpace.prototype = ...@@ -5099,7 +5264,15 @@ CChartSpace.prototype =
} }
else if(hor_labels_pos === TICK_LABEL_POSITION_LOW) else if(hor_labels_pos === TICK_LABEL_POSITION_LOW)
{ {
left_gap = Math.max(first_val_lbl_half_width, cat_ax_ext_x); if(!bNeedReflect)
{
left_gap = Math.max(first_val_lbl_half_width, cat_ax_ext_x);
}
else
{
left_gap = Math.max(first_val_lbl_half_width, 0);
}
unit_width = checkFiniteNumber((rect.w - left_gap - last_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0])); unit_width = checkFiniteNumber((rect.w - left_gap - last_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0]));
...@@ -5114,7 +5287,15 @@ CChartSpace.prototype = ...@@ -5114,7 +5287,15 @@ CChartSpace.prototype =
{ {
cat_labels_align_left = false; cat_labels_align_left = false;
right_gap = Math.max(last_val_lbl_half_width, cat_ax_ext_x); if(!bNeedReflect)
{
right_gap = Math.max(last_val_lbl_half_width, cat_ax_ext_x);
}
else
{
right_gap = Math.max(last_val_lbl_half_width, 0);
}
unit_width = checkFiniteNumber((rect.w - right_gap - first_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0])); unit_width = checkFiniteNumber((rect.w - right_gap - first_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0]));
cat_ax.posX = rect.x + first_val_lbl_half_width + (crosses_val_ax - arr_val[0])*unit_width; cat_ax.posX = rect.x + first_val_lbl_half_width + (crosses_val_ax - arr_val[0])*unit_width;
...@@ -5137,7 +5318,14 @@ CChartSpace.prototype = ...@@ -5137,7 +5318,14 @@ CChartSpace.prototype =
{ {
if(cat_ax.crosses === CROSSES_MAX) if(cat_ax.crosses === CROSSES_MAX)
{ {
left_gap = Math.max(cat_ax_ext_x, last_val_lbl_half_width); if(!bNeedReflect)
{
left_gap = Math.max(cat_ax_ext_x, last_val_lbl_half_width);
}
else
{
left_gap = Math.max(0, last_val_lbl_half_width);
}
unit_width = checkFiniteNumber((rect.w - left_gap - first_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0])); unit_width = checkFiniteNumber((rect.w - left_gap - first_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0]));
cat_ax.xPos = rect.x + rect.w - first_val_lbl_half_width - (crosses_val_ax - arr_val[0])*unit_width; cat_ax.xPos = rect.x + rect.w - first_val_lbl_half_width - (crosses_val_ax - arr_val[0])*unit_width;
if(cat_ax.labels) if(cat_ax.labels)
...@@ -5146,7 +5334,7 @@ CChartSpace.prototype = ...@@ -5146,7 +5334,7 @@ CChartSpace.prototype =
else else
{ {
cat_labels_align_left = false; cat_labels_align_left = false;
if(first_val_lbl_half_width < cat_ax_ext_x) if(!bNeedReflect && first_val_lbl_half_width < cat_ax_ext_x)
{ {
unit_width = checkFiniteNumber((rect.w - cat_ax_ext_x - last_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0])); unit_width = checkFiniteNumber((rect.w - cat_ax_ext_x - last_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0]));
} }
...@@ -5160,7 +5348,15 @@ CChartSpace.prototype = ...@@ -5160,7 +5348,15 @@ CChartSpace.prototype =
else if(hor_labels_pos === TICK_LABEL_POSITION_LOW) else if(hor_labels_pos === TICK_LABEL_POSITION_LOW)
{ {
cat_labels_align_left = false; cat_labels_align_left = false;
right_gap = Math.max(first_val_lbl_half_width, cat_ax_ext_x); if(!bNeedReflect)
{
right_gap = Math.max(first_val_lbl_half_width, cat_ax_ext_x);
}
else
{
right_gap = Math.max(first_val_lbl_half_width, 0);
}
unit_width = checkFiniteNumber((rect.w - last_val_lbl_half_width - right_gap)/(arr_val[arr_val.length-1] - arr_val[0])); unit_width = checkFiniteNumber((rect.w - last_val_lbl_half_width - right_gap)/(arr_val[arr_val.length-1] - arr_val[0]));
cat_ax.xPos = rect.x + last_val_lbl_half_width + (arr_val[arr_val.length-1] - crosses_val_ax)*crosses_val_ax; cat_ax.xPos = rect.x + last_val_lbl_half_width + (arr_val[arr_val.length-1] - crosses_val_ax)*crosses_val_ax;
if(cat_ax.labels) if(cat_ax.labels)
...@@ -5171,7 +5367,15 @@ CChartSpace.prototype = ...@@ -5171,7 +5367,15 @@ CChartSpace.prototype =
} }
else if(hor_labels_pos === TICK_LABEL_POSITION_HIGH) else if(hor_labels_pos === TICK_LABEL_POSITION_HIGH)
{ {
left_gap = Math.max(cat_ax_ext_x, last_val_lbl_half_width); if(!bNeedReflect)
{
left_gap = Math.max(cat_ax_ext_x, last_val_lbl_half_width);
}
else
{
left_gap = Math.max(0, last_val_lbl_half_width);
}
unit_width = checkFiniteNumber((rect.w - left_gap - first_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0])); unit_width = checkFiniteNumber((rect.w - left_gap - first_val_lbl_half_width)/(arr_val[arr_val.length - 1] - arr_val[0]));
cat_ax.xPos = rect.x + rect.w - first_val_lbl_half_width - (crosses_val_ax - arr_val[0])*unit_width; cat_ax.xPos = rect.x + rect.w - first_val_lbl_half_width - (crosses_val_ax - arr_val[0])*unit_width;
if(cat_ax.labels) if(cat_ax.labels)
...@@ -5196,6 +5400,8 @@ CChartSpace.prototype = ...@@ -5196,6 +5400,8 @@ CChartSpace.prototype =
val_ax.labels.x = Math.min.apply(Math, arr_val_labels_points) - max_val_ax_label_width/2; val_ax.labels.x = Math.min.apply(Math, arr_val_labels_points) - max_val_ax_label_width/2;
val_ax.labels.extX = Math.max.apply(Math, arr_val_labels_points) - Math.min.apply(Math, arr_val_labels_points) + max_val_ax_label_width; val_ax.labels.extX = Math.max.apply(Math, arr_val_labels_points) - Math.min.apply(Math, arr_val_labels_points) + max_val_ax_label_width;
//val_axis_labels_gap - вертикальный зазор //val_axis_labels_gap - вертикальный зазор
val_ax.labels.align = bottom_val_ax_labels_align;
if(bottom_val_ax_labels_align) if(bottom_val_ax_labels_align)
{ {
var y_pos = val_ax.labels.y + val_axis_labels_gap; var y_pos = val_ax.labels.y + val_axis_labels_gap;
...@@ -5244,9 +5450,24 @@ CChartSpace.prototype = ...@@ -5244,9 +5450,24 @@ CChartSpace.prototype =
{ {
cat_ax.labels.y = rect.y; cat_ax.labels.y = rect.y;
cat_ax.labels.extY = point_interval*intervals_count; cat_ax.labels.extY = point_interval*intervals_count;
if(bNeedReflect)
{
if(cat_labels_align_left)
{
cat_labels_align_left = false;
cat_ax.labels.x += cat_ax.labels.extX;
}
else
{
cat_labels_align_left = true;
cat_ax.labels.x -= cat_ax.labels.extX;
}
}
if(cat_labels_align_left) if(cat_labels_align_left)
{ {
if(width_flag === 0) if(width_flag === 0)
{ {
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i) for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
...@@ -5412,24 +5633,40 @@ CChartSpace.prototype = ...@@ -5412,24 +5633,40 @@ CChartSpace.prototype =
{ {
var oAxisByTypes = this.chart.plotArea.chart.getAxisByTypes(); var oAxisByTypes = this.chart.plotArea.chart.getAxisByTypes();
var oCatAx = oAxisByTypes.catAx[0], oValAx = oAxisByTypes.valAx[0], deltaX, deltaY, i, oAxisLabels, oLabel, oNewPos; var oCatAx = oAxisByTypes.catAx[0], oValAx = oAxisByTypes.valAx[0], deltaX, deltaY, i, oAxisLabels, oLabel, oNewPos;
if(oCatAx && oValAx) var oProcessor3D = this.chartObj && this.chartObj.processor3D;
if(oCatAx && oValAx && oProcessor3D)
{ {
if(( (oCatAx.axPos === AX_POS_B || oCatAx.axPos === AX_POS_T) && oCatAx.transformXPoints && oCatAx.xPoints) && if(( (oCatAx.axPos === AX_POS_B || oCatAx.axPos === AX_POS_T) && oCatAx.xPoints) &&
((oValAx.axPos === AX_POS_L || oValAx.axPos === AX_POS_R) && oValAx.transformYPoints && oValAx.yPoints)) ((oValAx.axPos === AX_POS_L || oValAx.axPos === AX_POS_R) && oValAx.yPoints))
{ {
oAxisLabels = oCatAx.labels; oAxisLabels = oCatAx.labels;
if(oAxisLabels) if(oAxisLabels)
{ {
for(i = 0; i < oAxisLabels.arrLabels.length; ++i) var dZPositionCatAxis = oProcessor3D.calculateZPositionCatAxis();
var dPosY, dPosY2
if(oAxisLabels.align)
{
dPosY = oAxisLabels.y*this.chartObj.calcProp.pxToMM;
dPosY2 = oAxisLabels.y;
}
else
{
dPosY = (oAxisLabels.y + oAxisLabels.extY)*this.chartObj.calcProp.pxToMM;
dPosY2 = oAxisLabels.y + oAxisLabels.extY;
}
for(i = 0; i < oAxisLabels.arrLabels.length; ++i)
{ {
oLabel = oAxisLabels.arrLabels[i]; oLabel = oAxisLabels.arrLabels[i];
if(oLabel) if(oLabel)
{ {
deltaX = oLabel.localTransformText.tx - oCatAx.xPoints[i].pos; var oCPosLabelX = oLabel.localTransformText.TransformPointX(oLabel.txBody.content.XLimit/2, 0);
deltaY = oLabel.localTransformText.ty - oAxisLabels.y; var oCPosLabelY = oLabel.localTransformText.TransformPointY(oLabel.txBody.content.XLimit/2, 0);
oNewPos = oCatAx.transformXPoints[i]; oNewPos = oProcessor3D.convertAndTurnPoint(oCPosLabelX*this.chartObj.calcProp.pxToMM, dPosY, dZPositionCatAxis);
oLabel.setPosition2(oNewPos.x + deltaX, oNewPos.y + deltaY);
oLabel.setPosition2(oNewPos.x/this.chartObj.calcProp.pxToMM + oLabel.localTransformText.tx - oCPosLabelX, oLabel.localTransformText.ty - dPosY2 + oNewPos.y/this.chartObj.calcProp.pxToMM );
} }
} }
} }
...@@ -5438,36 +5675,68 @@ CChartSpace.prototype = ...@@ -5438,36 +5675,68 @@ CChartSpace.prototype =
oAxisLabels = oValAx.labels; oAxisLabels = oValAx.labels;
if(oAxisLabels) if(oAxisLabels)
{ {
for(i = 0; i < oAxisLabels.arrLabels.length; ++i) var dZPositionCatAxis = oProcessor3D.calculateZPositionValAxis();
var dPosX, dPosX2;
if(!oAxisLabels.align)
{
dPosX2 = oAxisLabels.x;
dPosX = oAxisLabels.x*this.chartObj.calcProp.pxToMM;
}
else
{
dPosX2 = oAxisLabels.x + oAxisLabels.extX;
dPosX = (oAxisLabels.x + oAxisLabels.extX)*this.chartObj.calcProp.pxToMM;
}
for(i = 0; i < oAxisLabels.arrLabels.length; ++i)
{ {
oLabel = oAxisLabels.arrLabels[i]; oLabel = oAxisLabels.arrLabels[i];
if(oLabel) if(oLabel)
{ {
deltaX = oLabel.localTransformText.tx - oAxisLabels.x; oNewPos = oProcessor3D.convertAndTurnPoint(dPosX, oLabel.localTransformText.ty*this.chartObj.calcProp.pxToMM, dZPositionCatAxis);
deltaY = oLabel.localTransformText.ty - oValAx.yPoints[i].pos; oLabel.setPosition2(oLabel.localTransformText.tx - dPosX2 + oNewPos.x/this.chartObj.calcProp.pxToMM, oNewPos.y/this.chartObj.calcProp.pxToMM);
oNewPos = oValAx.transformYPoints[i];
oLabel.setPosition2(oNewPos.x + deltaX, oNewPos.y + deltaY);
} }
} }
} }
} }
else if(((oCatAx.axPos === AX_POS_L || oCatAx.axPos === AX_POS_R) && oCatAx.transformYPoints && oCatAx.yPoints) && else if(((oCatAx.axPos === AX_POS_L || oCatAx.axPos === AX_POS_R) && oCatAx.yPoints) &&
((oValAx.axPos === AX_POS_T || oValAx.axPos === AX_POS_B) && oValAx.transformXPoints && oValAx.xPoints)) ((oValAx.axPos === AX_POS_T || oValAx.axPos === AX_POS_B) && oValAx.xPoints))
{ {
oAxisLabels = oValAx.labels; oAxisLabels = oValAx.labels;
if(oAxisLabels) if(oAxisLabels)
{ {
var dZPositionValAxis = oProcessor3D.calculateZPositionValAxis();
var dPosY, dPosY2
if(oAxisLabels.align)
{
dPosY = oAxisLabels.y*this.chartObj.calcProp.pxToMM;
dPosY2 = oAxisLabels.y;
}
else
{
dPosY = (oAxisLabels.y + oAxisLabels.extY)*this.chartObj.calcProp.pxToMM;
dPosY2 = oAxisLabels.y + oAxisLabels.extY;
}
for(i = 0; i < oAxisLabels.arrLabels.length; ++i) for(i = 0; i < oAxisLabels.arrLabels.length; ++i)
{ {
oLabel = oAxisLabels.arrLabels[i]; oLabel = oAxisLabels.arrLabels[i];
if(oLabel) if(oLabel)
{ {
deltaX = oLabel.localTransformText.tx - oValAx.xPoints[i].pos;
deltaY = oLabel.localTransformText.ty - oAxisLabels.y; var oCPosLabelX = oLabel.localTransformText.TransformPointX(oLabel.txBody.content.XLimit/2, 0);
oNewPos = oValAx.transformXPoints[i]; var oCPosLabelY = oLabel.localTransformText.TransformPointY(oLabel.txBody.content.XLimit/2, 0);
oLabel.setPosition2(oNewPos.x + deltaX, oNewPos.y + deltaY); oNewPos = oProcessor3D.convertAndTurnPoint(oCPosLabelX*this.chartObj.calcProp.pxToMM, dPosY, dZPositionValAxis);
oLabel.setPosition2(oNewPos.x/this.chartObj.calcProp.pxToMM + oLabel.localTransformText.tx - oCPosLabelX, oLabel.localTransformText.ty - dPosY2 + oNewPos.y/this.chartObj.calcProp.pxToMM );
//oNewPos = oProcessor3D.convertAndTurnPoint(oLabel.localTransformText.tx*this.chartObj.calcProp.pxToMM, oLabel.localTransformText.ty*this.chartObj.calcProp.pxToMM, dZPositionValAxis);;
//oLabel.setPosition2(oNewPos.x/this.chartObj.calcProp.pxToMM, oNewPos.y/this.chartObj.calcProp.pxToMM);
} }
} }
} }
...@@ -5477,15 +5746,28 @@ CChartSpace.prototype = ...@@ -5477,15 +5746,28 @@ CChartSpace.prototype =
if(oAxisLabels) if(oAxisLabels)
{ {
var dZPositionCatAxis = oProcessor3D.calculateZPositionCatAxis();
var dPosX, dPosX2;
if(oAxisLabels.align)
{
dPosX2 = oAxisLabels.x;
dPosX = oAxisLabels.x*this.chartObj.calcProp.pxToMM;
}
else
{
dPosX2 = oAxisLabels.x + oAxisLabels.extX;
dPosX = (oAxisLabels.x + oAxisLabels.extX)*this.chartObj.calcProp.pxToMM;
}
for(i = 0; i < oAxisLabels.arrLabels.length; ++i) for(i = 0; i < oAxisLabels.arrLabels.length; ++i)
{ {
oLabel = oAxisLabels.arrLabels[i]; oLabel = oAxisLabels.arrLabels[i];
if(oLabel) if(oLabel)
{ {
deltaX = oLabel.localTransformText.tx - oAxisLabels.x;
deltaY = oLabel.localTransformText.ty - oCatAx.yPoints[i].pos; oNewPos = oProcessor3D.convertAndTurnPoint(dPosX, oLabel.localTransformText.ty*this.chartObj.calcProp.pxToMM, dZPositionCatAxis);
oNewPos = oCatAx.transformYPoints[i]; oLabel.setPosition2(oLabel.localTransformText.tx - dPosX2 + oNewPos.x/this.chartObj.calcProp.pxToMM, oNewPos.y/this.chartObj.calcProp.pxToMM);
oLabel.setPosition2(oNewPos.x + deltaX, oNewPos.y + deltaY);
} }
} }
} }
......
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