Commit a45a9e79 authored by Anna.Pavlova's avatar Anna.Pavlova Committed by Alexander.Trofimov

1. Поправила CreateElem для ParagraphContent (в связи с тем, что нужно учесть...

1. Поправила CreateElem для ParagraphContent (в связи с тем, что нужно учесть дефолтные настройки из settings и свойства прокинуть позднее при добавлении в формулу)
2. Поправила для степени с верхним/нижнем индексом расположение итератора ( для случая с верхним, чтобы не уезжал, когда основание текст, более правильное позиционирование, когда идет формула; для случая  нижнем итератором все итераторы выровнены по baseline, текст при этом в основании мб различный)
3. Gaps for "±"
4. Убрала gaps для argSize < 0

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@54298 954022d7-b5bf-4e40-9824-e11837661b57
parent ff9f5801
...@@ -131,7 +131,12 @@ CDegree.prototype.recalculateSup = function(oMeasure) ...@@ -131,7 +131,12 @@ CDegree.prototype.recalculateSup = function(oMeasure)
if(bBaseOnlyText) if(bBaseOnlyText)
{ {
var UpBaseline = 1.786*shCenter; // baseline итератора var UpBaseline = 1.786*shCenter; // baseline итератора
if(UpBaseline + iter.ascent> base.ascent)
// iter.height - UpBaseline - iter.ascent + base.ascent > 2/3 * base.height
if(iter.height - UpBaseline - iter.ascent + base.ascent > 2/3 * base.ascent)
this.upBase = iter.height - 2/3*base.ascent;
else if(UpBaseline + iter.ascent > base.ascent)
this.upBase = UpBaseline + iter.ascent - base.ascent; this.upBase = UpBaseline + iter.ascent - base.ascent;
else else
this.upIter = base.ascent - UpBaseline - iter.ascent; this.upIter = base.ascent - UpBaseline - iter.ascent;
...@@ -139,9 +144,9 @@ CDegree.prototype.recalculateSup = function(oMeasure) ...@@ -139,9 +144,9 @@ CDegree.prototype.recalculateSup = function(oMeasure)
else else
{ {
this.upBase = iter.ascent - 1.2*shCenter; this.upBase = iter.ascent - 1.2*shCenter;
var ascBase = base.ascent - shCenter > 0.27*mgCtrPrp.FontSize ? base.ascent - shCenter : 2/3*base.ascent;
if(iter.height - this.upBase > 0.5*base.ascent) if(iter.height - this.upBase > ascBase)
this.upBase = iter.height - 0.5*base.ascent; this.upBase = iter.height - ascBase;
} }
var height = this.upBase + base.height; var height = this.upBase + base.height;
...@@ -157,6 +162,7 @@ CDegree.prototype.recalculateSup = function(oMeasure) ...@@ -157,6 +162,7 @@ CDegree.prototype.recalculateSup = function(oMeasure)
this.size = {width: width, height: height, ascent: ascent}; this.size = {width: width, height: height, ascent: ascent};
} }
CDegree.prototype.recalculateSubScript = function(oMeasure) CDegree.prototype.recalculateSubScript = function(oMeasure)
{ {
var base = this.elements[0][0].size, var base = this.elements[0][0].size,
...@@ -171,10 +177,15 @@ CDegree.prototype.recalculateSubScript = function(oMeasure) ...@@ -171,10 +177,15 @@ CDegree.prototype.recalculateSubScript = function(oMeasure)
if(bBaseOnlyText) if(bBaseOnlyText)
{ {
this.upIter = base.ascent + 0.9*shCenter - iter.ascent; var DownBaseline = 0.9*shCenter;
if(iter.ascent - DownBaseline > 3/4*base.ascent)
this.upIter = 1/4*base.ascent;
else
this.upIter = base.ascent + DownBaseline - iter.ascent;
if(base.ascent/2 > this.upIter) /*if(base.ascent/2 > this.upIter)
this.upIter = base.ascent/2; this.upIter = base.ascent/2;*/
} }
else else
{ {
......
...@@ -4843,6 +4843,14 @@ CMathContent.prototype = ...@@ -4843,6 +4843,14 @@ CMathContent.prototype =
right = null; right = null;
var curr = this.content[posCurr].value; var curr = this.content[posCurr].value;
if(this.argSize < 0)
{
// выставим нулевые gaps для случая, если при копировании/вставки часть контента добавили в итератор
this.content[posCurr].gaps.left = 0;
this.content[posCurr].gaps.right = 0;
}
else
{
var EQUAL = 0x3D, var EQUAL = 0x3D,
PLUS = 0x2B, PLUS = 0x2B,
MINUS = 0x2212, MINUS = 0x2212,
...@@ -5055,6 +5063,7 @@ CMathContent.prototype = ...@@ -5055,6 +5063,7 @@ CMathContent.prototype =
console.log(""); console.log("");
} }
}*/ }*/
}
}, },
getGapsMComp: function(MComp) getGapsMComp: function(MComp)
...@@ -5153,12 +5162,13 @@ CMathContent.prototype = ...@@ -5153,12 +5162,13 @@ CMathContent.prototype =
return code == MULT || code == DIVISION || code == B_SLASH; return code == MULT || code == DIVISION || code == B_SLASH;
}, },
checkOperSign: function(code) // "+", "-", "<", ">" checkOperSign: function(code) // "+", "-", "<", ">", "±"
{ {
var PLUS = 0x2B, var PLUS = 0x2B,
MINUS = 0x2212, MINUS = 0x2212,
LESS = 0x3C, LESS = 0x3C,
GREATER = 0x3E; GREATER = 0x3E,
PLUS_MINUS = 0xB1;
return code == PLUS || code == MINUS || code == LESS || code == GREATER; return code == PLUS || code == MINUS || code == LESS || code == GREATER;
}, },
...@@ -6587,118 +6597,7 @@ CMathContent.prototype = ...@@ -6587,118 +6597,7 @@ CMathContent.prototype =
}, },
Save_Changes: function(Data, Writer) Save_Changes: function(Data, Writer)
{ {
Writer.WriteLong( historyitem_type_Math );
var Type = Data.Type;
// Пишем тип
Writer.WriteLong( Type );
var Math = this.Composition.Parent;
switch ( Type )
{
case historyitem_Math_AddItem:
{
var bArray = Data.UseArray;
var Count = Data.Items.length;
Writer.WriteLong( Count );
for ( var Index = 0; Index < Count; Index++ )
{
if ( true === bArray )
Writer.WriteLong( Data.PosArray[Index] );
else
Writer.WriteLong( Data.Pos + Index );
Math.Write_MathElemToBinary(Writer, Data.Items[Index]);
}
break;
}
case historyitem_Math_RemoveItem:
{
/*var bArray = Data.UseArray;
var Count = Data.Items.length;
var StartPos = Writer.GetCurPosition();
Writer.Skip(4);
var RealCount = Count;
for ( var Index = 0; Index < Count; Index++ )
{
if ( true === bArray )
{
if ( false === Data.PosArray[Index] )
RealCount--;
else
Writer.WriteLong( Data.PosArray[Index] );
}
else
Writer.WriteLong( Data.Pos );
}
var EndPos = Writer.GetCurPosition();
Writer.Seek( StartPos );
Writer.WriteLong( RealCount );
Writer.Seek( EndPos );
break;*/
}
}
/*var oThis = this;
this.bs = new BinaryCommonWriter(Writer);
this.boMaths = new Binary_oMathWriter(Writer);
this.bs.WriteItemWithLength ( function(){oThis.boMaths.WriteArgNodes(oThis.Data);});
*/
},
Load_Changes : function(Reader)
{
// Сохраняем изменения из тех, которые используются для Undo/Redo в бинарный файл.
// Long : тип класса
// Long : тип изменений
var ClassType = Reader.GetLong();
if ( historyitem_type_Math != ClassType )
return;
var paraMath = this.Composition.Parent;
var Type = Reader.GetLong();
switch ( Type )
{
case historyitem_Math_AddItem:
{
var Count = Reader.GetLong();
//var oMathComp = new CMathComposition;
for ( var Index = 0; Index < Count; Index++ )
{
var Pos = Reader.GetLong()
var elem = paraMath.Read_MathElemFromBinary(Reader);
if ( null != elem )
{
//paraMath.Math.AddToComposition(Item.Math.Root);
// TODO: Подумать над тем как по минимуму вставлять отметки совместного редактирования
var Element = new mathElem(elem);
this.content.splice( Pos, 0, new ParaCollaborativeChangesEnd() );
this.content.splice( Pos, 0, Element );
this.content.splice( Pos, 0, new ParaCollaborativeChangesStart() );
CollaborativeEditing.Add_ChangedClass(this);
}
}
this.DeleteCollaborativeMarks = false;
break;
}
}
}, },
Refresh_RecalcData: function() Refresh_RecalcData: function()
{ {
...@@ -7091,14 +6990,6 @@ CMathContent.prototype = ...@@ -7091,14 +6990,6 @@ CMathContent.prototype =
this.setEndPos_Selection(1); this.setEndPos_Selection(1);
//this.setEnd_Selection(1); //this.setEnd_Selection(1);
//this.selection.active = false; //this.selection.active = false;
},
Get_Id : function()
{
return this.GetId();
},
GetId : function()
{
return this.Id;
} }
///////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////
...@@ -7154,10 +7045,6 @@ function CMathComposition() ...@@ -7154,10 +7045,6 @@ function CMathComposition()
}; };
this.Init(); this.Init();
//для совместного редактирования каждый элемент записываем в глобальную таблицу
//this.Id = g_oIdCounter.Get_NewId();
//g_oTableId.Add( this, this.Id );
} }
CMathComposition.prototype = CMathComposition.prototype =
{ {
...@@ -7907,8 +7794,6 @@ CMathComposition.prototype = ...@@ -7907,8 +7794,6 @@ CMathComposition.prototype =
var Pos = this.SelectContent.CurPos, var Pos = this.SelectContent.CurPos,
EndPos = this.SelectContent.CurPos + 1; EndPos = this.SelectContent.CurPos + 1;
//для совместного редактирования
this.CurrentContent.Id = this.Id;
History.Add(this.CurrentContent, {Type: historyitem_Math_AddItem, Items: items, Pos: Pos, PosEnd: EndPos}); History.Add(this.CurrentContent, {Type: historyitem_Math_AddItem, Items: items, Pos: Pos, PosEnd: EndPos});
}, },
CreateEquation: function(indef) CreateEquation: function(indef)
......
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