Commit 3ecc40b7 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@53363 954022d7-b5bf-4e40-9824-e11837661b57
parent 71eaa094
...@@ -535,6 +535,17 @@ CChartAsGroup.prototype = ...@@ -535,6 +535,17 @@ CChartAsGroup.prototype =
return this.transform; return this.transform;
}, },
getSnapArrays: function(snapX, snapY)
{
var transform = this.getTransformMatrix();
snapX.push(transform.tx);
snapX.push(transform.tx + this.extX*0.5);
snapX.push(transform.tx + this.extX);
snapY.push(transform.ty);
snapY.push(transform.ty + this.extY*0.5);
snapY.push(transform.ty + this.extY);
},
setXfrm: function(offX, offY, extX, extY, rot, flipH, flipV) setXfrm: function(offX, offY, extX, extY, rot, flipH, flipV)
......
...@@ -733,6 +733,17 @@ CGraphicFrame.prototype = ...@@ -733,6 +733,17 @@ CGraphicFrame.prototype =
return new MoveShapeImageTrack(this); return new MoveShapeImageTrack(this);
}, },
getSnapArrays: function(snapX, snapY)
{
var transform = this.getTransformMatrix();
snapX.push(transform.tx);
snapX.push(transform.tx + this.extX*0.5);
snapX.push(transform.tx + this.extX);
snapY.push(transform.ty);
snapY.push(transform.ty + this.extY*0.5);
snapY.push(transform.ty + this.extY);
},
createRotateInGroupTrack: function() createRotateInGroupTrack: function()
{ {
......
...@@ -685,6 +685,25 @@ CGroupShape.prototype = ...@@ -685,6 +685,25 @@ CGroupShape.prototype =
} }
return this.transform; return this.transform;
}, },
getSnapArrays: function(snapX, snapY)
{
var transform = this.getTransformMatrix();
snapX.push(transform.tx);
snapX.push(transform.tx + this.extX*0.5);
snapX.push(transform.tx + this.extX);
snapY.push(transform.ty);
snapY.push(transform.ty + this.extY*0.5);
snapY.push(transform.ty + this.extY);
for(var i = 0; i < this.arrGraphicObjects.length; ++i)
{
if(this.arrGraphicObjects[i].getSnapArrays)
{
this.arrGraphicObjects[i].getSnapArrays(snapX, snapY);
}
}
},
getPlaceholderType: function() getPlaceholderType: function()
{ {
return this.isPlaceholder() ? this.nvGrpSpPr.nvPr.ph.type : null; return this.isPlaceholder() ? this.nvGrpSpPr.nvPr.ph.type : null;
......
...@@ -98,6 +98,17 @@ CImageShape.prototype = ...@@ -98,6 +98,17 @@ CImageShape.prototype =
}, },
getSnapArrays: function(snapX, snapY)
{
var transform = this.getTransformMatrix();
snapX.push(transform.tx);
snapX.push(transform.tx + this.extX*0.5);
snapX.push(transform.tx + this.extX);
snapY.push(transform.ty);
snapY.push(transform.ty + this.extY*0.5);
snapY.push(transform.ty + this.extY);
},
getBoundsInGroup: function() getBoundsInGroup: function()
{ {
var r = isRealNumber(this.rot) ? this.rot : 0; var r = isRealNumber(this.rot) ? this.rot : 0;
......
...@@ -1916,6 +1916,17 @@ CShape.prototype = ...@@ -1916,6 +1916,17 @@ CShape.prototype =
editor.asc_fireCallback("asc_canDecreaseIndent", false); editor.asc_fireCallback("asc_canDecreaseIndent", false);
}, },
getSnapArrays: function(snapX, snapY)
{
var transform = this.getTransformMatrix();
snapX.push(transform.tx);
snapX.push(transform.tx + this.extX*0.5);
snapX.push(transform.tx + this.extX);
snapY.push(transform.ty);
snapY.push(transform.ty + this.extY*0.5);
snapY.push(transform.ty + this.extY);
},
getTransformMatrix: function () { getTransformMatrix: function () {
if (this.recalcInfo.recalculateTransform) { if (this.recalcInfo.recalculateTransform) {
this.recalculateTransform(); this.recalculateTransform();
......
...@@ -1191,6 +1191,20 @@ Slide.prototype = ...@@ -1191,6 +1191,20 @@ Slide.prototype =
} }
}, },
getSnapArrays: function()
{
var snapX = [];
var snapY = [];
for(var i = 0; i < this.cSld.spTree.length; ++i)
{
if(this.cSld.spTree[i].getSnapArrays)
{
this.cSld.spTree[i].getSnapArrays(snapX, snapY);
}
}
return {snapX: snapX, snapY: snapY};
},
Write_ToBinary2: function(w) Write_ToBinary2: function(w)
{ {
w.WriteLong(historyitem_type_Slide); w.WriteLong(historyitem_type_Slide);
......
...@@ -3257,7 +3257,6 @@ CGraphicObjects.prototype = { ...@@ -3257,7 +3257,6 @@ CGraphicObjects.prototype = {
} }
}, },
remove: function(Count, bOnlyText, bRemoveOnlySelection) remove: function(Count, bOnlyText, bRemoveOnlySelection)
{ {
switch (this.State.id) switch (this.State.id)
...@@ -3649,7 +3648,6 @@ CGraphicObjects.prototype = { ...@@ -3649,7 +3648,6 @@ CGraphicObjects.prototype = {
this.State.onMouseUp(e, x, y); this.State.onMouseUp(e, x, y);
}, },
onMouseUp2: function(e, x, y) onMouseUp2: function(e, x, y)
{ {
this.State.onMouseUp(e, x, y); this.State.onMouseUp(e, x, y);
...@@ -3672,7 +3670,6 @@ CGraphicObjects.prototype = { ...@@ -3672,7 +3670,6 @@ CGraphicObjects.prototype = {
this.State.updateCursorType(e, x, y); this.State.updateCursorType(e, x, y);
}, },
updateSelectionState: function() updateSelectionState: function()
{ {
if(isRealObject(this.State.textObject)) if(isRealObject(this.State.textObject))
...@@ -3709,6 +3706,19 @@ CGraphicObjects.prototype = { ...@@ -3709,6 +3706,19 @@ CGraphicObjects.prototype = {
this.arrTrackObjects.length = 0; this.arrTrackObjects.length = 0;
}, },
getSnapArraysTrackObjects: function()
{
var snapX = [], snapY = [];
for(var i = 0; i < this.arrTrackObjects.length; ++i)
{
if(this.arrTrackObjects[i].originalObject && this.arrTrackObjects[i].originalObject.getSnapArrays)
{
this.arrTrackObjects[i].originalObject.getSnapArrays(snapX, snapY);
}
}
return {snapX: snapX, snapY: snapY};
},
addTrackObject: function(trackObject) addTrackObject: function(trackObject)
{ {
this.arrTrackObjects.push(trackObject); this.arrTrackObjects.push(trackObject);
......
...@@ -51,7 +51,7 @@ var STATES_ID_MOVE_INTERNAL_CHART_OBJECT_GROUP = 0x41; ...@@ -51,7 +51,7 @@ var STATES_ID_MOVE_INTERNAL_CHART_OBJECT_GROUP = 0x41;
var STATES_ID_CHART_GROUP = 0x42; var STATES_ID_CHART_GROUP = 0x42;
var STATES_ID_CHART_GROUP_TEXT_ADD = 0x43; var STATES_ID_CHART_GROUP_TEXT_ADD = 0x43;
var SNAP_DISTANCE = 1.27;
function resetGroupChartSelection(state) function resetGroupChartSelection(state)
{ {
...@@ -2827,12 +2827,35 @@ function ResizeState(drawingObjectsController, drawingObjects, majorObject, card ...@@ -2827,12 +2827,35 @@ function ResizeState(drawingObjectsController, drawingObjects, majorObject, card
this.handleNum = this.majorObject.getNumByCardDirection(cardDirection); this.handleNum = this.majorObject.getNumByCardDirection(cardDirection);
this.cardDirection = cardDirection; this.cardDirection = cardDirection;
var snap = this.drawingObjects.getSnapArrays();
this.snapX = snap.snapX;
this.snapY = snap.snapY;
this.onMouseDown = function(e, x, y) this.onMouseDown = function(e, x, y)
{}; {};
this.onMouseMove = function(e, x, y) this.onMouseMove = function(e, x, y)
{ {
var resize_coefficients = this.majorObject.getResizeCoefficients(this.handleNum, x, y); var point_x, point_y;
var snap_object_x = GetSnapObject([x], 0, this.snapX);
var snap_object_y = GetSnapObject([y], 0, this.snapY);
if(snap_object_x.point !== null)
{
point_x = snap_object_x.point;
}
else
{
point_x = x;
}
if(snap_object_y.point !== null)
{
point_y = snap_object_y.point;
}
else
{
point_y = y;
}
var resize_coefficients = this.majorObject.getResizeCoefficients(this.handleNum, point_x, point_y);
this.drawingObjectsController.trackResizeObjects(resize_coefficients.kd1, resize_coefficients.kd2, e); this.drawingObjectsController.trackResizeObjects(resize_coefficients.kd1, resize_coefficients.kd2, e);
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
...@@ -3360,6 +3383,14 @@ function MoveState(drawingObjectsController, drawingObjects, startX, startY, rec ...@@ -3360,6 +3383,14 @@ function MoveState(drawingObjectsController, drawingObjects, startX, startY, rec
this.majorObject = majorObject; this.majorObject = majorObject;
this.majorTrack = null; this.majorTrack = null;
var snap = this.drawingObjects.getSnapArrays();
this.snapX = snap.snapX;
this.snapY = snap.snapY;
trackSnap = this.drawingObjectsController.getSnapArraysTrackObjects();
this.trackSnapX = trackSnap.snapX;
this.trackSnapY = trackSnap.snapY;
this.onMouseDown = function(e, x, y) this.onMouseDown = function(e, x, y)
{ {
...@@ -3370,7 +3401,36 @@ function MoveState(drawingObjectsController, drawingObjects, startX, startY, rec ...@@ -3370,7 +3401,36 @@ function MoveState(drawingObjectsController, drawingObjects, startX, startY, rec
var dx = x - this.startX; var dx = x - this.startX;
var dy = y - this.startY; var dy = y - this.startY;
var shiftX = 0, shiftY = 0; var shiftX = 0, shiftY = 0;
this.drawingObjectsController.trackMoveObjects(dx, dy); var snapObjectX = GetSnapObject(this.trackSnapX, dx, this.snapX);
var snapObjectY = GetSnapObject(this.trackSnapY, dy, this.snapY);
if(snapObjectX.distance !== null)
{
shiftX = snapObjectX.distance;
}
if(snapObjectY.distance !== null)
{
shiftY = snapObjectY.distance;
}
var result_dx, result_dy;
if(!e.ShiftKey)
{
result_dx = dx + shiftX;
result_dy = dy + shiftY;
}
else
{
result_dx = dx + shiftX;
result_dy = dy + shiftY;
if(Math.abs(result_dx) > Math.abs(result_dy))
{
result_dy = 0;
}
else
{
result_dx = 0;
}
}
this.drawingObjectsController.trackMoveObjects(result_dx, result_dy);
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
}; };
...@@ -3435,6 +3495,37 @@ function MoveState(drawingObjectsController, drawingObjects, startX, startY, rec ...@@ -3435,6 +3495,37 @@ function MoveState(drawingObjectsController, drawingObjects, startX, startY, rec
}; };
} }
function GetSnapObject(trackSnapArr, dist, snapArr)
{
var min_d = null, point = null;
for(var i = 0; i < trackSnapArr.length; ++i)
{
var p = trackSnapArr[i] + dist;
for(var j = 0; j < snapArr.length; ++j)
{
var d = snapArr[j] - p;
if(Math.abs(d) < SNAP_DISTANCE)
{
if(point === null)
{
point = snapArr[j];
min_d = d;
}
else
{
if(Math.abs(d) < Math.abs(min_d))
{
min_d = d;
point = snapArr[j];
}
}
}
}
}
return {distance: min_d, point: point};
}
function PreChangeAdjState(drawingObjectsController, drawingObjects, majorObject) function PreChangeAdjState(drawingObjectsController, drawingObjects, majorObject)
{ {
...@@ -4094,6 +4185,16 @@ function MoveInGroupState(drawingObjectsController, drawingObjects, group, start ...@@ -4094,6 +4185,16 @@ function MoveInGroupState(drawingObjectsController, drawingObjects, group, start
this.rectY = rectY; this.rectY = rectY;
this.rectW = rectW; this.rectW = rectW;
this.rectH = rectH; this.rectH = rectH;
var snap = this.drawingObjects.getSnapArrays();
this.snapX = snap.snapX;
this.snapY = snap.snapY;
trackSnap = this.drawingObjectsController.getSnapArraysTrackObjects();
this.trackSnapX = trackSnap.snapX;
this.trackSnapY = trackSnap.snapY;
this.onMouseDown = function(e, x, y) this.onMouseDown = function(e, x, y)
{ {
...@@ -4103,7 +4204,37 @@ function MoveInGroupState(drawingObjectsController, drawingObjects, group, start ...@@ -4103,7 +4204,37 @@ function MoveInGroupState(drawingObjectsController, drawingObjects, group, start
{ {
var dx = x - this.startX; var dx = x - this.startX;
var dy = y - this.startY; var dy = y - this.startY;
this.drawingObjectsController.trackMoveObjects(dx, dy); var shiftX = 0, shiftY = 0;
var snapObjectX = GetSnapObject(this.trackSnapX, dx, this.snapX);
var snapObjectY = GetSnapObject(this.trackSnapY, dy, this.snapY);
if(snapObjectX.distance !== null)
{
shiftX = snapObjectX.distance;
}
if(snapObjectY.distance !== null)
{
shiftY = snapObjectY.distance;
}
var result_dx, result_dy;
if(!e.ShiftKey)
{
result_dx = dx + shiftX;
result_dy = dy + shiftY;
}
else
{
result_dx = dx + shiftX;
result_dy = dy + shiftY;
if(Math.abs(result_dx) > Math.abs(result_dy))
{
result_dy = 0;
}
else
{
result_dx = 0;
}
}
this.drawingObjectsController.trackMoveObjects(result_dx, result_dy);
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
}; };
...@@ -4421,12 +4552,38 @@ function ResizeInGroupState(drawingObjectsController, drawingObjects, group, maj ...@@ -4421,12 +4552,38 @@ function ResizeInGroupState(drawingObjectsController, drawingObjects, group, maj
this.majorObject = majorObject; this.majorObject = majorObject;
this.handleNum = handleNum; this.handleNum = handleNum;
this.cardDirection = cardDirection; this.cardDirection = cardDirection;
var snap = this.drawingObjects.getSnapArrays();
this.snapX = snap.snapX;
this.snapY = snap.snapY;
this.onMouseDown = function(e, x, y) this.onMouseDown = function(e, x, y)
{}; {};
this.onMouseMove = function(e, x, y) this.onMouseMove = function(e, x, y)
{ {
var resize_coefficients = this.majorObject.getResizeCoefficients(this.handleNum, x, y); var point_x, point_y;
var snap_object_x = GetSnapObject([x], 0, this.snapX);
var snap_object_y = GetSnapObject([y], 0, this.snapY);
if(snap_object_x.point !== null)
{
point_x = snap_object_x.point;
}
else
{
point_x = x;
}
if(snap_object_y.point !== null)
{
point_y = snap_object_y.point;
}
else
{
point_y = y;
}
var resize_coefficients = this.majorObject.getResizeCoefficients(this.handleNum, point_x, point_y);
this.drawingObjectsController.trackResizeObjects(resize_coefficients.kd1, resize_coefficients.kd2, e); this.drawingObjectsController.trackResizeObjects(resize_coefficients.kd1, resize_coefficients.kd2, e);
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
}; };
...@@ -4589,7 +4746,8 @@ function SplineBezierState2(drawingObjectsController, drawingObjects, startX, st ...@@ -4589,7 +4746,8 @@ function SplineBezierState2(drawingObjectsController, drawingObjects, startX, st
this.drawingObjectsController.clearTrackObjects(); this.drawingObjectsController.clearTrackObjects();
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects)); this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects));
editor.sync_EndAddShape();
} }
}; };
...@@ -4656,7 +4814,7 @@ function SplineBezierState3(drawingObjectsController, drawingObjects, startX, st ...@@ -4656,7 +4814,7 @@ function SplineBezierState3(drawingObjectsController, drawingObjects, startX, st
this.drawingObjectsController.clearTrackObjects(); this.drawingObjectsController.clearTrackObjects();
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects)); this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects));
editor.sync_EndAddShape();
} }
}; };
...@@ -4756,7 +4914,8 @@ function SplineBezierState4(drawingObjectsController, drawingObjects, spline) ...@@ -4756,7 +4914,8 @@ function SplineBezierState4(drawingObjectsController, drawingObjects, spline)
this.drawingObjectsController.clearTrackObjects(); this.drawingObjectsController.clearTrackObjects();
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects)); this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects));
editor.sync_EndAddShape();
} }
}; };
...@@ -4874,7 +5033,8 @@ function SplineBezierState5(drawingObjectsController, drawingObjects, startX, st ...@@ -4874,7 +5033,8 @@ function SplineBezierState5(drawingObjectsController, drawingObjects, startX, st
this.drawingObjectsController.clearTrackObjects(); this.drawingObjectsController.clearTrackObjects();
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects)); this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects));
editor.sync_EndAddShape();
} }
}; };
...@@ -5066,7 +5226,8 @@ function PolyLineAddState2(drawingObjectsController, drawingObjects, minDistance ...@@ -5066,7 +5226,8 @@ function PolyLineAddState2(drawingObjectsController, drawingObjects, minDistance
this.drawingObjectsController.clearTrackObjects(); this.drawingObjectsController.clearTrackObjects();
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects)); this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects));
editor.sync_EndAddShape();
}; };
...@@ -5218,7 +5379,8 @@ function AddPolyLine2State3(drawingObjectsController, drawingObjects, polyline) ...@@ -5218,7 +5379,8 @@ function AddPolyLine2State3(drawingObjectsController, drawingObjects, polyline)
this.drawingObjectsController.clearTrackObjects(); this.drawingObjectsController.clearTrackObjects();
this.drawingObjects.OnUpdateOverlay(); this.drawingObjects.OnUpdateOverlay();
this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects)); this.drawingObjectsController.changeCurrentState(new NullState(this.drawingObjectsController, this.drawingObjects));
editor.sync_EndAddShape();
} }
}; };
......
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