Commit 13d08417 authored by Alexander.Trofimov's avatar Alexander.Trofimov

getDrawingAreaMetrics -> getMaxColRow

parent 50e955f7
...@@ -1379,8 +1379,8 @@ ...@@ -1379,8 +1379,8 @@
WorksheetView.prototype._calcWidthColumns = function (fullRecalc) { WorksheetView.prototype._calcWidthColumns = function (fullRecalc) {
var x = this.cellsLeft; var x = this.cellsLeft;
var visibleW = this.drawingCtx.getWidth(); var visibleW = this.drawingCtx.getWidth();
var obr = this.objectRender ? this.objectRender.getDrawingAreaMetrics() : {maxCol: 0, maxRow: 0}; var maxColObjects = this.objectRender ? this.objectRender.getMaxColRow().col : -1;
var l = Math.max(this.model.getColsCount() + 1, this.nColsCount, obr.maxCol); var l = Math.max(this.model.getColsCount() + 1, this.nColsCount, maxColObjects);
var i = 0, w, column, isBestFit, hiddenW = 0; var i = 0, w, column, isBestFit, hiddenW = 0;
// Берем дефалтовую ширину документа // Берем дефалтовую ширину документа
...@@ -1423,8 +1423,8 @@ ...@@ -1423,8 +1423,8 @@
WorksheetView.prototype._calcHeightRows = function (fullRecalc) { WorksheetView.prototype._calcHeightRows = function (fullRecalc) {
var y = this.cellsTop; var y = this.cellsTop;
var visibleH = this.drawingCtx.getHeight(); var visibleH = this.drawingCtx.getHeight();
var obr = this.objectRender ? this.objectRender.getDrawingAreaMetrics() : {maxCol: 0, maxRow: 0}; var maxRowObjects = this.objectRender ? this.objectRender.getMaxColRow().row : -1;
var l = Math.max(this.model.getRowsCount() + 1, this.nRowsCount, obr.maxRow); var l = Math.max(this.model.getRowsCount() + 1, this.nRowsCount, maxRowObjects);
var defaultH = this.defaultRowHeight; var defaultH = this.defaultRowHeight;
var i = 0, h, hR, isCustomHeight, row, hiddenH = 0; var i = 0, h, hR, isCustomHeight, row, hiddenH = 0;
...@@ -1701,11 +1701,10 @@ ...@@ -1701,11 +1701,10 @@
maxRows = lastR + 1; maxRows = lastR + 1;
// Получаем максимальную колонку/строку для изображений/чатов // Получаем максимальную колонку/строку для изображений/чатов
maxCell = this.objectRender.getDrawingAreaMetrics(); maxCell = this.objectRender.getMaxColRow();
if (maxCell) { maxCols = Math.max(maxCols, maxCell.col);
maxCols = Math.max(maxCols, maxCell.maxCol); maxRows = Math.max(maxRows, maxCell.row);
maxRows = Math.max(maxRows, maxCell.maxRow);
}
} else { } else {
maxCols = selectionRange.c2 + 1; maxCols = selectionRange.c2 + 1;
maxRows = selectionRange.r2 + 1; maxRows = selectionRange.r2 + 1;
...@@ -5308,7 +5307,7 @@ ...@@ -5308,7 +5307,7 @@
} }
function findEOT() { function findEOT() {
var obr = t.objectRender ? t.objectRender.getDrawingAreaMetrics() : {maxCol: 0, maxRow: 0}; var obr = t.objectRender ? t.objectRender.getMaxColRow() : new AscCommon.CellBase(-1, -1);
var maxCols = t.model.getColsCount(); var maxCols = t.model.getColsCount();
var maxRows = t.model.getRowsCount(); var maxRows = t.model.getRowsCount();
var lastC = -1, lastR = -1; var lastC = -1, lastR = -1;
...@@ -5321,7 +5320,7 @@ ...@@ -5321,7 +5320,7 @@
} }
} }
} }
return {col: Math.max(lastC, obr.maxCol), row: Math.max(lastR, obr.maxRow)}; return {col: Math.max(lastC, obr.col), row: Math.max(lastR, obr.row)};
} }
var eot = dc > +2.0001 && dc < +2.9999 && dr > +2.0001 && dr < +2.9999 ? findEOT() : null; var eot = dc > +2.0001 && dc < +2.9999 && dr > +2.0001 && dr < +2.9999 ? findEOT() : null;
...@@ -10166,8 +10165,8 @@ ...@@ -10166,8 +10165,8 @@
}; };
WorksheetView.prototype.expandColsOnScroll = function (isNotActive, updateColsCount, newColsCount) { WorksheetView.prototype.expandColsOnScroll = function (isNotActive, updateColsCount, newColsCount) {
var obr = this.objectRender ? this.objectRender.getDrawingAreaMetrics() : {maxCol: 0, maxRow: 0}; var maxColObjects = this.objectRender ? this.objectRender.getMaxColRow().col : -1;
var maxc = Math.max(this.model.getColsCount() + 1, this.cols.length, obr.maxCol); var maxc = Math.max(this.model.getColsCount() + 1, this.cols.length, maxColObjects);
if (newColsCount) { if (newColsCount) {
maxc = Math.max(maxc, newColsCount); maxc = Math.max(maxc, newColsCount);
} }
...@@ -10197,8 +10196,8 @@ ...@@ -10197,8 +10196,8 @@
}; };
WorksheetView.prototype.expandRowsOnScroll = function (isNotActive, updateRowsCount, newRowsCount) { WorksheetView.prototype.expandRowsOnScroll = function (isNotActive, updateRowsCount, newRowsCount) {
var obr = this.objectRender ? this.objectRender.getDrawingAreaMetrics() : {maxCol: 0, maxRow: 0}; var maxRowObjects = this.objectRender ? this.objectRender.getMaxColRow().row : -1;
var maxr = Math.max(this.model.getRowsCount() + 1, this.rows.length, obr.maxRow); var maxr = Math.max(this.model.getRowsCount() + 1, this.rows.length, maxRowObjects);
if (newRowsCount) { if (newRowsCount) {
maxr = Math.max(maxr, newRowsCount); maxr = Math.max(maxr, newRowsCount);
} }
......
...@@ -2189,26 +2189,14 @@ function DrawingObjects() { ...@@ -2189,26 +2189,14 @@ function DrawingObjects() {
} }
}; };
_this.getDrawingAreaMetrics = function() { _this.getMaxColRow = function() {
var r = -1, c = -1;
/* aObjects.forEach(function (item) {
* Объект, определяющий max колонку и строчку для отрисовки объектов листа r = Math.max(r, item.to.row + 1);
*/ c = Math.max(c, item.to.col + 1);
});
var metrics = {
maxCol: 0,
maxRow: 0
};
for (var i = 0; aObjects && (i < aObjects.length); i++) {
var drawingObject = aObjects[i]; return new AscCommon.CellBase(r, c);
if ( drawingObject.to.col >= metrics.maxCol )
metrics.maxCol = drawingObject.to.col + 1; // учитываем colOff
if ( drawingObject.to.row >= metrics.maxRow )
metrics.maxRow = drawingObject.to.row + 1; // учитываем rowOff
}
return metrics;
}; };
_this.clipGraphicsCanvas = function(canvas, graphicOption) { _this.clipGraphicsCanvas = function(canvas, graphicOption) {
......
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