Commit a4da4123 authored by Oleg Korshul's avatar Oleg Korshul

add inline contentconrol tracks

parent 4ff4381f
......@@ -54,13 +54,41 @@ var c_oContentControlTrack = {
In : 1
};
function CContentControlTrack(_id, _type, _rects, _transform)
function CContentControlTrack(_id, _type, _data, _transform)
{
this.id = (undefined == _id) ? -1 : _id;
this.type = (undefined == _type) ? -1 : _type;
this.rects = (undefined == _rects) ? null : _rects;
this.rects = undefined;
this.paths = undefined;
if (undefined === _data[0].Points)
this.rects = _data;
else
this.paths = _data;
this.transform = (undefined == _transform) ? null : _transform;
}
CContentControlTrack.prototype.getPage = function()
{
if (this.rects)
return this.rects[0].Page;
if (this.path)
return this.paths[0].Page;
return 0;
};
CContentControlTrack.prototype.getXY = function()
{
if (this.rects)
return { X : this.rects[0].X, Y : this.rects[0].Y };
if (this.path)
return { X : this.paths[0].Points[0].X, Y : this.paths[0].Points[0].Y };
return null;
};
CContentControlTrack.prototype.Copy = function()
{
return new CContentControlTrack(this.id, this.type, this.rects ? this.rects : this.paths, this.transform);
};
function CColumnsMarkupColumn()
{
......@@ -3770,8 +3798,7 @@ function CDrawingDocument()
this.ContentControlObjectsLast = [];
for (var i = 0; i < this.ContentControlObjects.length; i++)
{
var _obj = this.ContentControlObjects[i];
this.ContentControlObjectsLast.push(new CContentControlTrack(_obj.id, _obj.type, _obj.rects));
this.ContentControlObjectsLast.push(this.ContentControlObjects[i].Copy());
}
};
......@@ -3794,6 +3821,8 @@ function CDrawingDocument()
if (_obj1.type != _obj2.type)
return true;
if (_obj1.rects && _obj2.rects)
{
count1 = _obj1.rects.length;
count2 = _obj2.rects.length;
......@@ -3812,6 +3841,38 @@ function CDrawingDocument()
}
}
}
else if (_obj1.path && _obj2.path)
{
count1 = _obj1.paths.length;
count2 = _obj2.paths.length;
if (count1 != count2)
return true;
var _points1, _points2;
for (var j = 0; j < count1; j++)
{
if (_obj1.paths[j].Page != _obj2.paths[j].Page)
return true;
_points1 = _obj1.paths[j].Points;
_points2 = _obj2.paths[j].Points;
if (_points1.length != _points2.length)
return true;
for (var k = 0; k < _points1.length; k++)
{
if (Math.abs(_points1[k].X - _points[k].X) > 0.00001 || Math.abs(_points1[k].Y - _points[k].Y) > 0.00001)
return true;
}
}
}
else
{
return true;
}
}
return false;
};
......@@ -3822,14 +3883,16 @@ function CDrawingDocument()
ctx.strokeStyle = "#ADADAD";
ctx.lineWidth = 1;
var _object, _rect;
var _object, _rect, _path;
var _x, _y, _r, _b;
var _transform, offset_x, offset_y;
var _curPage;
for (var i = 0; i < this.ContentControlObjects.length; i++)
{
_object = this.ContentControlObjects[i];
_transform = _object.transform;
_curPage = _object.getPage();
offset_x = 0;
offset_y = 0;
......@@ -3841,6 +3904,8 @@ function CDrawingDocument()
}
if (!_transform)
{
if (_object.rects)
{
for (var j = 0; j < _object.rects.length; j++)
{
......@@ -3862,16 +3927,6 @@ function CDrawingDocument()
_r = (drPage.left + dKoefX * (_rect.R + offset_x));
_b = (drPage.top + dKoefY * (_rect.B + offset_y));
if (_x < overlay.min_x)
overlay.min_x = _x;
if (_r > overlay.max_x)
overlay.max_x = _r;
if (_y < overlay.min_y)
overlay.min_y = _y;
if (_b > overlay.max_y)
overlay.max_y = _b;
overlay.CheckRect(_x, _y, _r - _x, _b - _y);
ctx.rect((_x >> 0) + 0.5, (_y >> 0) + 0.5, (_r - _x) >> 0, (_b - _y) >> 0);
......@@ -3884,88 +3939,56 @@ function CDrawingDocument()
ctx.beginPath();
}
if (_object.type == c_oContentControlTrack.In)
}
else if (_object.paths)
{
_rect = _object.rects[0];
for (var j = 0; j < _object.paths.length; j++)
{
_path = _object.paths[j];
if (_path.Page < this.m_lDrawingFirst || _path.Page > this.m_lDrawingEnd)
continue;
var _page = this.m_arrPages[_rect.Page];
var drPage = _page.drawingPage;
_x = (drPage.left + dKoefX * (_rect.X + offset_x));
_y = (drPage.top + dKoefY * (_rect.Y + offset_y));
var dKoefX = (drPage.right - drPage.left) / _page.width_mm;
var dKoefY = (drPage.bottom - drPage.top) / _page.height_mm;
_x = ((_x >> 0) + 0.5) - 15;
_y = ((_y >> 0) + 0.5);
ctx.beginPath();
ctx.rect(_x, _y, 15, 20);
var Points = _object.path.Points;
overlay.CheckRect(_x, _y, 15, 20);
if (1 == this.ContentControlObjectState)
var nCount = Points.length;
for (var nIndex = 0; nIndex < nCount; nIndex++)
{
ctx.fillStyle = "#CFCFCF";
ctx.fill();
}
_x = (drPage.left + dKoefX * (Points[nIndex].X + offset_x));
_y = (drPage.top + dKoefY * (Points[nIndex].Y + offset_y));
ctx.stroke();
ctx.beginPath();
var cx = _x - 0.5 + 4;
var cy = _y - 0.5 + 4;
var _color1 = "#ADADAD";
var _color2 = "#D4D4D4";
_x = (_x >> 0) + 0.5;
_y = (_y >> 0) + 0.5;
if (0 == this.ContentControlObjectState || 1 == this.ContentControlObjectState)
{
_color1 = "#444444";
_color2 = "#9D9D9D";
if (0 == nIndex)
ctx.moveTo(_x, _y);
else
ctx.lineTo(_x, _y);
}
overlay.AddRect(cx, cy, 3, 3);
overlay.AddRect(cx + 5, cy, 3, 3);
overlay.AddRect(cx, cy + 5, 3, 3);
overlay.AddRect(cx + 5, cy + 5, 3, 3);
overlay.AddRect(cx, cy + 10, 3, 3);
overlay.AddRect(cx + 5, cy + 10, 3, 3);
ctx.closePath();
ctx.fillStyle = _color2;
if (_object.type == c_oContentControlTrack.Hover)
{
ctx.fillStyle = "rgba(205, 205, 205, 0.5)";
ctx.fill();
ctx.beginPath();
ctx.moveTo(cx + 1.5, cy);
ctx.lineTo(cx + 1.5, cy + 3);
ctx.moveTo(cx + 6.5, cy);
ctx.lineTo(cx + 6.5, cy + 3);
ctx.moveTo(cx + 1.5, cy + 5);
ctx.lineTo(cx + 1.5, cy + 8);
ctx.moveTo(cx + 6.5, cy + 5);
ctx.lineTo(cx + 6.5, cy + 8);
ctx.moveTo(cx + 1.5, cy + 10);
ctx.lineTo(cx + 1.5, cy + 13);
ctx.moveTo(cx + 6.5, cy + 10);
ctx.lineTo(cx + 6.5, cy + 13);
ctx.moveTo(cx, cy + 1.5);
ctx.lineTo(cx + 3, cy + 1.5);
ctx.moveTo(cx + 5, cy + 1.5);
ctx.lineTo(cx + 8, cy + 1.5);
ctx.moveTo(cx, cy + 6.5);
ctx.lineTo(cx + 3, cy + 6.5);
ctx.moveTo(cx + 5, cy + 6.5);
ctx.lineTo(cx + 8, cy + 6.5);
ctx.moveTo(cx, cy + 11.5);
ctx.lineTo(cx + 3, cy + 11.5);
ctx.moveTo(cx + 5, cy + 11.5);
ctx.lineTo(cx + 8, cy + 11.5);
}
ctx.strokeStyle = _color1;
ctx.stroke();
ctx.beginPath();
}
}
}
else
{
if (_object.rects)
{
for (var j = 0; j < _object.rects.length; j++)
{
......@@ -4024,17 +4047,142 @@ function CDrawingDocument()
ctx.beginPath();
}
}
else if (_object.paths)
{
for (var j = 0; j < _object.paths.length; j++)
{
_path = _object.paths[j];
if (_path.Page < this.m_lDrawingFirst || _path.Page > this.m_lDrawingEnd)
continue;
var _page = this.m_arrPages[_rect.Page];
var drPage = _page.drawingPage;
var dKoefX = (drPage.right - drPage.left) / _page.width_mm;
var dKoefY = (drPage.bottom - drPage.top) / _page.height_mm;
ctx.beginPath();
var Points = _object.path.Points;
var nCount = Points.length;
for (var nIndex = 0; nIndex < nCount; nIndex++)
{
var _x = _transform.TransformPointX(Points[nIndex].X, Points[nIndex].Y);
var _y = _transform.TransformPointY(Points[nIndex].X, Points[nIndex].Y);
_x = (drPage.left + dKoefX * _x);
_y = (drPage.top + dKoefY * _y);
if (0 == nIndex)
ctx.moveTo(_x, _y);
else
ctx.lineTo(_x, _y);
}
ctx.closePath();
if (_object.type == c_oContentControlTrack.Hover)
{
ctx.fillStyle = "rgba(205, 205, 205, 0.5)";
ctx.fill();
}
ctx.stroke();
ctx.beginPath();
}
}
}
if (_object.type == c_oContentControlTrack.In)
{
_rect = _object.rects[0];
if (_curPage < this.m_lDrawingFirst || _curPage > this.m_lDrawingEnd)
continue;
var _page = this.m_arrPages[_rect.Page];
_rect = _object.getXY();
var _page = this.m_arrPages[_curPage];
var drPage = _page.drawingPage;
var dKoefX = (drPage.right - drPage.left) / _page.width_mm;
var dKoefY = (drPage.bottom - drPage.top) / _page.height_mm;
if (!_transform)
{
_x = (drPage.left + dKoefX * (_rect.X + offset_x));
_y = (drPage.top + dKoefY * (_rect.Y + offset_y));
_x = ((_x >> 0) + 0.5) - 15;
_y = ((_y >> 0) + 0.5);
ctx.rect(_x, _y, 15, 20);
overlay.CheckRect(_x, _y, 15, 20);
if (1 == this.ContentControlObjectState)
{
ctx.fillStyle = "#CFCFCF";
ctx.fill();
}
ctx.stroke();
ctx.beginPath();
var cx = _x - 0.5 + 4;
var cy = _y - 0.5 + 4;
var _color1 = "#ADADAD";
var _color2 = "#D4D4D4";
if (0 == this.ContentControlObjectState || 1 == this.ContentControlObjectState)
{
_color1 = "#444444";
_color2 = "#9D9D9D";
}
overlay.AddRect(cx, cy, 3, 3);
overlay.AddRect(cx + 5, cy, 3, 3);
overlay.AddRect(cx, cy + 5, 3, 3);
overlay.AddRect(cx + 5, cy + 5, 3, 3);
overlay.AddRect(cx, cy + 10, 3, 3);
overlay.AddRect(cx + 5, cy + 10, 3, 3);
ctx.fillStyle = _color2;
ctx.fill();
ctx.beginPath();
ctx.moveTo(cx + 1.5, cy);
ctx.lineTo(cx + 1.5, cy + 3);
ctx.moveTo(cx + 6.5, cy);
ctx.lineTo(cx + 6.5, cy + 3);
ctx.moveTo(cx + 1.5, cy + 5);
ctx.lineTo(cx + 1.5, cy + 8);
ctx.moveTo(cx + 6.5, cy + 5);
ctx.lineTo(cx + 6.5, cy + 8);
ctx.moveTo(cx + 1.5, cy + 10);
ctx.lineTo(cx + 1.5, cy + 13);
ctx.moveTo(cx + 6.5, cy + 10);
ctx.lineTo(cx + 6.5, cy + 13);
ctx.moveTo(cx, cy + 1.5);
ctx.lineTo(cx + 3, cy + 1.5);
ctx.moveTo(cx + 5, cy + 1.5);
ctx.lineTo(cx + 8, cy + 1.5);
ctx.moveTo(cx, cy + 6.5);
ctx.lineTo(cx + 3, cy + 6.5);
ctx.moveTo(cx + 5, cy + 6.5);
ctx.lineTo(cx + 8, cy + 6.5);
ctx.moveTo(cx, cy + 11.5);
ctx.lineTo(cx + 3, cy + 11.5);
ctx.moveTo(cx + 5, cy + 11.5);
ctx.lineTo(cx + 8, cy + 11.5);
ctx.strokeStyle = _color1;
ctx.stroke();
ctx.beginPath();
}
else
{
var _x = _rect.X - (15 / dKoefX);
var _y = _rect.Y;
var _r = _rect.X;
......@@ -4148,7 +4296,7 @@ function CDrawingDocument()
if (this.ContentControlObjects.length != 0 && this.ContentControlObjects[0].id == id)
return;
this.ContentControlObjects.unshift(new CContentControlTrack(id, type, rects, transform));
this.ContentControlObjects.push(new CContentControlTrack(id, type, rects, transform));
}
};
......@@ -6489,9 +6637,9 @@ function CDrawingDocument()
var _object = this.ContentControlObjects[i];
if (_object.type == c_oContentControlTrack.In)
{
var _rect = _object.rects[0];
var _rect = _object.getXY();
var _page = this.m_arrPages[_rect.Page];
var _page = this.m_arrPages[_object.getPage()];
var drPage = _page.drawingPage;
var dKoefX = (drPage.right - drPage.left) / _page.width_mm;
......@@ -6650,7 +6798,7 @@ function CDrawingDocument()
}
}
if (_content_control && pos.Page == _content_control.rects[0].Page)
if (_content_control && pos.Page == _content_control.getPage())
{
if (1 == this.ContentControlObjectState)
{
......@@ -6669,7 +6817,7 @@ function CDrawingDocument()
var dKoefX = (drPage.right - drPage.left) / _page.width_mm;
var dKoefY = (drPage.bottom - drPage.top) / _page.height_mm;
var rect = _content_control.rects[0];
var rect = _content_control.getXY();
var _x = rect.X - (15 / dKoefX);
var _y = rect.Y;
var _r = rect.X;
......
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