Commit 0c523843 authored by Sergey.Luzyanin's avatar Sergey.Luzyanin Committed by Alexander.Trofimov

отрисовка вертикальных и горизонтальных линий при приснапливании

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@51092 954022d7-b5bf-4e40-9824-e11837661b57
parent dc48cea5
...@@ -1358,6 +1358,43 @@ CChartAsGroup.prototype = ...@@ -1358,6 +1358,43 @@ CChartAsGroup.prototype =
}, },
calculateSnapArrays: function(snapArrayX, snapArrayY)
{
var t = this.transform;
var _t = t;
if(isRealObject(this.parent))
{
if(this.parent.Is_Inline())
{
if(this.parent.DocumentContent instanceof CDocumentContent)
{
var cur_doc_content = this.parent.DocumentContent;
while(cur_doc_content.Is_TableCellContent())
{
cur_doc_content = cur_doc_content.Parent.Row.Table.Parent;
}
if((cur_doc_content instanceof CDocumentContent && cur_doc_content.Parent instanceof WordShape))
{
_t = t.CreateDublicate();
global_MatrixTransformer.MultiplyAppend(_t, cur_doc_content.Parent.transformText);
}
}
}
}
snapArrayX.push(_t.TransformPointX(0, 0));
snapArrayY.push(_t.TransformPointY(0, 0));
snapArrayX.push(_t.TransformPointX(this.absExtX, 0));
snapArrayY.push(_t.TransformPointY(this.absExtX, 0));
snapArrayX.push(t.TransformPointX(this.absExtX*0.5, this.absExtY*0.5));
snapArrayY.push(t.TransformPointY(this.absExtX*0.5, this.absExtY*0.5))
snapArrayX.push(_t.TransformPointX(this.absExtX, this.absExtY));
snapArrayY.push(_t.TransformPointY(this.absExtX, this.absExtY));
snapArrayX.push(_t.TransformPointX(0, this.absExtY));
snapArrayY.push(_t.TransformPointY(0, this.absExtY));
},
hitToHandle: function(x, y, radius) hitToHandle: function(x, y, radius)
{ {
......
...@@ -393,6 +393,8 @@ function CGeometry() ...@@ -393,6 +393,8 @@ function CGeometry()
return duplicate; return duplicate;
}; };
this.createDuplicateForTrack = function() this.createDuplicateForTrack = function()
{ {
var _duplicate = new Geometry(); var _duplicate = new Geometry();
...@@ -479,6 +481,16 @@ CGeometry.prototype= ...@@ -479,6 +481,16 @@ CGeometry.prototype=
}, },
canFill: function()
{
for(var i = 0; i < this.pathLst.length; ++i)
{
if(this.pathLst[i].fill !== "none")
return true;
}
return false;
},
Write_ToBinary2: function(Writer) Write_ToBinary2: function(Writer)
{ {
var w = Writer; var w = Writer;
......
...@@ -2147,6 +2147,8 @@ WordGroupShapes.prototype = ...@@ -2147,6 +2147,8 @@ WordGroupShapes.prototype =
snapArrayX.push(t.TransformPointX(this.absExtX, 0)); snapArrayX.push(t.TransformPointX(this.absExtX, 0));
snapArrayY.push(t.TransformPointY(this.absExtX, 0)); snapArrayY.push(t.TransformPointY(this.absExtX, 0));
snapArrayX.push(t.TransformPointX(this.absExtX*0.5, this.absExtY*0.5));
snapArrayY.push(t.TransformPointY(this.absExtX*0.5, this.absExtY*0.5))
snapArrayX.push(t.TransformPointX(this.absExtX, this.absExtY)); snapArrayX.push(t.TransformPointX(this.absExtX, this.absExtY));
snapArrayY.push(t.TransformPointY(this.absExtX, this.absExtY)); snapArrayY.push(t.TransformPointY(this.absExtX, this.absExtY));
snapArrayX.push(t.TransformPointX(0, this.absExtY)); snapArrayX.push(t.TransformPointX(0, this.absExtY));
......
...@@ -795,6 +795,8 @@ WordImage.prototype = ...@@ -795,6 +795,8 @@ WordImage.prototype =
snapArrayX.push(_t.TransformPointX(this.absExtX, 0)); snapArrayX.push(_t.TransformPointX(this.absExtX, 0));
snapArrayY.push(_t.TransformPointY(this.absExtX, 0)); snapArrayY.push(_t.TransformPointY(this.absExtX, 0));
snapArrayX.push(t.TransformPointX(this.absExtX*0.5, this.absExtY*0.5));
snapArrayY.push(t.TransformPointY(this.absExtX*0.5, this.absExtY*0.5))
snapArrayX.push(_t.TransformPointX(this.absExtX, this.absExtY)); snapArrayX.push(_t.TransformPointX(this.absExtX, this.absExtY));
snapArrayY.push(_t.TransformPointY(this.absExtX, this.absExtY)); snapArrayY.push(_t.TransformPointY(this.absExtX, this.absExtY));
snapArrayX.push(_t.TransformPointX(0, this.absExtY)); snapArrayX.push(_t.TransformPointX(0, this.absExtY));
......
...@@ -3500,6 +3500,8 @@ WordShape.prototype = ...@@ -3500,6 +3500,8 @@ WordShape.prototype =
snapArrayX.push(t.TransformPointX(this.absExtX, 0)); snapArrayX.push(t.TransformPointX(this.absExtX, 0));
snapArrayY.push(t.TransformPointY(this.absExtX, 0)); snapArrayY.push(t.TransformPointY(this.absExtX, 0));
snapArrayX.push(t.TransformPointX(this.absExtX*0.5, this.absExtY*0.5));
snapArrayY.push(t.TransformPointY(this.absExtX*0.5, this.absExtY*0.5))
snapArrayX.push(t.TransformPointX(this.absExtX, this.absExtY)); snapArrayX.push(t.TransformPointX(this.absExtX, this.absExtY));
snapArrayY.push(t.TransformPointY(this.absExtX, this.absExtY)); snapArrayY.push(t.TransformPointY(this.absExtX, this.absExtY));
snapArrayX.push(t.TransformPointX(0, this.absExtY)); snapArrayX.push(t.TransformPointX(0, this.absExtY));
......
...@@ -5600,31 +5600,76 @@ function MoveState(graphicObjects) ...@@ -5600,31 +5600,76 @@ function MoveState(graphicObjects)
var startBehindArr = startPage.behindDocObjects; var startBehindArr = startPage.behindDocObjects;
var min_dx = null, min_dy = null; var min_dx = null, min_dy = null;
var dx, dy; var dx, dy;
var snap_x = null, snap_y = null;
var snapHorArray = [], snapVerArray = [];
snapHorArray.push(X_Left_Field);
snapHorArray.push(X_Right_Field);
snapHorArray.push(Page_Width/2);
snapVerArray.push(Y_Top_Field);
snapVerArray.push(Y_Bottom_Field);
snapVerArray.push(Page_Height/2);
if(result_x === this.graphicObjects.startTrackPos.x) if(result_x === this.graphicObjects.startTrackPos.x)
{ {
min_dx = 0; min_dx = 0;
} }
else else
{ {
for(var track_index = 0; track_index < _arr_track_objects.length; ++track_index) for(var track_index = 0; track_index < _arr_track_objects.length; ++track_index)
{ {
var cur_track_original_shape = _arr_track_objects[track_index].originalGraphicObject; var cur_track_original_shape = _arr_track_objects[track_index].originalGraphicObject;
var trackSnapArrayX = cur_track_original_shape.snapArrayX; var trackSnapArrayX = cur_track_original_shape.snapArrayX;
var curDX = result_x - startPos.x; var curDX = result_x - startPos.x;
for(snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index)
{
var snap_obj = GetMinSnapDistanceXObjectByArrays(trackSnapArrayX[snap_index] + curDX, snapHorArray);
if(isRealObject(snap_obj))
{
dx = snap_obj.dist;
if(dx !== null)
{
if(min_dx === null)
{
min_dx = dx;
snap_x = snap_obj.pos;
}
else
{
if(Math.abs(min_dx) > Math.abs(dx))
{
min_dx = dx;
snap_x = snap_obj.pos;
}
}
}
}
}
if(startBeforeArr.length > 0) if(startBeforeArr.length > 0)
{ {
for(var snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index) for(var snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index)
{ {
dx = GetMinSnapDistanceX(trackSnapArrayX[snap_index] + curDX, startBeforeArr); var snap_obj = GetMinSnapDistanceXObject(trackSnapArrayX[snap_index] + curDX, startBeforeArr);
if(isRealObject(snap_obj))
{
dx = snap_obj.dist;
if(dx !== null) if(dx !== null)
{ {
if(min_dx === null) if(min_dx === null)
{
snap_x = snap_obj.pos;
min_dx = dx; min_dx = dx;
}
else else
{ {
if(Math.abs(min_dx) > Math.abs(dx)) if(Math.abs(min_dx) > Math.abs(dx))
{
min_dx = dx; min_dx = dx;
snap_x = snap_obj.pos;
}
}
} }
} }
} }
...@@ -5635,15 +5680,25 @@ function MoveState(graphicObjects) ...@@ -5635,15 +5680,25 @@ function MoveState(graphicObjects)
{ {
for(snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index) for(snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index)
{ {
dx = GetMinSnapDistanceX(trackSnapArrayX[snap_index] + curDX, startWrapArr); var snap_obj = GetMinSnapDistanceXObject(trackSnapArrayX[snap_index] + curDX, startWrapArr);
if(isRealObject(snap_obj))
{
dx = snap_obj.dist;
if(dx !== null) if(dx !== null)
{ {
if(min_dx === null) if(min_dx === null)
{
min_dx = dx; min_dx = dx;
snap_x = snap_obj.pos;
}
else else
{ {
if(Math.abs(min_dx) > Math.abs(dx)) if(Math.abs(min_dx) > Math.abs(dx))
{
min_dx = dx; min_dx = dx;
snap_x = snap_obj.pos;
}
}
} }
} }
} }
...@@ -5653,15 +5708,25 @@ function MoveState(graphicObjects) ...@@ -5653,15 +5708,25 @@ function MoveState(graphicObjects)
{ {
for(snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index) for(snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index)
{ {
dx = GetMinSnapDistanceX(trackSnapArrayX[snap_index] + curDX, startInlineArr); var snap_obj = GetMinSnapDistanceXObject(trackSnapArrayX[snap_index] + curDX, startInlineArr);
if(isRealObject(snap_obj))
{
dx = snap_obj.dist;
if(dx !== null) if(dx !== null)
{ {
if(min_dx === null) if(min_dx === null)
{
min_dx = dx; min_dx = dx;
snap_x = snap_obj.pos;
}
else else
{ {
if(Math.abs(min_dx) > Math.abs(dx)) if(Math.abs(min_dx) > Math.abs(dx))
{
min_dx = dx; min_dx = dx;
snap_x = snap_obj.pos;
}
}
} }
} }
} }
...@@ -5672,15 +5737,25 @@ function MoveState(graphicObjects) ...@@ -5672,15 +5737,25 @@ function MoveState(graphicObjects)
{ {
for(snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index) for(snap_index = 0; snap_index < trackSnapArrayX.length; ++snap_index)
{ {
dx = GetMinSnapDistanceX(trackSnapArrayX[snap_index] + curDX, startBehindArr); var snap_obj = GetMinSnapDistanceXObject(trackSnapArrayX[snap_index] + curDX, startBehindArr);
if(isRealObject(snap_obj))
{
dx = snap_obj.dist;
if(dx !== null) if(dx !== null)
{ {
if(min_dx === null) if(min_dx === null)
{
min_dx = dx; min_dx = dx;
snap_x = snap_obj.pos;
}
else else
{ {
if(Math.abs(min_dx) > Math.abs(dx)) if(Math.abs(min_dx) > Math.abs(dx))
{
min_dx = dx; min_dx = dx;
snap_x = snap_obj.pos;
}
}
} }
} }
} }
...@@ -5700,19 +5775,55 @@ function MoveState(graphicObjects) ...@@ -5700,19 +5775,55 @@ function MoveState(graphicObjects)
var trackSnapArrayY = cur_track_original_shape.snapArrayY; var trackSnapArrayY = cur_track_original_shape.snapArrayY;
var curDY = result_y - startPos.y; var curDY = result_y - startPos.y;
for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index)
{
var snap_obj = GetMinSnapDistanceYObjectByArrays(trackSnapArrayY[snap_index] + curDY, snapVerArray);
if(isRealObject(snap_obj))
{
dy = snap_obj.dist;
if(dy !== null)
{
if(min_dy === null)
{
min_dy = dy;
snap_y = snap_obj.pos;
}
else
{
if(Math.abs(min_dy) > Math.abs(dy))
{
min_dy = dy;
snap_y = snap_obj.pos;
}
}
}
}
}
if(startBeforeArr.length > 0) if(startBeforeArr.length > 0)
{ {
for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index) for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index)
{ {
dy = GetMinSnapDistanceY(trackSnapArrayY[snap_index] + curDY, startBeforeArr); var snap_obj = GetMinSnapDistanceYObject(trackSnapArrayY[snap_index] + curDY, startBeforeArr);
if(isRealObject(snap_obj))
{
dy = snap_obj.dist;
if(dy !== null) if(dy !== null)
{ {
if(min_dy === null) if(min_dy === null)
{
min_dy = dy; min_dy = dy;
snap_y = snap_obj.pos;
}
else else
{ {
if(Math.abs(min_dy) > Math.abs(dy)) if(Math.abs(min_dy) > Math.abs(dy))
{
min_dy = dy; min_dy = dy;
snap_y = snap_obj.pos;
}
}
} }
} }
} }
...@@ -5724,15 +5835,25 @@ function MoveState(graphicObjects) ...@@ -5724,15 +5835,25 @@ function MoveState(graphicObjects)
{ {
for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index) for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index)
{ {
dy = GetMinSnapDistanceY(trackSnapArrayY[snap_index] + curDY, startWrapArr); var snap_obj = GetMinSnapDistanceYObject(trackSnapArrayY[snap_index] + curDY, startWrapArr);
if(isRealObject(snap_obj))
{
dy = snap_obj.dist;
if(dy !== null) if(dy !== null)
{ {
if(min_dy === null) if(min_dy === null)
{
min_dy = dy; min_dy = dy;
snap_y = snap_obj.pos;
}
else else
{ {
if(Math.abs(min_dy) > Math.abs(dy)) if(Math.abs(min_dy) > Math.abs(dy))
{
min_dy = dy; min_dy = dy;
snap_y = snap_obj.pos;
}
}
} }
} }
} }
...@@ -5743,15 +5864,25 @@ function MoveState(graphicObjects) ...@@ -5743,15 +5864,25 @@ function MoveState(graphicObjects)
{ {
for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index) for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index)
{ {
dy = GetMinSnapDistanceY(trackSnapArrayY[snap_index] + curDY, startInlineArr); var snap_obj = GetMinSnapDistanceYObject(trackSnapArrayY[snap_index] + curDY, startInlineArr);
if(isRealObject(snap_obj))
{
dy = snap_obj.dist;
if(dy !== null) if(dy !== null)
{ {
if(min_dy === null) if(min_dy === null)
{
min_dy = dy; min_dy = dy;
snap_y = snap_obj.pos;
}
else else
{ {
if(Math.abs(min_dy) > Math.abs(dy)) if(Math.abs(min_dy) > Math.abs(dy))
{
min_dy = dy; min_dy = dy;
snap_y = snap_obj.pos;
}
}
} }
} }
} }
...@@ -5761,15 +5892,25 @@ function MoveState(graphicObjects) ...@@ -5761,15 +5892,25 @@ function MoveState(graphicObjects)
{ {
for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index) for(snap_index = 0; snap_index < trackSnapArrayY.length; ++snap_index)
{ {
dy = GetMinSnapDistanceY(trackSnapArrayY[snap_index] + curDY, startBehindArr); var snap_obj = GetMinSnapDistanceYObject(trackSnapArrayY[snap_index] + curDY, startBehindArr);
if(isRealObject(snap_obj))
{
dy = snap_obj.dist;
if(dy !== null) if(dy !== null)
{ {
if(min_dy === null) if(min_dy === null)
{
min_dy = dy; min_dy = dy;
snap_y = snap_obj.pos;
}
else else
{ {
if(Math.abs(min_dy) > Math.abs(dy)) if(Math.abs(min_dy) > Math.abs(dy))
{
min_dy = dy; min_dy = dy;
snap_y = snap_obj.pos;
}
}
} }
} }
} }
...@@ -5782,9 +5923,24 @@ function MoveState(graphicObjects) ...@@ -5782,9 +5923,24 @@ function MoveState(graphicObjects)
if(min_dx === null || Math.abs(min_dx) > SNAP_DISTANCE) if(min_dx === null || Math.abs(min_dx) > SNAP_DISTANCE)
min_dx = 0; min_dx = 0;
else
{
if(isRealNumber(snap_x))
{
editor.WordControl.m_oDrawingDocument.DrawVerAnchor(pageIndex, snap_x);
}
}
if(min_dy === null || Math.abs(min_dy) > SNAP_DISTANCE) if(min_dy === null || Math.abs(min_dy) > SNAP_DISTANCE)
min_dy = 0; min_dy = 0;
else
{
if(isRealNumber(snap_y))
{
editor.WordControl.m_oDrawingDocument.DrawHorAnchor(pageIndex, snap_y);
}
}
for(_object_index = 0; _object_index < _objects_count; ++_object_index) for(_object_index = 0; _object_index < _objects_count; ++_object_index)
_arr_track_objects[_object_index].track(result_x + min_dx, result_y + min_dy, pageIndex); _arr_track_objects[_object_index].track(result_x + min_dx, result_y + min_dy, pageIndex);
...@@ -5794,44 +5950,6 @@ function MoveState(graphicObjects) ...@@ -5794,44 +5950,6 @@ function MoveState(graphicObjects)
this.graphicObjects.drawingDocument.m_oWordControl.OnUpdateOverlay(); this.graphicObjects.drawingDocument.m_oWordControl.OnUpdateOverlay();
}; };
/*this.OnMouseUp2 = function(e, x, y, pageIndex)
{
var _arr_track_objects = this.graphicObjects.arrTrackObjects;
var _objects_count = _arr_track_objects.length;
var _object_index;
var near_pos = null;
for(var i = 0; i < _objects_count; ++i)
{
if(_arr_track_objects[i].originalGraphicObject === this.graphicObjects.majorGraphicObject)
{
var bounds33 = _arr_track_objects[i].getBounds();
near_pos = this.graphicObjects.document.Get_NearestPos(pageIndex, bounds33.l, bounds33.t, true, this.graphicObjects.majorGraphicObject);
}
}
if(near_pos!= null && false === this.graphicObjects.document.Document_Is_SelectionLocked(changestype_Drawing_Props, {Type : changestype_2_Element_and_Type , Element : near_pos.Paragraph, CheckType : changestype_Paragraph_Content} ))
{
History.Create_NewPoint();
for(_object_index = 0; _object_index < _objects_count; ++_object_index)
{
_arr_track_objects[_object_index].trackEnd(e);
}
var bounds_2 = this.graphicObjects.majorGraphicObject.getBounds();
for(var i = 0; i < _arr_track_objects.length; ++i)
{
var or_gr_obj = _arr_track_objects[i].originalGraphicObject;
or_gr_obj.calculateOffset();
var pos_x = or_gr_obj.absOffsetX - or_gr_obj.boundsOffsetX;
var pos_y = or_gr_obj.absOffsetY - or_gr_obj.boundsOffsetY;
bounds_2 = or_gr_obj.getBounds();
var W = bounds_2.r - bounds_2.l;
var H = bounds_2.b - bounds_2.t;
or_gr_obj.OnEnd_ChangeFlow(pos_x, pos_y, or_gr_obj.pageIndex, W, H, near_pos, _arr_track_objects[i].trackGraphicObject.boolChangePos, i == _arr_track_objects.length-1);
}
}
this.graphicObjects.arrTrackObjects = [];
this.graphicObjects.changeCurrentState(new NullState(this.graphicObjects));
} */
this.OnMouseUp = function(e, x, y, pageIndex) this.OnMouseUp = function(e, x, y, pageIndex)
{ {
...@@ -10927,3 +11045,113 @@ function GetMinSnapDistanceY(pointY, arrGrObjects) ...@@ -10927,3 +11045,113 @@ function GetMinSnapDistanceY(pointY, arrGrObjects)
} }
return min_dy; return min_dy;
} }
function GetMinSnapDistanceXObject(pointX, arrGrObjects)
{
var min_dx = null;
var ret = null;
for(var i = 0; i < arrGrObjects.length; ++i)
{
var cur_snap_arr_x = arrGrObjects[i].snapArrayX;
var count = cur_snap_arr_x.length;
for(var snap_index = 0; snap_index < count; ++snap_index)
{
var dx = cur_snap_arr_x[snap_index] - pointX;
if(min_dx === null)
{
ret = {dist: dx, pos: cur_snap_arr_x[snap_index]};
min_dx = dx;
}
else
{
if(Math.abs(dx) < Math.abs(min_dx))
{
min_dx = dx;
ret = {dist: dx, pos: cur_snap_arr_x[snap_index]};
}
}
}
}
return ret;
}
function GetMinSnapDistanceYObject(pointY, arrGrObjects)
{
var min_dy = null;
var ret = null;
for(var i = 0; i < arrGrObjects.length; ++i)
{
var cur_snap_arr_y = arrGrObjects[i].snapArrayY;
var count = cur_snap_arr_y.length;
for(var snap_index = 0; snap_index < count; ++snap_index)
{
var dy = cur_snap_arr_y[snap_index] - pointY;
if(min_dy === null)
{
min_dy = dy;
ret = {dist: dy, pos: cur_snap_arr_y[snap_index]};
}
else
{
if(Math.abs(dy) < Math.abs(min_dy))
{
min_dy = dy;
ret = {dist: dy, pos: cur_snap_arr_y[snap_index]};
}
}
}
}
return ret;
}
function GetMinSnapDistanceXObjectByArrays(pointX, snapArrayX)
{
var min_dx = null;
var ret = null;
var cur_snap_arr_x = snapArrayX;
var count = cur_snap_arr_x.length;
for(var snap_index = 0; snap_index < count; ++snap_index)
{
var dx = cur_snap_arr_x[snap_index] - pointX;
if(min_dx === null)
{
ret = {dist: dx, pos: cur_snap_arr_x[snap_index]};
min_dx = dx;
}
else
{
if(Math.abs(dx) < Math.abs(min_dx))
{
min_dx = dx;
ret = {dist: dx, pos: cur_snap_arr_x[snap_index]};
}
}
}
return ret;
}
function GetMinSnapDistanceYObjectByArrays(pointY, snapArrayY)
{
var min_dy = null;
var ret = null;
var cur_snap_arr_y = snapArrayY;
var count = cur_snap_arr_y.length;
for(var snap_index = 0; snap_index < count; ++snap_index)
{
var dy = cur_snap_arr_y[snap_index] - pointY;
if(min_dy === null)
{
min_dy = dy;
ret = {dist: dy, pos: cur_snap_arr_y[snap_index]};
}
else
{
if(Math.abs(dy) < Math.abs(min_dy))
{
min_dy = dy;
ret = {dist: dy, pos: cur_snap_arr_y[snap_index]};
}
}
}
return ret;
}
\ No newline at end of file
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