/* * (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);