Commit 5a8eb389 authored by Oleg Korshul's avatar Oleg Korshul

developing...

parent 046e616d
...@@ -756,6 +756,7 @@ function (window, undefined) ...@@ -756,6 +756,7 @@ function (window, undefined)
} }
var isCheckContextMenuMode = true; var isCheckContextMenuMode = true;
var isCheckContextMenuSelect = false;
var isPreventDefault = false; var isPreventDefault = false;
switch (this.Mode) switch (this.Mode)
...@@ -833,6 +834,7 @@ function (window, undefined) ...@@ -833,6 +834,7 @@ function (window, undefined)
this.Mode = AscCommon.MobileTouchMode.None; this.Mode = AscCommon.MobileTouchMode.None;
this.delegate.Drawing_OnMouseUp(_e); this.delegate.Drawing_OnMouseUp(_e);
//AscCommon.stopEvent(e); //AscCommon.stopEvent(e);
isCheckContextMenuSelect = true;
break; break;
} }
default: default:
...@@ -843,7 +845,7 @@ function (window, undefined) ...@@ -843,7 +845,7 @@ function (window, undefined)
AscCommon.g_inputContext.preventVirtualKeyboard(e); AscCommon.g_inputContext.preventVirtualKeyboard(e);
if (true !== this.iScroll.isAnimating) if (true !== this.iScroll.isAnimating)
this.CheckContextMenuTouchEnd(isCheckContextMenuMode); this.CheckContextMenuTouchEnd(isCheckContextMenuMode, isCheckContextMenuSelect);
return false; return false;
}; };
......
...@@ -1030,7 +1030,7 @@ ...@@ -1030,7 +1030,7 @@
}, 500); }, 500);
}; };
CMobileTouchManagerBase.prototype.CheckContextMenuTouchEnd = function(isCheck) CMobileTouchManagerBase.prototype.CheckContextMenuTouchEnd = function(isCheck, isSelectTouch)
{ {
// isCheck: если пришли сюда после скролла или зума (или их анимации) - то не нужно проверять состояние редактора. // isCheck: если пришли сюда после скролла или зума (или их анимации) - то не нужно проверять состояние редактора.
// Нужно проверять последнее сохраненной состояние // Нужно проверять последнее сохраненной состояние
...@@ -1055,6 +1055,142 @@ ...@@ -1055,6 +1055,142 @@
this.SendShowContextMenu(); this.SendShowContextMenu();
}; };
CMobileTouchManagerBase.prototype.CheckContextMenuTouchEndNew = function(isCheck, isSelectTouch)
{
// isCheck: если пришли сюда после скролла или зума (или их анимации) - то не нужно проверять состояние редактора.
// Нужно проверять последнее сохраненной состояние
var isShowContextMenu = false;
var isSelectCell = false;
if (isCheck)
{
var oldLastInfo = this.ContextMenuLastInfo;
var oldLasdMode = this.ContextMenuLastMode;
this.ContextMenuLastMode = this.delegate.GetContextMenuType();
this.delagate.GetContextMenuInfo(this.ContextMenuLastInfo);
var _data1 = null;
var _data2 = null;
if (this.ContextMenuLastMode == oldLasdMode)
{
var isEqual = false;
switch (this.ContextMenuLastMode)
{
case AscCommon.MobileTouchContextMenuType.Target:
{
_data1 = this.ContextMenuLastInfo.targetPos;
_data2 = oldLastInfo.targetPos;
if (_data1 && _data2)
{
if (_data1.Page == _data1.Page &&
Math.abs(_data1.X - _data2.X) < 10 &&
Math.abs(_data1.Y - _data2.Y) < 10)
{
isEqual = true;
}
}
break;
}
case AscCommon.MobileTouchContextMenuType.Select:
{
_data1 = this.ContextMenuLastInfo.selectText;
_data2 = oldLastInfo.selectText;
if (_data1 && _data2)
{
if (_data1.Page1 == _data2.Page1 && _data1.Page2 == _data2.Page2 &&
Math.abs(_data1.X1 - _data2.X1) < 0.1 &&
Math.abs(_data1.Y1 - _data2.Y1) < 0.1 &&
Math.abs(_data1.X2 - _data2.X2) < 0.1 &&
Math.abs(_data1.Y2 - _data2.Y2) < 0.1)
{
isEqual = true;
}
}
else
{
_data1 = this.ContextMenuLastInfo.selectCell;
_data2 = oldLastInfo.selectCell;
if (_data1 && _data2)
{
isSelectCell = true;
if (Math.abs(_data1.X - _data2.X) < 0.1 &&
Math.abs(_data1.Y - _data2.Y) < 0.1 &&
Math.abs(_data1.W - _data2.W) < 0.1 &&
Math.abs(_data1.H - _data2.H) < 0.1)
{
isEqual = true;
}
}
}
break;
}
case AscCommon.MobileTouchContextMenuType.Object:
{
_data1 = this.ContextMenuLastInfo.objectBounds;
_data2 = oldLastInfo.objectBounds;
if (_data1 && _data2)
{
if (_data1.Page == _data2.Page &&
Math.abs(_data1.X - _data2.X) < 0.1 &&
Math.abs(_data1.Y - _data2.Y) < 0.1 &&
Math.abs(_data1.R - _data2.R) < 0.1 &&
Math.abs(_data1.B - _data2.B) < 0.1)
{
isEqual = true;
}
}
break;
}
case AscCommon.MobileTouchContextMenuType.Slide:
{
_data1 = this.ContextMenuLastInfo.objectSlideThumbnail;
_data2 = oldLastInfo.objectSlideThumbnail;
if (_data1 && _data2)
{
if (_data1.Slide == _data2.Slide)
isEqual = true;
}
else
{
isEqual = true;
}
break;
}
default:
break;
}
}
if (this.ContextMenuLastMode == oldLasdMode)
{
this.ContextMenuLastModeCounter++;
this.ContextMenuLastModeCounter &= 0x01;
}
else
{
this.ContextMenuLastModeCounter = 0;
}
}
else
{
}
if (this.ContextMenuLastMode > AscCommon.MobileTouchContextMenuType.None && 1 == this.ContextMenuLastModeCounter)
this.SendShowContextMenu();
};
CMobileTouchManagerBase.prototype.ClearContextMenu = function() CMobileTouchManagerBase.prototype.ClearContextMenu = function()
{ {
//this.ContextMenuLastMode = AscCommon.MobileTouchContextMenuType.None; //this.ContextMenuLastMode = AscCommon.MobileTouchContextMenuType.None;
......
...@@ -737,6 +737,7 @@ ...@@ -737,6 +737,7 @@
} }
var isCheckContextMenuMode = true; var isCheckContextMenuMode = true;
var isCheckContextMenuSelect = false;
var isPreventDefault = false; var isPreventDefault = false;
switch (this.Mode) switch (this.Mode)
...@@ -819,6 +820,7 @@ ...@@ -819,6 +820,7 @@
var pos = this.delegate.ConvertCoordsFromCursor(global_mouseEvent.X, global_mouseEvent.Y); var pos = this.delegate.ConvertCoordsFromCursor(global_mouseEvent.X, global_mouseEvent.Y);
this.delegate.Logic_OnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page); this.delegate.Logic_OnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page);
AscCommon.stopEvent(e); AscCommon.stopEvent(e);
isCheckContextMenuSelect = true;
break; break;
} }
case AscCommon.MobileTouchMode.TableMove: case AscCommon.MobileTouchMode.TableMove:
...@@ -928,7 +930,7 @@ ...@@ -928,7 +930,7 @@
AscCommon.g_inputContext.preventVirtualKeyboard(e); AscCommon.g_inputContext.preventVirtualKeyboard(e);
if (true !== this.iScroll.isAnimating) if (true !== this.iScroll.isAnimating)
this.CheckContextMenuTouchEnd(isCheckContextMenuMode); this.CheckContextMenuTouchEnd(isCheckContextMenuMode, isCheckContextMenuSelect);
return false; return false;
}; };
......
...@@ -458,6 +458,7 @@ ...@@ -458,6 +458,7 @@
} }
var isCheckContextMenuMode = true; var isCheckContextMenuMode = true;
var isCheckContextMenuSelect = false;
var isPreventDefault = false; var isPreventDefault = false;
switch (this.Mode) switch (this.Mode)
...@@ -540,6 +541,7 @@ ...@@ -540,6 +541,7 @@
var pos = this.delegate.ConvertCoordsFromCursor(global_mouseEvent.X, global_mouseEvent.Y); var pos = this.delegate.ConvertCoordsFromCursor(global_mouseEvent.X, global_mouseEvent.Y);
this.delegate.Logic_OnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page); this.delegate.Logic_OnMouseUp(global_mouseEvent, pos.X, pos.Y, pos.Page);
AscCommon.stopEvent(e); AscCommon.stopEvent(e);
isCheckContextMenuSelect = true;
break; break;
} }
case AscCommon.MobileTouchMode.TableMove: case AscCommon.MobileTouchMode.TableMove:
...@@ -649,7 +651,7 @@ ...@@ -649,7 +651,7 @@
AscCommon.g_inputContext.preventVirtualKeyboard(e); AscCommon.g_inputContext.preventVirtualKeyboard(e);
if (true !== this.iScroll.isAnimating) if (true !== this.iScroll.isAnimating)
this.CheckContextMenuTouchEnd(isCheckContextMenuMode); this.CheckContextMenuTouchEnd(isCheckContextMenuMode, isCheckContextMenuSelect);
return false; return false;
}; };
......
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