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

поправлены gaps для мат. объектов

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@53477 954022d7-b5bf-4e40-9824-e11837661b57
parent 9467d81b
......@@ -18,7 +18,7 @@
/// TODO
// 0. Пересмотреть схему для findDisposition(base.js), т.к. если нажали за границами элемента, то происходит селект, т.к. теперь на mouseDown и mouseDown одни и те же функции
// 1. центр => baseline
// 1. сделать Gaps, line 4745, checkGapsSign
// 2. поправить центр для delimiters (когда оператор текст)
// 3. поправить accent расположение глифов в случае небольшого размера шрифта (н-р, 14)
// 5. сделать gaps для мат. объектов, +, - в зависимости от расположения в контенте
......@@ -4536,6 +4536,10 @@ CMathContent.prototype =
}
return posChange;
},
getTypeLRObj: function(order)
{
},
// выставить курсор в начало конента
cursor_MoveToStartPos: function() // home => cursor_MoveToStartPos
......@@ -4659,6 +4663,7 @@ CMathContent.prototype =
else if(type == MATH_COMP)
{
this.content[i].value.Resize(oMeasure);
this.checkGapsSign(oMeasure, i);
}
else if(type == MATH_RUN_PRP)
{
......@@ -4694,16 +4699,27 @@ CMathContent.prototype =
},
checkGapsSign: function(oMeasure, pos)
{
/*var bPlus = this.content[pos].value.code === 0x2B,
bMinus = this.content[pos].value.code === 0x2212,
bMult = this.content[pos].value.code === 0x2217,
bDivision = this.content[pos].value.code === 0x002F;*/
var bPlus = false, bMinus = false,
/*var leftType = pos > 0 ? this.content[pos - 1].value.typeObj : null,
left2_Type = pos - 1 > 0 ? this.content[pos - 2].value.typeObj : null,
left3_Type = pos - 2 > 0 ? this.content[pos - 3].value.typeObj : null,
rightType = pos < this.content.length - 1 ? this.content[pos + 1].value.typeObj : null,
right2_Type = pos + 1 < this.content.length - 1 ? this.content[pos + 2].value.typeObj : null;
var bLeftComp = leftType == MATH_RUN_PRP && left2_Type == MATH_EMPTY && left3_Type == MATH_COMP,
bLeftLetter = leftType == MATH_TEXT || (leftType == MATH_RUN_PRP && left2_Type == MATH_TEXT);
var bRightComp = rightType == MATH_COMP,
bRightLetter = rightType == MATH_TEXT || (rightType == MATH_RUN_PRP && right2_Type == MATH_TEXT);*/
/*var bPlus = false, bMinus = false,
bMult = false, bDivision = false,
bEqual = false;
if(this.content[pos].value.typeObj == MATH_TEXT)
var currType = this.content[pos].value.typeObj;
if(currType == MATH_TEXT)
{
var code = this.content[pos].value.getCodeChr();
......@@ -4714,21 +4730,38 @@ CMathContent.prototype =
bEqual = code === 0x3D;
}
var leftType = pos > 0 ? this.content[pos - 1].value.typeObj : null,
left2_Type = pos - 1 > 0 ? this.content[pos - 2].value.typeObj : null,
left3_Type = pos - 2 > 0 ? this.content[pos - 3].value.typeObj : null,
rightType = pos < this.content.length - 1 ? this.content[pos + 1].value.typeObj : null,
right2_Type = pos + 1 < this.content.length - 1 ? this.content[pos + 2].value.typeObj : null;
var bSign = (bPlus || bMinus || bEqual),
bComp = this.content[pos].value.typeObj == MATH_COMP;*/
var bLeftComp = leftType == MATH_RUN_PRP && left2_Type == MATH_EMPTY && left3_Type == MATH_COMP,
bLeftLetter = leftType == MATH_TEXT || (leftType == MATH_RUN_PRP && left2_Type == MATH_TEXT);
var currType = this.content[pos].value.typeObj;
var bRightComp = rightType == MATH_COMP,
bRightLetter = rightType == MATH_TEXT || rightType == MATH_RUN_PRP && right2_Type == MATH_TEXT;
var bTextType = currType == MATH_TEXT,
bCompType = currType == MATH_COMP;
if(bPlus || bMinus || bEqual)
{
if(bLeftComp || bLeftLetter)
// TODO
// сделать через geLRObj, не тип, а именно так, так как для текста надо запросить код буквы
// т.к. нужно правильно передать позицию , могут быть RunPrp, CEMpty и пр.
var bCurrGapObj = this.checkSignComp(pos),
bLeftGapObj = this.checkSignComp(pos - 1),
bRightGapObj = this.checkSignComp(pos + 1);
var bFirstLetter = currType == MATH_TEXT && pos == 2,
bFirstComp = currType == MATH_COMP && pos == 1,
bLastLetter = currType == MATH_TEXT && pos == this.content.length - 1,
bLastComp = currType == MATH_COMP && pos == this.content.length - 2;
var bLeft = !bFirstLetter && !bFirstComp,
bRight =!bLastLetter && !bLastComp;
var bNeedGap = bLeft || bRight;
var bGap = bCurrGapObj && bNeedGap;
if(bGap)
{
var rPrp = this.getRPrpByPosition(pos);
var txtPrp = new CMathTextPrp();
......@@ -4736,22 +4769,100 @@ CMathContent.prototype =
txtPrp.Merge(rPrp);
//txtPrp.Italic = false;
this.content[pos].gaps.left = 0.6*this.Composition.GetGapSign(oMeasure, txtPrp);
var gapSign = this.Composition.GetGapSign(oMeasure, txtPrp);
if(bTextType)
{
var code = this.content[pos].value.getCodeChr();
var bPlus = code === 0x2B,
bMinus = code === 0x2212;
if(bPlus || bMinus)
{
if(bLeft)
this.content[pos].gaps.left = 0.6*gapSign;
if(bRight)
this.content[pos].gaps.right = 0.5*gapSign;
}
else
{
if(bLeft)
this.content[pos].gaps.left = 0.3*gapSign;
if(bRightComp || bRightLetter)
if(bRight)
this.content[pos].gaps.right = 0.3*gapSign;
}
}
else if(bCompType)
{
var rPrp = this.getRPrpByPosition(pos);
var txtPrp = new CMathTextPrp();
txtPrp.Merge(this.Composition.DEFAULT_RUN_PRP);
txtPrp.Merge(rPrp);
//txtPrp.Italic = false;
if(bLeft && bLeftGapObj)
this.content[pos].gaps.left = 0.3*gapSign;
else
this.content[pos].gaps.left = 0.5*gapSign;
if(bRight && bRightGapObj)
this.content[pos].gaps.right = 0.3*gapSign;
else
this.content[pos].gaps.right = 0.5*gapSign;
}
/*if(bPlus || bMinus)
{
if(bLeft)
this.content[pos].gaps.left = 0.6*gapSign;
if(bRight)
this.content[pos].gaps.right = 0.5*gapSign;
}
else if(bEqual)
{
if(bLeft)
this.content[pos].gaps.left = 0.3*gapSign;
this.content[pos].gaps.right = 0.5*this.Composition.GetGapSign(oMeasure, txtPrp);
if(bRight)
this.content[pos].gaps.right = 0.3*gapSign;
}
else if(bComp)
{
if(bLeft && bLeftGapObj)
this.content[pos].gaps.left = 0.3*gapSign;
else
this.content[pos].gaps.left = 0.5*gapSign;
if(bRight && bRightGapObj)
this.content[pos].gaps.right = 0.3*gapSign;
else
this.content[pos].gaps.right = 0.5*gapSign;
}*/
}
},
checkSignComp: function(pos)
{
var bPlus = false, bMinus = false,
bMult = false, bDivision = false,
bEqual = false;
var currType = pos > 0 && pos < this.content.length ? this.content[pos].value.typeObj : null;
if(currType == MATH_TEXT)
{
var code = this.content[pos].value.getCodeChr();
bPlus = code === 0x2B;
bMinus = code === 0x2212;
bMult = code === 0x2217;
bDivision = code === 0x002F;
bEqual = code === 0x3D;
}
var bSign = (bPlus || bMinus || bEqual),
bComp = currType == MATH_COMP;
return bSign || bComp;
},
old_draw: function(pGraphics)
{
......
......@@ -118,7 +118,6 @@ CMathText.prototype =
code = 0x1D6A4;
else if(code == 0x237) // "j" without dot
code = 0x1D6A5;
}
/*else
{
......
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