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

1. поправила перемещение по стрелкам для плейсхолдера (пока выставляется курсор вместо селекта)

2. поправила функцию для смерженных текстовых настроек (applyArgSize) в base.js

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@55817 954022d7-b5bf-4e40-9824-e11837661b57
parent a204c9b1
...@@ -183,16 +183,19 @@ CMathBase.prototype = ...@@ -183,16 +183,19 @@ CMathBase.prototype =
if( !this.elements[i][j].IsJustDraw()) if( !this.elements[i][j].IsJustDraw())
this.elements[i][j].setArgSize(argSize); this.elements[i][j].setArgSize(argSize);
}, },
// TO DO
// посмотреть для всех мат. объектов, где используется эта функция
mergeCtrTPrp: function() mergeCtrTPrp: function()
{ {
var tPrp = this.getCtrPrp(); var tPrp = this.getCtrPrp();
this.Composition.Parent.ApplyArgSize(tPrp);
if(this.argSize == -1) /*if(this.argSize == -1)
//tPrp.FontSize *= 0.8; //tPrp.FontSize *= 0.8;
tPrp.FontSize *= 0.728; tPrp.FontSize *= 0.728;
else if(this.argSize == -2) else if(this.argSize == -2)
//tPrp.FontSize *= 0.65; //tPrp.FontSize *= 0.65;
tPrp.FontSize *= 0.53; tPrp.FontSize *= 0.53;*/
return tPrp; return tPrp;
}, },
...@@ -1443,7 +1446,10 @@ CMathBase.prototype = ...@@ -1443,7 +1446,10 @@ CMathBase.prototype =
{ {
while(CurPos_Y >= 0) while(CurPos_Y >= 0)
{ {
if( ! this.elements[CurPos_X][CurPos_Y].IsJustDraw() ) var bJDraw = this.elements[CurPos_X][CurPos_Y].IsJustDraw(),
usePlh = bUseContent && this.elements[CurPos_X][CurPos_Y].IsPlaceholder();
if(!bJDraw && ! usePlh)
{ {
this.elements[CurPos_X][CurPos_Y].Get_LeftPos(SearchPos, ContentPos, Depth + 2, bUseContent, EndRun); this.elements[CurPos_X][CurPos_Y].Get_LeftPos(SearchPos, ContentPos, Depth + 2, bUseContent, EndRun);
SearchPos.Pos.Update(CurPos_X, Depth); SearchPos.Pos.Update(CurPos_X, Depth);
...@@ -1469,48 +1475,6 @@ CMathBase.prototype = ...@@ -1469,48 +1475,6 @@ CMathBase.prototype =
result = SearchPos.Found; result = SearchPos.Found;
/*if( ! this.elements[CurPos_X][CurPos_Y].IsJustDraw() )
{
this.elements[CurPos_X][CurPos_Y].Get_LeftPos(SearchPos, ContentPos, Depth + 2, UseContentPos, EndRun);
SearchPos.Pos.Update(CurPos_X, Depth);
SearchPos.Pos.Update(CurPos_Y, Depth+1);
if(SearchPos.Found === true)
result = true;
}
if( result == false)
{
while(CurPos_Y >= 0)
{
while(CurPos_X >= 0)
{
if( this.elements[CurPos_X][CurPos_Y].IsJustDraw() == false)
{
this.elements[CurPos_X][CurPos_Y].Get_LeftPos(SearchPos, ContentPos, Depth + 2, false, true);
SearchPos.Pos.Update(CurPos_X, Depth);
SearchPos.Pos.Update(CurPos_Y, Depth+1);
}
if(SearchPos.Found === true)
{
result = true;
break;
}
CurPos_X--;
}
if(SearchPos.Found === true)
break;
CurPos_Y--;
CurPos_X = this.nRow;
}
}*/
return result; return result;
}, },
Get_RightPos: function(SearchPos, ContentPos, Depth, UseContentPos, BegRun) Get_RightPos: function(SearchPos, ContentPos, Depth, UseContentPos, BegRun)
...@@ -1535,7 +1499,10 @@ CMathBase.prototype = ...@@ -1535,7 +1499,10 @@ CMathBase.prototype =
{ {
while(CurPos_Y < this.nCol) while(CurPos_Y < this.nCol)
{ {
if( ! this.elements[CurPos_X][CurPos_Y].IsJustDraw() ) var bJDraw = this.elements[CurPos_X][CurPos_Y].IsJustDraw(),
usePlh = bUseContent && this.elements[CurPos_X][CurPos_Y].IsPlaceholder();
if(!bJDraw && ! usePlh)
{ {
this.elements[CurPos_X][CurPos_Y].Get_RightPos(SearchPos, ContentPos, Depth + 2, bUseContent, BegRun); this.elements[CurPos_X][CurPos_Y].Get_RightPos(SearchPos, ContentPos, Depth + 2, bUseContent, BegRun);
SearchPos.Pos.Update(CurPos_X, Depth); SearchPos.Pos.Update(CurPos_X, Depth);
......
This diff is collapsed.
...@@ -142,6 +142,9 @@ CCoeffGaps.prototype = ...@@ -142,6 +142,9 @@ CCoeffGaps.prototype =
var COEFF_GAPS = new CCoeffGaps(); var COEFF_GAPS = new CCoeffGaps();
// TODO
// проконтролировать GapLeft и GapRight для setPosition всех элементов
function CRecalculateInfo(oMeasure, Parent) function CRecalculateInfo(oMeasure, Parent)
{ {
this.measure = oMeasure; this.measure = oMeasure;
...@@ -5045,7 +5048,8 @@ CMathContent.prototype = ...@@ -5045,7 +5048,8 @@ CMathContent.prototype =
var runPrp = this.content[pos].getRunPrp(); var runPrp = this.content[pos].getRunPrp();
var currRPrp = runPrp.getMergedWPrp(); var currRPrp = runPrp.getMergedWPrp();
this.applyArgSize(currRPrp); //this.applyArgSize(currRPrp);
this.Composition.Parent.ApplyArgSize(currRPrp); // в ParaMath
RecalcInfo.currRunPrp = currRPrp; RecalcInfo.currRunPrp = currRPrp;
...@@ -5059,7 +5063,8 @@ CMathContent.prototype = ...@@ -5059,7 +5063,8 @@ CMathContent.prototype =
{ {
var oWPrp = this.Parent.getCtrPrp(); var oWPrp = this.Parent.getCtrPrp();
this.applyArgSize(oWPrp); //this.applyArgSize(oWPrp);
this.Composition.Parent.ApplyArgSize(oWPrp);
oWPrp.Italic = false; oWPrp.Italic = false;
oMeasure.SetFont(oWPrp); oMeasure.SetFont(oWPrp);
...@@ -5181,7 +5186,8 @@ CMathContent.prototype = ...@@ -5181,7 +5186,8 @@ CMathContent.prototype =
var oWPrp = new CTextPr(); var oWPrp = new CTextPr();
oWPrp.Merge(mgWPrp); oWPrp.Merge(mgWPrp);
this.applyArgSize(oWPrp); //this.applyArgSize(oWPrp);
this.Composition.Parent.ApplyArgSize(oWPrp);
pGraphics.SetFont(oWPrp); pGraphics.SetFont(oWPrp);
} }
...@@ -5191,7 +5197,9 @@ CMathContent.prototype = ...@@ -5191,7 +5197,9 @@ CMathContent.prototype =
var oWPrp = this.Parent.getCtrPrp(); var oWPrp = this.Parent.getCtrPrp();
this.applyArgSize(oWPrp); //this.applyArgSize(oWPrp);
this.Composition.Parent.ApplyArgSize(oWPrp);
oWPrp.Italic = false; oWPrp.Italic = false;
pGraphics.SetFont(oWPrp); pGraphics.SetFont(oWPrp);
...@@ -5719,48 +5727,6 @@ CMathContent.prototype = ...@@ -5719,48 +5727,6 @@ CMathContent.prototype =
return rPrp; return rPrp;
}, },
applyArgSize: function(oWPrp)
{
var tPrp = new CTextPr();
var defaultRPrp = this.Composition.GetDefaultRunPrp();
var gWPrp = defaultRPrp.getMergedWPrp();
tPrp.Merge(gWPrp);
tPrp.Merge(oWPrp);
var FSize = tPrp.FontSize;
if(this.argSize == -1)
{
//aa: 0.0013 bb: 0.66 cc: 0.5
//aa: 0.0009 bb: 0.68 cc: 0.26
FSize = 0.0009*FSize*FSize + 0.68*FSize + 0.26;
//FSize = 0.001*FSize*FSize + 0.723*FSize - 1.318;
//FSize = 0.0006*FSize*FSize + 0.743*FSize - 1.53;
}
else if(this.argSize == -2)
{
// aa: -0.0004 bb: 0.66 cc: 0.87
// aa: -0.0014 bb: 0.71 cc: 0.39
// aa: 0 bb: 0.63 cc: 1.11
//FSize = 0.63*FSize + 1.11;
FSize = -0.0004*FSize*FSize + 0.66*FSize + 0.87;
//tPrp.FontSize *= 0.473;
}
tPrp.FontSize = FSize;
oWPrp.Merge(tPrp);
/*
if(this.argSize == -1)
//tPrp.FontSize *= 0.8;
tPrp.FontSize *= 0.728;
//tPrp.FontSize *= 0.65;
else if(this.argSize == -2)
//tPrp.FontSize *= 0.65;
tPrp.FontSize *= 0.53;
//tPrp.FontSize *= 0.473;*/
},
increaseArgSize: function() increaseArgSize: function()
{ {
if(this.argSize < 2) if(this.argSize < 2)
...@@ -5868,7 +5834,21 @@ CMathContent.prototype = ...@@ -5868,7 +5834,21 @@ CMathContent.prototype =
Y = this.pos.y + absPos.y + this.size.ascent; Y = this.pos.y + absPos.y + this.size.ascent;
_X = this.pos.x + absPos.x + this.size.width; _X = this.pos.x + absPos.x + this.size.width;
result = { X: _X}; var ctrPrp = this.Parent.getCtrPrp();
this.Composition.Parent.ApplyArgSize(ctrPrp);
//this.applyArgSize(ctrPrp);
var sizeCursor = ctrPrp.FontSize*g_dKoef_pt_to_mm;
Y -= sizeCursor*0.8;
this.Composition.Parent.Paragraph.DrawingDocument.SetTargetSize(sizeCursor);
//Para.DrawingDocument.UpdateTargetFromPaint = true;
this.Composition.Parent.Paragraph.DrawingDocument.UpdateTarget( _X, Y, this.Composition.Parent.Paragraph.Get_StartPage_Absolute() + _CurPage );
//console.log("X of placeholder " + _X);
result = {X: _X, Y: Y};
} }
return result; return result;
...@@ -6241,7 +6221,13 @@ CMathContent.prototype = ...@@ -6241,7 +6221,13 @@ CMathContent.prototype =
var curType = this.content[CurPos].typeObj, var curType = this.content[CurPos].typeObj,
prevType = CurPos > 0 ? this.content[CurPos - 1].typeObj : null; prevType = CurPos > 0 ? this.content[CurPos - 1].typeObj : null;
if(curType == MATH_COMP) if(curType == MATH_PLACEHOLDER)
{
SearchPos.Pos.Update(0, Depth + 1);
SearchPos.Found = true;
}
else if(curType == MATH_COMP)
{ {
this.content[CurPos].Get_LeftPos(SearchPos, ContentPos, Depth + 1, bUseContent, EndRun); this.content[CurPos].Get_LeftPos(SearchPos, ContentPos, Depth + 1, bUseContent, EndRun);
} }
...@@ -6273,37 +6259,6 @@ CMathContent.prototype = ...@@ -6273,37 +6259,6 @@ CMathContent.prototype =
/// для коррекции позиции курсора в начале Run /// для коррекции позиции курсора в начале Run
// используется функция Correct_ContentPos в Paragraph // используется функция Correct_ContentPos в Paragraph
/*if ( true === SearchPos.Found )
result = true;
if(this.content[CurPos].typeObj == MATH_COMP)
EndRun = true;
CurPos--;
if(result == false)
{
while ( CurPos >= 0 )
{
this.content[CurPos].Get_LeftPos(SearchPos, ContentPos, Depth + 1, false, EndRun);
SearchPos.Pos.Update( CurPos, Depth );
if ( true === SearchPos.Found )
{
result = true;
break;
}
if(this.content[CurPos].typeObj == MATH_COMP)
EndRun = true;
else
EndRun = false;
CurPos--;
}
}*/
return result; return result;
}, },
...@@ -6319,7 +6274,12 @@ CMathContent.prototype = ...@@ -6319,7 +6274,12 @@ CMathContent.prototype =
var curType = this.content[CurPos].typeObj, var curType = this.content[CurPos].typeObj,
nextType = CurPos < this.content.length - 1 ? this.content[CurPos + 1].typeObj : null; nextType = CurPos < this.content.length - 1 ? this.content[CurPos + 1].typeObj : null;
if(curType == MATH_COMP) if(curType == MATH_PLACEHOLDER)
{
SearchPos.Pos.Update(0, Depth + 1);
SearchPos.Found = true;
}
else if(curType == MATH_COMP)
{ {
this.content[CurPos].Get_RightPos(SearchPos, ContentPos, Depth + 1, bUseContent, BegRun); this.content[CurPos].Get_RightPos(SearchPos, ContentPos, Depth + 1, bUseContent, BegRun);
} }
...@@ -7289,7 +7249,6 @@ CMathComposition.prototype = ...@@ -7289,7 +7249,6 @@ CMathComposition.prototype =
this.SelectContent.RecalculateReverse(oMeasure); this.SelectContent.RecalculateReverse(oMeasure);
},*/ },*/
//////////////* end of test functions *////////////////// //////////////* end of test functions *//////////////////
Init: function() Init: function()
{ {
this.Root = new CMathContent(); this.Root = new CMathContent();
......
...@@ -13,6 +13,9 @@ var DIV_CENT = 0.1386; ...@@ -13,6 +13,9 @@ var DIV_CENT = 0.1386;
var StartTextElement = 0x2B1A; // Cambria Math var StartTextElement = 0x2B1A; // Cambria Math
// TODO
// убрать CMathTextPrp
function CMathTextPrp() function CMathTextPrp()
{ {
this.FontFamily = undefined; this.FontFamily = undefined;
...@@ -305,7 +308,7 @@ CMathText.prototype = ...@@ -305,7 +308,7 @@ CMathText.prototype =
setPosition: function(pos) setPosition: function(pos)
{ {
if( ! this.bJDraw) // for text if( ! this.bJDraw) // for text
this.pos = {x : pos.x, y: pos.y}; this.pos = {x : pos.x + this.GapLeft, y: pos.y};
else // for symbol only drawing else // for symbol only drawing
{ {
var x = pos.x - this.rasterOffsetX, var x = pos.x - this.rasterOffsetX,
......
...@@ -183,4 +183,7 @@ var extend = function(Child, Parent) ...@@ -183,4 +183,7 @@ var extend = function(Child, Parent)
Child.prototype.constructor = Child; Child.prototype.constructor = Child;
Child.superclass = Parent.prototype; Child.superclass = Parent.prototype;
} }
\ No newline at end of file
// default Txt Prp
// argSize
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