Commit 625f2168 authored by Alexander.Trofimov's avatar Alexander.Trofimov Committed by Alexander.Trofimov

Поправил баг http://bugzserver/show_bug.cgi?id=25750

Поправил проблему с наведением на подсветку в формуле (или диаграмме) в закрепленной области.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@57672 954022d7-b5bf-4e40-9824-e11837661b57
parent bef50ca6
...@@ -5631,19 +5631,17 @@ ...@@ -5631,19 +5631,17 @@
WorksheetView.prototype._getCursorFormulaOrChart = function (x, y, offsetX, offsetY) { WorksheetView.prototype._getCursorFormulaOrChart = function (x, y, offsetX, offsetY) {
var i; var i;
if (this.isFormulaEditMode || this.isChartAreaEditMode) { if (this.isFormulaEditMode || this.isChartAreaEditMode) {
var cursor, oFormulaRange, oFormulaIn, xFormula1, xFormula2, yFormula1, yFormula2; var cursor, oFormulaRange, xFormula1, xFormula2, yFormula1, yFormula2;
var col = -1, row = -1; var col = -1, row = -1;
var arrRanges = this.isFormulaEditMode ? this.arrActiveFormulaRanges : this.arrActiveChartsRanges, var arrRanges = this.isFormulaEditMode ? this.arrActiveFormulaRanges : this.arrActiveChartsRanges,
targetArr = this.isFormulaEditMode ? 0 : -1; targetArr = this.isFormulaEditMode ? 0 : -1;
for (i in arrRanges) { for (i in arrRanges) {
oFormulaRange = arrRanges[i].clone(true); oFormulaRange = arrRanges[i].clone(true);
oFormulaIn = oFormulaRange.intersection(this.visibleRange); xFormula1 = this.cols[oFormulaRange.c1].left - offsetX;
if (oFormulaIn) { xFormula2 = this.cols[oFormulaRange.c2].left + this.cols[oFormulaRange.c2].width - offsetX;
xFormula1 = this.cols[oFormulaIn.c1].left - offsetX; yFormula1 = this.rows[oFormulaRange.r1].top - offsetY;
xFormula2 = this.cols[oFormulaIn.c2].left + this.cols[oFormulaIn.c2].width - offsetX; yFormula2 = this.rows[oFormulaRange.r2].top + this.rows[oFormulaRange.r2].height - offsetY;
yFormula1 = this.rows[oFormulaIn.r1].top - offsetY;
yFormula2 = this.rows[oFormulaIn.r2].top + this.rows[oFormulaIn.r2].height - offsetY;
if ( if (
(x >= xFormula1 + 5 && x <= xFormula2 - 5) && ((y >= yFormula1 - this.height_2px && y <= yFormula1 + this.height_2px) || (y >= yFormula2 - this.height_2px && y <= yFormula2 + this.height_2px)) (x >= xFormula1 + 5 && x <= xFormula2 - 5) && ((y >= yFormula1 - this.height_2px && y <= yFormula1 + this.height_2px) || (y >= yFormula2 - this.height_2px && y <= yFormula2 + this.height_2px))
...@@ -5654,27 +5652,26 @@ ...@@ -5654,27 +5652,26 @@
break; break;
} else if( x >= xFormula1 && x < xFormula1 + 5 && y >= yFormula1 && y < yFormula1 + 5 ){ } else if( x >= xFormula1 && x < xFormula1 + 5 && y >= yFormula1 && y < yFormula1 + 5 ){
cursor = kCurSEResize; cursor = kCurSEResize;
col = oFormulaIn.c2; col = oFormulaRange.c2;
row = oFormulaIn.r2; row = oFormulaRange.r2;
break; break;
} else if ( x > xFormula2 - 5 && x <= xFormula2 && y > yFormula2 - 5 && y <= yFormula2 ){ } else if ( x > xFormula2 - 5 && x <= xFormula2 && y > yFormula2 - 5 && y <= yFormula2 ){
cursor = kCurSEResize; cursor = kCurSEResize;
col = oFormulaIn.c1; col = oFormulaRange.c1;
row = oFormulaIn.r1; row = oFormulaRange.r1;
break; break;
} else if( x > xFormula2 - 5 && x <= xFormula2 && y >= yFormula1 && y < yFormula1 + 5 ){ } else if( x > xFormula2 - 5 && x <= xFormula2 && y >= yFormula1 && y < yFormula1 + 5 ){
cursor = kCurNEResize; cursor = kCurNEResize;
col = oFormulaIn.c1; col = oFormulaRange.c1;
row = oFormulaIn.r2; row = oFormulaRange.r2;
break; break;
} else if( x >= xFormula1 && x < xFormula1 + 5 && y > yFormula2 - 5 && y <= yFormula2 ){ } else if( x >= xFormula1 && x < xFormula1 + 5 && y > yFormula2 - 5 && y <= yFormula2 ){
cursor = kCurNEResize; cursor = kCurNEResize;
col = oFormulaIn.c2; col = oFormulaRange.c2;
row = oFormulaIn.r1; row = oFormulaRange.r1;
break; break;
} }
} }
}
if (cursor) { if (cursor) {
return {cursor: cursor, target: c_oTargetType.MoveResizeRange, col: col, row: row, return {cursor: cursor, target: c_oTargetType.MoveResizeRange, col: col, row: row,
formulaRange: oFormulaRange, indexFormulaRange: i, targetArr: targetArr}; formulaRange: oFormulaRange, indexFormulaRange: i, targetArr: targetArr};
...@@ -5793,12 +5790,9 @@ ...@@ -5793,12 +5790,9 @@
rFrozen = this.topLeftFrozenCell.getRow0(); rFrozen = this.topLeftFrozenCell.getRow0();
widthDiff = this.cols[cFrozen].left - this.cols[0].left; widthDiff = this.cols[cFrozen].left - this.cols[0].left;
heightDiff = this.rows[rFrozen].top - this.rows[0].top; heightDiff = this.rows[rFrozen].top - this.rows[0].top;
if (x < this.cellsLeft + widthDiff)
widthDiff = 0; offsetX = (x < this.cellsLeft + widthDiff) ? 0 : offsetX - widthDiff;
if (y < this.cellsTop + heightDiff) offsetY = (y < this.cellsTop + heightDiff) ? 0 : offsetY - heightDiff;
heightDiff = 0;
offsetX -= widthDiff;
offsetY -= heightDiff;
} }
if (x <= this.cellsLeft && y >= this.cellsTop) { if (x <= this.cellsLeft && y >= this.cellsTop) {
...@@ -5914,8 +5908,8 @@ ...@@ -5914,8 +5908,8 @@
lockRangePosLeft = this.getCellLeft(c1Recalc, /*pt*/1); lockRangePosLeft = this.getCellLeft(c1Recalc, /*pt*/1);
lockRangePosTop = this.getCellTop(r1Recalc, /*pt*/1); lockRangePosTop = this.getCellTop(r1Recalc, /*pt*/1);
// Пересчитываем X и Y относительно видимой области // Пересчитываем X и Y относительно видимой области
lockRangePosLeft -= (this.cols[this.visibleRange.c1].left - this.cellsLeft); lockRangePosLeft -= offsetX;
lockRangePosTop -= (this.rows[this.visibleRange.r1].top - this.cellsTop); lockRangePosTop -= offsetY;
// Пересчитываем в px // Пересчитываем в px
lockRangePosLeft *= asc_getcvt(1/*pt*/, 0/*px*/, this._getPPIX()); lockRangePosLeft *= asc_getcvt(1/*pt*/, 0/*px*/, this._getPPIX());
lockRangePosTop *= asc_getcvt(1/*pt*/, 0/*px*/, this._getPPIY()); lockRangePosTop *= asc_getcvt(1/*pt*/, 0/*px*/, this._getPPIY());
......
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