Commit 2e3c18aa authored by Ilya.Kirillov's avatar Ilya.Kirillov Committed by Alexander.Trofimov

Доработан пересчет максимальной и минимальной ширин параграфа в новом варианте.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@55033 954022d7-b5bf-4e40-9824-e11837661b57
parent cf4c4352
......@@ -1052,6 +1052,11 @@ ParaComment.prototype =
{
return { X : X };
},
Recalculate_MinMaxContentWidth : function()
{
},
//-----------------------------------------------------------------------------------
// Функции отрисовки
//-----------------------------------------------------------------------------------
......
......@@ -958,6 +958,15 @@ ParaHyperlink.prototype =
{
this.Paragraph.Refresh_RecalcData2(0);
},
Recalculate_MinMaxContentWidth : function(MinMax)
{
var Count = this.Content.length;
for ( var Pos = 0; Pos < Count; Pos++ )
{
this.Content[Pos].Recalculate_MinMaxContentWidth(MinMax);
}
},
//-----------------------------------------------------------------------------------
// Функции отрисовки
//-----------------------------------------------------------------------------------
......
......@@ -584,6 +584,29 @@ ParaMath2.prototype =
{
this.Paragraph.Refresh_RecalcData2(0);
},
Recalculate_MinMaxContentWidth : function(MinMax)
{
// TODO: Если формула не измерена, тогда здесь её надо измерить
if ( false === MinMax.bWord )
{
MinMax.bWord = true;
MinMax.nWordLen = this.Width;
}
else
{
MinMax.nWordLen += this.Width;
}
if ( MinMax.nSpaceLen > 0 )
{
MinMax.nCurMaxWidth += MinMax.nSpaceLen;
MinMax.nSpaceLen = 0;
}
MinMax.nCurMaxWidth += this.Width;
},
//-----------------------------------------------------------------------------------
// Функции отрисовки
//-----------------------------------------------------------------------------------
......
......@@ -5637,6 +5637,8 @@ Paragraph.prototype =
},
Recalculate_MinMaxContentWidth : function()
{
if ( true !== Debug_ParaRunMode )
{
// Пересчитаем ширины всех элементов
this.Internal_Recalculate_0();
......@@ -5814,6 +5816,23 @@ Paragraph.prototype =
// добавляем 0.001, чтобы избавиться от погрешностей
return { Min : ( nMinWidth > 0 ? nMinWidth + 0.001 : 0 ), Max : ( nMaxWidth > 0 ? nMaxWidth + 0.001 : 0 ) };
}
else
{
var MinMax = new CParagraphMinMaxContentWidth();
var Count = this.Content.length;
for ( var Pos = 0; Pos < Count; Pos++ )
{
var Item = this.Content[Pos];
Item.Recalculate_MinMaxContentWidth( MinMax );
}
// добавляем 0.001, чтобы избавиться от погрешностей
return { Min : ( MinMax.nMinWidth > 0 ? MinMax.nMinWidth + 0.001 : 0 ), Max : ( MinMax.nMaxWidth > 0 ? MinMax.nMaxWidth + 0.001 : 0 ) };
}
},
Draw : function(PageNum, pGraphics)
......@@ -22215,3 +22234,13 @@ function CParagraphStatistics(Stats)
this.Space = false;
this.NewWord = false;
}
function CParagraphMinMaxContentWidth()
{
this.bWord = false;
this.nWordLen = 0;
this.nSpaceLen = 0;
this.nMinWidth = 0;
this.nMaxWidth = 0;
this.nCurMaxWidth = 0;
}
\ No newline at end of file
......@@ -2346,6 +2346,185 @@ ParaRun.prototype =
return true;
},
Recalculate_MinMaxContentWidth : function(MinMax)
{
this.Recalculate_MeasureContent();
var bWord = MinMax.bWord;
var nWordLen = MinMax.nWordLen;
var nSpaceLen = MinMax.nSpaceLen;
var nMinWidth = MinMax.nMinWidth;
var nMaxWidth = MinMax.nMaxWidth;
var nCurMaxWidth = MinMax.nCurMaxWidth;
var Count = this.Content.length;
for ( var Pos = 0; Pos < Count; Pos++ )
{
var Item = this.Content[Pos];
switch( Item.Type )
{
case para_Text:
{
if ( false === bWord )
{
bWord = true;
nWordLen = Item.Width;
}
else
{
nWordLen += Item.Width;
if ( true === Item.SpaceAfter )
{
if ( nMinWidth < nWordLen )
nMinWidth = nWordLen;
bWord = false;
nWordLen = 0;
}
}
if ( nSpaceLen > 0 )
{
nCurMaxWidth += nSpaceLen;
nSpaceLen = 0;
}
nCurMaxWidth += Item.Width;
break;
}
case para_Space:
{
if ( true === bWord )
{
if ( nMinWidth < nWordLen )
nMinWidth = nWordLen;
bWord = false;
nWordLen = 0;
}
// Мы сразу не добавляем ширину пробелов к максимальной ширине, потому что
// пробелы, идущие в конце параграфа или перед переносом строки(явным), не
// должны учитываться.
nSpaceLen += Item.Width;
break;
}
case para_Drawing:
{
if ( true === bWord )
{
if ( nMinWidth < nWordLen )
nMinWidth = nWordLen;
bWord = false;
nWordLen = 0;
}
if ( ( true === Item.Is_Inline() || true === this.Parent.Is_DrawingShape() ) && Item.Width > nMinWidth )
nMinWidth = Item.Width;
if ( nSpaceLen > 0 )
{
nCurMaxWidth += nSpaceLen;
nSpaceLen = 0;
}
nCurMaxWidth += Item.Width;
break;
}
case para_PageNum:
{
if ( true === bWord )
{
if ( nMinWidth < nWordLen )
nMinWidth = nWordLen;
bWord = false;
nWordLen = 0;
}
if ( Item.Width > nMinWidth )
nMinWidth = Item.Width;
if ( nSpaceLen > 0 )
{
nCurMaxWidth += nSpaceLen;
nSpaceLen = 0;
}
nCurMaxWidth += Item.Width;
break;
}
case para_Tab:
{
nWordLen += Item.Width;
if ( nMinWidth < nWordLen )
nMinWidth = nWordLen;
bWord = false;
nWordLen = 0;
if ( nSpaceLen > 0 )
{
nCurMaxWidth += nSpaceLen;
nSpaceLen = 0;
}
nCurMaxWidth += Item.Width;
break;
}
case para_NewLine:
{
if ( nMinWidth < nWordLen )
nMinWidth = nWordLen;
bWord = false;
nWordLen = 0;
nSpaceLen = 0;
if ( nCurMaxWidth > nMaxWidth )
nMaxWidth = nCurMaxWidth;
nCurMaxWidth = 0;
break;
}
case para_End:
{
if ( nMinWidth < nWordLen )
nMinWidth = nWordLen;
if ( nCurMaxWidth > nMaxWidth )
nMaxWidth = nCurMaxWidth;
break;
}
}
}
MinMax.bWord = bWord;
MinMax.nWordLen = nWordLen;
MinMax.nSpaceLen = nSpaceLen;
MinMax.nMinWidth = nMinWidth;
MinMax.nMaxWidth = nMaxWidth;
MinMax.nCurMaxWidth = nCurMaxWidth;
},
//-----------------------------------------------------------------------------------
// Функции отрисовки
//-----------------------------------------------------------------------------------
......
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