Commit e4cf369d authored by Oleg.Korshul's avatar Oleg.Korshul Committed by Alexander.Trofimov

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@51415 954022d7-b5bf-4e40-9824-e11837661b57
parent d476e193
...@@ -477,6 +477,8 @@ CGeometry.prototype= ...@@ -477,6 +477,8 @@ CGeometry.prototype=
{ {
canFill: function() canFill: function()
{ {
if(this.preset === "line")
return false;
for(var i = 0; i < this.pathLst.length; ++i) for(var i = 0; i < this.pathLst.length; ++i)
{ {
if(this.pathLst[i].fill !== "none") if(this.pathLst[i].fill !== "none")
......
...@@ -5,6 +5,7 @@ var TRACK_DISTANCE_ROTATE = 25; ...@@ -5,6 +5,7 @@ var TRACK_DISTANCE_ROTATE = 25;
var TRACK_DISTANCE_ROTATE2 = 25; var TRACK_DISTANCE_ROTATE2 = 25;
var TRACK_ADJUSTMENT_SIZE = 10; var TRACK_ADJUSTMENT_SIZE = 10;
var TRACK_WRAPPOINTS_SIZE = 6; var TRACK_WRAPPOINTS_SIZE = 6;
var IMAGE_ROTATE_TRACK_W = 17;
var bIsUseImageRotateTrack = true; var bIsUseImageRotateTrack = true;
if (bIsUseImageRotateTrack) if (bIsUseImageRotateTrack)
...@@ -14,7 +15,7 @@ if (bIsUseImageRotateTrack) ...@@ -14,7 +15,7 @@ if (bIsUseImageRotateTrack)
window.g_track_rotate_marker.onload = function(){ window.g_track_rotate_marker.onload = function(){
window.g_track_rotate_marker.asc_complete = true; window.g_track_rotate_marker.asc_complete = true;
}; };
window.g_track_rotate_marker.src = ""; window.g_track_rotate_marker.src = "";
TRACK_DISTANCE_ROTATE2 = 20; TRACK_DISTANCE_ROTATE2 = 20;
} }
...@@ -72,6 +73,11 @@ COverlay.prototype = ...@@ -72,6 +73,11 @@ COverlay.prototype =
if (null == this.m_oContext) if (null == this.m_oContext)
{ {
this.m_oContext = this.m_oControl.HtmlElement.getContext('2d'); this.m_oContext = this.m_oControl.HtmlElement.getContext('2d');
this.m_oContext.imageSmoothingEnabled = false;
this.m_oContext.mozImageSmoothingEnabled = false;
this.m_oContext.oImageSmoothingEnabled = false;
this.m_oContext.webkitImageSmoothingEnabled = false;
} }
this.m_oContext.beginPath(); this.m_oContext.beginPath();
...@@ -813,6 +819,33 @@ CAutoshapeTrack.prototype = ...@@ -813,6 +819,33 @@ CAutoshapeTrack.prototype =
var xC = ((x1 + x2) / 2) >> 0; var xC = ((x1 + x2) / 2) >> 0;
if (!isLine && isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = IMAGE_ROTATE_TRACK_W;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
}
ctx.beginPath();
if (!isLine && isCanRotate) if (!isLine && isCanRotate)
{ {
ctx.moveTo(xC + 0.5, y1); ctx.moveTo(xC + 0.5, y1);
...@@ -859,33 +892,6 @@ CAutoshapeTrack.prototype = ...@@ -859,33 +892,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (!isLine && isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = 15;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
}
ctx.beginPath();
} }
else else
{ {
...@@ -914,6 +920,37 @@ CAutoshapeTrack.prototype = ...@@ -914,6 +920,37 @@ CAutoshapeTrack.prototype =
var xc1 = (x1 + x2) / 2; var xc1 = (x1 + x2) / 2;
var yc1 = (y1 + y2) / 2; var yc1 = (y1 + y2) / 2;
ctx.beginPath();
if (!isLine && isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = IMAGE_ROTATE_TRACK_W;
var _w2 = IMAGE_ROTATE_TRACK_W / 2;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
}
if (!isLine && isCanRotate) if (!isLine && isCanRotate)
{ {
ctx.beginPath(); ctx.beginPath();
...@@ -959,13 +996,29 @@ CAutoshapeTrack.prototype = ...@@ -959,13 +996,29 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
}
if (!isLine && isCanRotate) break;
}
case TYPE_TRACK_TEXT:
case TYPE_TRACK_GROUP_PASSIVE:
{
if (bIsClever)
{
overlay.CheckRect(x1, y1, x4 - x1, y4 - y1);
this.AddRectDashClever(ctx, x1, y1, x4, y4, 8, 3);
ctx.strokeStyle = _style_blue;
ctx.stroke();
ctx.beginPath();
if (isCanRotate)
{ {
if (!bIsUseImageRotateTrack) if (!bIsUseImageRotateTrack)
{ {
ctx.beginPath(); ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS); overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green; ctx.fillStyle = _style_green;
ctx.fill(); ctx.fill();
...@@ -975,35 +1028,15 @@ CAutoshapeTrack.prototype = ...@@ -975,35 +1028,15 @@ CAutoshapeTrack.prototype =
{ {
if (window.g_track_rotate_marker.asc_complete) if (window.g_track_rotate_marker.asc_complete)
{ {
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE; var _w = IMAGE_ROTATE_TRACK_W;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE; var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _w = 15; var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
var _w2 = 7.5;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w); overlay.CheckRect(_xI, _yI, _w, _w);
} ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
} }
ctx.beginPath();
} }
break;
} }
case TYPE_TRACK_TEXT:
case TYPE_TRACK_GROUP_PASSIVE:
{
if (bIsClever)
{
overlay.CheckRect(x1, y1, x4 - x1, y4 - y1);
this.AddRectDashClever(ctx, x1, y1, x4, y4, 8, 3);
ctx.strokeStyle = _style_blue;
ctx.stroke();
if (isCanRotate) if (isCanRotate)
{ {
...@@ -1048,33 +1081,6 @@ CAutoshapeTrack.prototype = ...@@ -1048,33 +1081,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = 15;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
}
ctx.beginPath();
} }
else else
{ {
...@@ -1096,6 +1102,37 @@ CAutoshapeTrack.prototype = ...@@ -1096,6 +1102,37 @@ CAutoshapeTrack.prototype =
var xc1 = (x1 + x2) / 2; var xc1 = (x1 + x2) / 2;
var yc1 = (y1 + y2) / 2; var yc1 = (y1 + y2) / 2;
ctx.beginPath();
if (isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = IMAGE_ROTATE_TRACK_W;
var _w2 = IMAGE_ROTATE_TRACK_W / 2;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
}
if (isCanRotate) if (isCanRotate)
{ {
ctx.beginPath(); ctx.beginPath();
...@@ -1135,37 +1172,6 @@ CAutoshapeTrack.prototype = ...@@ -1135,37 +1172,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = 15;
var _w2 = 7.5;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
}
ctx.beginPath();
} }
break; break;
...@@ -1194,6 +1200,30 @@ CAutoshapeTrack.prototype = ...@@ -1194,6 +1200,30 @@ CAutoshapeTrack.prototype =
ctx.beginPath(); ctx.beginPath();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = IMAGE_ROTATE_TRACK_W;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
ctx.beginPath();
ctx.fillStyle = _style_white; ctx.fillStyle = _style_white;
if (bIsEllipceCorner) if (bIsEllipceCorner)
...@@ -1224,30 +1254,6 @@ CAutoshapeTrack.prototype = ...@@ -1224,30 +1254,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = 15;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
ctx.beginPath();
} }
else else
{ {
...@@ -1293,6 +1299,34 @@ CAutoshapeTrack.prototype = ...@@ -1293,6 +1299,34 @@ CAutoshapeTrack.prototype =
ctx.beginPath(); ctx.beginPath();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_DISTANCE_ROTATE);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = IMAGE_ROTATE_TRACK_W;
var _w2 = IMAGE_ROTATE_TRACK_W / 2;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
ctx.beginPath();
ctx.fillStyle = _style_white; ctx.fillStyle = _style_white;
if (bIsEllipceCorner) if (bIsEllipceCorner)
...@@ -1320,34 +1354,6 @@ CAutoshapeTrack.prototype = ...@@ -1320,34 +1354,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_DISTANCE_ROTATE);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = 15;
var _w2 = 7.5;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
ctx.beginPath();
} }
break; break;
......
...@@ -1230,7 +1230,7 @@ function CLayoutThumbnailDrawer() ...@@ -1230,7 +1230,7 @@ function CLayoutThumbnailDrawer()
this.DrawingDocument = null; this.DrawingDocument = null;
this.GetThumbnail = function(_layout) this.GetThumbnail = function(_layout, use_background, use_master_shapes, use_layout_shapes)
{ {
_layout.recalculate2(); _layout.recalculate2();
...@@ -1305,21 +1305,28 @@ function CLayoutThumbnailDrawer() ...@@ -1305,21 +1305,28 @@ function CLayoutThumbnailDrawer()
if (_back_fill != null) if (_back_fill != null)
_back_fill.calculate(_theme, null, _layout, _master, RGBA); _back_fill.calculate(_theme, null, _layout, _master, RGBA);
if (use_background !== false)
DrawBackground(g, _back_fill, this.WidthMM, this.HeightMM); DrawBackground(g, _back_fill, this.WidthMM, this.HeightMM);
var _sx = g.m_oCoordTransform.sx; var _sx = g.m_oCoordTransform.sx;
var _sy = g.m_oCoordTransform.sy; var _sy = g.m_oCoordTransform.sy;
if (use_master_shapes !== false)
{
if (_layout.showMasterSp == true || _layout.showMasterSp == undefined) if (_layout.showMasterSp == true || _layout.showMasterSp == undefined)
{ {
_master.draw(g); _master.draw(g);
} }
}
for (var i = 0; i < _layout.cSld.spTree.length; i++) for (var i = 0; i < _layout.cSld.spTree.length; i++)
{ {
var _sp_elem = _layout.cSld.spTree[i]; var _sp_elem = _layout.cSld.spTree[i];
if (!_sp_elem.isPlaceholder()) if (!_sp_elem.isPlaceholder())
{
if (use_layout_shapes !== false)
_sp_elem.draw(g); _sp_elem.draw(g);
}
else else
{ {
_ctx.globalAlpha = 1; _ctx.globalAlpha = 1;
...@@ -1432,6 +1439,21 @@ function CLayoutThumbnailDrawer() ...@@ -1432,6 +1439,21 @@ function CLayoutThumbnailDrawer()
} }
} }
try
{
return this.CanvasImage.toDataURL("image/png"); return this.CanvasImage.toDataURL("image/png");
} }
catch (err)
{
this.CanvasImage = null;
if (undefined === use_background && undefined === use_master_shapes && undefined == use_layout_shapes)
return this.GetThumbnail(_layout, true, true, false);
else if (use_background && use_master_shapes && !use_layout_shapes)
return this.GetThumbnail(_layout, true, false, false);
else if (use_background && !use_master_shapes && !use_layout_shapes)
return this.GetThumbnail(_layout, false, false, false);
}
return "";
}
} }
\ No newline at end of file
...@@ -1008,7 +1008,7 @@ function CMasterThumbnailDrawer() ...@@ -1008,7 +1008,7 @@ function CMasterThumbnailDrawer()
this.DrawingDocument = null; this.DrawingDocument = null;
this.GetThumbnail = function(_master) this.GetThumbnail = function(_master, use_background, use_master_shapes)
{ {
var h_px = 40; var h_px = 40;
var w_px = (this.WidthMM * h_px / this.HeightMM) >> 0; var w_px = (this.WidthMM * h_px / this.HeightMM) >> 0;
...@@ -1066,11 +1066,13 @@ function CMasterThumbnailDrawer() ...@@ -1066,11 +1066,13 @@ function CMasterThumbnailDrawer()
if (_back_fill != null) if (_back_fill != null)
_back_fill.calculate(_theme, null, null, _master, RGBA); _back_fill.calculate(_theme, null, null, _master, RGBA);
if (use_background !== false)
DrawBackground(g, _back_fill, this.WidthMM, this.HeightMM); DrawBackground(g, _back_fill, this.WidthMM, this.HeightMM);
var _sx = g.m_oCoordTransform.sx; var _sx = g.m_oCoordTransform.sx;
var _sy = g.m_oCoordTransform.sy; var _sy = g.m_oCoordTransform.sy;
if (use_master_shapes !== false)
_master.draw(g); _master.draw(g);
g.reset(); g.reset();
...@@ -1138,6 +1140,18 @@ function CMasterThumbnailDrawer() ...@@ -1138,6 +1140,18 @@ function CMasterThumbnailDrawer()
History.TurnOn(); History.TurnOn();
_api.isViewMode = _oldTurn; _api.isViewMode = _oldTurn;
try
{
return this.CanvasImage.toDataURL("image/png"); return this.CanvasImage.toDataURL("image/png");
} }
catch (err)
{
this.CanvasImage = null;
if (undefined === use_background && undefined === use_master_shapes)
return this.GetThumbnail(_master, true, false);
else if (use_background && !use_master_shapes)
return this.GetThumbnail(_master, false, false);
}
return "";
}
} }
\ No newline at end of file
...@@ -5572,7 +5572,7 @@ function CDrawingDocument() ...@@ -5572,7 +5572,7 @@ function CDrawingDocument()
var _pos = this.ConvertCoordsToCursor4(xPos, 0, pageNum); var _pos = this.ConvertCoordsToCursor4(xPos, 0, pageNum);
if (_pos.Error === false) if (_pos.Error === false)
{ {
this.m_oWordControl.m_oOverlayApi.DashLineColor = "#FF0000"; this.m_oWordControl.m_oOverlayApi.DashLineColor = "#C8C8C8";
this.m_oWordControl.m_oOverlayApi.VertLine2(_pos.X); this.m_oWordControl.m_oOverlayApi.VertLine2(_pos.X);
this.m_oWordControl.m_oOverlayApi.DashLineColor = "#000000"; this.m_oWordControl.m_oOverlayApi.DashLineColor = "#000000";
} }
...@@ -5589,7 +5589,7 @@ function CDrawingDocument() ...@@ -5589,7 +5589,7 @@ function CDrawingDocument()
var _pos = this.ConvertCoordsToCursor4(0, yPos, pageNum); var _pos = this.ConvertCoordsToCursor4(0, yPos, pageNum);
if (_pos.Error === false) if (_pos.Error === false)
{ {
this.m_oWordControl.m_oOverlayApi.DashLineColor = "#FF0000"; this.m_oWordControl.m_oOverlayApi.DashLineColor = "#C8C8C8";
this.m_oWordControl.m_oOverlayApi.HorLine2(_pos.Y); this.m_oWordControl.m_oOverlayApi.HorLine2(_pos.Y);
this.m_oWordControl.m_oOverlayApi.DashLineColor = "#000000"; this.m_oWordControl.m_oOverlayApi.DashLineColor = "#000000";
} }
......
...@@ -5,6 +5,7 @@ var TRACK_DISTANCE_ROTATE = 25; ...@@ -5,6 +5,7 @@ var TRACK_DISTANCE_ROTATE = 25;
var TRACK_DISTANCE_ROTATE2 = 25; var TRACK_DISTANCE_ROTATE2 = 25;
var TRACK_ADJUSTMENT_SIZE = 10; var TRACK_ADJUSTMENT_SIZE = 10;
var TRACK_WRAPPOINTS_SIZE = 6; var TRACK_WRAPPOINTS_SIZE = 6;
var IMAGE_ROTATE_TRACK_W = 17;
var bIsUseImageRotateTrack = true; var bIsUseImageRotateTrack = true;
if (bIsUseImageRotateTrack) if (bIsUseImageRotateTrack)
...@@ -14,7 +15,7 @@ if (bIsUseImageRotateTrack) ...@@ -14,7 +15,7 @@ if (bIsUseImageRotateTrack)
window.g_track_rotate_marker.onload = function(){ window.g_track_rotate_marker.onload = function(){
window.g_track_rotate_marker.asc_complete = true; window.g_track_rotate_marker.asc_complete = true;
}; };
window.g_track_rotate_marker.src = ""; window.g_track_rotate_marker.src = "";
TRACK_DISTANCE_ROTATE2 = 20; TRACK_DISTANCE_ROTATE2 = 20;
} }
...@@ -152,6 +153,9 @@ COverlay.prototype = ...@@ -152,6 +153,9 @@ COverlay.prototype =
if (this.max_x < position) if (this.max_x < position)
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.min_y = 0;
this.max_y = this.m_oControl.HtmlElement.height; this.max_y = this.m_oControl.HtmlElement.height;
...@@ -160,16 +164,18 @@ COverlay.prototype = ...@@ -160,16 +164,18 @@ COverlay.prototype =
var x = ((position + 0.5) >> 0) + 0.5; var x = ((position + 0.5) >> 0) + 0.5;
var y = 0; var y = 0;
/*
this.m_oContext.strokeStyle = "#FFFFFF"; this.m_oContext.strokeStyle = "#FFFFFF";
this.m_oContext.beginPath(); this.m_oContext.beginPath();
this.m_oContext.moveTo(x, y); this.m_oContext.moveTo(x, y);
this.m_oContext.lineTo(x, this.max_y); this.m_oContext.lineTo(x, this.max_y);
this.m_oContext.stroke(); this.m_oContext.stroke();
*/
this.m_oContext.strokeStyle = this.DashLineColor; this.m_oContext.strokeStyle = this.DashLineColor;
this.m_oContext.beginPath(); this.m_oContext.beginPath();
var dist = 5; var dist = 1;
while (y < this.max_y) while (y < this.max_y)
{ {
...@@ -182,6 +188,8 @@ COverlay.prototype = ...@@ -182,6 +188,8 @@ COverlay.prototype =
this.m_oContext.stroke(); this.m_oContext.stroke();
this.m_oContext.beginPath(); this.m_oContext.beginPath();
this.Show(); this.Show();
this.m_oContext.globalAlpha = _old_global;
}, },
HorLine : function(position, bIsSimpleAdd) HorLine : function(position, bIsSimpleAdd)
...@@ -201,8 +209,6 @@ COverlay.prototype = ...@@ -201,8 +209,6 @@ COverlay.prototype =
this.min_x = 0; this.min_x = 0;
this.max_x = this.m_oControl.HtmlElement.width; this.max_x = this.m_oControl.HtmlElement.width;
//this.min_y = position;
//this.max_y = position;
if (this.min_y > position) if (this.min_y > position)
this.min_y = position; this.min_y = position;
if (this.max_y < position) if (this.max_y < position)
...@@ -257,6 +263,9 @@ COverlay.prototype = ...@@ -257,6 +263,9 @@ COverlay.prototype =
if (this.max_y < position) if (this.max_y < position)
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.min_x = 0;
this.max_x = this.m_oControl.HtmlElement.width; this.max_x = this.m_oControl.HtmlElement.width;
...@@ -265,16 +274,18 @@ COverlay.prototype = ...@@ -265,16 +274,18 @@ COverlay.prototype =
var y = ((position + 0.5) >> 0) + 0.5; var y = ((position + 0.5) >> 0) + 0.5;
var x = 0; var x = 0;
/*
this.m_oContext.strokeStyle = "#FFFFFF"; this.m_oContext.strokeStyle = "#FFFFFF";
this.m_oContext.beginPath(); this.m_oContext.beginPath();
this.m_oContext.moveTo(x, y); this.m_oContext.moveTo(x, y);
this.m_oContext.lineTo(this.max_x, y); this.m_oContext.lineTo(this.max_x, y);
this.m_oContext.stroke(); this.m_oContext.stroke();
*/
this.m_oContext.strokeStyle = this.DashLineColor; this.m_oContext.strokeStyle = this.DashLineColor;
this.m_oContext.beginPath(); this.m_oContext.beginPath();
var dist = 5; var dist = 1;
while (x < this.max_x) while (x < this.max_x)
{ {
...@@ -287,6 +298,8 @@ COverlay.prototype = ...@@ -287,6 +298,8 @@ COverlay.prototype =
this.m_oContext.stroke(); this.m_oContext.stroke();
this.m_oContext.beginPath(); this.m_oContext.beginPath();
this.Show(); this.Show();
this.m_oContext.globalAlpha = _old_global;
}, },
CheckPoint1 : function(x,y) CheckPoint1 : function(x,y)
...@@ -914,6 +927,33 @@ CAutoshapeTrack.prototype = ...@@ -914,6 +927,33 @@ CAutoshapeTrack.prototype =
var xC = ((x1 + x2) / 2) >> 0; var xC = ((x1 + x2) / 2) >> 0;
if (!isLine && isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = IMAGE_ROTATE_TRACK_W;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
}
ctx.beginPath();
if (!isLine && isCanRotate) if (!isLine && isCanRotate)
{ {
ctx.moveTo(xC + 0.5, y1); ctx.moveTo(xC + 0.5, y1);
...@@ -960,33 +1000,6 @@ CAutoshapeTrack.prototype = ...@@ -960,33 +1000,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (!isLine && isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = 15;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
}
ctx.beginPath();
} }
else else
{ {
...@@ -1015,6 +1028,37 @@ CAutoshapeTrack.prototype = ...@@ -1015,6 +1028,37 @@ CAutoshapeTrack.prototype =
var xc1 = (x1 + x2) / 2; var xc1 = (x1 + x2) / 2;
var yc1 = (y1 + y2) / 2; var yc1 = (y1 + y2) / 2;
ctx.beginPath();
if (!isLine && isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = IMAGE_ROTATE_TRACK_W;
var _w2 = IMAGE_ROTATE_TRACK_W / 2;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
}
if (!isLine && isCanRotate) if (!isLine && isCanRotate)
{ {
ctx.beginPath(); ctx.beginPath();
...@@ -1060,13 +1104,29 @@ CAutoshapeTrack.prototype = ...@@ -1060,13 +1104,29 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
}
if (!isLine && isCanRotate) break;
}
case TYPE_TRACK_TEXT:
case TYPE_TRACK_GROUP_PASSIVE:
{
if (bIsClever)
{
overlay.CheckRect(x1, y1, x4 - x1, y4 - y1);
this.AddRectDashClever(ctx, x1, y1, x4, y4, 8, 3);
ctx.strokeStyle = _style_blue;
ctx.stroke();
ctx.beginPath();
if (isCanRotate)
{ {
if (!bIsUseImageRotateTrack) if (!bIsUseImageRotateTrack)
{ {
ctx.beginPath(); ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS); overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green; ctx.fillStyle = _style_green;
ctx.fill(); ctx.fill();
...@@ -1076,35 +1136,15 @@ CAutoshapeTrack.prototype = ...@@ -1076,35 +1136,15 @@ CAutoshapeTrack.prototype =
{ {
if (window.g_track_rotate_marker.asc_complete) if (window.g_track_rotate_marker.asc_complete)
{ {
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE; var _w = IMAGE_ROTATE_TRACK_W;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE; var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _w = 15; var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
var _w2 = 7.5;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w); overlay.CheckRect(_xI, _yI, _w, _w);
} ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
} }
ctx.beginPath();
} }
break;
} }
case TYPE_TRACK_TEXT:
case TYPE_TRACK_GROUP_PASSIVE:
{
if (bIsClever)
{
overlay.CheckRect(x1, y1, x4 - x1, y4 - y1);
this.AddRectDashClever(ctx, x1, y1, x4, y4, 8, 3);
ctx.strokeStyle = _style_blue;
ctx.stroke();
if (isCanRotate) if (isCanRotate)
{ {
...@@ -1149,33 +1189,6 @@ CAutoshapeTrack.prototype = ...@@ -1149,33 +1189,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = 15;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
}
ctx.beginPath();
} }
else else
{ {
...@@ -1197,6 +1210,37 @@ CAutoshapeTrack.prototype = ...@@ -1197,6 +1210,37 @@ CAutoshapeTrack.prototype =
var xc1 = (x1 + x2) / 2; var xc1 = (x1 + x2) / 2;
var yc1 = (y1 + y2) / 2; var yc1 = (y1 + y2) / 2;
ctx.beginPath();
if (isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = IMAGE_ROTATE_TRACK_W;
var _w2 = IMAGE_ROTATE_TRACK_W / 2;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
}
if (isCanRotate) if (isCanRotate)
{ {
ctx.beginPath(); ctx.beginPath();
...@@ -1236,37 +1280,6 @@ CAutoshapeTrack.prototype = ...@@ -1236,37 +1280,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (isCanRotate)
{
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_CIRCLE_RADIUS);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = 15;
var _w2 = 7.5;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
}
ctx.beginPath();
} }
break; break;
...@@ -1295,6 +1308,30 @@ CAutoshapeTrack.prototype = ...@@ -1295,6 +1308,30 @@ CAutoshapeTrack.prototype =
ctx.beginPath(); ctx.beginPath();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = IMAGE_ROTATE_TRACK_W;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
ctx.beginPath();
ctx.fillStyle = _style_white; ctx.fillStyle = _style_white;
if (bIsEllipceCorner) if (bIsEllipceCorner)
...@@ -1325,30 +1362,6 @@ CAutoshapeTrack.prototype = ...@@ -1325,30 +1362,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xC, y1 - TRACK_DISTANCE_ROTATE);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _w = 15;
var _xI = ((x1 + x2 - _w) / 2) >> 0;
var _yI = y1 - TRACK_DISTANCE_ROTATE - (_w >> 1);
overlay.CheckRect(_xI, _yI, _w, _w);
ctx.drawImage(window.g_track_rotate_marker, _xI, _yI, _w, _w);
}
}
ctx.beginPath();
} }
else else
{ {
...@@ -1394,6 +1407,34 @@ CAutoshapeTrack.prototype = ...@@ -1394,6 +1407,34 @@ CAutoshapeTrack.prototype =
ctx.beginPath(); ctx.beginPath();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_DISTANCE_ROTATE);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = IMAGE_ROTATE_TRACK_W;
var _w2 = IMAGE_ROTATE_TRACK_W / 2;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
ctx.beginPath();
ctx.fillStyle = _style_white; ctx.fillStyle = _style_white;
if (bIsEllipceCorner) if (bIsEllipceCorner)
...@@ -1421,34 +1462,6 @@ CAutoshapeTrack.prototype = ...@@ -1421,34 +1462,6 @@ CAutoshapeTrack.prototype =
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
if (!bIsUseImageRotateTrack)
{
ctx.beginPath();
overlay.AddEllipse(xc1 + ex2 * TRACK_DISTANCE_ROTATE, yc1 + ey2 * TRACK_DISTANCE_ROTATE, TRACK_DISTANCE_ROTATE);
ctx.fillStyle = _style_green;
ctx.fill();
ctx.stroke();
}
else
{
if (window.g_track_rotate_marker.asc_complete)
{
var _xI = xc1 + ex2 * TRACK_DISTANCE_ROTATE;
var _yI = yc1 + ey2 * TRACK_DISTANCE_ROTATE;
var _w = 15;
var _w2 = 7.5;
ctx.setTransform(ex1, ey1, -ey1, ex1, _xI, _yI);
ctx.drawImage(window.g_track_rotate_marker, -_w2, -_w2, _w, _w);
ctx.setTransform(1, 0, 0, 1, 0, 0);
overlay.CheckRect(_xI - _w2, _yI - _w2, _w, _w);
}
}
ctx.beginPath();
} }
break; break;
......
...@@ -483,6 +483,8 @@ CGeometry.prototype= ...@@ -483,6 +483,8 @@ CGeometry.prototype=
canFill: function() canFill: function()
{ {
if(this.preset === "line")
return false;
for(var i = 0; i < this.pathLst.length; ++i) for(var i = 0; i < this.pathLst.length; ++i)
{ {
if(this.pathLst[i].fill !== "none") if(this.pathLst[i].fill !== "none")
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment