Commit 738e7eaa authored by GoshaZotov's avatar GoshaZotov

draw verges without rotation(3d hbar)

parent dea06aa1
...@@ -333,7 +333,7 @@ Processor3D.prototype.calculateZPositionCatAxis = function() ...@@ -333,7 +333,7 @@ Processor3D.prototype.calculateZPositionCatAxis = function()
//***functions for complete transformation point*** //***functions for complete transformation point***
Processor3D.prototype.convertAndTurnPoint = function(x, y, z, isNotProject) Processor3D.prototype.convertAndTurnPoint = function(x, y, z, isNScale, isNRotate, isNProject)
{ {
var res = null; var res = null;
...@@ -343,7 +343,7 @@ Processor3D.prototype.convertAndTurnPoint = function(x, y, z, isNotProject) ...@@ -343,7 +343,7 @@ Processor3D.prototype.convertAndTurnPoint = function(x, y, z, isNotProject)
} }
else else
{ {
res = this.convertAndTurnPointPerspective(x, y, z, isNotProject); res = this.convertAndTurnPointPerspective(x, y, z, isNScale, isNRotate, isNProject);
} }
return res; return res;
...@@ -408,49 +408,68 @@ Processor3D.prototype.convertAndTurnPointRAngAx = function(x, y, z) ...@@ -408,49 +408,68 @@ Processor3D.prototype.convertAndTurnPointRAngAx = function(x, y, z)
return {x: projectionPoint.x, y: projectionPoint.y, z: z}; return {x: projectionPoint.x, y: projectionPoint.y, z: z};
}; };
Processor3D.prototype.convertAndTurnPointPerspective = function(x, y, z, isNotProject) Processor3D.prototype.convertAndTurnPointPerspective = function(x, y, z, isNScale, isNRotate, isNProject)
{
var point3D = new Point3D(x, y, z, this);
if(!isNScale)
{
this.scale(point3D);
}
if(!isNRotate)
{
this.rotate1(point3D);
}
if(!isNProject)
{
this.project1(point3D);
}
return {x: point3D.x, y: point3D.y, z: point3D.z};
};
Processor3D.prototype.scale = function(point3D)
{ {
//aspectRatio //aspectRatio
x = x / this.aspectRatioX; point3D.x = point3D.x / this.aspectRatioX;
y = y / this.aspectRatioY; point3D.y = point3D.y / this.aspectRatioY;
x = x / this.scaleX; point3D.x = point3D.x / this.scaleX;
y = y / this.scaleY; point3D.y = point3D.y / this.scaleY;
z = z / this.scaleZ; point3D.z = point3D.z / this.scaleZ;
},
var point3D = new Point3D(x, y, z, this);
Processor3D.prototype.rotate1 = function(point3D)
{
//diff //diff
var centerZDiff = this.depthPerspective / 2; point3D.offset((-this.widthCanvas / 2) / this.aspectRatioX, (-this.heightCanvas / 2) / this.aspectRatioY, 0);
//rotate
var matrixRotateAllAxis = this._getMatrixRotateAllAxis();
point3D.multiplyPointOnMatrix1(matrixRotateAllAxis);
point3D.offset((-this.widthCanvas / 2) / this.aspectRatioX, (-this.heightCanvas / 2) / this.aspectRatioY /** aspectRatio*/, 0); point3D.offset((this.widthCanvas / 2) / this.aspectRatioX, (this.heightCanvas / 2) / this.aspectRatioY, 0);
};
//rotate
var matrixRotateAllAxis;
if(!this.view3D.rAngAx)
matrixRotateAllAxis = this._getMatrixRotateAllAxis();
else
matrixRotateAllAxis = this._shearXY();
point3D.multiplyPointOnMatrix1(matrixRotateAllAxis); Processor3D.prototype.project1 = function(point3D)
{
//diff
point3D.offset((-this.widthCanvas / 2) / this.aspectRatioX, (-this.heightCanvas / 2) / this.aspectRatioY /** aspectRatio*/, 0);
// diff camera for charts write into rect // diff camera for charts write into rect
point3D.offset(this.cameraDiffX, this.cameraDiffY, this.cameraDiffZ); point3D.offset(this.cameraDiffX, this.cameraDiffY, this.cameraDiffZ);
//project //project
var projectionPoint = point3D;
if(!this.view3D.rAngAx && !isNotProject)
{
var projectiveMatrix = this._getPerspectiveProjectionMatrix(1 / (this.rPerspective)); var projectiveMatrix = this._getPerspectiveProjectionMatrix(1 / (this.rPerspective));
projectionPoint = point3D.project(projectiveMatrix); point3D.project(projectiveMatrix);
}
//undiff //undiff
var specialReverseDiffX = this.widthCanvas / 2 + (this.left - this.right) / 2; var specialReverseDiffX = this.widthCanvas / 2 + (this.left - this.right) / 2;
var specialReverseDiffY = this.heightCanvas / 2 + (this.top - this.bottom) / 2; var specialReverseDiffY = this.heightCanvas / 2 + (this.top - this.bottom) / 2;
projectionPoint.offset(specialReverseDiffX, specialReverseDiffY, centerZDiff); point3D.offset(specialReverseDiffX, specialReverseDiffY, 0);
return {x: projectionPoint.x, y: projectionPoint.y, z: projectionPoint.z};
}; };
//functions for step transformation point //functions for step transformation point
......
This diff is collapsed.
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