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

Реализовала обтекание картинки формулой

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@63224 954022d7-b5bf-4e40-9824-e11837661b57
parent 5cad5cde
......@@ -347,10 +347,6 @@ function CMathInfo()
this.bWordLarge = false;
this.NeedUpdateWrap = true;
}
CMathInfo.prototype.GetFirstLineOnPage = function()
{
return this.FirstLineOnPage;
};
CMathInfo.prototype.GetCountLines = function()
{
return this.LineWidths.GetCountLines();
......@@ -448,12 +444,11 @@ CMathPageInfo.prototype.IsFirstPage = function(_Page)
};
CMathPageInfo.prototype.GetStarLinetWidth = function()
{
return this.Info[0].LineWidths.Get(0);
return this.Info[0].LineWidths.GetFirst();
};
CMathPageInfo.prototype.UpdateCurrentWidth = function(_Line, Width)
{
var Line = this.Info[this.CurPage].GetNumberLine(_Line - this.StartLine);
//var Line = _Line - this.StartLine - this.Info[this.CurPage].FirstLineOnPage;
return this.Info[this.CurPage].LineWidths.UpdateWidth(Line, Width);
};
......@@ -509,7 +504,7 @@ CMathPageInfo.prototype.GetFirstLineOnPage = function(_Page)
{
var Page = _Page - this.StartPage;
var FirstLineOnPage = this.Info[Page].GetFirstLineOnPage();
var FirstLineOnPage = this.Info[Page].FirstLineOnPage;
return this.StartLine + FirstLineOnPage;
};
......@@ -773,7 +768,7 @@ ParaMath.prototype.Get_AlignToLine = function(_CurLine, _CurRange, _Page, _X, _X
W = MaxW;
}
if(this.Root.IsStartLine(_CurLine)) // первая строка первой страницы
if(this.Root.IsFirstRange(_CurLine, _CurRange)) // первая строка первой страницы, если строка разбивается на несколько отрезко, то это уже будет inline-формула
{
switch(Jc)
{
......@@ -1146,7 +1141,7 @@ ParaMath.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
var Page = AbsolutePage + PRS.Page;
var PrevLineObject = PRS.RestartPageRecalcInfo.Object;
var bStartLine = this.Root.IsStartLine(ParaLine);
var bFirstRange = this.Root.IsFirstRange(ParaLine, ParaRange);
var MathSettings = Get_WordDocumentDefaultMathSettings();
......@@ -1156,7 +1151,7 @@ ParaMath.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
var ArgSize = new CMathArgSize();
// первый пересчет
if(PrevLineObject == null && true == bStartLine && PRS.bFastRecalculate == false)
if(PrevLineObject == null && true == bFirstRange && PRS.bFastRecalculate == false)
{
this.PageInfo.Reset();
this.PageInfo.SetStartPos(Page, ParaLine);
......@@ -1189,7 +1184,7 @@ ParaMath.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
PRS.WrapIndent = WrapIndent;
if(bStartLine == false)
if(this.Root.IsStartLine() == false)
{
PRS.X += WrapIndent;
PRS.bCompareWrapIndent = false;
......@@ -1328,6 +1323,13 @@ ParaMath.prototype.Recalculate_Range_Spaces = function(PRSA, _CurLine, _CurRange
Page = this.Paragraph.Get_StartPage_Absolute();
var pos = new CMathPosition();
if(false == this.Root.IsStartRange(_CurLine, _CurRange))
{
var LinePos = this.Root.GetPos(_CurLine);
pos.x += PRSA.X - LinePos.x;
}
this.Root.setPosition(pos, PRSA, _CurLine, _CurRange, Page + _CurPage);
this.Root.Recalculate_Range_Spaces(PRSA, _CurLine, _CurRange, Page + _CurPage);
......@@ -1436,18 +1438,8 @@ ParaMath.prototype.Recalculate_MinMaxContentWidth = function(MinMax)
ParaMath.prototype.Get_Range_VisibleWidth = function(RangeW, _CurLine, _CurRange)
{
var CurLine = _CurLine - this.StartLine;
var CurRange = ( 0 === CurLine ? _CurRange - this.StartRange : _CurRange );
var StartPos = this.protected_GetRangeStartPos(CurLine, CurRange);
var EndPos = this.protected_GetRangeEndPos(CurLine, CurRange);
if ( EndPos >= 1 )
{
RangeW.W += this.Width;
}
this.Root.Get_Range_VisibleWidth(RangeW, _CurLine, _CurRange);
};
ParaMath.prototype.Is_BrkBinBefore = function()
{
var MathSettings = Get_WordDocumentDefaultMathSettings();
......@@ -1921,39 +1913,6 @@ ParaMath.prototype.Cursor_MoveToEndPos = function(SelectFromEnd)
this.Root.Cursor_MoveToEndPos(SelectFromEnd);
};
ParaMath.prototype.old_Get_ParaContentPosByXY = function(SearchPos, Depth, _CurLine, _CurRange, StepEnd, Flag) // получить логическую позицию по XY
{
var Result = false;
var CurLine = _CurLine - this.StartLine;
var CurRange = ( 0 === CurLine ? _CurRange - this.StartRange : _CurRange ); // если находимся в нулевой строке (для текущей позиции), то CurRange мб ненулевой
var EndPos = this.protected_GetRangeEndPos(CurLine, CurRange);
// Проверяем, попали ли мы в формулу
if ( EndPos >= 1 )
{
var Dx = this.Root.size.width;
var D = SearchPos.X - SearchPos.CurX;
var CurX = SearchPos.CurX;
Result = this.Root.Get_ParaContentPosByXY(SearchPos, Depth, _CurLine, _CurRange, StepEnd);
if ( D >= - 0.001 && D <= Dx + 0.001 )
{
SearchPos.InText = true;
SearchPos.DiffX = 0.001;
SearchPos.InTextPos.Copy_FromDepth(SearchPos.Pos, Depth);
}
SearchPos.CurX = CurX + Dx;
}
return Result;
};
ParaMath.prototype.Get_ParaContentPosByXY = function(SearchPos, Depth, _CurLine, _CurRange, StepEnd, Flag) // получить логическую позицию по XY
{
var Result = this.Root.Get_ParaContentPosByXY(SearchPos, Depth, _CurLine, _CurRange, StepEnd);
......
......@@ -1011,7 +1011,7 @@ ParaRun.prototype.Get_ParaPosByContentPos = function(ContentPos, Depth)
};
ParaRun.prototype.Recalculate_CurPos = function(X, Y, CurrentRun, _CurRange, _CurLine, CurPage, UpdateCurPos, UpdateTarget, ReturnTarget, PointsInfo)
ParaRun.prototype.Recalculate_CurPos = function(X, Y, CurrentRun, _CurRange, _CurLine, CurPage, UpdateCurPos, UpdateTarget, ReturnTarget)
{
var Para = this.Paragraph;
......@@ -1030,9 +1030,11 @@ ParaRun.prototype.Recalculate_CurPos = function(X, Y, CurrentRun, _CurRange, _Cu
Pos = _EndPos;
var loc;
var MATH_X = X;
var LocParaMath = this.ParaMath.GetLinePosition(_CurLine);
X = LocParaMath.x;
var MATH_Y = Y;
var loc;
if(Lng == 0)
{
......@@ -2071,6 +2073,8 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
var ContentLen = this.Content.length;
var XRange = PRS.XRange;
var bAbsent_Internal_Ranges;
if (false === StartWord && true === FirstItemOnLine && XEnd - X < 0.001 && RangesCount > 0)
{
NewRange = true;
......@@ -2198,7 +2202,6 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
// При проверке, убирается ли слово, мы должны учитывать ширину предшествующих пробелов.
var LetterLen = Item.Get_Width2() / TEXTWIDTH_DIVIDER;//var LetterLen = Item.Get_Width();
if (true !== Word)
{
// Слово только началось. Делаем следующее:
......@@ -2228,7 +2231,7 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
{
if(X + SpaceLen + WordLen + LetterLen > XEnd)
{
if(true === FirstItemOnLine)
if(true === FirstItemOnLine && true === Para.Internal_Check_Ranges(ParaLine, ParaRange))
{
// Слово оказалось единственным элементом в промежутке, и, все равно,
// не умещается целиком. Делаем следующее:
......@@ -2288,11 +2291,13 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
bNoOneBreakOperator = false;
var bFirstItem = true === FirstItemOnLine && true === Para.Internal_Check_Ranges(ParaLine, ParaRange);
if(bOperInEndContent || bLowPriority)
{
if(X + SpaceLen + WordLen + BrkLen > XEnd)
{
if(true === FirstItemOnLine)
if(bFirstItem == true)
{
bMathWordLarge = true;
}
......@@ -2318,7 +2323,7 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
var bOverXEnd;
if(bCompareOper && bFirstCompareOper == true && PRS.bCompareWrapIndent == true && WorLenCompareOper > PRS.WrapIndent && !(Word == false && FirstItemOnLine == true)) // (Word == true && FirstItemOnLine == true) - не первый элемент в строке
if(bCompareOper && bFirstCompareOper == true && PRS.bCompareWrapIndent == true && WorLenCompareOper > PRS.WrapIndent && !(Word == false && bFirstItem == true)) // (Word == true && FirstItemOnLine == true) - не первый элемент в строке
bFirstCompareOper = false;
if(bOperBefore) // оператор "до"
......@@ -2326,7 +2331,7 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
bOverXEnd = X + WordLen + SpaceLen > XEnd;
if(bOverXEnd && FirstItemOnLine == false) // Слово не убирается в отрезке. Переносим слово в следующий отрезок
if(bOverXEnd && bFirstItem == false) // Слово не убирается в отрезке. Переносим слово в следующий отрезок
{
MoveToLBP = true;
NewRange = true;
......@@ -2351,15 +2356,15 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
if(SpaceLen !== 0)
FirstItemOnLine = false;
if(FirstItemOnLine == false)
if(bFirstItem == false)
{
PRS.Set_LineBreakPos(Pos);
// FirstItemOnLine == true && Word == false
// первое слово в строке
if(FirstItemOnLine == true)
}
else
{
SpaceLen += BrkLen - Item.GapLeft;
}
}
}
}
......@@ -2367,7 +2372,7 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
{
bOverXEnd = X + WordLen + BrkLen - Item.GapRight > XEnd;
if(bOverXEnd && FirstItemOnLine == false) // Слово не убирается в отрезке. Переносим слово в следующий отрезок
if(bOverXEnd && bFirstItem == false) // Слово не убирается в отрезке. Переносим слово в следующий отрезок
{
MoveToLBP = true;
NewRange = true;
......@@ -3729,12 +3734,14 @@ ParaRun.prototype.Get_Range_VisibleWidth = function(RangeW, _CurLine, _CurRange)
case para_Sym:
case para_Text:
case para_Space:
case para_Math_Text:
case para_Math_Ampersand:
case para_Math_Placeholder:
case para_Math_BreakOperator:
{
RangeW.W += Item.Get_WidthVisible();
break;
}
case para_Drawing:
{
if ( true === Item.Is_Inline() )
......
......@@ -1305,76 +1305,8 @@ CMathBase.prototype.Recalculate_CurPos = function(_X, Y, CurrentRun, _CurRange,
{
return this.Content[this.CurPos].Recalculate_CurPos(_X, Y, CurrentRun, _CurRange, _CurLine, _CurPage, UpdateCurPos, UpdateTarget, ReturnTarget);
};
CMathBase.prototype.old_Get_ParaContentPosByXY = function(SearchPos, Depth, _CurLine, _CurRange, StepEnd)
{
var nCount = this.Content.length;
if (nCount <= 0)
return false;
var aBounds = [];
for (var nIndex = 0; nIndex < nCount; nIndex++)
{
var oBounds = this.Content[nIndex].Get_Bounds();
if (oBounds.W > 0.001 && oBounds.H > 0.001)
aBounds.push(oBounds);
else
aBounds.push(null);
}
var X = SearchPos.X;
var Y = SearchPos.Y;
var dDiff = null;
var nCurIndex = 0;
var nFindIndex = 0;
while (nCurIndex < nCount)
{
var oBounds = aBounds[nCurIndex];
if (null !== oBounds)
{
if (oBounds.X <= X && X <= oBounds.X + oBounds.W && oBounds.Y <= Y && Y <= oBounds.Y + oBounds.H)
{
nFindIndex = nCurIndex;
break;
}
else
{
var dCurDiffX = X - (oBounds.X + oBounds.W / 2);
var dCurDiffY = Y - (oBounds.Y + oBounds.H / 2);
var dCurDiff = dCurDiffX * dCurDiffX + dCurDiffY * dCurDiffY;
if (null === dDiff || dDiff > dCurDiff)
{
dDiff = dCurDiff;
nFindIndex = nCurIndex;
}
}
}
nCurIndex++;
}
if (null === aBounds[nFindIndex])
return false;
SearchPos.CurX = aBounds[nFindIndex].X;
SearchPos.CurY = aBounds[nFindIndex].Y;
var bResult = this.Content[nFindIndex].Get_ParaContentPosByXY(SearchPos, Depth + 1, _CurLine, _CurRange, StepEnd);
if(true === bResult)
{
SearchPos.Pos.Update2(nFindIndex, Depth);
}
return bResult;
};
CMathBase.prototype.Get_ParaContentPosByXY = function(SearchPos, Depth, _CurLine, _CurRange, StepEnd)
{
var bResult = false;
var nCount = this.Content.length;
if (nCount <= 0)
return false;
......@@ -1438,7 +1370,8 @@ CMathBase.prototype.Get_ParaContentPosByXY = function(SearchPos, Depth, _CurLine
SearchPos.CurX = aBounds[nFindIndex].X;
SearchPos.CurY = aBounds[nFindIndex].Y;
bResult = this.Content[nFindIndex].Get_ParaContentPosByXY(SearchPos, Depth + 1, _CurLine, _CurRange, StepEnd);
var bResult = this.Content[nFindIndex].Get_ParaContentPosByXY(SearchPos, Depth + 1, _CurLine, _CurRange, StepEnd);
if(true === bResult)
{
SearchPos.Pos.Update2(nFindIndex, Depth);
......@@ -1831,8 +1764,6 @@ CMathBase.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
var RangeStartPos = this.protected_AddRange(CurLine, CurRange),
RangeEndPos = Len - 1;
//this.VerifyWordLen(PRS);
if(CurLine == 0 && CurRange == 0)
{
PRS.WordLen += this.BrGapLeft;
......@@ -1908,11 +1839,6 @@ CMathBase.prototype.Math_GetWidth = function(_CurLine, _CurRange)
{
return this.size.width;
};
CMathBase.prototype.VerifyWordLen = function(PRS)
{
if(true !== PRS.Word)
PRS.WordLen = 0;
};
CMathBase.prototype.Update_WordLen = function(PRS, WordLen)
{
if(this.bInside == false)
......@@ -2083,6 +2009,26 @@ CMathBase.prototype.IsShade = function()
var oShd = this.Get_CompiledCtrPrp().Shd;
return !(oShd === undefined || shd_Nil === oShd.Value);
};
CMathBase.prototype.Get_Range_VisibleWidth = function(RangeW, _CurLine, _CurRange)
{
if(this.bOneLine)
{
RangeW.W += this.size.width;
}
else
{
var CurLine = _CurLine - this.StartLine;
var CurRange = ( 0 === CurLine ? _CurRange - this.StartRange : _CurRange );
var StartPos = this.protected_GetRangeStartPos(CurLine, CurRange);
var EndPos = this.protected_GetRangeEndPos(CurLine, CurRange);
for (var CurPos = StartPos; CurPos <= EndPos; CurPos++ )
{
this.Content[CurPos].Get_Range_VisibleWidth(RangeW, _CurLine, _CurRange);
}
}
};
CMathBase.prototype.Get_CurrentParaPos = CMathContent.prototype.Get_CurrentParaPos;
CMathBase.prototype.private_UpdatePosOnAdd = CMathContent.prototype.private_UpdatePosOnAdd;
CMathBase.prototype.private_UpdatePosOnRemove = CMathContent.prototype.private_UpdateOnRemove;
......
......@@ -1013,7 +1013,9 @@ CMathContent.prototype.setPosition = function(pos, PRSA, Line, Range, Page)
this.pos.x = pos.x;
}
if(this.IsStartRange(Line, Range))
this.Bounds.SetPos(CurLine, this.pos, PRSA);
this.Bounds.SetPage(CurLine, Page);
for(var i = StartPos; i <= EndPos; i++)
......@@ -3116,29 +3118,6 @@ CMathContent.prototype.Get_CurrentParaPos = function()
return new CParaPos( this.StartRange, this.StartLine, 0, 0 );
};
CMathContent.prototype.old_Get_ParaContentPosByXY = function(SearchPos, Depth, _CurLine, _CurRange, StepEnd)
{
var nLength = this.Content.length;
if (nLength <= 0)
return false;
var bResult = false;
for (var nPos = 0; nPos < nLength; nPos++)
{
var CurX = SearchPos.CurX;
if(true === this.Content[nPos].Get_ParaContentPosByXY(SearchPos, Depth + 1, _CurLine, _CurRange, StepEnd))
{
SearchPos.Pos.Update2(nPos, Depth);
bResult = true;
}
SearchPos.CurX = CurX + this.Content[nPos].size.width;
}
return bResult;
};
CMathContent.prototype.Get_ParaContentPos = function(bSelection, bStart, ContentPos)
{
var nPos = (true !== bSelection ? this.CurPos : (false !== bStart ? this.Selection.Start : this.Selection.End));
......@@ -4315,16 +4294,18 @@ CMathContent.prototype.Math_Is_End = function(_CurLine, _CurRange)
return result;
};
CMathContent.prototype.IsStartRange = function(Line, Range)
{
var bFirstLine = Line - this.StartLine == 0;
return bFirstLine ? Range - this.StartRange == 0 : Range == 0;
};
CMathContent.prototype.IsStartLine = function(Line)
{
return Line - this.StartLine == 0;
return Line == this.StartLine;
};
CMathContent.prototype.IsFirstRange = function(Line, Range)
{
var CurLine = Line - this.StartLine,
CurRange = Range - this.StartRange;
return CurLine == 0 && CurRange == 0;
return Line - this.StartLine == 0 && Range - this.StartRange == 0;
};
CMathContent.prototype.IsEndLine = function(Line)
{
......
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