Commit e41424ef authored by Alexander.Trofimov's avatar Alexander.Trofimov Committed by Alexander.Trofimov

Переделал получение merge ячеек для border-ов.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@59840 954022d7-b5bf-4e40-9824-e11837661b57
parent 8622c395
...@@ -2263,8 +2263,8 @@ ...@@ -2263,8 +2263,8 @@
.clip(); .clip();
} }
this._drawCells(drawingCtx, range, offsetX, offsetY); var mergedCells = this._drawCells(drawingCtx, range, offsetX, offsetY);
this._drawCellsBorders(drawingCtx, range, offsetX, offsetY); this._drawCellsBorders(drawingCtx, range, offsetX, offsetY, mergedCells);
if (!drawingCtx) { if (!drawingCtx) {
// restore canvas' original clipping range // restore canvas' original clipping range
...@@ -2279,8 +2279,8 @@ ...@@ -2279,8 +2279,8 @@
var mergedCells = {}, mc, i; var mergedCells = {}, mc, i;
for (var row = range.r1; row <= range.r2; ++row) { for (var row = range.r1; row <= range.r2; ++row) {
$.extend( mergedCells, $.extend( mergedCells,
this._drawRowBG(drawingCtx, row, range.c1, range.c2, offsetX, offsetY, null), this._drawRowBG(drawingCtx, row, range.c1, range.c2, offsetX, offsetY, null),
this._drawRowText(drawingCtx, row, range.c1, range.c2, offsetX, offsetY) ); this._drawRowText(drawingCtx, row, range.c1, range.c2, offsetX, offsetY) );
} }
// draw merged cells at last stage to fix cells background issue // draw merged cells at last stage to fix cells background issue
for (i in mergedCells) { for (i in mergedCells) {
...@@ -2288,6 +2288,7 @@ ...@@ -2288,6 +2288,7 @@
this._drawRowBG(drawingCtx, mc.r1, mc.c1, mc.c1, offsetX, offsetY, mc); this._drawRowBG(drawingCtx, mc.r1, mc.c1, mc.c1, offsetX, offsetY, mc);
this._drawCellText(drawingCtx, mc.c1, mc.r1, range.c1, range.c2, offsetX, offsetY, true); this._drawCellText(drawingCtx, mc.c1, mc.r1, range.c1, range.c2, offsetX, offsetY, true);
} }
return mergedCells;
}; };
/** Рисует фон ячеек в строке */ /** Рисует фон ячеек в строке */
...@@ -2633,47 +2634,25 @@ ...@@ -2633,47 +2634,25 @@
}; };
/** Рисует рамки для ячеек */ /** Рисует рамки для ячеек */
WorksheetView.prototype._drawCellsBorders = function (drawingCtx, range, offsetX, offsetY) { WorksheetView.prototype._drawCellsBorders = function (drawingCtx, range, offsetX, offsetY, mergedCells) {
// ToDo убрать эту проверку (есть в функции выше!)
if (range === undefined) {
range = this.visibleRange;
} else {
// Если пришел диапазон не всего экрана, то нужно учитывать merge для бордеров
// ToDo возможно стоит оптимизировать, если будет тормозить
range = range.clone(true);
this._fixSelectionOfMergedCells(range);
// ToDo убрать это и переделать!!!
range.normalize();
// ToDo Точно нужно с этим разобраться!!!
range = range.intersectionSimple(this.visibleRange);
if (null === range)
return;
}
//TODO: использовать стили линий при рисовании границ //TODO: использовать стили линий при рисовании границ
var t = this; var t = this;
var ctx = (drawingCtx) ? drawingCtx : this.drawingCtx; var ctx = (drawingCtx) ? drawingCtx : this.drawingCtx;
var c = this.cols; var c = this.cols;
var r = this.rows; var r = this.rows;
var mergedCells = this.model.getMergedByRange(range);
var objectMergedCells = {}; // Двумерный map вида строка-колонка {1: {1: range, 4: range}} var objectMergedCells = {}; // Двумерный map вида строка-колонка {1: {1: range, 4: range}}
var i, length, arrMerged, mergeElem, col, row; var i, mergeCellInfo, startCol, endRow, endCol, col, row;
for (i = 0, arrMerged = mergedCells.inner, length = arrMerged.length; i < length; ++i) { for (i in mergedCells) {
for (mergeElem = arrMerged[i].bbox, row = mergeElem.r1; mergeCellInfo = mergedCells[i];
row <= mergeElem.r2 && row < this.nRowsCount; ++row) { startCol = Math.max(range.c1, mergeCellInfo.c1);
if (!objectMergedCells.hasOwnProperty(row)) endRow = Math.min(mergeCellInfo.r2, range.r2, this.nRowsCount);
objectMergedCells[row] = {}; endCol = Math.min(mergeCellInfo.c2, range.c2, this.nColsCount);
for (col = mergeElem.c1; col <= mergeElem.c2 && col < this.nColsCount; ++col) for (row = Math.max(range.r1, mergeCellInfo.r1); row <= endRow; ++row) {
objectMergedCells[row][col] = arrMerged[i].bbox;
}
}
for (i = 0, arrMerged = mergedCells.outer, length = arrMerged.length; i < length; ++i) {
for (mergeElem = range.intersectionSimple(arrMerged[i].bbox), row = mergeElem.r1;
row <= mergeElem.r2 && row < this.nRowsCount; ++row) {
if (!objectMergedCells.hasOwnProperty(row)) if (!objectMergedCells.hasOwnProperty(row))
objectMergedCells[row] = {}; objectMergedCells[row] = {};
for (col = mergeElem.c1; col <= mergeElem.c2 && col < this.nColsCount; ++col) for (col = startCol; col <= endCol; ++col)
objectMergedCells[row][col] = arrMerged[i].bbox; objectMergedCells[row][col] = mergeCellInfo;
} }
} }
......
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