Commit 05431962 authored by Dmitry.Vikulov's avatar Dmitry.Vikulov Committed by Alexander.Trofimov

- Undo/Redo чартов и картинок

- Исправлен баг с наложением для объектов с прозрачностью

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@49727 954022d7-b5bf-4e40-9824-e11837661b57
parent d4242407
......@@ -3096,8 +3096,8 @@ function DrawingObjects() {
var _w = checker.Bounds.max_x - checker.Bounds.min_x;
var _h = checker.Bounds.max_y - checker.Bounds.min_y;
overlayCtx.clearRect( mmToPt(checker.Bounds.min_x + pxToMm(scrollOffset.x)), mmToPt(checker.Bounds.min_y + pxToMm(scrollOffset.y)), mmToPt(_w), mmToPt(_h) );
drawingCtx.clearRect( mmToPt(checker.Bounds.min_x + pxToMm(scrollOffset.x)), mmToPt(checker.Bounds.min_y + pxToMm(scrollOffset.y)), mmToPt(_w), mmToPt(_h) );
//overlayCtx.clearRect( mmToPt(checker.Bounds.min_x + pxToMm(scrollOffset.x)), mmToPt(checker.Bounds.min_y + pxToMm(scrollOffset.y)), mmToPt(_w), mmToPt(_h) );
//drawingCtx.clearRect( mmToPt(checker.Bounds.min_x + pxToMm(scrollOffset.x)), mmToPt(checker.Bounds.min_y + pxToMm(scrollOffset.y)), mmToPt(_w), mmToPt(_h) );
// Top left
var foundRow = worksheet._findRowUnderCursor( mmToPt(checker.Bounds.min_y + pxToMm(scrollOffset.y)), true);
......@@ -3129,14 +3129,32 @@ function DrawingObjects() {
_this.raiseLayerDrawingObjects = function() {
var bRedraw = false;
var selection = worksheet.activeRange;
if ( selection ) {
for ( var i = 0; i < aObjects.length; i++ ) {
/*var boundsChecker = _this.getBoundsChecker(aObjects[i]);
var _w = boundsChecker.Bounds.max_x - boundsChecker.Bounds.min_x;
var _h = boundsChecker.Bounds.max_y - boundsChecker.Bounds.min_y;
overlayCtx.clearRect( mmToPt(boundsChecker.Bounds.min_x + pxToMm(scrollOffset.x)), mmToPt(boundsChecker.Bounds.min_y + pxToMm(scrollOffset.y)), mmToPt(_w), mmToPt(_h) );*/
var drawingObject = aObjects[i];
aObjects[i].graphicObject.draw(shapeOverlayCtx);
// Объекты не пересекаются
if ( (selection.c2 < drawingObject.from.col) || (selection.c1 > drawingObject.to.col) || (selection.r2 < drawingObject.from.row) || (selection.r1 > drawingObject.to.row) )
continue;
else {
bRedraw = true;
break;
}
}
}
if ( bRedraw ) {
for ( var i = 0; i < aObjects.length; i++ ) {
var boundsChecker = _this.getBoundsChecker(aObjects[i]);
restoreSheetArea(boundsChecker);
}
for ( var i = 0; i < aObjects.length; i++ ) {
aObjects[i].graphicObject.draw(shapeCtx);
}
}
if ( aObjects.length )
_this.drawWorksheetHeaders();
}
......@@ -3175,8 +3193,7 @@ function DrawingObjects() {
if ( clearCanvas )
_this.clearDrawingObjects();
if ( !aObjects.length )
return;
if ( aObjects.length ) {
worksheet._drawGraphic();
worksheet.model.Drawings = aObjects;
......@@ -3184,27 +3201,35 @@ function DrawingObjects() {
for (var i = 0; i < aObjects.length; i++) {
var index = i;
var obj = aObjects[i];
var drawingObject = aObjects[i];
if ( !obj.inVisibleArea() )
if ( !drawingObject.inVisibleArea() )
continue;
if ( !obj.flags.anchorUpdated )
obj.updateAnchorPosition();
if ( !drawingObject.flags.anchorUpdated )
drawingObject.updateAnchorPosition();
// Shape render
if ( obj.isGraphicObject() ) {
obj.graphicObject.draw( printOptions ? printOptions.ctx.DocumentRenderer : shapeCtx);
if ( drawingObject.isGraphicObject() ) {
drawingObject.graphicObject.draw( printOptions ? printOptions.ctx.DocumentRenderer : shapeCtx );
continue;
}
}
}
}
if ( !printOptions ) {
if ( aObjects.length ) {
if ( _this.controller.selectedObjects.length )
_this.OnUpdateOverlay();
else
_this.raiseLayerDrawingObjects();
}
else {
worksheet.cleanSelection();
worksheet._drawSelection();
}
_this.drawWorksheetHeaders();
}
......@@ -3330,7 +3355,6 @@ function DrawingObjects() {
worksheet.model.workbook.handlers.trigger("asc_onError", c_oAscError.ID.UplImageUrl, c_oAscError.Level.NoCritical);
}
else {
History.Create_NewPoint();
var obj = _this.createDrawingObject();
obj.worksheet = worksheet;
......@@ -3363,20 +3387,8 @@ function DrawingObjects() {
obj.graphicObject = new CImageShape(obj, _this);
obj.graphicObject.initDefault( x, y, w, h, _image.src );
obj.graphicObject.select(_this.controller);
aObjects.push(obj);
obj.setGraphicObjectCoords();
obj.setActive();
_this.showDrawingObjects(false);
_this.sendGraphicObjectProps();
var boundsChecker = _this.getBoundsChecker(obj);
aBoundsCheckers.push(boundsChecker);
_this.objectLocker.reset();
_this.objectLocker.addObjectId(obj.id);
_this.objectLocker.checkObjects( function(result){ return result; } );
obj.graphicObject.addToDrawingObjects();
}
worksheet.model.workbook.handlers.trigger("asc_onEndAction", c_oAscAsyncActionType.BlockInteraction, c_oAscAsyncAction.LoadImage);
......@@ -3451,7 +3463,6 @@ function DrawingObjects() {
chart.rebuildSeries();
chart.worksheet = worksheet; // Для формул серий
History.Create_NewPoint();
return this.controller.addChartDrawingObject(chart, options);
}
else if ( isObject(chart) && chart["binary"] ) {
......
......@@ -1493,6 +1493,11 @@ CChartAsGroup.prototype =
{
this.drawingObjects.deleteDrawingBase(this.Id);
break;
}
case historyitem_AutoShapes_DeleteDrawingBase:
{
this.drawingObjects.addGraphicObject(this, data.oldValue);
break;
}
}
},
......@@ -1506,11 +1511,15 @@ CChartAsGroup.prototype =
this.recalculate();
break;
}
case historyitem_AutoShapes_Add_To_Drawing_Objects:
{
this.drawingObjects.addGraphicObject(this, data.oldValue);
break;
}
case historyitem_AutoShapes_DeleteDrawingBase:
{
this.drawingObjects.deleteDrawingBase(this.Id);
break;
}
}
},
......
......@@ -1057,6 +1057,16 @@ CImageShape.prototype =
this.calculateContent();
this.calculateTransformTextMatrix();
break;
}
case historyitem_AutoShapes_Add_To_Drawing_Objects:
{
this.drawingObjects.deleteDrawingBase(this.Id);
break;
}
case historyitem_AutoShapes_DeleteDrawingBase:
{
this.drawingObjects.addGraphicObject(this, data.oldValue);
break;
}
}
},
......@@ -1071,6 +1081,16 @@ CImageShape.prototype =
this.calculateContent();
this.calculateTransformTextMatrix();
break;
}
case historyitem_AutoShapes_Add_To_Drawing_Objects:
{
this.drawingObjects.addGraphicObject(this, data.oldValue);
break;
}
case historyitem_AutoShapes_DeleteDrawingBase:
{
this.drawingObjects.deleteDrawingBase(this.Id);
break;
}
}
},
......
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