Commit 027786c4 authored by Oleg.Korshul's avatar Oleg.Korshul Committed by Alexander.Trofimov

переделан селект. баги

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@61556 954022d7-b5bf-4e40-9824-e11837661b57
parent dae6e9ea
...@@ -1498,6 +1498,8 @@ CDrawingDocument.prototype = ...@@ -1498,6 +1498,8 @@ CDrawingDocument.prototype =
this.SelectDrag = 1; this.SelectDrag = 1;
this.LogicDocument.Cursor_MoveRight(); this.LogicDocument.Cursor_MoveRight();
/*
это старая версия. грамотная реализация - моус даун и ап с шифтом. Так и проще и правильнее
var _xDown = this.SelectRect2.X + this.SelectRect2.W; var _xDown = this.SelectRect2.X + this.SelectRect2.W;
var _yDown = this.SelectRect2.Y + this.SelectRect2.H / 2; var _yDown = this.SelectRect2.Y + this.SelectRect2.H / 2;
if (!this.TextMatrix) if (!this.TextMatrix)
...@@ -1525,6 +1527,31 @@ CDrawingDocument.prototype = ...@@ -1525,6 +1527,31 @@ CDrawingDocument.prototype =
this.SelectMobileYOffset = (ret.Y + ret2.Y) - global_mouseEvent.Y; this.SelectMobileYOffset = (ret.Y + ret2.Y) - global_mouseEvent.Y;
this.OnMouseMove(e); this.OnMouseMove(e);
*/
var _xStamp = this.SelectRect1.X;
var _yStamp = this.SelectRect1.Y;
if (this.TextMatrix)
{
_xStamp = this.TextMatrix.TransformPointX(this.SelectRect1.X, this.SelectRect1.Y);
_yStamp = this.TextMatrix.TransformPointY(this.SelectRect1.X, this.SelectRect1.Y);
}
var ret = this.__DD_ConvertCoordsToCursor(_xStamp, _yStamp, this.SelectRect1.Page);
var ret2 = this.CorrectMouseSelectPosition(Math.min(this.SelectMobileConstantOffsetEpsilon, this.SelectRect1.H / 2));
this.SelectMobileXOffset = (ret.X + ret2.X) - global_mouseEvent.X;
this.SelectMobileYOffset = (ret.Y + ret2.Y) - global_mouseEvent.Y;
var pos = this.GetMouseMoveCoords();
if (pos.Page == -1)
return;
var _oldShift = global_mouseEvent.ShiftKey;
global_mouseEvent.ShiftKey = true;
this.LogicDocumentOnMouseDown(global_mouseEvent, pos.X, pos.Y, pos.Page);
this.LogicDocumentOnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page);
global_mouseEvent.ShiftKey = _oldShift;
this.SelectClearLock = false; this.SelectClearLock = false;
} }
...@@ -1534,6 +1561,8 @@ CDrawingDocument.prototype = ...@@ -1534,6 +1561,8 @@ CDrawingDocument.prototype =
this.SelectDrag = 2; this.SelectDrag = 2;
this.LogicDocument.Cursor_MoveLeft(); this.LogicDocument.Cursor_MoveLeft();
/*
это старая версия. грамотная реализация - моус даун и ап с шифтом. Так и проще и правильнее
var _xDown = this.SelectRect1.X; var _xDown = this.SelectRect1.X;
var _yDown = this.SelectRect1.Y + this.SelectRect1.H / 2; var _yDown = this.SelectRect1.Y + this.SelectRect1.H / 2;
if (!this.TextMatrix) if (!this.TextMatrix)
...@@ -1562,6 +1591,32 @@ CDrawingDocument.prototype = ...@@ -1562,6 +1591,32 @@ CDrawingDocument.prototype =
this.SelectMobileYOffset = (ret.Y - ret2.Y) - global_mouseEvent.Y; this.SelectMobileYOffset = (ret.Y - ret2.Y) - global_mouseEvent.Y;
this.OnMouseMove(e); this.OnMouseMove(e);
*/
var _xStamp = this.SelectRect2.X + this.SelectRect2.W;
var _yStamp = this.SelectRect2.Y + this.SelectRect2.H;
if (this.TextMatrix)
{
var _xTmp = _xStamp;
_xStamp = this.TextMatrix.TransformPointX(_xTmp, _yStamp);
_yStamp = this.TextMatrix.TransformPointY(_xTmp, _yStamp);
}
var ret = this.__DD_ConvertCoordsToCursor(_xStamp, _yStamp, this.SelectRect2.Page);
var ret2 = this.CorrectMouseSelectPosition(Math.min(this.SelectMobileConstantOffsetEpsilon, this.SelectRect2.H / 2));
this.SelectMobileXOffset = (ret.X - ret2.X) - global_mouseEvent.X;
this.SelectMobileYOffset = (ret.Y - ret2.Y) - global_mouseEvent.Y;
var pos = this.GetMouseMoveCoords();
if (pos.Page == -1)
return;
var _oldShift = global_mouseEvent.ShiftKey;
global_mouseEvent.ShiftKey = true;
this.LogicDocumentOnMouseDown(global_mouseEvent, pos.X, pos.Y, pos.Page);
this.LogicDocumentOnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page);
global_mouseEvent.ShiftKey = _oldShift;
this.SelectClearLock = false; this.SelectClearLock = false;
} }
...@@ -1652,19 +1707,14 @@ CDrawingDocument.prototype = ...@@ -1652,19 +1707,14 @@ CDrawingDocument.prototype =
{ {
check_MouseUpEvent(e); check_MouseUpEvent(e);
var pos = this.GetMouseMoveCoords();
var _is_select = false;
if (this.SelectDrag == 1 || this.SelectDrag == 2) if (this.SelectDrag == 1 || this.SelectDrag == 2)
{ {
global_mouseEvent.X += this.SelectMobileXOffset; _is_select = true;
global_mouseEvent.Y += this.SelectMobileYOffset;
} }
this.SelectDrag = -1; this.SelectDrag = -1;
var pos = null;
if (this.AutoShapesTrackLockPageNum == -1)
pos = this.__DD_ConvertCoordsFromCursor(global_mouseEvent.X, global_mouseEvent.Y);
else
pos = this.__DD_ConvetToPageCoords(global_mouseEvent.X, global_mouseEvent.Y, this.AutoShapesTrackLockPageNum);
if (pos.Page == -1) if (pos.Page == -1)
return this.CheckReturnMouseUp(); return this.CheckReturnMouseUp();
...@@ -1693,7 +1743,18 @@ CDrawingDocument.prototype = ...@@ -1693,7 +1743,18 @@ CDrawingDocument.prototype =
this.Native["DD_NeedScrollToTargetFlag"](true); this.Native["DD_NeedScrollToTargetFlag"](true);
this.LogicDocumentOnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page); if (_is_select)
{
var _oldShift = global_mouseEvent.ShiftKey;
global_mouseEvent.ShiftKey = true;
this.LogicDocumentOnMouseDown(global_mouseEvent, pos.X, pos.Y, pos.Page);
this.LogicDocumentOnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page);
global_mouseEvent.ShiftKey = _oldShift;
}
else
{
this.LogicDocumentOnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page);
}
this.Native["DD_NeedScrollToTargetFlag"](false); this.Native["DD_NeedScrollToTargetFlag"](false);
this.Native.m_bIsMouseUpSend = false; this.Native.m_bIsMouseUpSend = false;
...@@ -1708,18 +1769,7 @@ CDrawingDocument.prototype = ...@@ -1708,18 +1769,7 @@ CDrawingDocument.prototype =
{ {
check_MouseMoveEvent(e); check_MouseMoveEvent(e);
if (this.SelectDrag == 1 || this.SelectDrag == 2) var pos = this.GetMouseMoveCoords();
{
global_mouseEvent.X += this.SelectMobileXOffset;
global_mouseEvent.Y += this.SelectMobileYOffset;
}
var pos = null;
if (this.AutoShapesTrackLockPageNum == -1)
pos = this.__DD_ConvertCoordsFromCursor(global_mouseEvent.X, global_mouseEvent.Y);
else
pos = this.__DD_ConvetToPageCoords(global_mouseEvent.X, global_mouseEvent.Y, this.AutoShapesTrackLockPageNum);
if (pos.Page == -1) if (pos.Page == -1)
return; return;
...@@ -1741,7 +1791,21 @@ CDrawingDocument.prototype = ...@@ -1741,7 +1791,21 @@ CDrawingDocument.prototype =
return; return;
this.TableOutlineDr.bIsNoTable = true; this.TableOutlineDr.bIsNoTable = true;
this.LogicDocument.OnMouseMove(global_mouseEvent, pos.X, pos.Y, pos.Page);
if (this.SelectDrag == 1 || this.SelectDrag == 2)
{
this.SelectClearLock = true;
var _oldShift = global_mouseEvent.ShiftKey;
global_mouseEvent.ShiftKey = true;
this.LogicDocumentOnMouseDown(global_mouseEvent, pos.X, pos.Y, pos.Page);
this.LogicDocumentOnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page);
global_mouseEvent.ShiftKey = _oldShift;
this.SelectClearLock = false;
}
else
{
this.LogicDocument.OnMouseMove(global_mouseEvent, pos.X, pos.Y, pos.Page);
}
if (this.TableOutlineDr.bIsNoTable === false) if (this.TableOutlineDr.bIsNoTable === false)
{ {
...@@ -1752,6 +1816,23 @@ CDrawingDocument.prototype = ...@@ -1752,6 +1816,23 @@ CDrawingDocument.prototype =
this.EndUpdateOverlay(); this.EndUpdateOverlay();
}, },
GetMouseMoveCoords : function()
{
if (this.SelectDrag == 1 || this.SelectDrag == 2)
{
global_mouseEvent.X += this.SelectMobileXOffset;
global_mouseEvent.Y += this.SelectMobileYOffset;
}
var pos = null;
if (this.AutoShapesTrackLockPageNum == -1)
pos = this.__DD_ConvertCoordsFromCursor(global_mouseEvent.X, global_mouseEvent.Y);
else
pos = this.__DD_ConvetToPageCoords(global_mouseEvent.X, global_mouseEvent.Y, this.AutoShapesTrackLockPageNum);
return pos;
},
CorrectMouseSelectPosition : function(eps) CorrectMouseSelectPosition : function(eps)
{ {
var xOff = 0; var xOff = 0;
......
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