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

1. Реализовала функцию fillMathComposition в качестве эмулятора конструктора...

1. Реализовала функцию fillMathComposition в качестве эмулятора конструктора классов (для совместного редактирования и т.п.) для accent, borderBox, bar, box, degree, degreeSubSup, limit, math function, matrix
2. Поправила баг с lineGap у матриц (не подхватывались)

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@56531 954022d7-b5bf-4e40-9824-e11837661b57
parent 9b531a9e
......@@ -510,10 +510,6 @@ function CAccent(props)
chrType: null
};
/*this.chr = null;
this.chrType = null;
this.loc = LOCATION_TOP;*/
/////////////////
this.operator = new COperator(OPER_ACCENT);
......@@ -532,19 +528,12 @@ function CAccent(props)
extend(CAccent, CMathBase);
CAccent.prototype.init = function(props)
{
this.Pr.chr = props.chr;
this.Pr.chrType = props.chrType;
//this.operator.init(prp, defaultPrp);
//this.operator.relate(this);
this.setProperties(props);
this.setDimension(1, 1);
this.setContent();
this.elements[0][0].SetDot(true);
if(props.ctrPrp !== null && typeof(props.ctrPrp) !== "undefined")
this.setCtrPrp(props.ctrPrp);
}
CAccent.prototype.setChr = function(chr)
{
......@@ -1138,7 +1127,7 @@ CAccent.prototype.Resize = function(Parent, ParaMath, oMeasure)
type: ACCENT_CIRCUMFLEX
};
this.operator.setProperties(prp, defaultPrp);
this.operator.mergeProperties(prp, defaultPrp);
this.Pr.chr = String.fromCharCode(this.operator.code);
this.Pr.chrType = this.operator.typeOper;
......@@ -1229,6 +1218,22 @@ CAccent.prototype.findDisposition = function(pos)
return {pos: posCurs, mCoord: mouseCoord, inside_flag: inside_flag};
}
CAccent.prototype.setProperties = function(props)
{
this.Pr.chr = props.chr;
this.Pr.chrType = props.chrType;
this.setCtrPrp(props.ctrPrp);
this.RecalcInfo.bProps = true;
}
CAccent.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.init(props);
// Base
this.elements[0][0] = contents[0];
}
CAccent.prototype.Save_Changes = function(Data, Writer)
{
Writer.WriteLong( historyitem_type_acc );
......
......@@ -101,8 +101,8 @@ CMathBase.prototype =
///////// RunPrp, CtrPrp
setCtrPrp: function(txtPrp) // выставляем ctrPrp на чтение
{
if(txtPrp !== null && typeof(txtPrp) !== "undefined")
this.CtrPrp.Merge(txtPrp);
//this.RunPrp.setTxtPrp(txtPrp);
},
Get_CtrPrp: function()
{
......
......@@ -38,42 +38,16 @@ function CBorderBox(props)
extend(CBorderBox, CMathBase);
CBorderBox.prototype.init = function(props)
{
/*if(typeof(props) !== "undefined" && props !== null)
{
if(props.hideLeft === true || props.hideLeft === 1)
this.bLeft = false;
if(props.hideRight === true || props.hideRight === 1)
this.bRight = false;
if(props.hideTop === true || props.hideTop === 1)
this.bTop = false;
if(props.hideBot === true || props.hideBot === 1)
this.bBot = false;
if(props.strikeBLTR === true || props.strikeBLTR === 1)
this.bRDiag = true;
if(props.strikeTLBR === true || props.strikeTLBR === 1)
this.bLDiag = true;
if(props.strikeH === true || props.strikeH === 1)
this.bHor = true;
if(props.strikeV === true || props.strikeV === 1)
this.bVert = true;
}*/
this.setBorders(props);
this.setProperties(props);
this.fillContent();
}
CBorderBox.prototype.fillContent = function()
{
this.setDimension(1, 1);
this.setContent();
if(props.ctrPrp !== null && typeof(props.ctrPrp) !== "undefined")
this.setCtrPrp(props.ctrPrp);
}
CBorderBox.prototype.setBorders = function(props)
CBorderBox.prototype.setProperties = function(props)
{
if(typeof(props) !== "undefined" && props !== null)
{
if(typeof(props.hideLeft) !== "undefined" && props.hideLeft !== null)
this.Pr.hideLeft = props.hideLeft;
......@@ -97,7 +71,9 @@ CBorderBox.prototype.setBorders = function(props)
if(typeof(props.strikeV) !== "undefined" && props.strikeV !== null)
this.Pr.strikeV = props.strikeV;
}
this.setCtrPrp(props.ctrPrp);
this.RecalcInfo.bProps = true;
}
......@@ -458,6 +434,14 @@ CBorderBox.prototype.getBase = function()
{
return this.elements[0][0];
}
CBorderBox.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.setProperties(props);
this.fillContent();
// Base
this.elements[0][0] = contents[0];
}
CBorderBox.prototype.getPropsForWrite = function()
{
/*var props = {};
......@@ -572,6 +556,8 @@ CBorderBox.prototype.Get_Id = function()
return this.Id;
}
function CBox(props)
{
this.Id = g_oIdCounter.Get_NewId();
......@@ -592,6 +578,19 @@ function CBox(props)
}
extend(CBox, CMathBase);
CBox.prototype.init = function(props)
{
this.setProperties(props);
this.fillContent();
}
CBox.prototype.fillContent = function()
{
this.setDimension(1, 1);
this.setContent();
if(this.opEmu)
this.elements[0][0].decreaseArgSize();
}
CBox.prototype.setProperties = function(props)
{
if(props.opEmu === true || props.opEmu === 1)
this.opEmu = true;
......@@ -608,14 +607,17 @@ CBox.prototype.init = function(props)
if(props.aln === true || props.aln === 1)
this.aln = true;
this.setDimension(1, 1);
this.setContent();
this.setCtrPrp(props.ctrPrp);
if(this.opEmu)
this.elements[0][0].decreaseArgSize();
this.RecalcInfo.bProps = true;
}
CBox.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.setProperties(props);
this.fillContent();
if(props.ctrPrp !== null && typeof(props.ctrPrp) !== "undefined")
this.setCtrPrp(props.ctrPrp);
// Base
this.elements[0][0] = contents[0];
}
CBox.prototype.getBase = function()
{
......@@ -732,32 +734,13 @@ function CBar(props)
extend(CBar, CCharacter);
CBar.prototype.init = function(props)
{
if(props.pos === LOCATION_TOP || props.location === LOCATION_TOP)
this.Pr.pos = LOCATION_TOP;
else if(props.pos === LOCATION_BOT || props.location === LOCATION_BOT)
this.Pr.pos = LOCATION_BOT;
var prp =
{
loc: this.Pr.pos,
type: DELIMITER_LINE
};
var defaultProps =
{
loc: LOCATION_BOT
};
this.setCharacter(prp, defaultProps);
if(props.ctrPrp !== null && typeof(props.ctrPrp) !== "undefined")
this.setCtrPrp(props.ctrPrp);
this.setProperties(props);
this.fillContent();
}
CBar.prototype.setLocation = function(pos)
CBar.prototype.fillContent = function()
{
this.Pr.pos = pos;
this.RecalcInfo.bProps = true;
this.setDimension(1, 1);
this.setContent();
}
CBar.prototype.Resize = function(Parent, ParaMath, oMeasure)
{
......@@ -791,6 +774,23 @@ CBar.prototype.getAscent = function()
return ascent;
}
CBar.prototype.setProperties = function(props)
{
if(props.pos === LOCATION_TOP || props.pos === LOCATION_BOT)
this.Pr.pos = LOCATION_TOP;
this.setCtrPrp(props.ctrPrp);
this.RecalcInfo.bProps = true;
}
CBar.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.setProperties(props);
this.fillContent();
// Base
this.elements[0][0] = contents[0];
}
CBar.prototype.getPropsForWrite = function()
{
return this.Pr;
......@@ -850,30 +850,68 @@ function CPhantom(props)
this.props = null;
CMathBase.call(this);
this.init(props);
this.Pr =
{
show: true,
transp: false,
zeroAsc: false,
zeroDesc: false,
zeroWid: false
};
if(props !== null && typeof(props) !== "undefined")
this.setCtrPrp(props.ctrPrp);
this.init(props);
g_oTableId.Add( this, this.Id );
}
extend(CPhantom, CMathBase);
CPhantom.prototype.init = function(props)
{
this.props = props;
this.setProperties(props);
this.fillContent();
}
CPhantom.prototype.fillContent = function()
{
this.setDimension(1, 1);
this.setContent();
}
CPhantom.prototype.getBase = function()
{
return this.elements[0][0];
}
CPhantom.prototype.setProperties = function(props)
{
if(props.show == true || props.show == false)
this.Pr.show = props.show;
if(props.transp == false || props.transp == true)
this.Pr.transp = props.transp;
if(props.zeroAsc == false || props.zeroAsc == true)
this.Pr.zeroAsc = props.zeroAsc;
if(props.zeroDesc == false || props.zeroDesc == true)
this.Pr.zeroDesc = props.zeroDesc;
if(props.zeroWid == false || props.zeroWid == true)
this.Pr.zeroWid = props.zeroWid;
if(props.ctrPrp !== null && typeof(props.ctrPrp) !== "undefined")
this.setCtrPrp(props.ctrPrp);
this.RecalcInfo.bProps = true;
}
CPhantom.prototype.getPropsForWrite = function()
CPhantom.prototype.fillMathComposition = function(props, contents /*array*/)
{
return this.props;
this.setProperties(props);
this.fillContent();
// Base
this.elements[0][0] = contents[0];
}
CPhantom.prototype.getBase = function()
CPhantom.prototype.getPropsForWrite = function()
{
return this.elements[0][0];
return this.props;
}
CPhantom.prototype.Save_Changes = function(Data, Writer)
{
......
......@@ -3,10 +3,8 @@ function CDegree(props)
this.Id = g_oIdCounter.Get_NewId();
this.kind = MATH_DEGREE;
//this.type = DEGREE_SUPERSCRIPT;
this.upBase = 0; // отступ сверху для основания
this.upIter = 0; // отступ сверху для итератора
//this.alnScr = false; // не выровнены, итераторы идут в соответствии с наклоном буквы/мат. объекта
this.Pr =
{
......@@ -15,27 +13,26 @@ function CDegree(props)
CMathBase.call(this);
if(props !== null && typeof(props) !== "undefined")
this.init(props);
this.setCtrPrp(props.ctrPrp);
g_oTableId.Add( this, this.Id );
}
extend(CDegree, CMathBase);
CDegree.prototype.init = function(props)
{
/*if(props.alnScr === true || props.alnScr === 1)
this.alnScr = true;
else if(props.alnScr === false || props.alnScr === 0)
this.alnScr = false;*/
this.setProperties(props);
this.fillContent();
}
CDegree.prototype.fillContent = function()
{
var oBase = new CMathContent();
if(props.indef == 2) /// props include Base for CNary
{
oBase = props.oBase;
if(props.type === DEGREE_SUPERSCRIPT)
this.Pr.type = DEGREE_SUPERSCRIPT;
else if(props.type === DEGREE_SUBSCRIPT)
this.Pr.type = DEGREE_SUBSCRIPT;
oBase.setCtrPrp(props.ctrPrp);
}
this.setDimension(1, 2);
......@@ -44,20 +41,6 @@ CDegree.prototype.init = function(props)
this.addMCToContent(oBase, oDegree);
}
/*CDegree.prototype.init_2 = function(props, oBase)
{
if(props.type === DEGREE_SUPERSCRIPT)
this.type = DEGREE_SUPERSCRIPT;
else if(props.type === DEGREE_SUBSCRIPT)
this.type = DEGREE_SUBSCRIPT;
this.setDimension(1, 2);
var oDegree = new CMathContent();
oDegree.decreaseArgSize();
this.addMCToContent(oBase, oDegree);
}*/
CDegree.prototype.recalculateSize = function(oMeasure)
{
if(this.Pr.type === DEGREE_SUPERSCRIPT)
......@@ -458,22 +441,35 @@ CDegree.prototype.getBase = function()
{
return this.elements[0][0];
}
/*CDegree.prototype.getPropsForWrite = function()
CDegree.prototype.IsPlhIterator = function()
{
var props = {};
return this.elements[0][1].IsPlaceholder();
}
CDegree.prototype.setProperties = function(props)
{
if(props.type === DEGREE_SUPERSCRIPT)
this.Pr.type = DEGREE_SUPERSCRIPT;
else if(props.type === DEGREE_SUBSCRIPT)
this.Pr.type = DEGREE_SUBSCRIPT;
props.type = this.type;
//props.alnScr = this.alnScr;
this.setCtrPrp(props.ctrPrp);
return props;
}*/
CDegree.prototype.getPropsForWrite = function()
this.RecalcInfo.bProps = true;
}
CDegree.prototype.fillMathComposition = function(props, contents /*array*/)
{
return this.Pr;
this.setProperties(props);
this.fillContent();
// Base
this.elements[0][0] = contents[0];
// Iterator
this.elements[0][1] = contents[1];
}
CDegree.prototype.IsPlhIterator = function()
CDegree.prototype.getPropsForWrite = function()
{
return this.elements[0][1].IsPlaceholder();
return this.Pr;
}
CDegree.prototype.Save_Changes = function(Data, Writer)
{
......@@ -643,6 +639,11 @@ CIterators.prototype.Get_CompiledCtrPrp = function()
{
return this.Parent.Get_CompiledCtrPrp();
}
CIterators.prototype.fillMathComposition = function(upperIterator, lowerIterator)
{
this.elements[0][0] = upperIterator;
this.elements[1][0] = lowerIterator;
}
function CDegreeSubSup(props)
{
......@@ -662,25 +663,26 @@ function CDegreeSubSup(props)
CMathBase.call(this);
if(props !== null && typeof(props) !== "undefined")
this.init(props);
this.setCtrPrp(props.ctrPrp);
g_oTableId.Add( this, this.Id );
}
extend(CDegreeSubSup, CMathBase);
CDegreeSubSup.prototype.init = function(props)
{
if(props.alnScr === true || props.alnScr === 1)
this.Pr.alnScr = true;
else if(props.alnScr === false || props.alnScr === 0)
this.Pr.alnScr = false;
this.setProperties(props);
this.fillContent();
}
CDegreeSubSup.prototype.fillContent = function()
{
var oBase = new CMathContent();
if(props.indef == 2) /// props include Base for CNary
{
oBase = props.oBase;
if(props.type === DEGREE_SubSup || props.type === DEGREE_PreSubSup)
this.Pr.type = props.type;
oBase.setCtrPrp(props.ctrPrp);
}
this.setDimension(1, 2);
......@@ -702,41 +704,7 @@ CDegreeSubSup.prototype.init = function(props)
oIters.alignHor(-1, 1);
this.addMCToContent(oIters, oBase);
}
/// вызов этой функции обязательно в конце
//this.WriteContentsToHistory();
}
/*CDegreeSubSup.prototype.init_2 = function(props, oBase)
{
if(props.type === DEGREE_SubSup)
this.type = DEGREE_SubSup;
else if(props.type === DEGREE_PreSubSup)
this.type = DEGREE_PreSubSup;
this.setDimension(1, 2);
var oIters = new CIterators();
oIters.init();
oIters.decreaseArgSize();
oIters.lUp = 0;
oIters.lD = 0;
if(this.type == DEGREE_SubSup)
{
oIters.alignHor(-1, 0);
this.addMCToContent(oBase, oIters);
}
else if(this.type == DEGREE_PreSubSup)
{
oIters.alignHor(-1, 1);
this.addMCToContent(oIters, oBase);
}
/// вызов этой функции обязательно в конце
this.WriteContentsToHistory();
}*/
CDegreeSubSup.prototype.old_old_recalculateSize = function(oMeasure)
{
var mgCtrPrp = this.Get_CompiledCtrPrp();
......@@ -1130,15 +1098,44 @@ CDegreeSubSup.prototype.getLowerIterator = function()
return iter;
}
CDegreeSubSup.prototype.getPropsForWrite = function()
CDegreeSubSup.prototype.setProperties = function(props)
{
if(props.alnScr === true || props.alnScr === 1)
this.Pr.alnScr = true;
else if(props.alnScr === false || props.alnScr === 0)
this.Pr.alnScr = false;
if(props.type === DEGREE_SubSup || props.type === DEGREE_PreSubSup)
this.Pr.type = props.type;
this.setCtrPrp(props.ctrPrp);
this.RecalcInfo.bProps = true;
}
CDegreeSubSup.prototype.fillMathComposition = function(props, contents /*array*/)
{
/*var props = {};
this.setProperties(props);
this.fillContent();
props.type = this.type;
props.alnScr = this.alnScr;
if(this.Pr.type == DEGREE_SubSup)
{
// Base
this.elements[0][0] = contents[0];
return props;*/
// Iterators
this.elements[0][1].fillMathComposition(contents[1]/*upper iterator*/, contents[2]/*lower iterator*/);
}
else
{
// Base
this.elements[0][1] = contents[0];
// Iterators
this.elements[0][0].fillMathComposition(contents[1]/*upper iterator*/, contents[2]/*lower iterator*/);
}
}
CDegreeSubSup.prototype.getPropsForWrite = function()
{
return this.Pr;
}
CDegreeSubSup.prototype.Save_Changes = function(Data, Writer)
......@@ -1198,16 +1195,3 @@ CDegreeSubSup.prototype.Get_Id = function()
{
return this.Id;
}
//выяcнить: почему и с этой ф-ией и без нее работает всё ok...
//всё ok, т.к. в контенте 2 элемента, и их center сравниваем
/*CDegreeSubSup.prototype.getCenter = function()
{
var center = 0;
if(this.type == 0)
center = this.elements[0][1].size.center;
else
center = this.elements[0][0].size.center;
return center;
}*/
......@@ -13,6 +13,7 @@ function CFraction(props)
CMathBase.call(this);
if(props !== null && typeof(props) !== "undefined")
this.init(props);
g_oTableId.Add( this, this.Id );
......@@ -20,48 +21,8 @@ function CFraction(props)
extend(CFraction, CMathBase);
CFraction.prototype.init = function(props)
{
this.setType(props.type);
if(props.ctrPrp !== null && typeof(props.ctrPrp) !== "undefined")
this.setCtrPrp(props.ctrPrp);
}
CFraction.prototype.setType = function(type)
{
var bValid = typeof(type) !== "undefined" && type !== null;
if(bValid)
{
var bBar = type === BAR_FRACTION || type === NO_BAR_FRACTION,
bSkew = type === SKEWED_FRACTION,
bLin = type === LINEAR_FRACTION;
if(bBar || bSkew || bLin) // на всякий случай
this.Pr.type = type;
}
if(this.Pr.type == BAR_FRACTION || this.Pr.type == NO_BAR_FRACTION)
{
var num = new CNumerator();
var den = new CDenominator();
this.setDimension(2, 1);
if(this.Pr.type == NO_BAR_FRACTION)
this.bHideBar = true;
this.addMCToContent(num, den);
}
else if(this.Pr.type == SKEWED_FRACTION)
{
this.setDimension(1, 2);
this.setContent();
}
else if(this.Pr.type == LINEAR_FRACTION)
{
this.setDimension(1, 2);
this.setContent();
}
this.setProperties(props);
this.fillContent();
}
CFraction.prototype.getType = function()
{
......@@ -424,11 +385,71 @@ CFraction.prototype.findDisposition = function( mCoord )
return disposition;
}
CFraction.prototype.setProperties = function(props)
{
var bBar = props.type === BAR_FRACTION || props.type === NO_BAR_FRACTION,
bSkew = props.type === SKEWED_FRACTION,
bLin = props.type === LINEAR_FRACTION;
if(bBar || bSkew || bLin)
this.Pr.type = props.type;
this.setCtrPrp(props.ctrPrp);
}
CFraction.prototype.fillContent = function()
{
if(this.Pr.type == BAR_FRACTION || this.Pr.type == NO_BAR_FRACTION)
{
var num = new CNumerator();
var den = new CDenominator();
this.setDimension(2, 1);
if(this.Pr.type == NO_BAR_FRACTION)
this.bHideBar = true;
this.addMCToContent(num, den);
}
else if(this.Pr.type == SKEWED_FRACTION)
{
this.setDimension(1, 2);
this.setContent();
}
else if(this.Pr.type == LINEAR_FRACTION)
{
this.setDimension(1, 2);
this.setContent();
}
}
CFraction.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.setProperties(props);
this.fillContent();
if(this.Pr.type == BAR_FRACTION || this.Pr.type == NO_BAR_FRACTION)
{
// Numerator
this.elements[0][0].fillMathComposition(contents[0]);
// Denominator
this.elements[1][0].fillMathComposition(contents[1]);
}
else
{
// Numerator
this.elements[0][0] = contents[0];
// Denominator
this.elements[0][1] = contents[1];
}
}
CFraction.prototype.getPropsForWrite = function()
{
return this.Pr;
}
CFraction.prototype.Save_Changes = function(Data, Writer)
{
Writer.WriteLong( historyitem_type_frac );
......@@ -587,6 +608,10 @@ CNumerator.prototype.getElement = function()
{
return this.elements[0][0];
}
CNumerator.prototype.fillMathComposition = function(content)
{
this.elements[0][0] = content;
}
CNumerator.prototype.Get_CompiledCtrPrp = function()
{
return this.Parent.Get_CompiledCtrPrp();
......@@ -664,6 +689,10 @@ CDenominator.prototype.getElement = function(txt)
{
return this.elements[0][0];
}
CDenominator.prototype.fillMathComposition = function(content)
{
this.elements[0][0] = content;
}
CDenominator.prototype.Get_CompiledCtrPrp = function()
{
return this.Parent.Get_CompiledCtrPrp();
......
......@@ -11,26 +11,17 @@ function CLimit(props)
CMathBase.call(this);
if(props.type === LIMIT_UP || props.type === LIMIT_LOW)
this.Pr.type = props.type;
this.setDimension(2, 1);
var oBase = new CMathContent();
var oIter = new CMathContent();
oIter.decreaseArgSize();
if(this.Pr.type == LIMIT_LOW)
this.addMCToContent(oBase, oIter);
else if(this.Pr.type == LIMIT_UP)
this.addMCToContent(oIter, oBase);
this.setCtrPrp(props.ctrPrp);
if(props !== null && typeof(props) !== "undefined")
this.init(props);
g_oTableId.Add( this, this.Id );
}
extend(CLimit, CMathBase);
CLimit.prototype.init = function(props)
{
this.setProperties(props);
this.fillContent();
}
CLimit.prototype.getAscent = function()
{
var ascent;
......@@ -65,6 +56,50 @@ CLimit.prototype.setDistance = function()
{
this.dH = 0.03674768518518519*this.Get_CompiledCtrPrp().FontSize;
}
CLimit.prototype.setProperties = function(props)
{
if(props.type === LIMIT_UP || props.type === LIMIT_LOW)
this.Pr.type = props.type;
this.setCtrPrp(props.ctrPrp);
}
CLimit.prototype.fillContent = function()
{
this.setDimension(2, 1);
var oBase = new CMathContent();
var oIter = new CMathContent();
oIter.decreaseArgSize();
if(this.Pr.type == LIMIT_LOW)
this.addMCToContent(oBase, oIter);
else if(this.Pr.type == LIMIT_UP)
this.addMCToContent(oIter, oBase);
}
CLimit.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.setProperties(props);
this.fillContent();
if(this.Pr.type == LIMIT_LOW)
{
// Base
this.elements[0][0] = contents[0];
// Iterator
this.elements[1][0] = contents[1];
}
else
{
// Iterator
this.elements[0][0] = contents[1];
// Base
this.elements[1][0] = contents[0];
}
}
CLimit.prototype.getPropsForWrite = function()
{
return this.Pr;
......@@ -115,14 +150,17 @@ function CMathFunc(props)
CMathBase.call(this);
this.setDimension(1, 2);
this.setContent();
this.setCtrPrp(props.ctrPrp);
if(props !== null && typeof(props) !== "undefined")
this.init(props);
g_oTableId.Add( this, this.Id );
}
extend(CMathFunc, CMathBase);
CMathFunc.prototype.init = function(props)
{
this.setProperties(props);
this.fillContent();
}
CMathFunc.prototype.setDistance = function()
{
this.dW = this.Get_CompiledCtrPrp().FontSize/6*g_dKoef_pt_to_mm;
......@@ -135,6 +173,27 @@ CMathFunc.prototype.getArgument = function()
{
return this.elements[0][1];
}
CMathFunc.prototype.setProperties = function(props)
{
this.setCtrPrp(props.ctrPrp);
}
CMathFunc.prototype.fillContent = function()
{
this.setDimension(1, 2);
this.setContent();
}
CMathFunc.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.setProperties(props);
this.fillContent();
// FName
this.elements[0][0] = contents[0];
// Argument
this.element[0][1] = contents[1];
}
CMathFunc.prototype.getPropsForWrite = function()
{
var props = {};
......
......@@ -3,10 +3,7 @@ function CMathMatrix(props)
this.Id = g_oIdCounter.Get_NewId();
this.kind = MATH_MATRIX;
this.lineGapColumn = 1.5;
this.lineGapRow = 1;
this.gaps = null;
this.plcHide = false;
this.Pr =
{
......@@ -26,9 +23,9 @@ function CMathMatrix(props)
{
rule: 0,
gap: 0,
minGap: 13/12 //em
minGap: 13/12 // em
// 780 /20 (pt) for font 36 pt
//minGap: 0
// minGap: 0
};
this.spaceColumn =
{
......@@ -37,9 +34,6 @@ function CMathMatrix(props)
minGap: 0 // minGap / 20 pt
};
this.plcHide = false;
this.baseJc = BASEJC_CENTER;
this.gaps =
{
row: new Array(),
......@@ -51,101 +45,19 @@ function CMathMatrix(props)
this.column = 0;
////
CMathBase.call(this);
CMathMatrix.superclass.constructor.call(this);
if(props !== null && typeof(props) !== "undefined")
this.init(props);
this.setCtrPrp(props.ctrPrp);
//this.constructor.superclass.init.call(this, props);
g_oTableId.Add( this, this.Id );
}
extend(CMathMatrix, CMathBase);
CMathMatrix.prototype.init = function(props)
{
if(typeof(props.row) === "undefined" || props.row === null)
props.row = 1;
if(typeof(props.column) === "undefined" || props.column === null)
props.column = 1;
this.setDimension(props.row, props.column);
this.setContent();
/*if(typeof(props.baseJc) !== "undefined" && props.baseJc !== null)
{
if(props.baseJc === "center")
this.baseJc = MATRIX_CENTER;
else if(props.baseJc === "top")
this.baseJc = MATRIX_TOP;
else if(props.baseJc === "bottom")
this.baseJc = MATRIX_BOTTOM;
}*/
/*if(props.baseJc === BASEJC_CENTER)
this.baseJc = BASEJC_CENTER;
else if(props.baseJc === BASEJC_TOP)
this.baseJc = BASEJC_TOP;
else if(props.baseJc === BASEJC_BOTTOM)
this.baseJc = BASEJC_BOTTOM;*/
if(props.baseJc === BASEJC_CENTER || props.baseJc === BASEJC_TOP || props.baseJc === BASEJC_BOTTOM)
this.baseJc = props.baseJc;
if(props.mcJc == MCJC_CENTER || props.mcJc == MCJC_LEFT || props.mcJc == MCJC_RIGHT)
this.mcJc = props.mcJc;
this.Pr.cGpRule = props.cGpRule;
this.Pr.cGp = props.cGp;
this.Pr.cSp = props.cSp;
this.Pr.rSpRule = props.rSpRule;
this.Pr.rSp = props.rSp;
//this.setRuleGap(this.spaceColumn, props.cGpRule, props.cGp, props.cSp);
//this.setRuleGap(this.spaceRow, props.rSpRule, props.rSp);
if(props.plcHide === true || props.plcHide === 1)
{
this.plcHide = true;
this.hidePlaceholder(true);
}
/*if(props.cGpRule !== "undefined" && props.cGpRule !== null)
{
this.setRuleGap(this.spaceColumn, props.cGpRule, props.cGp);
*//*this.spaceColumn.value = 0;
if(props.cGpRule == 0)
this.spaceColumn.rule = 0;
else if(props.cGpRule == 1)
this.spaceColumn.rule = 1;
else if(props.cGpRule == 2)
this.spaceColumn.rule = 2;
else if(props.cGpRule == 3)
{
this.spaceColumn.rule = 3;
if(props.cGp !== "undefined" || props.cGp !== null)
this.spaceColumn.value = props.cGp;
}
else if(props.cGpRule == 4)
{
this.spaceColumn.rule = 4;
if(props.cGp !== "undefined" || props.cGp !== null)
this.spaceColumn.value = props.cGp;
}
else
this.spaceColumn.rule = 0;*//*
}
if(props.rSpRule !== "undefined" && props.rSpRule !== null)
{
// если rSpRule не выставлено, то какое выставлено rSp не имеет значение
this.setRuleGap(this.spaceRow, props.rSpRule, props.rSp);
}*/
this.setProperties(props);
this.fillContent();
}
CMathMatrix.prototype.setRuleGap = function(oSpace, rule, gap, minGap)
{
......@@ -165,42 +77,18 @@ CMathMatrix.prototype.setRuleGap = function(oSpace, rule, gap, minGap)
if(minGap == minGap - 0 && minGap == minGap^0)
oSpace.minGap = gap;
}
CMathMatrix.prototype.recalculateSize = function(oMeasure)
{
/*else
oSpace.minGap = 0;*/
/*var Value = 0, Rule;
if(rule == 0)
Rule = 0;
else if(rule == 1)
Rule = 1;
else if(rule == 2)
Rule = 2;
else if(rule == 3)
{
Rule = 3;
if(gap !== "undefined" || gap !== null)
Value = gap;
}
else if(rule == 4)
if(this.RecalcInfo.bProps)
{
Rule = 4;
this.setRuleGap(this.spaceColumn, this.Pr.cGpRule, this.Pr.cGp, this.Pr.cSp);
this.setRuleGap(this.spaceRow, this.Pr.rSpRule, this.Pr.rSp);
if(gap !== "undefined" || gap !== null)
Value = gap;
this.RecalcInfo.bProps = false;
}
else
Rule = 0;
oSpace.rule = Rule;
oSpace.value = Value;*/
}
CMathMatrix.prototype.recalculateSize = function(oMeasure)
{
var txtPrp = this.Get_CompiledCtrPrp();
var intervalCol = this.getLineGap(txtPrp);
......@@ -213,14 +101,6 @@ CMathMatrix.prototype.recalculateSize = function(oMeasure)
var divCenter = 0;
var metrics = this.getMetrics();
if(this.RecalcInfo.bProps)
{
this.setRuleGap(this.spaceColumn, this.Pr.cGpRule, this.Pr.cGp, this.Pr.cSp);
this.setRuleGap(this.spaceRow, this.Pr.rSpRule, this.Pr.rSp);
this.RecalcInfo.bProps = false;
}
var plH = 0.2743827160493827 * txtPrp.FontSize;
var minGp = this.spaceRow.minGap*txtPrp.FontSize*g_dKoef_pt_to_mm;
minGp -= plH;
......@@ -229,7 +109,6 @@ CMathMatrix.prototype.recalculateSize = function(oMeasure)
{
divCenter = intervalRow - (metrics.descents[j] + metrics.ascents[j + 1]);
this.gaps.row[j + 1] = minGp > divCenter ? minGp : divCenter;
//this.gaps.row[j + 1] = divCenter;
}
var height = 0, width = 0;
......@@ -242,12 +121,12 @@ CMathMatrix.prototype.recalculateSize = function(oMeasure)
var ascent = 0;
if(this.baseJc == BASEJC_TOP)
if(this.Pr.baseJc == BASEJC_TOP)
{
for(var j = 0; j < this.nCol; j++)
ascent = this.elements[0][j].size.ascent > ascent ? this.elements[0][j].size.ascent : ascent;
}
else if(this.baseJc == BASEJC_BOTTOM)
else if(this.Pr.baseJc == BASEJC_BOTTOM)
{
var descent = 0,
currDsc;
......@@ -259,9 +138,9 @@ CMathMatrix.prototype.recalculateSize = function(oMeasure)
ascent = height - descent;
}
}
else /*this.baseJc == 0*/
else /*this.Pr.baseJc == 0*/
ascent = this.getAscent(oMeasure, height);
//center = height/2;
width += this.GapLeft + this.GapRight;
......@@ -504,23 +383,67 @@ CMathMatrix.prototype.getRowSpace = function(txtPrp)
}
CMathMatrix.prototype.baseJustification = function(type)
{
this.Pr.baseJc = type;
}
////
CMathMatrix.prototype.setProperties = function(props)
{
this.setCtrPrp(props.ctrPrp);
if(typeof(props.row) !== "undefined" || props.row !== null)
this.nRow = props.row;
if(typeof(props.column) !== "undefined" || props.column !== null)
this.nCol = props.column;
if(props.plcHide === true || props.plcHide === 1)
{
this.Pr.plcHide = true;
this.hidePlaceholder(true);
}
if(props.baseJc === BASEJC_CENTER || props.baseJc === BASEJC_TOP || props.baseJc === BASEJC_BOTTOM)
this.Pr.baseJc = props.baseJc;
if(props.mcJc == MCJC_CENTER || props.mcJc == MCJC_LEFT || props.mcJc == MCJC_RIGHT)
this.mcJc = props.mcJc;
this.Pr.cGpRule = props.cGpRule;
this.Pr.cGp = props.cGp;
this.Pr.cSp = props.cSp;
this.Pr.rSpRule = props.rSpRule;
this.Pr.rSp = props.rSp;
}
CMathMatrix.prototype.fillContent = function()
{
if(this.nRow == 0)
this.nRow = 1;
// 0 - center
// 1 - top
// 2 - bottom
if(this.nCol == 0)
this.nCol = 1;
this.baseJc = type;
this.setDimension(this.nRow, this.nCol);
this.setContent();
}
CMathMatrix.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.setProperties(props);
this.fillContent();
for(var i = 0; i < this.nRow; i++)
for(var j = 0; j < this.nCol; j++)
this.elements[i][j] = contents[j + i*this.nCol];
}
////
CMathMatrix.prototype.getPropsForWrite = function()
{
var props = {};
props.baseJc = this.baseJc;
props.row = this.nRow;
props.column = this.nCol;
props.plcHide = this.plcHide;
props.baseJc = this.Pr.baseJc;
props.row = this.Pr.nRow;
props.column = this.Pr.nCol;
props.plcHide = this.Pr.plcHide;
props.cGpRule = this.spaceColumn.rule;
props.cGp = this.spaceColumn.gap;
......@@ -690,28 +613,20 @@ CEqArray.prototype.init_2 = function(props)
Pr.ctrPrp = props.ctrPrp;
CMathMatrix.call(this, Pr);
//CEqArray.superclass.init.call(this, Pr);
}
CEqArray.prototype.old_init = function(props)
{
var prps =
{
column: 1,
row: props.row,
baseJc: "center",
rSpRule: 4,
rSp: 0
};
CEqArray.superclass.init.call(this, prps);
CEqArray.superclass.constructor.call(this, Pr);
}
CEqArray.prototype.getElement = function(num)
{
return this.elements[num][0];
}
CEqArray.prototype.fillMathComposition = function(props, contents /*array*/)
{
this.setProperties(props);
this.fillContent();
for(var i = 0; i < this.nRow; i++)
this.elements[i][0] = contents[i];
}
CEqArray.prototype.getPropsForWrite = function()
{
var props = {};
......
......@@ -18,24 +18,17 @@ function CNary(props)
limLoc: null
};
//this.limLoc = null;
//this.type = null;
//this.code = null; // for "read"
//this.grow = false;
//this.supHide = false;
//this.subHide = false;
CMathBase.call(this);
if(props !== null && typeof(props) !== "undefined")
this.init(props);
//this.setCtrPrp(props.ctrPrp);
g_oTableId.Add( this, this.Id );
}
extend(CNary, CMathBase);
CNary.prototype.init = function(props)
{
if(props.ctrPrp !== null && typeof(props.ctrPrp)!== "undefined")
this.setCtrPrp(props.ctrPrp);
if(props.supHide === true || props.supHide === 1)
......@@ -51,8 +44,6 @@ CNary.prototype.init = function(props)
var oSign = this.getSign(props.chr, props.signType);
//this.Pr.chrType = oSign.chrType;
//this.Pr.chr = String.fromCharCode(oSign.chrCode);
this.Pr.chrType = props.chrType;
this.Pr.chr = props.chr;
......@@ -65,8 +56,6 @@ CNary.prototype.init = function(props)
{
var bIntegral = oSign.chrCode > 0x222A && oSign.chrCode < 0x2231;
//var MPrp = this.Parent.Composition.GetMathPr();
if(bIntegral)
this.Pr.limLoc = g_oMathSettings.intLim;
else
......@@ -106,19 +95,20 @@ CNary.prototype.init = function(props)
}
else
{
var prp;
if( this.Pr.supHide && !this.Pr.subHide )
{
var prp = {type: DEGREE_SUBSCRIPT, indef: 2, oBase: oSign.operator, ctrPrp: this.CtrPrp.Copy() };
prp = {type: DEGREE_SUBSCRIPT, indef: 2, oBase: oSign.operator, ctrPrp: this.CtrPrp.Copy() };
base = new CDegree(prp);
}
else if( !this.Pr.supHide && this.Pr.subHide )
{
var prp = {type: DEGREE_SUPERSCRIPT, indef: 2, oBase: oSign.operator, ctrPrp: this.CtrPrp.Copy()};
prp = {type: DEGREE_SUPERSCRIPT, indef: 2, oBase: oSign.operator, ctrPrp: this.CtrPrp.Copy()};
base = new CDegree(prp);
}
else
{
var prp = {type: DEGREE_SubSup, indef: 2, oBase: oSign.operator, ctrPrp: this.CtrPrp.Copy()};
prp = {type: DEGREE_SubSup, indef: 2, oBase: oSign.operator, ctrPrp: this.CtrPrp.Copy()};
base = new CDegreeSubSup(prp);
}
}
......@@ -283,14 +273,7 @@ CNary.prototype.getLowerIterator = function()
}
CNary.prototype.getPropsForWrite = function()
{
var props = {
chr: String.fromCharCode(this.code),
grow: this.grow,
limLoc: this.limLoc,
subHide: this.subHide,
supHide: this.supHide
};
return props;
return this.Pr;
}
CNary.prototype.Save_Changes = function(Data, Writer)
{
......
......@@ -2267,7 +2267,7 @@ function COperator(type)
this.shiftAccent = 0;
}
COperator.prototype.setProperties = function(properties, defaultProps) // props (chr, type, location), defaultProps (chr, location)
COperator.prototype.mergeProperties = function(properties, defaultProps) // props (chr, type, location), defaultProps (chr, location)
{
var props = this.getProps(properties, defaultProps);
......@@ -3522,7 +3522,7 @@ CDelimiter.prototype.Resize = function(Parent, ParaMath, oMeasure)
{
type: PARENTHESIS_LEFT
};
this.begOper.setProperties(begPrp, begDefaultPrp);
this.begOper.mergeProperties(begPrp, begDefaultPrp);
this.begOper.relate(this);
var endPrp =
......@@ -3536,7 +3536,7 @@ CDelimiter.prototype.Resize = function(Parent, ParaMath, oMeasure)
type: PARENTHESIS_RIGHT
};
this.endOper.setProperties(endPrp, endDefaultPrp);
this.endOper.mergeProperties(endPrp, endDefaultPrp);
this.endOper.relate(this);
var sepPrp =
......@@ -3553,7 +3553,7 @@ CDelimiter.prototype.Resize = function(Parent, ParaMath, oMeasure)
if(this.nCol == 1 )
sepPrp.type = OPERATOR_EMPTY;
this.sepOper.setProperties(sepPrp, sepDefaultPrp);
this.sepOper.mergeProperties(sepPrp, sepDefaultPrp);
this.sepOper.relate(this);
......@@ -3983,11 +3983,11 @@ function CCharacter()
extend(CCharacter, CMathBase);
CCharacter.prototype.setCharacter = function(props, defaultProps)
{
this.operator.setProperties(props, defaultProps);
this.operator.mergeProperties(props, defaultProps);
this.operator.relate(this);
this.setDimension(1, 1);
this.setContent();
//this.setDimension(1, 1);
//this.setContent();
}
CCharacter.prototype.Resize = function(Parent, ParaMath, oMeasure)
{
......
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