Files
DocumentServer-v-9.2.0/sdkjs/common/Overlay.js
Yajbir Singh f1b860b25c
Some checks failed
check / markdownlint (push) Has been cancelled
check / spellchecker (push) Has been cancelled
updated
2025-12-11 19:03:17 +05:30

3483 lines
127 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
* (c) Copyright Ascensio System SIA 2010-2024
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL 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.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish
* street, Riga, Latvia, EU, LV-1050.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
"use strict";
(function(window, undefined){
var AscBrowser = AscCommon.AscBrowser;
var TRACK_CIRCLE_RADIUS = 5;
var TRACK_RECT_SIZE2 = 4;
var TRACK_RECT_SIZE = 8;
var TRACK_RECT_SIZE_FORM = 6;
var TRACK_RECT_SIZE_CT = 6;
var TRACK_DISTANCE_ROTATE = 25;
var TRACK_DISTANCE_ROTATE2 = 25;
var TRACK_ADJUSTMENT_SIZE = 10;
var TRACK_WRAPPOINTS_SIZE = 6;
var ROTATE_TRACK_W = 21;
var bIsUseImageRotateTrack = true;
if (bIsUseImageRotateTrack)
{
window.g_track_rotate_marker = new Image();
window.g_track_rotate_marker;
window.g_track_rotate_marker.asc_complete = false;
window.g_track_rotate_marker.onload = function(){
window.g_track_rotate_marker.asc_complete = true;
};
window.g_track_rotate_marker.src = "";
window.g_track_rotate_marker2 = new Image();
window.g_track_rotate_marker2;
window.g_track_rotate_marker2.asc_complete = false;
window.g_track_rotate_marker2.onload = function(){
window.g_track_rotate_marker2.asc_complete = true;
};
window.g_track_rotate_marker2.src = "";
TRACK_DISTANCE_ROTATE2 = 18;
}
function COverlay()
{
this.m_oControl = null;
this.m_oContext = null;
this.min_x = 0xFFFF;
this.min_y = 0xFFFF;
this.max_x = -0xFFFF;
this.max_y = -0xFFFF;
this.m_bIsShow = false;
this.m_bIsAlwaysUpdateOverlay = false;
this.m_oHtmlPage = null;
this.DashLineColor = "#000000";
this.ClearAll = false;
this.IsCellEditor = false;
}
COverlay.prototype =
{
init : function(context, controlName, x, y, w_pix, h_pix, w_mm, h_mm)
{
this.m_oContext = context;
this.m_oControl = AscCommon.CreateControl(controlName);
this.m_oHtmlPage = new AscCommon.CHtmlPage();
this.m_oHtmlPage.init(x, y, w_pix, h_pix, w_mm, h_mm);
},
Clear : function()
{
if (null == this.m_oContext)
{
this.m_oContext = AscCommon.AscBrowser.getContext2D(this.m_oControl.HtmlElement);
this.m_oContext.imageSmoothingEnabled = false;
this.m_oContext.mozImageSmoothingEnabled = false;
this.m_oContext.oImageSmoothingEnabled = false;
this.m_oContext.webkitImageSmoothingEnabled = false;
}
this.SetBaseTransform();
this.m_oContext.beginPath();
if (this.max_x != -0xFFFF && this.max_y != -0xFFFF)
{
if (this.ClearAll === true)
{
this.m_oContext.clearRect(0, 0, this.m_oControl.HtmlElement.width, this.m_oControl.HtmlElement.height);
this.ClearAll = false;
}
else
{
var _eps = 5;
this.m_oContext.clearRect(this.min_x - _eps, this.min_y - _eps, this.max_x - this.min_x + 2*_eps, this.max_y - this.min_y + 2 * _eps);
}
}
this.min_x = 0xFFFF;
this.min_y = 0xFFFF;
this.max_x = -0xFFFF;
this.max_y = -0xFFFF;
},
GetImageTrackRotationImage : function()
{
return AscCommon.AscBrowser.isCustomScalingAbove2() ? window.g_track_rotate_marker2 : window.g_track_rotate_marker;
},
SetTransform : function(sx, shy, shx, sy, tx, ty)
{
this.SetBaseTransform();
this.m_oContext.setTransform(sx, shy, shx, sy, tx, ty);
},
SetBaseTransform : function()
{
this.m_oContext.setTransform(1, 0, 0, 1, 0, 0);
},
Show : function()
{
if (this.m_bIsShow)
return;
this.m_bIsShow = true;
this.m_oControl.HtmlElement.style.display = "block";
},
UnShow : function()
{
if (!this.m_bIsShow)
return;
this.m_bIsShow = false;
this.m_oControl.HtmlElement.style.display = "none";
},
VertLine : function(position, bIsSimpleAdd)
{
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
if (bIsSimpleAdd !== true)
{
this.Clear();
if (this.m_bIsAlwaysUpdateOverlay || true/*мало ли что есть на оверлее*/)
{
if (!editor.WordControl.OnUpdateOverlay())
{
editor.WordControl.EndUpdateOverlay();
}
}
}
position *= rPR;
if (this.min_x > position)
this.min_x = position;
if (this.max_x < position)
this.max_x = position;
//this.min_x = position;
//this.max_x = position;
this.min_y = 0;
this.max_y = this.m_oControl.HtmlElement.height;
this.m_oContext.lineWidth = Math.round(rPR);
var x = ((position + 0.5 * this.m_oContext.lineWidth) >> 0) + 0.5 * this.m_oContext.lineWidth;
var y = 0;
this.m_oContext.strokeStyle = this.DashLineColor;
this.m_oContext.beginPath();
var lineWidth = this.m_oContext.lineWidth;
while (y < this.max_y)
{
this.m_oContext.moveTo(x, y); y += lineWidth;
this.m_oContext.lineTo(x, y); y += lineWidth;
this.m_oContext.moveTo(x, y); y += lineWidth;
this.m_oContext.lineTo(x, y); y += lineWidth;
this.m_oContext.moveTo(x, y); y += lineWidth;
this.m_oContext.lineTo(x, y); y += lineWidth;
y += 5 * lineWidth;
}
this.m_oContext.stroke();
y = lineWidth;
this.m_oContext.strokeStyle = "#FFFFFF";
this.m_oContext.beginPath();
while (y < this.max_y)
{
this.m_oContext.moveTo(x, y); y += lineWidth;
this.m_oContext.lineTo(x, y); y += lineWidth;
this.m_oContext.moveTo(x, y); y += lineWidth;
this.m_oContext.lineTo(x, y); y += lineWidth;
this.m_oContext.moveTo(x, y); y += lineWidth;
this.m_oContext.lineTo(x, y); y += lineWidth;
y += 5 * lineWidth;
}
this.m_oContext.stroke();
this.Show();
},
VertLine2 : function(position)
{
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
position *= rPR;
if (this.min_x > position)
this.min_x = position;
if (this.max_x < position)
this.max_x = position;
var _old_global = this.m_oContext.globalAlpha;
this.m_oContext.globalAlpha = 1;
this.min_y = 0;
this.max_y = this.m_oControl.HtmlElement.height;
this.m_oContext.lineWidth = Math.round(rPR);
var indent = 0.5 * this.m_oContext.lineWidth;
var x = ((position + indent) >> 0) + indent;
var y = 0;
/*
this.m_oContext.strokeStyle = "#FFFFFF";
this.m_oContext.beginPath();
this.m_oContext.moveTo(x, y);
this.m_oContext.lineTo(x, this.max_y);
this.m_oContext.stroke();
*/
this.m_oContext.strokeStyle = this.DashLineColor;
this.m_oContext.beginPath();
var dist = this.m_oContext.lineWidth;
while (y < this.max_y)
{
this.m_oContext.moveTo(x, y);
y += dist;
this.m_oContext.lineTo(x, y);
y += dist;
}
this.m_oContext.stroke();
this.m_oContext.beginPath();
this.Show();
this.m_oContext.globalAlpha = _old_global;
},
HorLine : function(position, bIsSimpleAdd)
{
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
if (bIsSimpleAdd !== true)
{
this.Clear();
if (this.m_bIsAlwaysUpdateOverlay || true/*мало ли что есть на оверлее*/)
{
if (!editor.WordControl.OnUpdateOverlay())
{
editor.WordControl.EndUpdateOverlay();
}
}
}
this.min_x = 0;
this.max_x = this.m_oControl.HtmlElement.width;
position *= rPR;
if (this.min_y > position)
this.min_y = position;
if (this.max_y < position)
this.max_y = position;
this.m_oContext.lineWidth = Math.round(rPR);
var y = ((position + 0.5 * this.m_oContext.lineWidth) >> 0) + 0.5 * this.m_oContext.lineWidth;
var x = 0;
this.m_oContext.strokeStyle = this.DashLineColor;
this.m_oContext.beginPath();
var lineWidth = this.m_oContext.lineWidth;
while (x < this.max_x)
{
this.m_oContext.moveTo(x, y); x += lineWidth;
this.m_oContext.lineTo(x, y); x += lineWidth;
this.m_oContext.moveTo(x, y); x += lineWidth;
this.m_oContext.lineTo(x, y); x += lineWidth;
this.m_oContext.moveTo(x, y); x += lineWidth;
this.m_oContext.lineTo(x, y); x += lineWidth;
x += 5 * lineWidth;
}
this.m_oContext.stroke();
x = lineWidth;
this.m_oContext.strokeStyle = "#FFFFFF";
this.m_oContext.beginPath();
while (x < this.max_x)
{
this.m_oContext.moveTo(x, y); x += lineWidth;
this.m_oContext.lineTo(x, y); x += lineWidth;
this.m_oContext.moveTo(x, y); x += lineWidth;
this.m_oContext.lineTo(x, y); x += lineWidth;
this.m_oContext.moveTo(x, y); x += lineWidth;
this.m_oContext.lineTo(x, y); x += lineWidth;
x += 5 * lineWidth;
}
this.m_oContext.stroke();
this.Show();
},
HorLine2 : function(position)
{
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
position *= rPR;
if (this.min_y > position)
this.min_y = position;
if (this.max_y < position)
this.max_y = position;
var _old_global = this.m_oContext.globalAlpha;
this.m_oContext.globalAlpha = 1;
this.min_x = 0;
this.max_x = this.m_oControl.HtmlElement.width;
this.m_oContext.lineWidth = Math.round(rPR);
var indent = 0.5 * this.m_oContext.lineWidth;
var y = ((position + indent) >> 0) + indent;
var x = 0;
/*
this.m_oContext.strokeStyle = "#FFFFFF";
this.m_oContext.beginPath();
this.m_oContext.moveTo(x, y);
this.m_oContext.lineTo(this.max_x, y);
this.m_oContext.stroke();
*/
this.m_oContext.strokeStyle = this.DashLineColor;
this.m_oContext.beginPath();
var dist = this.m_oContext.lineWidth;
while (x < this.max_x)
{
this.m_oContext.moveTo(x, y);
x += dist;
this.m_oContext.lineTo(x, y);
x += dist;
}
this.m_oContext.stroke();
this.m_oContext.beginPath();
this.Show();
this.m_oContext.globalAlpha = _old_global;
},
CheckPoint1 : function(x,y)
{
if (this.CanvasTransform) {
this.CheckPoint(x, y);
}
else {
if (x < this.min_x)
this.min_x = x;
if (y < this.min_y)
this.min_y = y;
}
},
CheckPoint2 : function(x,y)
{
if (this.CanvasTransform) {
this.CheckPoint(x, y);
}
else {
if (x > this.max_x)
this.max_x = x;
if (y > this.max_y)
this.max_y = y;
}
},
CheckPoint : function(x,y)
{
if (this.CanvasTransform) {
let oTr = this.CanvasTransform;
let oTrPt = oTr.TransformPoint(x, y);
x = oTrPt.x;
y = oTrPt.y;
}
if (x < this.min_x)
this.min_x = x ;
if (y < this.min_y)
this.min_y = y;
if (x > this.max_x)
this.max_x = x;
if (y > this.max_y)
this.max_y = y;
},
AddRect2 : function(x,y,r)
{
var _x = x - ((r / 2) >> 0);
var _y = y - ((r / 2) >> 0);
this.CheckPoint1(_x,_y);
this.CheckPoint2(_x+r,_y+r);
this.m_oContext.moveTo(_x,_y);
this.m_oContext.rect(_x,_y,r,r);
},
AddRect3 : function(x,y,r, ex1, ey1, ex2, ey2)
{
var _r = r / 2;
var x1 = x + _r * (ex2 - ex1);
var y1 = y + _r * (ey2 - ey1);
var x2 = x + _r * (ex2 + ex1);
var y2 = y + _r * (ey2 + ey1);
var x3 = x + _r * (-ex2 + ex1);
var y3 = y + _r * (-ey2 + ey1);
var x4 = x + _r * (-ex2 - ex1);
var y4 = y + _r * (-ey2 - ey1);
this.CheckPoint(x1,y1);
this.CheckPoint(x2,y2);
this.CheckPoint(x3,y3);
this.CheckPoint(x4,y4);
var ctx = this.m_oContext;
ctx.moveTo(x1,y1);
ctx.lineTo(x2,y2);
ctx.lineTo(x3,y3);
ctx.lineTo(x4,y4);
ctx.closePath();
},
AddRect : function(x,y,w,h)
{
this.CheckPoint1(x,y);
this.CheckPoint2(x + w,y + h);
this.m_oContext.moveTo(x,y);
this.m_oContext.rect(x,y,w,h);
//this.m_oContext.closePath();
},
CheckRectT : function(x,y,w,h,trans,eps)
{
var x1 = trans.TransformPointX(x, y);
var y1 = trans.TransformPointY(x, y);
var x2 = trans.TransformPointX(x+w, y);
var y2 = trans.TransformPointY(x+w, y);
var x3 = trans.TransformPointX(x+w, y+h);
var y3 = trans.TransformPointY(x+w, y+h);
var x4 = trans.TransformPointX(x, y+h);
var y4 = trans.TransformPointY(x, y+h);
this.CheckPoint(x1, y1);
this.CheckPoint(x2, y2);
this.CheckPoint(x3, y3);
this.CheckPoint(x4, y4);
if (eps !== undefined)
{
this.min_x -= eps;
this.min_y -= eps;
this.max_x += eps;
this.max_y += eps;
}
},
CheckRect : function(x,y,w,h)
{
this.CheckPoint1(x,y);
this.CheckPoint2(x + w,y + h);
},
AddEllipse : function(x,y,r)
{
this.CheckPoint1(x-r,y-r);
this.CheckPoint2(x+r,y+r);
this.m_oContext.moveTo(x+r,y);
this.m_oContext.arc(x,y,r,0,Math.PI*2,false);
//this.m_oContext.closePath();
},
AddEllipse2 : function(x,y,r)
{
this.m_oContext.moveTo(x+r,y);
this.m_oContext.arc(x,y,r,0,Math.PI*2,false);
//this.m_oContext.closePath();
},
AddDiamond : function(x,y,r)
{
this.CheckPoint1(x-r,y-r);
this.CheckPoint2(x+r,y+r);
this.m_oContext.moveTo(x-r,y);
this.m_oContext.lineTo(x, y-r);
this.m_oContext.lineTo(x+r, y);
this.m_oContext.lineTo(x, y+r);
this.m_oContext.lineTo(x-r, y);
//this.m_oContext.closePath();
},
AddRoundRect : function(x, y, w, h, r)
{
if (w < (2 * r) || h < (2 * r))
return this.AddRect(x, y, w, h);
this.CheckPoint1(x,y);
this.CheckPoint2(x + w,y + h);
var _ctx = this.m_oContext;
_ctx.moveTo(x + r, y);
_ctx.lineTo(x + w - r, y);
_ctx.quadraticCurveTo(x + w, y, x + w, y + r);
_ctx.lineTo(x + w, y + h - r);
_ctx.quadraticCurveTo(x + w, y + h, x + w - r, y + h);
_ctx.lineTo(x + r, y + h);
_ctx.quadraticCurveTo(x, y + h, x, y + h - r);
_ctx.lineTo(x, y + r);
_ctx.quadraticCurveTo(x, y, x + r, y);
_ctx.closePath();
},
AddRoundRectCtx : function(ctx, x, y, w, h, r)
{
if (w < (2 * r) || h < (2 * r))
return ctx.rect(x, y, w, h);
var _ctx = this.m_oContext;
_ctx.moveTo(x + r, y);
_ctx.lineTo(x + w - r, y);
_ctx.quadraticCurveTo(x + w, y, x + w, y + r);
_ctx.lineTo(x + w, y + h - r);
_ctx.quadraticCurveTo(x + w, y + h, x + w - r, y + h);
_ctx.lineTo(x + r, y + h);
_ctx.quadraticCurveTo(x, y + h, x, y + h - r);
_ctx.lineTo(x, y + r);
_ctx.quadraticCurveTo(x, y, x + r, y);
_ctx.closePath();
},
DrawFrozenPlaceHorLine: function(y, left, right)
{
this.m_oContext.strokeStyle = "#AAAAAA";
var nW = 2;
nW = AscCommon.AscBrowser.convertToRetinaValue(nW, true);
this.CheckPoint1(left, y - nW);
this.CheckPoint2(right, y + nW);
this.m_oContext.lineWidth = nW;
this.m_oContext.beginPath();
this.m_oContext.moveTo(left, y);
this.m_oContext.lineTo(right, y);
this.m_oContext.stroke();
},
DrawFrozenPlaceVerLine: function(x, top, bottom)
{
this.m_oContext.strokeStyle = "#AAAAAA";
var nW = 2;
nW = AscCommon.AscBrowser.convertToRetinaValue(nW, true);
this.CheckPoint1(x - nW, top);
this.CheckPoint2(x + nW, bottom);
this.m_oContext.lineWidth = nW;
this.m_oContext.beginPath();
this.m_oContext.moveTo(x, top);
this.m_oContext.lineTo(x, bottom);
this.m_oContext.stroke();
},
drawArrow : function(ctx, x, y, len, rgb, needToCorrectLen) {
ctx.beginPath();
var arrowSize = this.GetArrowSize();
if (needToCorrectLen && 0 == (len & 1) )
len += 1;
var _data, px,
_x = Math.round((arrowSize - len) / 2),
_y = Math.floor(arrowSize / 2),
r, g, b;
var __x = _x, __y = _y, _len = len;
// r = 147, g = 147, b = 147;
var r = rgb.r, g = rgb.g, b = rgb.b;
_data = ctx.createImageData(arrowSize, arrowSize);
px = _data.data;
while (_len > 0) {
var ind = 4 * (arrowSize * __y + __x);
for (var i = 0; i < _len; i++) {
px[ind++] = r;
px[ind++] = g;
px[ind++] = b;
px[ind++] = 255;
}
r = r >> 0;
g = g >> 0;
b = b >> 0;
__x += 1;
__y -= 1;
_len -= 2;
}
ctx.putImageData(_data, x, y);
},
GetArrowSize: function()
{
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
return Math.round(13 * rPR);
}
};
function CAutoshapeTrack()
{
AscCommon.CGraphicsBase.call(this, AscCommon.RendererType.Track);
this.m_oContext = null;
this.m_oOverlay = null;
this.Graphics = null;
this.MaxEpsLine = 0;
this.PageIndex = -1;
this.CurrentPageInfo = null;
this.ArrowCanvas = null;
this.RotatedArrowCanvas = null;
}
CAutoshapeTrack.prototype = Object.create(AscCommon.CGraphicsBase.prototype);
CAutoshapeTrack.prototype.constructor = CAutoshapeTrack;
CAutoshapeTrack.prototype.SetFont = function(font)
{
};
CAutoshapeTrack.prototype.init = function(overlay, x, y, r, b, w_mm, h_mm)
{
this.m_oOverlay = overlay;
this.m_oContext = this.m_oOverlay.m_oContext;
this.Graphics = new AscCommon.CGraphics();
var _scale = this.m_oOverlay.IsCellEditor ? 1 : AscCommon.AscBrowser.retinaPixelRatio;
this.Graphics.init(this.m_oContext, _scale * (r - x), _scale * (b - y), w_mm, h_mm);
this.Graphics.m_oCoordTransform.tx = _scale * x;
this.Graphics.m_oCoordTransform.ty = _scale * y;
this.Graphics.SetIntegerGrid(false);
this.Graphics.globalAlpha = 0.5;
this.m_oContext.globalAlpha = 0.5;
};
// draw styles
CAutoshapeTrack.prototype.p_color = function(r,g,b,a)
{
this.Graphics.p_color(r, g, b, a);
};
CAutoshapeTrack.prototype.p_width = function(w)
{
this.Graphics.p_width(w);
var xx1 = 0;
var yy1 = 0;
var xx2 = 1;
var yy2 = 1;
var xxx1 = this.Graphics.m_oFullTransform.TransformPointX(xx1, yy1);
var yyy1 = this.Graphics.m_oFullTransform.TransformPointY(xx1, yy1);
var xxx2 = this.Graphics.m_oFullTransform.TransformPointX(xx2, yy2);
var yyy2 = this.Graphics.m_oFullTransform.TransformPointY(xx2, yy2);
var _len2 = ((xxx2 - xxx1)*(xxx2 - xxx1) + (yyy2 - yyy1)*(yyy2 - yyy1));
var koef = Math.sqrt(_len2 / 2);
var _EpsLine = (w * koef / 1000) >> 0;
_EpsLine += 5;
if (_EpsLine > this.MaxEpsLine)
this.MaxEpsLine = _EpsLine;
};
CAutoshapeTrack.prototype.p_dash = function(params)
{
this.Graphics.p_dash(params);
};
CAutoshapeTrack.prototype.b_color1 = function(r,g,b,a)
{
this.Graphics.b_color1(r,g,b,a);
};
// path commands
CAutoshapeTrack.prototype._s = function()
{
this.Graphics._s();
};
CAutoshapeTrack.prototype._e = function()
{
this.Graphics._e();
};
CAutoshapeTrack.prototype._z = function()
{
this.Graphics._z();
};
CAutoshapeTrack.prototype._m = function(x,y)
{
this.Graphics._m(x,y);
var _x = this.Graphics.m_oFullTransform.TransformPointX(x,y);
var _y = this.Graphics.m_oFullTransform.TransformPointY(x,y);
this.m_oOverlay.CheckPoint(_x, _y);
};
CAutoshapeTrack.prototype._l = function(x,y)
{
this.Graphics._l(x,y);
var _x = this.Graphics.m_oFullTransform.TransformPointX(x,y);
var _y = this.Graphics.m_oFullTransform.TransformPointY(x,y);
this.m_oOverlay.CheckPoint(_x, _y);
};
CAutoshapeTrack.prototype._c = function(x1,y1,x2,y2,x3,y3)
{
this.Graphics._c(x1,y1,x2,y2,x3,y3);
var _x1 = this.Graphics.m_oFullTransform.TransformPointX(x1,y1);
var _y1 = this.Graphics.m_oFullTransform.TransformPointY(x1,y1);
var _x2 = this.Graphics.m_oFullTransform.TransformPointX(x2,y2);
var _y2 = this.Graphics.m_oFullTransform.TransformPointY(x2,y2);
var _x3 = this.Graphics.m_oFullTransform.TransformPointX(x3,y3);
var _y3 = this.Graphics.m_oFullTransform.TransformPointY(x3,y3);
this.m_oOverlay.CheckPoint(_x1, _y1);
this.m_oOverlay.CheckPoint(_x2, _y2);
this.m_oOverlay.CheckPoint(_x3, _y3);
};
CAutoshapeTrack.prototype._c2 = function(x1,y1,x2,y2)
{
this.Graphics._c2(x1,y1,x2,y2);
var _x1 = this.Graphics.m_oFullTransform.TransformPointX(x1,y1);
var _y1 = this.Graphics.m_oFullTransform.TransformPointY(x1,y1);
var _x2 = this.Graphics.m_oFullTransform.TransformPointX(x2,y2);
var _y2 = this.Graphics.m_oFullTransform.TransformPointY(x2,y2);
this.m_oOverlay.CheckPoint(_x1, _y1);
this.m_oOverlay.CheckPoint(_x2, _y2);
};
CAutoshapeTrack.prototype.ds = function()
{
this.Graphics.ds();
};
CAutoshapeTrack.prototype.df = function()
{
this.Graphics.df();
};
// canvas state
CAutoshapeTrack.prototype.save = function()
{
this.Graphics.save();
};
CAutoshapeTrack.prototype.restore = function()
{
this.Graphics.restore();
};
CAutoshapeTrack.prototype.clip = function()
{
this.Graphics.clip();
};
// transform
CAutoshapeTrack.prototype.reset = function()
{
this.Graphics.reset();
};
CAutoshapeTrack.prototype.transformPageMatrix = function(m)
{
if (!this.Graphics)
{
return m;
}
let t = this.CanvasTransform;
if (t)
{
let t3 = m ? m.CreateDublicate() : new AscCommon.CMatrix();
AscCommon.global_MatrixTransformer.MultiplyAppend(t3, this.Graphics.m_oCoordTransform);
AscCommon.global_MatrixTransformer.MultiplyAppend(t3, t);
let oInvCoord = AscCommon.global_MatrixTransformer.Invert(this.Graphics.m_oCoordTransform)
AscCommon.global_MatrixTransformer.MultiplyAppend(t3, oInvCoord);
return t3;
}
else
{
return m;
}
};
CAutoshapeTrack.prototype.transform3 = function(m)
{
let mt = this.transformPageMatrix(m);
this.Graphics.transform3(mt);
};
CAutoshapeTrack.prototype.transform = function(sx,shy,shx,sy,tx,ty)
{
this.Graphics.transform(sx,shy,shx,sy,tx,ty);
};
CAutoshapeTrack.prototype.drawImage = function(image, x, y, w, h, alpha, srcRect, nativeImage)
{
this.Graphics.drawImage(image, x, y, w, h, undefined, srcRect, nativeImage);
var _x1 = this.Graphics.m_oFullTransform.TransformPointX(x,y);
var _y1 = this.Graphics.m_oFullTransform.TransformPointY(x,y);
var _x2 = this.Graphics.m_oFullTransform.TransformPointX(x+w,y);
var _y2 = this.Graphics.m_oFullTransform.TransformPointY(x+w,y);
var _x3 = this.Graphics.m_oFullTransform.TransformPointX(x+w,(y+h));
var _y3 = this.Graphics.m_oFullTransform.TransformPointY(x+w,(y+h));
var _x4 = this.Graphics.m_oFullTransform.TransformPointX(x,(y+h));
var _y4 = this.Graphics.m_oFullTransform.TransformPointY(x,(y+h));
this.m_oOverlay.CheckPoint(_x1, _y1);
this.m_oOverlay.CheckPoint(_x2, _y2);
this.m_oOverlay.CheckPoint(_x3, _y3);
this.m_oOverlay.CheckPoint(_x4, _y4);
};
CAutoshapeTrack.prototype.CorrectOverlayBounds = function()
{
this.m_oOverlay.SetBaseTransform();
this.m_oOverlay.min_x -= this.MaxEpsLine;
this.m_oOverlay.min_y -= this.MaxEpsLine;
this.m_oOverlay.max_x += this.MaxEpsLine;
this.m_oOverlay.max_y += this.MaxEpsLine;
};
CAutoshapeTrack.prototype.GetCanvasTransform = function(nPageIndex)
{
if (Asc.editor.isPdfEditor())
{
let oDocument = Asc.editor.getPDFDoc();
let oPageTransform = oDocument.pagesTransform[nPageIndex];
if (oPageTransform)
{
let canvasTransform = AscCommon.global_MatrixTransformer.Invert(this.Graphics.m_oCoordTransform);
let scaleFactor = (25.4 / Asc.editor.getDocumentRenderer().file.pages[nPageIndex].Dpi);
let retinaFactor = 1 / AscCommon.AscBrowser.retinaPixelRatio;
let pageTransform = new AscCommon.CMatrix();
AscCommon.global_MatrixTransformer.ScaleAppend(pageTransform, retinaFactor, retinaFactor);
AscCommon.global_MatrixTransformer.MultiplyAppend(pageTransform, oPageTransform.normal);
AscCommon.global_MatrixTransformer.ScaleAppend(pageTransform, scaleFactor, scaleFactor);
let pageTransformInvert = AscCommon.global_MatrixTransformer.Invert(pageTransform);
AscCommon.global_MatrixTransformer.MultiplyAppend(canvasTransform, pageTransformInvert);
return canvasTransform;
}
}
return null;
};
CAutoshapeTrack.prototype.CheckCanvasTransform = function()
{
this.CanvasTransform = this.GetCanvasTransform(this.PageIndex);
if (this.CanvasTransform)
{
let m = this.CanvasTransform;
this.m_oContext.setTransform(m.sx,m.shy,m.shx,m.sy,m.tx,m.ty);
}
else
{
this.m_oContext.setTransform(1, 0, 0, 1, 0, 0);
}
this.m_oOverlay.CanvasTransform = this.CanvasTransform;
};
CAutoshapeTrack.prototype.SetCurrentPage = function(nPageIndex, isAttack)
{
if (nPageIndex == this.PageIndex && !isAttack)
return;
var oPage = this.m_oOverlay.m_oHtmlPage.GetDrawingPageInfo(nPageIndex);
this.PageIndex = nPageIndex;
var drawPage = oPage.drawingPage;
this.Graphics = new AscCommon.CGraphics();
var _scale = this.m_oOverlay.IsCellEditor ? 1 : AscCommon.AscBrowser.retinaPixelRatio;
this.Graphics.init(this.m_oContext, _scale * (drawPage.right - drawPage.left), _scale * (drawPage.bottom - drawPage.top), oPage.width_mm, oPage.height_mm);
this.Graphics.m_oCoordTransform.tx = _scale * drawPage.left;
this.Graphics.m_oCoordTransform.ty = _scale * drawPage.top;
if (Asc.editor.isPdfEditor())
{
// TODO: Do not use the renderer matrix to calculate logical coordinates!!!
this.Graphics.m_oCoordTransform.sx = _scale * (drawPage.right - drawPage.left) / oPage.width_mm;
this.Graphics.m_oCoordTransform.sy = _scale * (drawPage.bottom - drawPage.top) / oPage.height_mm;
}
this.Graphics.globalAlpha = 0.5;
this.m_oContext.globalAlpha = 0.5;
this.Graphics.SetIntegerGrid(false);
this.CheckCanvasTransform();
};
CAutoshapeTrack.prototype.init2 = function(overlay)
{
this.m_oOverlay = overlay;
this.m_oContext = this.m_oOverlay.m_oContext;
this.PageIndex = -1;
};
CAutoshapeTrack.prototype.AddClipRect = function()
{
};
CAutoshapeTrack.prototype.SavePen = function()
{
this.Graphics.SavePen();
};
CAutoshapeTrack.prototype.RestorePen = function()
{
this.Graphics.RestorePen();
};
CAutoshapeTrack.prototype.SaveBrush = function()
{
this.Graphics.SaveBrush();
};
CAutoshapeTrack.prototype.RestoreBrush = function()
{
this.Graphics.RestoreBrush();
};
CAutoshapeTrack.prototype.SavePenBrush = function()
{
this.Graphics.SavePenBrush();
};
CAutoshapeTrack.prototype.RestorePenBrush = function()
{
this.Graphics.RestorePenBrush();
};
CAutoshapeTrack.prototype.SaveGrState = function()
{
this.Graphics.SaveGrState();
};
CAutoshapeTrack.prototype.RestoreGrState = function()
{
this.Graphics.RestoreGrState();
};
CAutoshapeTrack.prototype.StartClipPath = function()
{
this.Graphics.StartClipPath();
};
CAutoshapeTrack.prototype.EndClipPath = function()
{
this.Graphics.EndClipPath();
};
/*************************************************************************/
/******************************** TRACKS *********************************/
/*************************************************************************/
CAutoshapeTrack.prototype.DrawTrack = function(type, matrix, left, top, width, height, isLine, isCanRotate, isNoMove, isDrawHandles)
{
if (true === isNoMove)
return;
var bDrawHandles = (isDrawHandles !== false);
if (bDrawHandles === false)
type = AscFormat.TYPE_TRACK.SHAPE;
if (this.m_oOverlay.IsCellEditor)
{
left /= AscCommon.AscBrowser.retinaPixelRatio;
top /= AscCommon.AscBrowser.retinaPixelRatio;
width /= AscCommon.AscBrowser.retinaPixelRatio;
height /= AscCommon.AscBrowser.retinaPixelRatio;
if (matrix)
{
matrix.tx /= AscCommon.AscBrowser.retinaPixelRatio;
matrix.ty /= AscCommon.AscBrowser.retinaPixelRatio;
}
}
// с самого начала нужно понять, есть ли поворот. Потому что если его нет, то можно
// (и нужно!) рисовать все по-умному
var overlay = this.m_oOverlay;
overlay.Show();
var bIsClever = false;
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = this.m_oOverlay.IsCellEditor ? drPage.left : drPage.left * rPR;
var yDst = this.m_oOverlay.IsCellEditor ? drPage.top : drPage.top * rPR;
var wDst = (drPage.right - drPage.left) * rPR;
var hDst = (drPage.bottom - drPage.top) * rPR;
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
var r = left + width;
var b = top + height;
// (x1,y1) --------- (x2,y2)
// | |
// | |
// (x3,y3) --------- (x4,y4)
var dx1 = xDst + dKoefX * (matrix.TransformPointX(left, top));
var dy1 = yDst + dKoefY * (matrix.TransformPointY(left, top));
var dx2 = xDst + dKoefX * (matrix.TransformPointX(r, top));
var dy2 = yDst + dKoefY * (matrix.TransformPointY(r, top));
var dx3 = xDst + dKoefX * (matrix.TransformPointX(left, b));
var dy3 = yDst + dKoefY * (matrix.TransformPointY(left, b));
var dx4 = xDst + dKoefX * (matrix.TransformPointX(r, b));
var dy4 = yDst + dKoefY * (matrix.TransformPointY(r, b));
var x1 = dx1 >> 0;
var y1 = dy1 >> 0;
var x2 = dx2 >> 0;
var y2 = dy2 >> 0;
var x3 = dx3 >> 0;
var y3 = dy3 >> 0;
var x4 = dx4 >> 0;
var y4 = dy4 >> 0;
var _eps = 0.01;
if (Math.abs(dx1 - dx3) < _eps &&
Math.abs(dx2 - dx4) < _eps &&
Math.abs(dy1 - dy2) < _eps &&
Math.abs(dy3 - dy4) < _eps &&
x1 < x2 && y1 < y3)
{
x3 = x1;
x4 = x2;
y2 = y1;
y4 = y3;
bIsClever = true;
}
var nIsCleverWithTransform = bIsClever;
var nType = 0;
if (!nIsCleverWithTransform &&
Math.abs(dx1 - dx3) < _eps &&
Math.abs(dx2 - dx4) < _eps &&
Math.abs(dy1 - dy2) < _eps &&
Math.abs(dy3 - dy4) < _eps)
{
x3 = x1;
x4 = x2;
y2 = y1;
y4 = y3;
nIsCleverWithTransform = true;
nType = 1;
if (false)
{
if (x1 > x2)
{
var tmp = x1;
x1 = x2; x3 = x2;
x2 = tmp; x4 = tmp;
}
if (y1 > y3)
{
var tmp = y1;
y1 = y3; y2 = y3;
y3 = tmp; y4 = tmp;
}
nType = 0;
bIsClever = true;
}
}
if (!nIsCleverWithTransform &&
Math.abs(dx1 - dx2) < _eps &&
Math.abs(dx3 - dx4) < _eps &&
Math.abs(dy1 - dy3) < _eps &&
Math.abs(dy2 - dy4) < _eps)
{
x2 = x1;
x4 = x3;
y3 = y1;
y4 = y2;
nIsCleverWithTransform = true;
nType = 2;
}
/*
if (x1 == x3 && x2 == x4 && y1 == y2 && y3 == y4 && x1 < x2 && y1 < y3)
bIsClever = true;
var nIsCleverWithTransform = bIsClever;
var nType = 0;
if (!nIsCleverWithTransform && x1 == x3 && x2 == x4 && y1 == y2 && y3 == y4)
{
nIsCleverWithTransform = true;
nType = 1;
}
if (!nIsCleverWithTransform && x1 == x2 && x3 == x4 && y1 == y3 && y2 == y4)
{
nIsCleverWithTransform = true;
nType = 2;
}
*/
var ctx = overlay.m_oContext;
var bIsEllipceCorner = false;
//var _style_blue = "#4D7399";
//var _style_blue = "#B2B2B2";
var _style_blue = "#939393";
var _style_green = "#84E036";
var _style_white = "#FFFFFF";
var _style_black = "#000000";
var _len_x = Math.sqrt((x1 - x2)*(x1 - x2) + (y1 - y2)*(y1 - y2));
var _len_y = Math.sqrt((x1 - x3)*(x1 - x3) + (y1 - y3)*(y1 - y3));
if (_len_x < 1)
_len_x = 1;
if (_len_y < 1)
_len_y = 1;
var epsForCenter = 30 * rPR;
var bIsRectsTrackX = (_len_x >= epsForCenter) ? true : false;
var bIsRectsTrackY = (_len_y >= epsForCenter) ? true : false;
// для stamp аннотации не рисуем
if (type == AscFormat.TYPE_TRACK.ANNOT_STAMP) {
bIsRectsTrackY = false;
bIsRectsTrackX = false;
}
var bIsRectsTrack = (bIsRectsTrackX || bIsRectsTrackY) ? true : false;
if (bIsRectsTrack && (type == AscFormat.TYPE_TRACK.CHART_TEXT))
bIsRectsTrack = false;
if (nType == 2)
{
var _tmp = bIsRectsTrackX;
bIsRectsTrackX = bIsRectsTrackY;
bIsRectsTrackY = _tmp;
}
ctx.lineWidth = Math.round(rPR);
ctx.beginPath();
var _oldGlobalAlpha = ctx.globalAlpha;
ctx.globalAlpha = 1;
var SCALE_TRACK_RECT_SIZE = Math.round(TRACK_RECT_SIZE * rPR),
SCALE_TRACK_RECT_SIZE_CT = Math.round(TRACK_RECT_SIZE_CT * rPR);
var indent = 0.5 * Math.round(rPR);
switch (type)
{
case AscFormat.TYPE_TRACK.FORM:
{
SCALE_TRACK_RECT_SIZE = Math.round(TRACK_RECT_SIZE_FORM * rPR);
type = AscFormat.TYPE_TRACK.SHAPE;
}
case AscFormat.TYPE_TRACK.SHAPE:
case AscFormat.TYPE_TRACK.GROUP:
case AscFormat.TYPE_TRACK.CHART_TEXT:
case AscFormat.TYPE_TRACK.ANNOT_STAMP:
{
if (bIsClever)
{
overlay.CheckRect(x1, y1, x4 - x1, y4 - y1);
ctx.strokeStyle = _style_blue;
if (!isLine)
{
ctx.rect(x1 + indent, y2 + indent, x4 - x1, y4 - y1);
ctx.stroke();
ctx.beginPath();
}
if(bDrawHandles)
{
var xC = ((x1 + x2) / 2) >> 0;
if (!isLine && isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - Math.round(TRACK_DISTANCE_ROTATE * rPR), Math.round(TRACK_CIRCLE_RADIUS * rPR));
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
var _image_track_rotate = overlay.GetImageTrackRotationImage();
if (_image_track_rotate.asc_complete)
{
var _w = Math.round(ROTATE_TRACK_W * rPR),
_xI = (xC + indent - _w / 2) >> 0,
_yI = y1 - Math.round(TRACK_DISTANCE_ROTATE * rPR),
radius = Math.round(6 * rPR);
overlay.CheckRect(_xI, _yI - radius * 2, _w, _w);
ctx.fillStyle = "#939393";
var cnvs = this.GetArrowCanvas();
ctx.drawImage(cnvs, xC - Math.round(12.5 * rPR), _yI - Math.round(4.5 * rPR))
ctx.beginPath();
ctx.lineWidth = Math.round(rPR);
ctx.arc(xC, _yI + Math.round(rPR), radius, -3 / 4 * Math.PI, Math.PI);
ctx.stroke();
ctx.beginPath();
ctx.arc(xC, _yI + Math.round(rPR), _w / 16, 0, 2 * Math.PI);
ctx.stroke();
ctx.closePath();
ctx.beginPath();
ctx.globalCompositeOperation = "destination-over";
ctx.arc(xC, _yI + Math.round(rPR), _w / 2, 0, 2 * Math.PI);
ctx.fillStyle = "#ffffff";
ctx.fill();
ctx.closePath();
ctx.globalCompositeOperation = "source-over";
}
}
ctx.beginPath();
ctx.moveTo(xC + indent, y1);
ctx.lineTo(xC + indent, y1 - Math.round(TRACK_DISTANCE_ROTATE2 * rPR));
ctx.stroke();
ctx.beginPath();
}
ctx.fillStyle = (type != AscFormat.TYPE_TRACK.CHART_TEXT) ? _style_white : _style_blue;
var TRACK_RECT_SIZE_CUR = (type != AscFormat.TYPE_TRACK.CHART_TEXT) ? SCALE_TRACK_RECT_SIZE : SCALE_TRACK_RECT_SIZE_CT;
if (type == AscFormat.TYPE_TRACK.CHART_TEXT)
ctx.strokeStyle = _style_white;
if (bIsEllipceCorner)
{
overlay.AddEllipse(x1, y1, Math.round(TRACK_CIRCLE_RADIUS * rPR));
if (!isLine)
{
overlay.AddEllipse(x2, y2, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x3, y3, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
overlay.AddEllipse(x4, y4, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
else
{
overlay.AddRect2(x1 + indent, y1 + indent, TRACK_RECT_SIZE_CUR);
if (!isLine)
{
overlay.AddRect2(x2 + indent, y2 + indent, TRACK_RECT_SIZE_CUR);
overlay.AddRect2(x3 + indent, y3 + indent, TRACK_RECT_SIZE_CUR);
}
overlay.AddRect2(x4 + indent, y4 + indent, TRACK_RECT_SIZE_CUR);
}
if (bIsRectsTrack && !isLine)
{
var _xC = (((x1 + x2) / 2) >> 0) + indent;
var _yC = (((y1 + y3) / 2) >> 0) + indent;
if (bIsRectsTrackX)
{
overlay.AddRect2(_xC, y1 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_xC, y3 + indent, SCALE_TRACK_RECT_SIZE);
}
if (bIsRectsTrackY)
{
overlay.AddRect2(x2 + indent, _yC, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x1 + indent, _yC, SCALE_TRACK_RECT_SIZE);
}
}
}
ctx.fill();
ctx.stroke();
ctx.beginPath();
}
else
{
var _x1 = x1;
var _y1 = y1;
var _x2 = x2;
var _y2 = y2;
var _x3 = x3;
var _y3 = y3;
var _x4 = x4;
var _y4 = y4;
if (nIsCleverWithTransform)
{
var _x1 = x1;
if (x2 < _x1)
_x1 = x2;
if (x3 < _x1)
_x1 = x3;
if (x4 < _x1)
_x1 = x4;
var _x4 = x1;
if (x2 > _x4)
_x4 = x2;
if (x3 > _x4)
_x4 = x3;
if (x4 > _x4)
_x4 = x4;
var _y1 = y1;
if (y2 < _y1)
_y1 = y2;
if (y3 < _y1)
_y1 = y3;
if (y4 < _y1)
_y1 = y4;
var _y4 = y1;
if (y2 > _y4)
_y4 = y2;
if (y3 > _y4)
_y4 = y3;
if (y4 > _y4)
_y4 = y4;
_x2 = _x4;
_y2 = _y1;
_x3 = _x1;
_y3 = _y4;
}
ctx.strokeStyle = _style_blue;
if (!isLine)
{
if (nIsCleverWithTransform)
{
ctx.rect(_x1 + indent, _y2 + indent, _x4 - _x1, _y4 - _y1);
ctx.stroke();
ctx.beginPath();
}
else
{
ctx.moveTo(x1, y1);
ctx.lineTo(x2, y2);
ctx.lineTo(x4, y4);
ctx.lineTo(x3, y3);
ctx.closePath();
ctx.stroke();
}
}
overlay.CheckPoint(x1, y1);
overlay.CheckPoint(x2, y2);
overlay.CheckPoint(x3, y3);
overlay.CheckPoint(x4, y4);
var ex1 = (x2 - x1) / _len_x;
var ey1 = (y2 - y1) / _len_x;
var ex2 = (x1 - x3) / _len_y;
var ey2 = (y1 - y3) / _len_y;
var _bAbsX1 = Math.abs(ex1) < 0.01;
var _bAbsY1 = Math.abs(ey1) < 0.01;
var _bAbsX2 = Math.abs(ex2) < 0.01;
var _bAbsY2 = Math.abs(ey2) < 0.01;
if (_bAbsX2 && _bAbsY2)
{
if (_bAbsX1 && _bAbsY1)
{
ex1 = 1;
ey1 = 0;
ex2 = 0;
ey2 = 1;
}
else
{
ex2 = -ey1;
ey2 = ex1;
}
}
else if (_bAbsX1 && _bAbsY1)
{
ex1 = ey2;
ey1 = -ex2;
}
var xc1 = (x1 + x2) / 2;
var yc1 = (y1 + y2) / 2;
ctx.beginPath();
if (bDrawHandles)
{
if (!isLine && isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE * rPR, yc1 + ey2 * TRACK_DISTANCE_ROTATE * rPR, Math.round(TRACK_CIRCLE_RADIUS * rPR));
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
var _image_track_rotate = overlay.GetImageTrackRotationImage();
if (_image_track_rotate.asc_complete)
{
var _xI = Math.round(xc1 + ex2 * TRACK_DISTANCE_ROTATE * rPR);
var _yI = Math.round(yc1 + ey2 * TRACK_DISTANCE_ROTATE * rPR);
var _w = Math.round(ROTATE_TRACK_W * rPR);
var _w2 = Math.round(ROTATE_TRACK_W / 2 * rPR);
if (nIsCleverWithTransform)
{
_xI >>= 0;
_yI >>= 0;
_w2 >>= 0;
_w2 += 1;
}
var _matrix = matrix.CreateDublicate();
_matrix.tx = 0;
_matrix.ty = 0;
var _xx = _matrix.TransformPointX(0, 1);
var _yy = _matrix.TransformPointY(0, 1);
var _angle = Math.atan2(_xx, -_yy) - Math.PI;
var _px = Math.cos(_angle);
var _py = Math.sin(_angle);
ctx.save();
var cnvs = this.GetArrowCanvas(),
cnvsRotate = this.GetRotatedArrowCanvas(),
cntxRotate = cnvsRotate.getContext('2d'),
arrowSize = overlay.GetArrowSize(),
x = arrowSize / 2,
y = arrowSize / 2,
radius = Math.round(6 * rPR);
ctx.beginPath();
// rotate arrow depending on the angle
cntxRotate.translate(x, y)
cntxRotate.rotate(_angle);
cntxRotate.translate(-x, -y);
cntxRotate.drawImage(cnvs, 0, 0);
ctx.drawImage(cnvsRotate, Math.round(_xI - 6.4 * rPR - radius * _px), Math.round(_yI - 6.4 * rPR - radius * _py));
//draw semicircle
ctx.beginPath();
ctx.lineWidth = Math.round(rPR);
ctx.arc(_xI, _yI, radius, -3 / 4 * Math.PI + _angle, Math.PI + _angle);
ctx.stroke();
//draw inner circle
ctx.beginPath();
ctx.arc(_xI, _yI, _w / 16, 0, 2 * Math.PI);
ctx.stroke();
//draw circular background
ctx.globalCompositeOperation = "destination-over";
ctx.arc(_xI, _yI, _w / 2, 0, 2 * Math.PI);
ctx.fillStyle = "#ffffff";
ctx.fill();
ctx.closePath();
ctx.globalCompositeOperation = "source-over";
ctx.restore();
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
ctx.beginPath();
if (!nIsCleverWithTransform)
{
ctx.moveTo(xc1, yc1);
ctx.lineTo(xc1 + ex2 * (TRACK_DISTANCE_ROTATE2 * rPR + Math.round(rPR)), yc1 + ey2 * (TRACK_DISTANCE_ROTATE2 * rPR + Math.round(rPR)));
}
else
{
ctx.moveTo((xc1 >> 0) + indent, (yc1 >> 0) + indent);
ctx.lineTo(((xc1 + ex2 * TRACK_DISTANCE_ROTATE2 * rPR) >> 0) + indent, ((yc1 + ey2 * TRACK_DISTANCE_ROTATE2 * rPR) >> 0) + indent);
}
ctx.stroke();
ctx.beginPath();
}
ctx.fillStyle = (type != AscFormat.TYPE_TRACK.CHART_TEXT) ? _style_white : _style_blue;
var TRACK_RECT_SIZE_CUR = (type != AscFormat.TYPE_TRACK.CHART_TEXT) ? SCALE_TRACK_RECT_SIZE : SCALE_TRACK_RECT_SIZE_CT;
if (type == AscFormat.TYPE_TRACK.CHART_TEXT)
ctx.strokeStyle = _style_white;
if (!nIsCleverWithTransform)
{
if (bIsEllipceCorner)
{
overlay.AddEllipse(x1, y1, Math.round(TRACK_CIRCLE_RADIUS * rPR));
if (!isLine)
{
overlay.AddEllipse(x2, y2, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x3, y3, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
overlay.AddEllipse(x4, y4, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
else
{
overlay.AddRect3(x1, y1, TRACK_RECT_SIZE_CUR, ex1, ey1, ex2, ey2);
if (!isLine)
{
overlay.AddRect3(x2, y2, TRACK_RECT_SIZE_CUR, ex1, ey1, ex2, ey2);
overlay.AddRect3(x3, y3, TRACK_RECT_SIZE_CUR, ex1, ey1, ex2, ey2);
}
overlay.AddRect3(x4, y4, TRACK_RECT_SIZE_CUR, ex1, ey1, ex2, ey2);
}
}
else
{
if (bIsEllipceCorner)
{
overlay.AddEllipse(_x1, _y1, Math.round(TRACK_CIRCLE_RADIUS * rPR));
if (!isLine)
{
overlay.AddEllipse(_x2, _y2, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(_x3, _y3, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
overlay.AddEllipse(_x4, _y4, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
else
{
if (!isLine)
{
overlay.AddRect2(_x1 + indent, _y1 + indent, TRACK_RECT_SIZE_CUR);
overlay.AddRect2(_x2 + indent, _y2 + indent, TRACK_RECT_SIZE_CUR);
overlay.AddRect2(_x3 + indent, _y3 + indent, TRACK_RECT_SIZE_CUR);
overlay.AddRect2(_x4 + indent, _y4 + indent, TRACK_RECT_SIZE_CUR);
}
else
{
overlay.AddRect2(x1 + indent, y1 + indent, TRACK_RECT_SIZE_CUR);
overlay.AddRect2(x4 + indent, y4 + indent, TRACK_RECT_SIZE_CUR);
}
}
}
if (!isLine)
{
if (!nIsCleverWithTransform)
{
if (bIsRectsTrack)
{
if (bIsRectsTrackX)
{
overlay.AddRect3((x1 + x2) / 2, (y1 + y2) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3((x3 + x4) / 2, (y3 + y4) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
}
if (bIsRectsTrackY)
{
overlay.AddRect3((x2 + x4) / 2, (y2 + y4) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3((x3 + x1) / 2, (y3 + y1) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
}
}
}
else
{
var _xC = (((_x1 + _x2) / 2) >> 0) + indent;
var _yC = (((_y1 + _y3) / 2) >> 0) + indent;
if (bIsRectsTrackX)
{
overlay.AddRect2(_xC, _y1 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_xC, _y3 + indent, SCALE_TRACK_RECT_SIZE);
}
if (bIsRectsTrackY)
{
overlay.AddRect2(_x2 + indent, _yC, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_x1 + indent, _yC, SCALE_TRACK_RECT_SIZE);
}
}
}
}
ctx.fill();
ctx.stroke();
ctx.beginPath();
}
break;
}
case AscFormat.TYPE_TRACK.TEXT:
case AscFormat.TYPE_TRACK.GROUP_PASSIVE:
{
if (bIsClever)
{
overlay.CheckRect(x1, y1, x4 - x1, y4 - y1);
ctx.strokeStyle = _style_blue;
this.AddRectDashClever(ctx, x1, y1, x4, y4, 8, 3, true);
ctx.beginPath();
if (isCanRotate)
{
var xC = ((x1 + x2) / 2) >> 0;
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - Math.round(TRACK_DISTANCE_ROTATE * rPR), Math.round(TRACK_CIRCLE_RADIUS * rPR));
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
var _image_track_rotate = overlay.GetImageTrackRotationImage();
if (_image_track_rotate.asc_complete)
{
var _w = Math.round(ROTATE_TRACK_W * rPR),
_xI = (xC + indent - _w / 2) >> 0,
_yI = y1 - Math.round(TRACK_DISTANCE_ROTATE * rPR),
radius = Math.round(6 * rPR);
overlay.CheckRect(_xI, _yI - radius * 2, _w, _w);
ctx.fillStyle = "#939393";
var cnvs = this.GetArrowCanvas();
ctx.drawImage(cnvs, xC - Math.round(12.5 * rPR), _yI - Math.round(4.5 * rPR))
ctx.beginPath();
ctx.lineWidth = Math.round(rPR);
ctx.arc(xC, _yI + Math.round(rPR), radius, -3 / 4 * Math.PI, Math.PI);
ctx.stroke();
ctx.beginPath();
ctx.arc(xC, _yI + Math.round(rPR), _w / 16, 0, 2 * Math.PI);
ctx.stroke();
ctx.closePath();
ctx.beginPath();
ctx.globalCompositeOperation = "destination-over";
ctx.arc(xC, _yI + Math.round(rPR), _w / 2, 0, 2 * Math.PI);
ctx.fillStyle = "#ffffff";
ctx.fill();
ctx.closePath();
ctx.globalCompositeOperation = "source-over";
}
}
ctx.beginPath();
ctx.moveTo(xC + indent, y1);
ctx.lineTo(xC + indent, y1 - Math.round(TRACK_DISTANCE_ROTATE2 * rPR));
ctx.stroke();
ctx.beginPath();
}
ctx.fillStyle = _style_white;
if (bIsEllipceCorner)
{
overlay.AddEllipse(x1, y1, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x2, y2, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x3, y3, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x4, y4, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
else
{
overlay.AddRect2(x1 + indent, y1 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x2 + indent, y2 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x3 + indent, y3 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x4 + indent, y4 + indent, SCALE_TRACK_RECT_SIZE);
}
if (bIsRectsTrack)
{
var _xC = (((x1 + x2) / 2) >> 0) + indent;
var _yC = (((y1 + y3) / 2) >> 0) + indent;
if (bIsRectsTrackX)
{
overlay.AddRect2(_xC, y1 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_xC, y3 + indent, SCALE_TRACK_RECT_SIZE);
}
if (bIsRectsTrackY)
{
overlay.AddRect2(x2 + indent, _yC, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x1 + indent, _yC, SCALE_TRACK_RECT_SIZE);
}
}
ctx.fill();
ctx.stroke();
ctx.beginPath();
}
else
{
var _x1 = x1;
var _y1 = y1;
var _x2 = x2;
var _y2 = y2;
var _x3 = x3;
var _y3 = y3;
var _x4 = x4;
var _y4 = y4;
if (nIsCleverWithTransform)
{
var _x1 = x1;
if (x2 < _x1)
_x1 = x2;
if (x3 < _x1)
_x1 = x3;
if (x4 < _x1)
_x1 = x4;
var _x4 = x1;
if (x2 > _x4)
_x4 = x2;
if (x3 > _x4)
_x4 = x3;
if (x4 > _x4)
_x4 = x4;
var _y1 = y1;
if (y2 < _y1)
_y1 = y2;
if (y3 < _y1)
_y1 = y3;
if (y4 < _y1)
_y1 = y4;
var _y4 = y1;
if (y2 > _y4)
_y4 = y2;
if (y3 > _y4)
_y4 = y3;
if (y4 > _y4)
_y4 = y4;
_x2 = _x4;
_y2 = _y1;
_x3 = _x1;
_y3 = _y4;
}
overlay.CheckPoint(x1, y1);
overlay.CheckPoint(x2, y2);
overlay.CheckPoint(x3, y3);
overlay.CheckPoint(x4, y4);
ctx.strokeStyle = _style_blue;
if (!nIsCleverWithTransform)
{
this.AddRectDash(ctx, x1, y1, x2, y2, x3, y3, x4, y4, 8, 3, true);
}
else
{
this.AddRectDashClever(ctx, _x1, _y1, _x4, _y4, 8, 3, true);
}
var ex1 = (x2 - x1) / _len_x;
var ey1 = (y2 - y1) / _len_x;
var ex2 = (x1 - x3) / _len_y;
var ey2 = (y1 - y3) / _len_y;
var _bAbsX1 = Math.abs(ex1) < 0.01;
var _bAbsY1 = Math.abs(ey1) < 0.01;
var _bAbsX2 = Math.abs(ex2) < 0.01;
var _bAbsY2 = Math.abs(ey2) < 0.01;
if (_bAbsX2 && _bAbsY2)
{
if (_bAbsX1 && _bAbsY1)
{
ex1 = 1;
ey1 = 0;
ex2 = 0;
ey2 = 1;
}
else
{
ex2 = -ey1;
ey2 = ex1;
}
}
else if (_bAbsX1 && _bAbsY1)
{
ex1 = ey2;
ey1 = -ex2;
}
var xc1 = (x1 + x2) / 2;
var yc1 = (y1 + y2) / 2;
ctx.beginPath();
if (isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE * rPR, yc1 + ey2 * TRACK_DISTANCE_ROTATE * rPR, Math.round(TRACK_CIRCLE_RADIUS * rPR));
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
var _image_track_rotate = overlay.GetImageTrackRotationImage();
if (_image_track_rotate.asc_complete)
{
var _xI = Math.round(xc1 + ex2 * TRACK_DISTANCE_ROTATE * rPR);
var _yI = Math.round(yc1 + ey2 * TRACK_DISTANCE_ROTATE * rPR);
var _w = Math.round(ROTATE_TRACK_W * rPR);
var _w2 = Math.round(ROTATE_TRACK_W / 2 * rPR);
if (nIsCleverWithTransform)
{
_xI >>= 0;
_yI >>= 0;
_w2 >>= 0;
_w2 += 1;
}
//ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
var _matrix = matrix.CreateDublicate();
_matrix.tx = 0;
_matrix.ty = 0;
var _xx = _matrix.TransformPointX(0, 1);
var _yy = _matrix.TransformPointY(0, 1);
var _angle = Math.atan2(_xx, -_yy) - Math.PI;
var _px = Math.cos(_angle);
var _py = Math.sin(_angle);
ctx.save();
var cnvs = this.GetArrowCanvas(),
cnvsRotate = this.GetRotatedArrowCanvas(),
cntxRotate = cnvsRotate.getContext('2d'),
arrowSize = overlay.GetArrowSize(),
x = arrowSize / 2,
y = arrowSize / 2,
radius = Math.round(6 * rPR);
ctx.beginPath();
// rotate arrow depending on the angle
cntxRotate.translate(x, y)
cntxRotate.rotate(_angle);
cntxRotate.translate(-x, -y);
cntxRotate.drawImage(cnvs, 0, 0);
ctx.drawImage(cnvsRotate, Math.round(_xI - 6.4 * rPR - radius * _px), Math.round(_yI - 6.4 * rPR - radius * _py));
//draw semicircle
ctx.beginPath();
ctx.lineWidth = Math.round(rPR);
ctx.arc(_xI, _yI, radius, -3 / 4 * Math.PI + _angle, Math.PI + _angle);
ctx.stroke();
//draw inner circle
ctx.beginPath();
ctx.arc(_xI, _yI, _w / 16, 0, 2 * Math.PI);
ctx.stroke();
//draw circular background
ctx.globalCompositeOperation = "destination-over";
ctx.arc(_xI, _yI, _w / 2, 0, 2 * Math.PI);
ctx.fillStyle = "#ffffff";
ctx.fill();
ctx.closePath();
ctx.globalCompositeOperation = "source-over";
ctx.restore();
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
ctx.beginPath();
if (!nIsCleverWithTransform)
{
ctx.moveTo(xc1, yc1);
ctx.lineTo(xc1 + ex2 * (TRACK_DISTANCE_ROTATE2 * rPR + Math.round(rPR)), yc1 + ey2 * (TRACK_DISTANCE_ROTATE2 * rPR + Math.round(rPR)));
}
else
{
ctx.moveTo((xc1 >> 0) + indent, (yc1 >> 0) + indent);
ctx.lineTo(((xc1 + ex2 * TRACK_DISTANCE_ROTATE2 * rPR) >> 0) + indent, ((yc1 + ey2 * TRACK_DISTANCE_ROTATE2 * rPR) >> 0) + indent);
}
ctx.stroke();
ctx.beginPath();
}
ctx.fillStyle = _style_white;
if (!nIsCleverWithTransform)
{
if (bIsEllipceCorner)
{
overlay.AddEllipse(x1, y1, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x2, y2, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x3, y3, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x4, y4, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
else
{
overlay.AddRect3(x1, y1, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3(x2, y2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3(x3, y3, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3(x4, y4, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
}
}
else
{
if (bIsEllipceCorner)
{
overlay.AddEllipse(x1, y1, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x2, y2, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x3, y3, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x4, y4, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
else
{
overlay.AddRect2(_x1 + indent, _y1 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_x2 + indent, _y2 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_x3 + indent, _y3 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_x4 + indent, _y4 + indent, SCALE_TRACK_RECT_SIZE);
}
}
if (!nIsCleverWithTransform)
{
if (bIsRectsTrack)
{
if (bIsRectsTrackX)
{
overlay.AddRect3((x1 + x2) / 2, (y1 + y2) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3((x3 + x4) / 2, (y3 + y4) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
}
if (bIsRectsTrackY)
{
overlay.AddRect3((x2 + x4) / 2, (y2 + y4) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3((x3 + x1) / 2, (y3 + y1) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
}
}
}
else
{
if (bIsRectsTrack)
{
var _xC = (((_x1 + _x2) / 2) >> 0) + indent;
var _yC = (((_y1 + _y3) / 2) >> 0) + indent;
if (bIsRectsTrackX)
{
overlay.AddRect2(_xC, _y1 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_xC, _y3 + indent, SCALE_TRACK_RECT_SIZE);
}
if (bIsRectsTrackY)
{
overlay.AddRect2(_x2 + indent, _yC, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_x1 + indent, _yC, SCALE_TRACK_RECT_SIZE);
}
}
}
ctx.fill();
ctx.stroke();
ctx.beginPath();
}
break;
}
case AscFormat.TYPE_TRACK.EMPTY_PH:
{
if (bIsClever)
{
overlay.CheckRect(x1, y1, x4 - x1, y4 - y1);
ctx.rect(x1 + indent, y2 + indent, x4 - x1 + 1, y4 - y1);
ctx.fillStyle = _style_white;
ctx.stroke();
ctx.beginPath();
ctx.strokeStyle = _style_blue;
this.AddRectDashClever(ctx, x1, y1, x4, y4, 8, 3, true);
ctx.beginPath();
var xC = ((x1 + x2) / 2) >> 0;
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - Math.round(TRACK_DISTANCE_ROTATE * rPR));
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
var _image_track_rotate = overlay.GetImageTrackRotationImage();
if (_image_track_rotate.asc_complete)
{
var _w = Math.round(ROTATE_TRACK_W * rPR);
var _xI = (xC + indent - _w / 2) >> 0;
var _yI = y1 - Math.round(TRACK_DISTANCE_ROTATE * rPR) - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(_image_track_rotate, _xI, _yI, _w, _w);
}
}
ctx.beginPath();
ctx.moveTo(xC + indent, y1);
ctx.lineTo(xC + indent, y1 - Math.round(TRACK_DISTANCE_ROTATE2 * rPR));
ctx.stroke();
ctx.beginPath();
ctx.fillStyle = _style_white;
if (bIsEllipceCorner)
{
overlay.AddEllipse(x1, y1, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x2, y2, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x3, y3, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x4, y4, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
else
{
overlay.AddRect2(x1 + indent, y1 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x2 + indent, y2 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x3 + indent, y3 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x4 + indent, y4 + indent, SCALE_TRACK_RECT_SIZE);
}
if (bIsRectsTrack && false)
{
var _xC = (((x1 + x2) / 2) >> 0) + indent;
var _yC = (((y1 + y3) / 2) >> 0) + indent;
overlay.AddRect2(_xC, y1 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x2 + indent, _yC, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(_xC, y3 + indent, SCALE_TRACK_RECT_SIZE);
overlay.AddRect2(x1 + indent, _yC, SCALE_TRACK_RECT_SIZE);
}
ctx.fill();
ctx.stroke();
ctx.beginPath();
}
else
{
overlay.CheckPoint(x1, y1);
overlay.CheckPoint(x2, y2);
overlay.CheckPoint(x3, y3);
overlay.CheckPoint(x4, y4);
ctx.moveTo(x1, y1);
ctx.lineTo(x2, y2);
ctx.lineTo(x3, y3);
ctx.lineTo(x4, y4);
ctx.closePath();
overlay.CheckPoint(x1, y1);
overlay.CheckPoint(x2, y2);
overlay.CheckPoint(x3, y3);
overlay.CheckPoint(x4, y4);
ctx.strokeStyle = _style_white;
ctx.stroke();
ctx.beginPath();
ctx.strokeStyle = _style_blue;
this.AddRectDash(ctx, x1, y1, x2, y2, x3, y3, x4, y4, 8, 3, true);
ctx.beginPath();
var ex1 = (x2 - x1) / _len_x;
var ey1 = (y2 - y1) / _len_x;
var ex2 = (x1 - x3) / _len_y;
var ey2 = (y1 - y3) / _len_y;
var _bAbsX1 = Math.abs(ex1) < 0.01;
var _bAbsY1 = Math.abs(ey1) < 0.01;
var _bAbsX2 = Math.abs(ex2) < 0.01;
var _bAbsY2 = Math.abs(ey2) < 0.01;
if (_bAbsX2 && _bAbsY2)
{
if (_bAbsX1 && _bAbsY1)
{
ex1 = 1;
ey1 = 0;
ex2 = 0;
ey2 = 1;
}
else
{
ex2 = -ey1;
ey2 = ex1;
}
}
else if (_bAbsX1 && _bAbsY1)
{
ex1 = ey2;
ey1 = -ex2;
}
var xc1 = (x1 + x2) / 2;
var yc1 = (y1 + y2) / 2;
ctx.beginPath();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE * rPR, yc1 + ey2 * TRACK_DISTANCE_ROTATE * rPR, Math.round(TRACK_DISTANCE_ROTATE * rPR));
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
var _image_track_rotate = overlay.GetImageTrackRotationImage();
if (_image_track_rotate.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE * rPR;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE * rPR;
var _w = Math.round(ROTATE_TRACK_W * rPR);
var _w2 = Math.round(ROTATE_TRACK_W / 2 * rPR);
ctx.save();
overlay.transform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(_image_track_rotate, -_w2, -_w2, _w, _w);
overlay.SetBaseTransform();
ctx.restore();
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
ctx.beginPath();
ctx.moveTo(xc1, yc1);
ctx.lineTo(xc1 + ex2 * TRACK_DISTANCE_ROTATE2 * rPR, yc1 + ey2 * TRACK_DISTANCE_ROTATE2 * rPR);
ctx.stroke();
ctx.beginPath();
ctx.fillStyle = _style_white;
if (bIsEllipceCorner)
{
overlay.AddEllipse(x1, y1, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x2, y2, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x3, y3, Math.round(TRACK_CIRCLE_RADIUS * rPR));
overlay.AddEllipse(x4, y4, Math.round(TRACK_CIRCLE_RADIUS * rPR));
}
else
{
overlay.AddRect3(x1, y1, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3(x2, y2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3(x3, y3, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3(x4, y4, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
}
if (bIsRectsTrack)
{
overlay.AddRect3((x1 + x2) / 2, (y1 + y2) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3((x2 + x4) / 2, (y2 + y4) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3((x3 + x4) / 2, (y3 + y4) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
overlay.AddRect3((x3 + x1) / 2, (y3 + y1) / 2, SCALE_TRACK_RECT_SIZE, ex1, ey1, ex2, ey2);
}
ctx.fill();
ctx.stroke();
ctx.beginPath();
}
break;
}
case AscFormat.TYPE_TRACK.CROP:
{
if (bIsClever)
{
overlay.CheckRect(x1, y1, x4 - x1, y4 - y1);
var widthCorner = (x4 - x1 + 1) >> 1;
var isCentralMarkerX = widthCorner > Math.round(40 * rPR) ? true : false;
var cropMarkerSize = Math.round(17 * rPR);
if (widthCorner > cropMarkerSize)
widthCorner = cropMarkerSize;
var heightCorner = (y4 - y1 + 1) >> 1;
var isCentralMarkerY = heightCorner > Math.round(40 * rPR) ? true : false;
if (heightCorner > cropMarkerSize)
heightCorner = cropMarkerSize;
ctx.rect(x1 + indent, y2 + indent, x4 - x1 + 1, y4 - y1);
ctx.strokeStyle = _style_black;
ctx.stroke();
ctx.beginPath();
ctx.strokeStyle = _style_white;
ctx.fillStyle = _style_black;
var roundRPR = Math.round(rPR);
ctx.moveTo(x1 + indent, y1 + indent);
ctx.lineTo(x1 + widthCorner + indent, y1 + indent);
ctx.lineTo(x1 + widthCorner + indent, y1 + 5.5 * roundRPR);
ctx.lineTo(x1 + 5.5 * roundRPR, y1 + 5.5 * roundRPR);
ctx.lineTo(x1 + 5.5 * roundRPR, y1 + widthCorner + indent);
ctx.lineTo(x1 + indent, y1 + widthCorner + indent);
ctx.closePath();
ctx.moveTo(x2 - widthCorner + indent, y2 + indent);
ctx.lineTo(x2 + indent, y2 + indent);
ctx.lineTo(x2 + indent, y2 + heightCorner + indent);
ctx.lineTo(x2 - 4.5 * roundRPR, y2 + heightCorner + indent);
ctx.lineTo(x2 - 4.5 * roundRPR, y2 + 5.5 * roundRPR);
ctx.lineTo(x2 - widthCorner + indent, y2 + 5.5 * roundRPR);
ctx.closePath();
ctx.moveTo(x4 - 4.5 * roundRPR, y4 - heightCorner + indent);
ctx.lineTo(x4 + indent, y4 - heightCorner + indent);
ctx.lineTo(x4 + indent, y4 + indent);
ctx.lineTo(x4 - widthCorner + indent, y4 + indent);
ctx.lineTo(x4 - widthCorner + indent, y4 - 4.5 * roundRPR);
ctx.lineTo(x4 - 4.5 * roundRPR, y4 - 4.5 * roundRPR);
ctx.closePath();
ctx.moveTo(x3 + indent, y3 - heightCorner + indent);
ctx.lineTo(x3 + 5.5 * roundRPR, y3 - heightCorner + indent);
ctx.lineTo(x3 + 5.5 * roundRPR, y3 - 4.5 * roundRPR);
ctx.lineTo(x3 + widthCorner + indent, y3 - 4.5 * roundRPR);
ctx.lineTo(x3 + widthCorner + indent, y3 + indent);
ctx.lineTo(x3 + indent, y3 + indent);
ctx.closePath();
if (isCentralMarkerX)
{
var xCentral = (x4 + x1 - widthCorner) >> 1;
ctx.moveTo(xCentral + indent, y1 + indent);
ctx.lineTo(xCentral + widthCorner + indent, y1 + indent);
ctx.lineTo(xCentral + widthCorner + indent, y1 + 5.5 * roundRPR);
ctx.lineTo(xCentral + indent, y1 + 5.5 * roundRPR);
ctx.closePath();
ctx.moveTo(xCentral + indent, y4 - 4.5 * roundRPR);
ctx.lineTo(xCentral + widthCorner + indent, y4 - 4.5 * roundRPR);
ctx.lineTo(xCentral + widthCorner + indent, y4);
ctx.lineTo(xCentral + indent, y4 + indent);
ctx.closePath();
}
if (isCentralMarkerY)
{
var yCentral = (y4 + y1 - heightCorner) >> 1;
ctx.moveTo(x1 + indent, yCentral + indent);
ctx.lineTo(x1 + 5.5 * roundRPR, yCentral + indent);
ctx.lineTo(x1 + 5.5 * roundRPR, yCentral + heightCorner + indent);
ctx.lineTo(x1 + indent, yCentral + heightCorner + indent);
ctx.closePath();
ctx.moveTo(x4 - 4.5 * roundRPR, yCentral + indent);
ctx.lineTo(x4 + indent, yCentral + indent);
ctx.lineTo(x4 + indent, yCentral + heightCorner + indent);
ctx.lineTo(x4 - 4.5 * roundRPR, yCentral + heightCorner + indent);
ctx.closePath();
}
ctx.fill();
ctx.stroke();
ctx.beginPath();
}
else
{
overlay.CheckPoint(x1, y1);
overlay.CheckPoint(x2, y2);
overlay.CheckPoint(x3, y3);
overlay.CheckPoint(x4, y4);
var ex1 = (x2 - x1) / _len_x;
var ey1 = (y2 - y1) / _len_x;
var ex2 = (x1 - x3) / _len_y;
var ey2 = (y1 - y3) / _len_y;
var _bAbsX1 = Math.abs(ex1) < 0.01;
var _bAbsY1 = Math.abs(ey1) < 0.01;
var _bAbsX2 = Math.abs(ex2) < 0.01;
var _bAbsY2 = Math.abs(ey2) < 0.01;
if (_bAbsX2 && _bAbsY2)
{
if (_bAbsX1 && _bAbsY1)
{
ex1 = 1;
ey1 = 0;
ex2 = 0;
ey2 = 1;
}
else
{
ex2 = -ey1;
ey2 = ex1;
}
}
else if (_bAbsX1 && _bAbsY1)
{
ex1 = ey2;
ey1 = -ex2;
}
var widthCorner = _len_x >> 1;
var isCentralMarkerX = widthCorner > Math.round(40 * rPR) ? true : false;
var cropMarkerSize = Math.round(17 * rPR);
if (widthCorner > cropMarkerSize)
widthCorner = cropMarkerSize;
var heightCorner = _len_y >> 1;
var isCentralMarkerY = heightCorner > Math.round(40 * rPR) ? true : false;
if (heightCorner > cropMarkerSize)
heightCorner = cropMarkerSize;
ctx.moveTo(x1, y1);
ctx.lineTo(x2, y2);
ctx.lineTo(x4, y4);
ctx.lineTo(x3, y3);
ctx.closePath();
ctx.strokeStyle = _style_black;
ctx.stroke();
ctx.beginPath();
ctx.strokeStyle = _style_white;
ctx.fillStyle = _style_black;
var xOff1 = widthCorner * ex1;
var xOff2 = 5 * ex1;
var xOff3 = -heightCorner * ex2;
var xOff4 = -5 * ex2;
var yOff1 = widthCorner * ey1;
var yOff2 = 5 * ey1;
var yOff3 = -heightCorner * ey2;
var yOff4 = -5 * ey2;
ctx.moveTo(x1, y1);
ctx.lineTo(x1 + xOff1, y1 + yOff1);
ctx.lineTo(x1 + xOff1 + xOff4, y1 + yOff1 + yOff4);
ctx.lineTo(x1 + xOff2 + xOff4, y1 + yOff2 + yOff4);
ctx.lineTo(x1 + xOff2 + xOff3, y1 + yOff2 + yOff3);
ctx.lineTo(x1 + xOff3, y1 + yOff3);
ctx.closePath();
ctx.moveTo(x2 - xOff1, y2 - yOff1);
ctx.lineTo(x2, y2);
ctx.lineTo(x2 + xOff3, y2 + yOff3);
ctx.lineTo(x2 + xOff3 - xOff2, y2 + yOff3 - yOff2);
ctx.lineTo(x2 - xOff2 + xOff4, y2 - yOff2 + yOff4);
ctx.lineTo(x2 - xOff1 + xOff4, y2 - yOff1 + yOff4);
ctx.closePath();
ctx.moveTo(x4 - xOff3 - xOff2, y4 - yOff3 - yOff2);
ctx.lineTo(x4 - xOff3, y4 - yOff3);
ctx.lineTo(x4, y4);
ctx.lineTo(x4 - xOff1, y4 - yOff1);
ctx.lineTo(x4 - xOff1 - xOff4, y4 - yOff1 - yOff4);
ctx.lineTo(x4 - xOff2 - xOff4, y4 - yOff2 - yOff4);
ctx.closePath();
ctx.moveTo(x3 - xOff3, y3 - yOff3);
ctx.lineTo(x3 - xOff3 + xOff2, y3 - yOff3 + yOff2);
ctx.lineTo(x3 - xOff4 + xOff2, y3 - yOff4 + yOff2);
ctx.lineTo(x3 + xOff1 - xOff4, y3 + yOff1 - yOff4);
ctx.lineTo(x3 + xOff1, y3 + yOff1);
ctx.lineTo(x3, y3);
ctx.closePath();
if (isCentralMarkerX)
{
var xCentral = x1 + (ex1 * (_len_x - widthCorner) / 2);
var yCentral = y1 + (ey1 * (_len_x - widthCorner) / 2);
ctx.moveTo(xCentral, yCentral);
ctx.lineTo(xCentral + xOff1, yCentral + yOff1);
ctx.lineTo(xCentral + xOff1 + xOff4, yCentral + yOff1 + yOff4);
ctx.lineTo(xCentral + xOff4, yCentral + yOff4);
ctx.closePath();
xCentral = x3 + (ex1 * (_len_x - widthCorner) / 2) - xOff4;
yCentral = y3 + (ey1 * (_len_x - widthCorner) / 2) - yOff4;
ctx.moveTo(xCentral, yCentral);
ctx.lineTo(xCentral + xOff1, yCentral + yOff1);
ctx.lineTo(xCentral + xOff1 + xOff4, yCentral + yOff1 + yOff4);
ctx.lineTo(xCentral + xOff4, yCentral + yOff4);
ctx.closePath();
}
if (isCentralMarkerY)
{
var xCentral = x1 - (ex2 * (_len_y - heightCorner) / 2);
var yCentral = y1 - (ey2 * (_len_y - heightCorner) / 2);
ctx.moveTo(xCentral, yCentral);
ctx.lineTo(xCentral + xOff2, yCentral + yOff2);
ctx.lineTo(xCentral + xOff2 + xOff3, yCentral + yOff2 + yOff3);
ctx.lineTo(xCentral + xOff3, yCentral + yOff3);
ctx.closePath();
xCentral = x2 - (ex2 * (_len_y - heightCorner) / 2) - xOff2;
yCentral = y2 - (ey2 * (_len_y - heightCorner) / 2) - yOff2;
ctx.moveTo(xCentral, yCentral);
ctx.lineTo(xCentral + xOff2, yCentral + yOff2);
ctx.lineTo(xCentral + xOff2 + xOff3, yCentral + yOff2 + yOff3);
ctx.lineTo(xCentral + xOff3, yCentral + yOff3);
ctx.closePath();
}
ctx.fill();
ctx.stroke();
ctx.beginPath();
}
break;
}
default:
break;
}
ctx.globalAlpha = _oldGlobalAlpha;
if (this.m_oOverlay.IsCellEditor)
{
this.m_oOverlay.SetBaseTransform();
if (matrix)
{
matrix.tx *= AscCommon.AscBrowser.retinaPixelRatio;
matrix.ty *= AscCommon.AscBrowser.retinaPixelRatio;
}
}
};
CAutoshapeTrack.prototype.DrawTrackSelectShapes = function(x, y, w, h)
{
var overlay = this.m_oOverlay;
overlay.Show();
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = drPage.left * rPR;
var yDst = drPage.top * rPR;
var wDst = (drPage.right - drPage.left) * rPR;
var hDst = (drPage.bottom - drPage.top) * rPR;
var indent = 0.5 * Math.round(rPR);
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
var x1 = (xDst + dKoefX * x) >> 0;
var y1 = (yDst + dKoefY * y) >> 0;
var x2 = (xDst + dKoefX * (x + w)) >> 0;
var y2 = (yDst + dKoefY * (y + h)) >> 0;
if (x1 > x2)
{
var tmp = x1;
x1 = x2;
x2 = tmp;
}
if (y1 > y2)
{
var tmp = y1;
y1 = y2;
y2 = tmp;
}
overlay.CheckRect(x1, y1, x2 - x1, y2 - y1);
var ctx = overlay.m_oContext;
overlay.SetBaseTransform();
var globalAlphaOld = ctx.globalAlpha;
ctx.globalAlpha = 0.5;
ctx.beginPath();
ctx.fillStyle = "rgba(51,102,204,255)";
ctx.strokeStyle = "#9ADBFE";
ctx.lineWidth = 1;
ctx.fillRect(x1, y1, x2 - x1, y2 - y1);
ctx.beginPath();
ctx.strokeRect(x1 - indent, y1 - indent, x2 - x1 + 1, y2 - y1 + 1);
ctx.globalAlpha = globalAlphaOld;
};
CAutoshapeTrack.prototype.AddRect = function(ctx, x, y, r, b, bIsClever)
{
if (bIsClever) {
var indent = 0.5 * Math.round(AscCommon.AscBrowser.retinaPixelRatio);
ctx.rect(x + indent, y + indent, r - x + 1, b - y + 1);
}
else
{
ctx.moveTo(x,y);
ctx.rect(x, y, r - x + 1, b - y + 1);
}
};
CAutoshapeTrack.prototype.AddRectDashClever = function(ctx, x, y, r, b, w_dot, w_dist, bIsStrokeAndCanUseNative)
{
var _support_native_dash = (undefined !== ctx.setLineDash);
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var indent = 0.5 * Math.round(rPR);
// здесь расчитано на толщину линии в один пиксел!
w_dot *= Math.round(rPR);
w_dist *= Math.round(rPR);
var _x = x + indent;
var _y = y + indent;
var _r = r + indent;
var _b = b + indent;
if (_support_native_dash && bIsStrokeAndCanUseNative === true)
{
ctx.setLineDash([w_dot, w_dist]);
// ctx.rect(x + indent, y + indent, r - x, b - y);
ctx.moveTo(x, _y);
ctx.lineTo(r - 1, _y);
ctx.moveTo(_r, y);
ctx.lineTo(_r, b - 1);
ctx.moveTo(r + 1, _b);
ctx.lineTo(x + 2, _b);
ctx.moveTo(_x, b + 1);
ctx.lineTo(_x, y + 2);
ctx.stroke();
ctx.setLineDash([]);
return;
}
for (var i = x; i < r; i += w_dist)
{
ctx.moveTo(i, _y);
i += w_dot;
if (i > (r - 1))
i = r - 1;
ctx.lineTo(i, _y);
}
for (var i = y; i < b; i += w_dist)
{
ctx.moveTo(_r, i);
i += w_dot;
if (i > (b - 1))
i = b - 1;
ctx.lineTo(_r, i);
}
for (var i = r + 1; i > (x + 1); i -= w_dist)
{
ctx.moveTo(i, _b);
i -= w_dot;
if (i < (x + 2))
i = x + 2;
ctx.lineTo(i, _b);
}
for (var i = b + 1; i > (y + 1); i -= w_dist)
{
ctx.moveTo(_x, i);
i -= w_dot;
if (i < (y + 2))
i = y + 2;
ctx.lineTo(_x, i);
}
if (bIsStrokeAndCanUseNative)
ctx.stroke();
};
CAutoshapeTrack.prototype.AddLineDash = function(ctx, x1, y1, x2, y2, w_dot, w_dist)
{
var len = Math.sqrt((x2-x1)*(x2-x1) + (y2-y1)*(y2-y1));
if (len < 1)
len = 1;
var len_x1 = Math.abs(w_dot*(x2-x1)/len);
var len_y1 = Math.abs(w_dot*(y2-y1)/len);
var len_x2 = Math.abs(w_dist*(x2-x1)/len);
var len_y2 = Math.abs(w_dist*(y2-y1)/len);
if (len_x1 < 0.01 && len_y1 < 0.01)
return;
if (len_x2 < 0.01 && len_y2 < 0.01)
return;
if (x1 <= x2 && y1 <= y2)
{
for (var i = x1, j = y1; i <= x2 && j <= y2; i += len_x2, j += len_y2)
{
ctx.moveTo(i, j);
i += len_x1;
j += len_y1;
if (i > x2)
i = x2;
if (j > y2)
j = y2;
ctx.lineTo(i, j);
}
}
else if (x1 <= x2 && y1 > y2)
{
for (var i = x1, j = y1; i <= x2 && j >= y2; i += len_x2, j -= len_y2)
{
ctx.moveTo(i, j);
i += len_x1;
j -= len_y1;
if (i > x2)
i = x2;
if (j < y2)
j = y2;
ctx.lineTo(i, j);
}
}
else if (x1 > x2 && y1 <= y2)
{
for (var i = x1, j = y1; i >= x2 && j <= y2; i -= len_x2, j += len_y2)
{
ctx.moveTo(i, j);
i -= len_x1;
j += len_y1;
if (i < x2)
i = x2;
if (j > y2)
j = y2;
ctx.lineTo(i, j);
}
}
else
{
for (var i = x1, j = y1; i >= x2 && j >= y2; i -= len_x2, j -= len_y2)
{
ctx.moveTo(i, j);
i -= len_x1;
j -= len_y1;
if (i < x2)
i = x2;
if (j < y2)
j = y2;
ctx.lineTo(i, j);
}
}
};
CAutoshapeTrack.prototype.AddRectDash = function(ctx, x1, y1, x2, y2, x3, y3, x4, y4, w_dot, w_dist, bIsStrokeAndCanUseNative)
{
var _support_native_dash = (undefined !== ctx.setLineDash);
if (_support_native_dash && bIsStrokeAndCanUseNative === true)
{
ctx.setLineDash([w_dot, w_dist]);
ctx.moveTo(x1, y1);
ctx.lineTo(x2, y2);
ctx.lineTo(x4, y4);
ctx.lineTo(x3, y3);
ctx.closePath();
ctx.stroke();
ctx.setLineDash([]);
return;
}
this.AddLineDash(ctx, x1, y1, x2, y2, w_dot, w_dist);
this.AddLineDash(ctx, x2, y2, x4, y4, w_dot, w_dist);
this.AddLineDash(ctx, x4, y4, x3, y3, w_dot, w_dist);
this.AddLineDash(ctx, x3, y3, x1, y1, w_dot, w_dist);
if (bIsStrokeAndCanUseNative)
ctx.stroke();
};
CAutoshapeTrack.prototype.DrawAdjustment = function(matrix, x, y, bTextWarp)
{
var overlay = this.m_oOverlay;
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = drPage.left;
var yDst = drPage.top;
var wDst = drPage.right - drPage.left;
var hDst = drPage.bottom - drPage.top;
if (!overlay.IsCellEditor) {
xDst *= rPR;
yDst *= rPR;
wDst *= rPR;
hDst *= rPR;
}
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
var cx = (xDst + dKoefX * (matrix.TransformPointX(x, y))) >> 0;
var cy = (yDst + dKoefY * (matrix.TransformPointY(x, y))) >> 0;
var _style_blue = "#4D7399";
var _style_yellow = "#FDF54A";
var _style_text_adj = "#F888FF";
var ctx = overlay.m_oContext;
var dist = TRACK_ADJUSTMENT_SIZE * rPR / 2;
ctx.lineWidth = Math.round(rPR);
ctx.moveTo(cx - dist, cy);
ctx.lineTo(cx, cy - dist);
ctx.lineTo(cx + dist, cy);
ctx.lineTo(cx, cy + dist);
ctx.closePath();
overlay.CheckRect(cx - dist, cy - dist, Math.round(TRACK_ADJUSTMENT_SIZE * rPR), Math.round(TRACK_ADJUSTMENT_SIZE * rPR));
if(bTextWarp === true)
{
ctx.fillStyle = _style_text_adj;
}
else
{
ctx.fillStyle = _style_yellow;
}
ctx.strokeStyle = _style_blue;
ctx.fill();
ctx.stroke();
ctx.beginPath();
};
CAutoshapeTrack.prototype.DrawGeomEditPoint = function(matrix, gmEditPoint)
{
var overlay = this.m_oOverlay;
var ctx = overlay.m_oContext;
//todo: remove duplicate code
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = drPage.left;
var yDst = drPage.top;
var wDst = drPage.right - drPage.left;
var hDst = drPage.bottom - drPage.top;
if (!overlay.IsCellEditor) {
xDst *= rPR;
yDst *= rPR;
wDst *= rPR;
hDst *= rPR;
}
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
//
var firstGuide, secondGuide;
if (gmEditPoint.g1X !== undefined && gmEditPoint.g1Y !== undefined) {
firstGuide = true;
}
if (gmEditPoint.g2X !== undefined && gmEditPoint.g2Y !== undefined) {
secondGuide = true;
}
var curPointX = (xDst + dKoefX * (matrix.TransformPointX(gmEditPoint.X, gmEditPoint.Y))) >> 0;
var curPointY = (yDst + dKoefY * (matrix.TransformPointY(gmEditPoint.X, gmEditPoint.Y))) >> 0;
var commandPointX1 = (xDst + dKoefX * (matrix.TransformPointX(gmEditPoint.g1X, gmEditPoint.g1Y))) >> 0;
var commandPointY1 = (yDst + dKoefY * (matrix.TransformPointY(gmEditPoint.g1X, gmEditPoint.g1Y))) >> 0;
var commandPointX2 = (xDst + dKoefX * (matrix.TransformPointX(gmEditPoint.g2X, gmEditPoint.g2Y))) >> 0;
var commandPointY2 = (yDst + dKoefY * (matrix.TransformPointY(gmEditPoint.g2X, gmEditPoint.g2Y))) >> 0;
ctx.strokeStyle = "#1873c0";
if (firstGuide) {
ctx.beginPath();
ctx.moveTo(curPointX, curPointY);
ctx.lineTo(commandPointX1, commandPointY1);
ctx.stroke();
}
if (secondGuide) {
ctx.beginPath();
ctx.moveTo(curPointX, curPointY);
ctx.lineTo(commandPointX2, commandPointY2);
ctx.stroke();
}
ctx.closePath();
ctx.beginPath();
ctx.fillStyle = "#ffffff";
ctx.strokeStyle = "#000000";
var SCALE_TRACK_RECT_SIZE = Math.round(TRACK_RECT_SIZE * rPR);
if (firstGuide)
overlay.AddRect2(commandPointX1, commandPointY1, SCALE_TRACK_RECT_SIZE);
if (secondGuide)
overlay.AddRect2(commandPointX2, commandPointY2, SCALE_TRACK_RECT_SIZE);
ctx.stroke();
ctx.fill();
};
CAutoshapeTrack.prototype.DrawGeometryEdit = function (matrix, pathLst, gmEditList, gmEditPoint, oBounds)
{
var overlay = this.m_oOverlay;
var ctx = overlay.m_oContext;
//todo: remove duplicate code
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = drPage.left;
var yDst = drPage.top;
var wDst = drPage.right - drPage.left;
var hDst = drPage.bottom - drPage.top;
if (!overlay.IsCellEditor) {
xDst *= rPR;
yDst *= rPR;
wDst *= rPR;
hDst *= rPR;
}
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
//
ctx.lineWidth = Math.round(rPR);
//red outline
overlay.m_oContext.strokeStyle = '#ff0000';
var t = this;
for (var i = 0; i < pathLst.length; i++) {
pathLst[i].ArrPathCommand.forEach(function (elem) {
if (elem.id === 0) {
var pointX = (xDst + dKoefX * (matrix.TransformPointX(elem.X, elem.Y))) >> 0;
var pointY = (yDst + dKoefY * (matrix.TransformPointY(elem.X, elem.Y))) >> 0;
ctx.moveTo(pointX + 0.5, pointY + 0.5);
} else if (elem.id === 4)
var pointX0 = (xDst + dKoefX * (matrix.TransformPointX(elem.X0, elem.Y0))) >> 0;
var pointY0 = (yDst + dKoefY * (matrix.TransformPointY(elem.X0, elem.Y0))) >> 0;
var pointX1 = (xDst + dKoefX * (matrix.TransformPointX(elem.X1, elem.Y1))) >> 0;
var pointY1 = (yDst + dKoefY * (matrix.TransformPointY(elem.X1, elem.Y1))) >> 0;
var pointX2 = (xDst + dKoefX * (matrix.TransformPointX(elem.X2, elem.Y2))) >> 0;
var pointY2 = (yDst + dKoefY * (matrix.TransformPointY(elem.X2, elem.Y2))) >> 0;
ctx.bezierCurveTo(pointX0 + 0.5, pointY0 + 0.5, pointX1 + 0.5, pointY1 + 0.5, pointX2 + 0.5, pointY2 + 0.5);
})
}
ctx.stroke();
ctx.closePath();
ctx.beginPath();
if (gmEditPoint) {
this.DrawGeomEditPoint(matrix, gmEditPoint);
}
ctx.closePath();
ctx.beginPath();
ctx.strokeStyle = "#ffffff";
ctx.fillStyle = "#000000";
var SCALE_TRACK_RECT_SIZE = Math.round(TRACK_RECT_SIZE * rPR);
for (var i = 0; i < gmEditList.length; i++) {
var gmEditPointX = (xDst + dKoefX * (matrix.TransformPointX(gmEditList[i].X, gmEditList[i].Y))) >> 0;
var gmEditPointY = (yDst + dKoefY * (matrix.TransformPointY(gmEditList[i].X, gmEditList[i].Y))) >> 0;
overlay.AddRect2(gmEditPointX, gmEditPointY, SCALE_TRACK_RECT_SIZE);
}
ctx.stroke();
ctx.fill();
var pointX1 = (xDst + dKoefX * oBounds.min_x) >> 0;
var pointY1 = (yDst + dKoefY * oBounds.min_y) >> 0;
var pointX2 = (xDst + dKoefX * oBounds.max_x + 0.5) >> 0;
var pointY2 = (yDst + dKoefY * oBounds.max_y + 0.5) >> 0;
overlay.CheckRect(pointX1, pointY1, pointX2 - pointX1, pointY2 - pointY1);
};
CAutoshapeTrack.prototype.DrawEditWrapPointsPolygon = function(points, matrix)
{
var _len = points.length;
if (0 == _len)
return;
var overlay = this.m_oOverlay;
overlay.SetBaseTransform();
var ctx = overlay.m_oContext;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var indent = 0.5 * Math.round(rPR);
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var xDst = drPage.left;
var yDst = drPage.top;
var wDst = drPage.right - drPage.left;
var hDst = drPage.bottom - drPage.top;
if (!overlay.IsCellEditor) {
xDst *= rPR;
yDst *= rPR;
wDst *= rPR;
hDst *= rPR;
}
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
var _tr_points_x = new Array(_len);
var _tr_points_y = new Array(_len);
for (var i = 0; i < _len; i++)
{
_tr_points_x[i] = (xDst + dKoefX * (matrix.TransformPointX(points[i].x, points[i].y))) >> 0;
_tr_points_y[i] = (yDst + dKoefY * (matrix.TransformPointY(points[i].x, points[i].y))) >> 0;
}
ctx.beginPath();
for (var i = 0; i < _len; i++)
{
if (0 == i)
ctx.moveTo(_tr_points_x[i], _tr_points_y[i]);
else
ctx.lineTo(_tr_points_x[i], _tr_points_y[i]);
overlay.CheckPoint(_tr_points_x[i], _tr_points_y[i]);
}
ctx.closePath();
ctx.lineWidth = Math.round(rPR);
ctx.strokeStyle = "#FF0000";
ctx.stroke();
ctx.beginPath();
for (var i = 0; i < _len; i++)
{
overlay.AddRect2(_tr_points_x[i] + indent, _tr_points_y[i] + indent, Math.round(TRACK_WRAPPOINTS_SIZE * rPR));
}
ctx.strokeStyle = "#FFFFFF";
ctx.fillStyle = "#000000";
ctx.fill();
ctx.stroke();
ctx.beginPath();
};
CAutoshapeTrack.prototype.DrawEditWrapPointsTrackLines = function(points, matrix)
{
var _len = points.length;
if (0 == _len)
return;
var overlay = this.m_oOverlay;
overlay.SetBaseTransform();
var ctx = overlay.m_oContext;
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = drPage.left * rPR;
var yDst = drPage.top * rPR;
var wDst = (drPage.right - drPage.left) * rPR;
var hDst = (drPage.bottom - drPage.top) * rPR;
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
var _tr_points_x = new Array(_len);
var _tr_points_y = new Array(_len);
for (var i = 0; i < _len; i++)
{
_tr_points_x[i] = (xDst + dKoefX * (matrix.TransformPointX(points[i].x, points[i].y))) >> 0;
_tr_points_y[i] = (yDst + dKoefY * (matrix.TransformPointY(points[i].x, points[i].y))) >> 0;
}
var globalAlpha = ctx.globalAlpha;
ctx.globalAlpha = 1.0;
ctx.beginPath();
for (var i = 0; i < _len; i++)
{
if (0 == i)
ctx.moveTo(_tr_points_x[i], _tr_points_y[i]);
else
ctx.lineTo(_tr_points_x[i], _tr_points_y[i]);
overlay.CheckPoint(_tr_points_x[i], _tr_points_y[i]);
}
ctx.lineWidth = 1;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.beginPath();
for (var i = 1; i < _len; i++)
{
this.AddLineDash(ctx, _tr_points_x[i-1], _tr_points_y[i-1], _tr_points_x[i], _tr_points_y[i], 4, 4);
}
ctx.lineWidth = Math.round(rPR);
ctx.strokeStyle = "#000000";
ctx.stroke();
ctx.beginPath();
ctx.globalAlpha = globalAlpha;
};
CAutoshapeTrack.prototype.DrawInlineMoveCursor = function(x, y, h, matrix, overlayNotes)
{
var overlay = this.m_oOverlay;
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = drPage.left * rPR;
var yDst = drPage.top * rPR;
var wDst = (drPage.right - drPage.left) * rPR;
var hDst = (drPage.bottom - drPage.top) * rPR;
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
if (overlayNotes)
{
dKoefX = AscCommon.g_dKoef_mm_to_pix * rPR;
dKoefY = AscCommon.g_dKoef_mm_to_pix * rPR;
overlay = overlayNotes;
var offsets = overlayNotes.getNotesOffsets();
xDst = offsets.X;
yDst = offsets.Y;
}
var bIsIdentMatr = true;
if (matrix !== undefined && matrix != null)
{
if (matrix.IsIdentity2())
{
x += matrix.tx;
y += matrix.ty;
}
else
{
bIsIdentMatr = false;
}
}
overlay.SetBaseTransform();
if (bIsIdentMatr)
{
var __x = (xDst + dKoefX * x) >> 0;
var __y = (yDst + dKoefY * y) >> 0;
var __h = (h * dKoefY) >> 0;
overlay.CheckRect(__x,__y,2,__h);
var ctx = overlay.m_oContext;
var _oldAlpha = ctx.globalAlpha;
ctx.globalAlpha = 1;
ctx.lineWidth = Math.round(rPR);
ctx.strokeStyle = "#000000";
var indent = 0.5 * Math.round(rPR);
var step = Math.round(rPR);
for (var i = 0; i < __h; i += (2 * step))
{
ctx.moveTo(__x,__y + i + indent);
ctx.lineTo(__x + 2 * step, __y + i + indent);
}
ctx.stroke();
ctx.beginPath();
ctx.strokeStyle = "#FFFFFF";
for (var i = step; i < __h; i += (2 * step))
{
ctx.moveTo(__x,__y + i + indent);
ctx.lineTo(__x + 2 * step, __y + i + indent);
}
ctx.stroke();
ctx.globalAlpha = _oldAlpha;
}
else
{
var _x1 = matrix.TransformPointX(x, y);
var _y1 = matrix.TransformPointY(x, y);
var _x2 = matrix.TransformPointX(x, y + h);
var _y2 = matrix.TransformPointY(x, y + h);
_x1 = xDst + dKoefX * _x1;
_y1 = yDst + dKoefY * _y1;
_x2 = xDst + dKoefX * _x2;
_y2 = yDst + dKoefY * _y2;
overlay.CheckPoint(_x1, _y1);
overlay.CheckPoint(_x2, _y2);
var ctx = overlay.m_oContext;
var _oldAlpha = ctx.globalAlpha;
ctx.globalAlpha = 1;
ctx.lineWidth = 2 * Math.round(rPR);
ctx.beginPath();
ctx.strokeStyle = "#FFFFFF";
ctx.moveTo(_x1, _y1);
ctx.lineTo(_x2, _y2);
ctx.stroke();
ctx.beginPath();
ctx.strokeStyle = "#000000";
var _vec_len = Math.sqrt((_x2 - _x1)*(_x2 - _x1) + (_y2 - _y1)*(_y2 - _y1));
var _dx = ((_x2 - _x1) / _vec_len);
var _dy = ((_y2 - _y1) / _vec_len);
var __x = _x1;
var __y = _y1;
var step = rPR;
_dx *= step;
_dy *= step;
for (var i = 0; i < _vec_len; i += (2 * step))
{
ctx.moveTo(__x, __y);
__x += _dx;
__y += _dy;
ctx.lineTo(__x, __y);
__x += _dx;
__y += _dy;
}
ctx.stroke();
ctx.globalAlpha = _oldAlpha;
}
};
CAutoshapeTrack.prototype.drawFlowAnchor = function(x, y)
{
var _flow_anchor = (AscCommon.OverlayRasterIcons && AscCommon.OverlayRasterIcons.Anchor) ? AscCommon.OverlayRasterIcons.Anchor.get() : undefined;
if (!_flow_anchor || (!editor || !editor.ShowParaMarks))
return;
var overlay = this.m_oOverlay;
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = drPage.left * rPR;
var yDst = drPage.top * rPR;
var wDst = (drPage.right - drPage.left) * rPR;
var hDst = (drPage.bottom - drPage.top) * rPR;
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
var __x = (xDst + dKoefX * x) >> 0;
var __y = (yDst + dKoefY * y) >> 0;
__x -= Math.round(8 * rPR);
overlay.CheckRect(__x,__y, Math.round(13 * rPR), Math.round(15 * rPR));
var ctx = overlay.m_oContext;
var _oldAlpha = ctx.globalAlpha;
ctx.globalAlpha = 1;
overlay.SetBaseTransform();
var _w = Math.round(13 * rPR);
var _h = Math.round(15 * rPR);
if (Math.abs(_w - _flow_anchor.width) < 2)
_w = _flow_anchor.width;
if (Math.abs(_h - _flow_anchor.height) < 2)
_h = _flow_anchor.height;
ctx.drawImage(_flow_anchor, __x, __y, _w, _h);
ctx.globalAlpha = _oldAlpha;
};
CAutoshapeTrack.prototype.DrawPresentationComment = function(type, x, y, w, h)
{
if (!AscCommon.g_comment_image || !AscCommon.g_comment_image.asc_complete)
return;
var overlay = this.m_oOverlay;
this.CurrentPageInfo = overlay.m_oHtmlPage.GetDrawingPageInfo(this.PageIndex);
var drPage = this.CurrentPageInfo.drawingPage;
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
var xDst = drPage.left * rPR;
var yDst = drPage.top * rPR;
var wDst = (drPage.right - drPage.left) * rPR;
var hDst = (drPage.bottom - drPage.top) * rPR;
var dKoefX = wDst / this.CurrentPageInfo.width_mm;
var dKoefY = hDst / this.CurrentPageInfo.height_mm;
var __x = (xDst + dKoefX * x) >> 0;
var __y = (yDst + dKoefY * y) >> 0;
var ctx = overlay.m_oContext;
var _oldAlpha = ctx.globalAlpha;
ctx.globalAlpha = 0.5;
overlay.SetBaseTransform();
var _index = 0;
if ((type & 0x02) == 0x02)
_index = 2;
if ((type & 0x01) == 0x01)
_index += 1;
var _offset = AscCommon.g_comment_image_offsets[_index];
overlay.CheckRect(__x, __y, rPR *_offset[2], rPR *_offset[3]);
this.m_oContext.drawImage(AscCommon.g_comment_image, _offset[0], _offset[1], _offset[2], _offset[3], __x, __y, rPR * _offset[2], rPR * _offset[3]);
ctx.globalAlpha = _oldAlpha;
};
CAutoshapeTrack.prototype.GetArrowCanvas = function()
{
if(!this.ArrowCanvas ||
this.ArrowCanvas.width !== this.m_oOverlay.GetArrowSize())
{
this.ArrowCanvas = this.CreateArrowCanvas();
}
return this.ArrowCanvas;
};
CAutoshapeTrack.prototype.GetRotatedArrowCanvas = function()
{
if(!this.RotatedArrowCanvas ||
this.RotatedArrowCanvas.width !== this.m_oOverlay.GetArrowSize())
{
this.RotatedArrowCanvas = this.CreateEmptyArrowCanvas();
}
var oCtx = this.RotatedArrowCanvas.getContext('2d');
oCtx.setTransform(1, 0, 0, 1, 0, 0);
oCtx.clearRect(0, 0, this.RotatedArrowCanvas.width, this.RotatedArrowCanvas.height);
return this.RotatedArrowCanvas;
};
CAutoshapeTrack.prototype.CreateEmptyArrowCanvas = function()
{
var arrowSize = this.m_oOverlay.GetArrowSize();
var oCanvas = document.createElement('canvas');
oCanvas.width = arrowSize;
oCanvas.height = arrowSize;
return oCanvas;
};
CAutoshapeTrack.prototype.CreateArrowCanvas = function()
{
var oCanvas = this.CreateEmptyArrowCanvas();
var cntx = oCanvas.getContext('2d');
var rPR = AscCommon.AscBrowser.retinaPixelRatio;
this.m_oOverlay.drawArrow(cntx, 0, 0, Math.round(4 * rPR), {r: 147, g: 147, b: 147}, true);
return oCanvas;
};
function DrawTextByCenter() // this!
{
var shape = new AscFormat.CShape();
shape.setTxBody(AscFormat.CreateTextBodyFromString("", this, shape));
var par = shape.txBody.content.Content[0];
par.Reset(0, 0, 1000, 1000, 0);
par.MoveCursorToStartPos();
var _paraPr = new CParaPr();
par.Pr = _paraPr;
var _textPr = new CTextPr();
_textPr.FontFamily = { Name : this.Font, Index : -1 };
_textPr.RFonts.Ascii = { Name : this.Font, Index : -1 };
_textPr.RFonts.EastAsia = { Name : this.Font, Index : -1 };
_textPr.RFonts.CS = { Name : this.Font, Index : -1 };
_textPr.RFonts.HAnsi = { Name : this.Font, Index : -1 };
_textPr.Bold = this.Bold;
_textPr.Italic = this.Italic;
_textPr.FontSize = this.Size;
_textPr.FontSizeCS = this.Size;
var parRun = new ParaRun(par); var Pos = 0;
parRun.Set_Pr(_textPr);
parRun.AddText(this.Text);
par.AddToContent(0, parRun);
par.Recalculate_Page(0);
par.Recalculate_Page(0);
var _bounds = par.Get_PageBounds(0);
var _canvas = this.getCanvas();
var _ctx = _canvas.getContext('2d');
var _wPx = _canvas.width;
var _hPx = _canvas.height;
var _wMm = _wPx * AscCommon.g_dKoef_pix_to_mm;
var _hMm = _hPx * AscCommon.g_dKoef_pix_to_mm;
_ctx.clearRect(0, 0, _wPx, _hPx);
var _pxBoundsW = par.Lines[0].Ranges[0].W * AscCommon.g_dKoef_mm_to_pix;//(_bounds.Right - _bounds.Left) * g_dKoef_mm_to_pix;
var _pxBoundsH = (_bounds.Bottom - _bounds.Top) * AscCommon.g_dKoef_mm_to_pix;
var _yOffset = (_hPx - _pxBoundsH) >> 1;
var _xOffset = (_wPx - _pxBoundsW) >> 1;
var graphics = new AscCommon.CGraphics();
graphics.init(_ctx, _wPx, _hPx, _wMm, _hMm);
graphics.m_oFontManager = AscCommon.g_fontManager;
graphics.m_oCoordTransform.tx = _xOffset;
graphics.m_oCoordTransform.ty = _yOffset;
graphics.transform(1,0,0,1,0,0);
par.Draw(0, graphics);
}
//--------------------------------------------------------export----------------------------------------------------
window['AscCommon'] = window['AscCommon'] || {};
window['AscCommon'].TRACK_CIRCLE_RADIUS = TRACK_CIRCLE_RADIUS;
window['AscCommon'].TRACK_DISTANCE_ROTATE = TRACK_DISTANCE_ROTATE;
window['AscCommon'].COverlay = COverlay;
window['AscCommon'].CAutoshapeTrack = CAutoshapeTrack;
window['AscCommon'].DrawTextByCenter = DrawTextByCenter;
})(window);