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

1. Сделала поддержку RFonts для мат текста, ctrPrp (Ascii, HAnsi etc)

2. Поправила баг : для случая когда в матрице один столбец не учитывалось выравнивание столбцов

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@59972 954022d7-b5bf-4e40-9824-e11837661b57
parent a6e0227a
...@@ -1165,21 +1165,6 @@ ParaMath.prototype.MathToImageConverter = function(bCopy, _canvasInput, _widthPx ...@@ -1165,21 +1165,6 @@ ParaMath.prototype.MathToImageConverter = function(bCopy, _canvasInput, _widthPx
return null; return null;
}; };
ParaMath.prototype.ApplyArgSize = function(FontSize, argSize)
{
var ResultFontSize = FontSize;
if(argSize == -1)
{
ResultFontSize *= g_dMathArgSizeKoeff_1;
}
else if(argSize == -2)
{
ResultFontSize *= g_dMathArgSizeKoeff_2;
}
return ResultFontSize;
};
ParaMath.prototype.GetFirstRPrp = function() ParaMath.prototype.GetFirstRPrp = function()
{ {
return this.Root.getFirstRPrp(this); return this.Root.getFirstRPrp(this);
...@@ -1990,6 +1975,11 @@ var historyitem_Math_CtrPrpStrikeout = 11; ...@@ -1990,6 +1975,11 @@ var historyitem_Math_CtrPrpStrikeout = 11;
var historyitem_Math_CtrPrpDoubleStrikeout = 12; var historyitem_Math_CtrPrpDoubleStrikeout = 12;
var historyitem_Math_CtrPrpItalic = 13; var historyitem_Math_CtrPrpItalic = 13;
var historyitem_Math_CtrPrpBold = 14; var historyitem_Math_CtrPrpBold = 14;
var historyitem_Math_RFontsAscii = 15;
var historyitem_Math_RFontsHAnsi = 16;
var historyitem_Math_RFontsCS = 17;
var historyitem_Math_RFontsEastAsia = 18;
var historyitem_Math_RFontsHint = 19;
function ReadChanges_FromBinary(Reader, Class) function ReadChanges_FromBinary(Reader, Class)
...@@ -2010,6 +2000,11 @@ function ReadChanges_FromBinary(Reader, Class) ...@@ -2010,6 +2000,11 @@ function ReadChanges_FromBinary(Reader, Class)
case historyitem_Math_CtrPrpDoubleStrikeout : Changes = new CChangesMath_DoubleStrikeout(); break; case historyitem_Math_CtrPrpDoubleStrikeout : Changes = new CChangesMath_DoubleStrikeout(); break;
case historyitem_Math_CtrPrpItalic : Changes = new CChangesMathItalic(); break; case historyitem_Math_CtrPrpItalic : Changes = new CChangesMathItalic(); break;
case historyitem_Math_CtrPrpBold : Changes = new CChangesMathBold(); break; case historyitem_Math_CtrPrpBold : Changes = new CChangesMathBold(); break;
case historyitem_Math_RFontsAscii : Changes = new CChangesMath_RFontsAscii(); break;
case historyitem_Math_RFontsHAnsi : Changes = new CChangesMath_RFontsHAnsi(); break;
case historyitem_Math_RFontsCS : Changes = new CChangesMath_RFontsCS(); break;
case historyitem_Math_RFontsEastAsia : Changes = new CChangesMath_RFontsEastAsia(); break;
case historyitem_Math_RFontsHint : Changes = new CChangesMath_RFontsHint(); break;
} }
if (null !== Changes) if (null !== Changes)
...@@ -2406,6 +2401,244 @@ CChangesMathBold.prototype.Load_Changes = function(Reader, Class) ...@@ -2406,6 +2401,244 @@ CChangesMathBold.prototype.Load_Changes = function(Reader, Class)
}; };
function CChangesMath_RFontsAscii(NewValue, OldValue)
{
this.New = NewValue;
this.Old = OldValue;
}
CChangesMath_RFontsAscii.prototype.Type = historyitem_Math_RFontsAscii;
CChangesMath_RFontsAscii.prototype.Undo = function(Class)
{
Class.raw_SetRFontsAscii(this.Old);
};
CChangesMath_RFontsAscii.prototype.Redo = function(Class)
{
Class.raw_SetRFontsAscii(this.New);
};
CChangesMath_RFontsAscii.prototype.Save_Changes = function(Writer)
{
// Bool : IsUndefined
// String : Font
if (undefined === this.New)
{
Writer.WriteBool(true);
}
else
{
Writer.WriteBool(false);
Writer.WriteString2(this.New.Name);
}
};
CChangesMath_RFontsAscii.prototype.Load_Changes = function(Reader, Class)
{
// Bool : IsUndefined
// String : Font
if(true === Reader.GetBool())
this.New = undefined;
else
{
this.New =
{
Name : Reader.GetString2(),
Index : -1
};
}
this.Redo(Class);
};
function CChangesMath_RFontsHAnsi(NewValue, OldValue)
{
this.New = NewValue;
this.Old = OldValue;
}
CChangesMath_RFontsHAnsi.prototype.Type = historyitem_Math_RFontsHAnsi;
CChangesMath_RFontsHAnsi.prototype.Undo = function(Class)
{
Class.raw_SetRFontsHAnsi(this.Old);
};
CChangesMath_RFontsHAnsi.prototype.Redo = function(Class)
{
Class.raw_SetRFontsHAnsi(this.New);
};
CChangesMath_RFontsHAnsi.prototype.Save_Changes = function(Writer)
{
// Bool : IsUndefined
// String : Font
if (undefined === this.New)
{
Writer.WriteBool(true);
}
else
{
Writer.WriteBool(false);
Writer.WriteString2(this.New.Name);
}
};
CChangesMath_RFontsHAnsi.prototype.Load_Changes = function(Reader, Class)
{
// Bool : IsUndefined
// String : Font
if(true === Reader.GetBool())
this.New = undefined;
else
{
this.New =
{
Name : Reader.GetString2(),
Index : -1
};
}
this.Redo(Class);
};
function CChangesMath_RFontsCS(NewValue, OldValue)
{
this.New = NewValue;
this.Old = OldValue;
}
CChangesMath_RFontsCS.prototype.Type = historyitem_Math_RFontsCS;
CChangesMath_RFontsCS.prototype.Undo = function(Class)
{
Class.raw_SetRFontsCS(this.Old);
};
CChangesMath_RFontsCS.prototype.Redo = function(Class)
{
Class.raw_SetRFontsCS(this.New);
};
CChangesMath_RFontsCS.prototype.Save_Changes = function(Writer)
{
// Bool : IsUndefined
// String : Font
if (undefined === this.New)
{
Writer.WriteBool(true);
}
else
{
Writer.WriteBool(false);
Writer.WriteString2(this.New.Name);
}
};
CChangesMath_RFontsCS.prototype.Load_Changes = function(Reader, Class)
{
// Bool : IsUndefined
// String : Font
if(true === Reader.GetBool())
this.New = undefined;
else
{
this.New =
{
Name : Reader.GetString2(),
Index : -1
};
}
this.Redo(Class);
};
function CChangesMath_RFontsEastAsia(NewValue, OldValue)
{
this.New = NewValue;
this.Old = OldValue;
}
CChangesMath_RFontsEastAsia.prototype.Type = historyitem_Math_RFontsEastAsia;
CChangesMath_RFontsEastAsia.prototype.Undo = function(Class)
{
Class.raw_SetRFontsEastAsia(this.Old);
};
CChangesMath_RFontsEastAsia.prototype.Redo = function(Class)
{
Class.raw_SetRFontsEastAsia(this.New);
};
CChangesMath_RFontsEastAsia.prototype.Save_Changes = function(Writer)
{
// Bool : IsUndefined
// String : Font
if (undefined === this.New)
{
Writer.WriteBool(true);
}
else
{
Writer.WriteBool(false);
Writer.WriteString2(this.New.Name);
}
};
CChangesMath_RFontsEastAsia.prototype.Load_Changes = function(Reader, Class)
{
// Bool : IsUndefined
// String : Font
if(true === Reader.GetBool())
this.New = undefined;
else
{
this.New =
{
Name : Reader.GetString2(),
Index : -1
};
}
this.Redo(Class);
};
function CChangesMath_RFontsHint(NewValue, OldValue)
{
this.New = NewValue;
this.Old = OldValue;
}
CChangesMath_RFontsHint.prototype.Type = historyitem_Math_RFontsHint;
CChangesMath_RFontsHint.prototype.Undo = function(Class)
{
Class.raw_SetRFontsHint(this.Old);
};
CChangesMath_RFontsHint.prototype.Redo = function(Class)
{
Class.raw_SetRFontsHint(this.New);
};
CChangesMath_RFontsHint.prototype.Save_Changes = function(Writer)
{
// Bool : IsUndefined
// String : Font
if (undefined === this.New)
{
Writer.WriteBool(true);
}
else
{
Writer.WriteBool(false);
Writer.WriteLong(this.New);
}
};
CChangesMath_RFontsHint.prototype.Load_Changes = function(Reader, Class)
{
// Bool : IsUndefined
// String : Font
if(true === Reader.GetBool())
this.New = undefined;
else
this.New = Reader.GetLong();
this.Redo(Class);
};
function CChangesMathAddItems(Pos, Items) function CChangesMathAddItems(Pos, Items)
{ {
this.Pos = Pos; this.Pos = Pos;
...@@ -2530,4 +2763,19 @@ CChangesMathEqArrayPr.prototype.Load_Changes = function(Reader, Class) ...@@ -2530,4 +2763,19 @@ CChangesMathEqArrayPr.prototype.Load_Changes = function(Reader, Class)
} }
this.Redo(Class); this.Redo(Class);
};
function MathApplyArgSize(FontSize, argSize)
{
var ResultFontSize = FontSize;
if(argSize == -1)
{
ResultFontSize *= g_dMathArgSizeKoeff_1;
}
else if(argSize == -2)
{
ResultFontSize *= g_dMathArgSizeKoeff_2;
}
return ResultFontSize;
}; };
\ No newline at end of file
...@@ -1203,7 +1203,7 @@ ParaRun.prototype.Create_FontMap = function(Map, ArgSize) ...@@ -1203,7 +1203,7 @@ ParaRun.prototype.Create_FontMap = function(Map, ArgSize)
FontSize = TextPr.FontSize; FontSize = TextPr.FontSize;
if(null !== this.Parent && undefined !== this.Parent && null !== this.Parent.ParaMath && undefined !== this.Parent.ParaMath) if(null !== this.Parent && undefined !== this.Parent && null !== this.Parent.ParaMath && undefined !== this.Parent.ParaMath)
TextPr.FontSize = this.Parent.ParaMath.ApplyArgSize(TextPr.FontSize, ArgSize.value); TextPr.FontSize = MathApplyArgSize(TextPr.FontSize, ArgSize.value);
} }
else else
TextPr = this.Get_CompiledPr(false); TextPr = this.Get_CompiledPr(false);
...@@ -3319,26 +3319,13 @@ ParaRun.prototype.Draw_Elements = function(PDSE) ...@@ -3319,26 +3319,13 @@ ParaRun.prototype.Draw_Elements = function(PDSE)
var CurTextPr = this.Get_CompiledPr( false ); var CurTextPr = this.Get_CompiledPr( false );
pGraphics.SetTextPr( CurTextPr, Theme ); pGraphics.SetTextPr( CurTextPr, Theme );
var Font; var NewMathTextPr;
if(this.Type == para_Math_Run) if(this.Type == para_Math_Run)
{ {
Y += this.size.ascent; Y += this.size.ascent;
Font = NewMathTextPr = GetMathModifiedFont(MathFont_ForMathText, CurTextPr, this);
{ pGraphics.SetTextPr( NewMathTextPr, Theme );
Bold : CurTextPr.Bold,
Italic : CurTextPr.Italic,
FontFamily : {Name : CurTextPr.FontFamily.Name, Index : CurTextPr.FontFamily.Index},
FontSize : this.Parent.ParaMath.ApplyArgSize(CurTextPr.FontSize, this.Parent.Compiled_ArgSz.value)
};
if(this.IsMathematicalText()) // выставляем false, чтобы не применился наклон к спец символам
{
Font.Italic = false;
Font.Bold = false;
}
pGraphics.SetFont(Font);
} }
if ( undefined !== CurTextPr.Shd && shd_Nil !== CurTextPr.Shd.Value ) if ( undefined !== CurTextPr.Shd && shd_Nil !== CurTextPr.Shd.Value )
...@@ -3414,7 +3401,6 @@ ParaRun.prototype.Draw_Elements = function(PDSE) ...@@ -3414,7 +3401,6 @@ ParaRun.prototype.Draw_Elements = function(PDSE)
if ( para_Drawing != ItemType || drawing_Anchor != Item.DrawingType ) if ( para_Drawing != ItemType || drawing_Anchor != Item.DrawingType )
{ {
Item.Draw( X, Y - this.YOffset, pGraphics ); Item.Draw( X, Y - this.YOffset, pGraphics );
X += Item.Get_WidthVisible(); X += Item.Get_WidthVisible();
} }
...@@ -3504,28 +3490,7 @@ ParaRun.prototype.Draw_Elements = function(PDSE) ...@@ -3504,28 +3490,7 @@ ParaRun.prototype.Draw_Elements = function(PDSE)
case para_Math_Text: case para_Math_Text:
case para_Math_Placeholder: case para_Math_Placeholder:
{ {
var bChangeFont = (Item.Is_SpecilalOperator() || this.IsPlaceholder()) && !this.IsNormalText() && Font.FontFamily.Name !== "Cambria Math", Item.draw(X, Y, pGraphics, NewMathTextPr);
FFont = {};
// опред набор символов, если Font не Cambria Math, рисуется все равно Font Cambria Math
if(bChangeFont) // для математического текста
{
FFont.FontFamily = {Name : "Cambria Math", Index : -1};
FFont.FontSize = Font.FontSize;
FFont.Bold = false;
FFont.Italic = false;
pGraphics.SetFont(FFont);
}
Item.draw(X, Y, pGraphics );
if(bChangeFont)
{
pGraphics.SetFont(Font);
}
break; break;
} }
...@@ -3935,7 +3900,6 @@ ParaRun.prototype.Set_ParaContentPos = function(ContentPos, Depth) ...@@ -3935,7 +3900,6 @@ ParaRun.prototype.Set_ParaContentPos = function(ContentPos, Depth)
Pos = 0; Pos = 0;
this.State.ContentPos = Pos; this.State.ContentPos = Pos;
}; };
ParaRun.prototype.Get_PosByElement = function(Class, ContentPos, Depth, UseRange, Range, Line) ParaRun.prototype.Get_PosByElement = function(Class, ContentPos, Depth, UseRange, Range, Line)
...@@ -4739,9 +4703,34 @@ ParaRun.prototype.Internal_Compile_Pr = function () ...@@ -4739,9 +4703,34 @@ ParaRun.prototype.Internal_Compile_Pr = function ()
return TextPr; return TextPr;
} }
// var Styles = this.Paragraph.Parent.Get_Styles();
// this.Paragraph.Parent.Styles (rPrDefault, pPrDefault) не влияют на Font Name в мат тексте, поэтому выставляем в Default в текстовых настройках RFonts "Cambria Math" (дефолтовый Font)
//
if(!this.IsNormalText()) // math text
{
var Styles = this.Paragraph.Parent.Get_Styles();
// скопируем текстовые настройки прежде чем подменим на пустые
var StyleDefaultTextPr = Styles.Default.TextPr.Copy();
var DefaultTextPr = new CTextPr();
DefaultTextPr.RFonts.Set_All("Cambria Math", -1);
Styles.Default.TextPr = DefaultTextPr;
var StyleId = this.Paragraph.Style_Get();
var Pr = Styles.Get_Pr( StyleId, styletype_Paragraph, null, null );
TextPr.RFonts.Set_FromObject(Pr.TextPr.RFonts);
// подменяем обратно
Styles.Default.TextPr = StyleDefaultTextPr;
}
// Not Apply ArgSize ! // Not Apply ArgSize !
var oWPrp = this.Parent.Get_Default_TPrp(); //var oWPrp = this.Parent.Get_Default_TPrp();
TextPr.Merge(oWPrp); //TextPr.Merge(oWPrp);
if(this.IsPlaceholder()) if(this.IsPlaceholder())
{ {
...@@ -5178,14 +5167,12 @@ ParaRun.prototype.Apply_Pr = function(TextPr) ...@@ -5178,14 +5167,12 @@ ParaRun.prototype.Apply_Pr = function(TextPr)
{ {
if(this.Type == para_Math_Run && !this.IsNormalText()) // при смене Font в этом случае (даже на Cambria Math) cs, eastAsia не меняются if(this.Type == para_Math_Run && !this.IsNormalText()) // при смене Font в этом случае (даже на Cambria Math) cs, eastAsia не меняются
{ {
// только для редактирования
// делаем так для проверки действительно ли нужно сменить Font, чтобы при смене других текстовых настроек не выставился Cambria Math (TextPr.RFonts приходит всегда в виде объекта) // делаем так для проверки действительно ли нужно сменить Font, чтобы при смене других текстовых настроек не выставился Cambria Math (TextPr.RFonts приходит всегда в виде объекта)
if(TextPr.RFonts.Ascii !== undefined || TextPr.RFonts.HAnsi !== undefined) if(TextPr.RFonts.Ascii !== undefined || TextPr.RFonts.HAnsi !== undefined)
{ {
var RFonts = var RFonts = new CRFonts();
{ RFonts.Set_All("Cambria Math", -1);
Ascii: {Name: "Cambria Math", Index: -1},
HAnsi: {Name: "Cambria Math", Index: -1}
};
this.Set_RFonts2(RFonts); this.Set_RFonts2(RFonts);
} }
...@@ -7834,7 +7821,7 @@ ParaRun.prototype.Math_Draw = function(x, y, pGraphics) ...@@ -7834,7 +7821,7 @@ ParaRun.prototype.Math_Draw = function(x, y, pGraphics)
Bold : oWPrp.Bold, Bold : oWPrp.Bold,
Italic : oWPrp.Italic, Italic : oWPrp.Italic,
FontFamily : {Name : oWPrp.FontFamily.Name, Index : oWPrp.FontFamily.Index}, FontFamily : {Name : oWPrp.FontFamily.Name, Index : oWPrp.FontFamily.Index},
FontSize : this.Parent.ParaMath.ApplyArgSize(oWPrp.FontSize, this.Parent.Compiled_ArgSz.value) FontSize : MathApplyArgSize(oWPrp.FontSize, this.Parent.Compiled_ArgSz.value)
}; };
if(this.IsMathematicalText()) // выставляем false, чтобы не применился наклон к спец символам if(this.IsMathematicalText()) // выставляем false, чтобы не применился наклон к спец символам
...@@ -7865,9 +7852,6 @@ ParaRun.prototype.Math_Recalculate = function(oMeasure, RPI, WidthPoints) ...@@ -7865,9 +7852,6 @@ ParaRun.prototype.Math_Recalculate = function(oMeasure, RPI, WidthPoints)
var RangeEndPos = this.Content.length; var RangeEndPos = this.Content.length;
//this.Paragraph = Paragraph;
//this.Parent = Parent;
// обновляем позиции start и end для Range // обновляем позиции start и end для Range
//this.Lines[0].Add_Range(0, RangeStartPos, RangeEndPos); //this.Lines[0].Add_Range(0, RangeStartPos, RangeEndPos);
this.protected_AddRange(0, 0); this.protected_AddRange(0, 0);
...@@ -7878,23 +7862,9 @@ ParaRun.prototype.Math_Recalculate = function(oMeasure, RPI, WidthPoints) ...@@ -7878,23 +7862,9 @@ ParaRun.prototype.Math_Recalculate = function(oMeasure, RPI, WidthPoints)
{ {
var oWPrp = this.Get_CompiledPr(false); var oWPrp = this.Get_CompiledPr(false);
var Font = var Theme = this.Paragraph.Get_Theme();
{ var NewMathTextPr = GetMathModifiedFont(MathFont_ForMathText, oWPrp, this);
Bold : oWPrp.Bold, g_oTextMeasurer.SetTextPr( NewMathTextPr, Theme );
Italic : oWPrp.Italic,
FontFamily : {Name : oWPrp.FontFamily.Name, Index : oWPrp.FontFamily.Index},
FontSize : this.Parent.ParaMath.ApplyArgSize(oWPrp.FontSize, this.Parent.Compiled_ArgSz.value)
};
if(this.IsMathematicalText()) // выставляем false, чтобы не применился наклон к спец символам
{
Font.Italic = false;
Font.Bold = false;
}
g_oTextMeasurer.SetFont(Font);
this.bEqqArray = RPI.bEqqArray; this.bEqqArray = RPI.bEqqArray;
...@@ -7906,28 +7876,9 @@ ParaRun.prototype.Math_Recalculate = function(oMeasure, RPI, WidthPoints) ...@@ -7906,28 +7876,9 @@ ParaRun.prototype.Math_Recalculate = function(oMeasure, RPI, WidthPoints)
var Lng = this.Content.length; var Lng = this.Content.length;
var FontFamily;
for (var i = 0 ; i < Lng; i++) for (var i = 0 ; i < Lng; i++)
{ {
var bChangeFont = (this.Content[i].Is_SpecilalOperator() || this.IsPlaceholder()) && Font.FontFamily.Name !== "Cambria Math"; this.Content[i].Resize(oMeasure, RPI, NewMathTextPr);
if(bChangeFont)
{
FontFamily = Font.FontFamily;
Font.FontFamily = {Name : "Cambria Math", Index : -1};
g_oTextMeasurer.SetFont(Font);
}
this.Content[i].Resize(oMeasure, RPI);
if(bChangeFont)
{
Font.FontFamily = FontFamily;
g_oTextMeasurer.SetFont(Font);
}
var oSize = this.Content[i].size; var oSize = this.Content[i].size;
...@@ -8157,6 +8108,8 @@ ParaRun.prototype.Get_RangesByPos = function(Pos) ...@@ -8157,6 +8108,8 @@ ParaRun.prototype.Get_RangesByPos = function(Pos)
return Ranges; return Ranges;
}; };
function CParaRunStartState(Run) function CParaRunStartState(Run)
{ {
this.Paragraph = Run.Paragraph; this.Paragraph = Run.Paragraph;
...@@ -8167,22 +8120,3 @@ function CParaRunStartState(Run) ...@@ -8167,22 +8120,3 @@ function CParaRunStartState(Run)
this.Content.push(Run.Content[i]); this.Content.push(Run.Content[i]);
} }
} }
function AddItemToRun(Run, code)
{
var NewText = null;
var bMath = Run.Type == para_Math_Run;
if(bMath)
{
NewText = new CMathText(false);
NewText.add(code);
}
else
{
NewText = new ParaText();
NewText.Set_CharCode(code);
}
Run.Add(NewText, bMath);
}
\ No newline at end of file
...@@ -21,7 +21,6 @@ function CMathBase(bInside) ...@@ -21,7 +21,6 @@ function CMathBase(bInside)
this.nRow = 0; this.nRow = 0;
this.nCol = 0; this.nCol = 0;
this.bInside = bInside === true ? true: false; this.bInside = bInside === true ? true: false;
this.elements = []; this.elements = [];
...@@ -44,7 +43,6 @@ function CMathBase(bInside) ...@@ -44,7 +43,6 @@ function CMathBase(bInside)
bProps: true bProps: true
}; };
this.Content = []; this.Content = [];
this.CurPos = 0; this.CurPos = 0;
...@@ -134,11 +132,11 @@ CMathBase.prototype = ...@@ -134,11 +132,11 @@ CMathBase.prototype =
CompiledCtrPrp = this.Get_CompiledCtrPrp_2(); CompiledCtrPrp = this.Get_CompiledCtrPrp_2();
if(bAllowInline !== false && this.ParaMath) if(bAllowInline !== false && this.ParaMath)
CompiledCtrPrp.FontSize = this.ParaMath.ApplyArgSize(CompiledCtrPrp.FontSize, this.Parent.Get_CompiledArgSize().value); CompiledCtrPrp.FontSize = MathApplyArgSize(CompiledCtrPrp.FontSize, this.Parent.Get_CompiledArgSize().value);
} }
if(bAllowInline !== false && this.ParaMath) if(bAllowInline !== false && this.ParaMath)
CompiledCtrPrp.FontSize = this.ParaMath.ApplyArgSize(CompiledCtrPrp.FontSize, this.ArgSize.value);// для настроек inline формул CompiledCtrPrp.FontSize = MathApplyArgSize(CompiledCtrPrp.FontSize, this.ArgSize.value);// для настроек inline формул
return CompiledCtrPrp; return CompiledCtrPrp;
}, },
...@@ -482,12 +480,12 @@ CMathBase.prototype = ...@@ -482,12 +480,12 @@ CMathBase.prototype =
{ {
var TxtPr = Parent.Get_TxtPrControlLetter(); var TxtPr = Parent.Get_TxtPrControlLetter();
FontSize = TxtPr.FontSize; FontSize = TxtPr.FontSize;
FontSize = ParaMath.ApplyArgSize(FontSize, this.ArgSize.value); FontSize = MathApplyArgSize(FontSize, this.ArgSize.value);
} }
else else
{ {
FontSize = ParaMath.ApplyArgSize(FontSize, Parent.Get_CompiledArgSize().value); FontSize = MathApplyArgSize(FontSize, Parent.Get_CompiledArgSize().value);
FontSize = ParaMath.ApplyArgSize(FontSize, this.ArgSize.value); FontSize = MathApplyArgSize(FontSize, this.ArgSize.value);
} }
this.TextPrControlLetter.FontSize = FontSize; this.TextPrControlLetter.FontSize = FontSize;
...@@ -730,6 +728,14 @@ CMathBase.prototype = ...@@ -730,6 +728,14 @@ CMathBase.prototype =
{ {
this.Set_DoubleStrikeout(TextPr.DStrikeout); this.Set_DoubleStrikeout(TextPr.DStrikeout);
} }
if ( undefined != TextPr.RFonts )
{
var RFonts = new CRFonts();
RFonts.Set_All("Cambria Math", -1);
this.raw_SetRFonts(RFonts);
}
} }
...@@ -826,53 +832,77 @@ CMathBase.prototype = ...@@ -826,53 +832,77 @@ CMathBase.prototype =
this.raw_SetItalic(Value); this.raw_SetItalic(Value);
} }
}, },
Set_RFonts_Ascii: function(Value)
{
if(this.CtrPrp.RFonts.Ascii !== Value)
{
History.Add(this, new CChangesMath_RFontsAscii(Value, this.CtrPrp.RFonts.Ascii));
this.raw_SetRFontsAscii(Value);
}
},
Set_RFonts_HAnsi: function(Value)
{
if(this.CtrPrp.RFonts.HAnsi !== Value)
{
History.Add(this, new CChangesMath_RFontsHAnsi(Value, this.CtrPrp.RFonts.HAnsi));
this.raw_SetRFontsHAnsi(Value);
}
},
Set_RFonts_CS: function(Value)
{
if(this.CtrPrp.RFonts.CS !== Value)
{
History.Add(this, new CChangesMath_RFontsCS(Value, this.CtrPrp.RFonts.CS));
this.raw_SetRFontsCS(Value);
}
},
Set_RFonts_EastAsia: function(Value)
{
if(this.CtrPrp.RFonts.EastAsia !== Value)
{
History.Add(this, new CChangesMath_RFontsEastAsia(Value, this.CtrPrp.RFonts.EastAsia));
this.raw_SetRFontsEastAsia(Value);
}
},
Set_RFonts_Hint: function(Value)
{
if(this.CtrPrp.RFonts.Hint !== Value)
{
History.Add(this, new CChangesMath_RFontsHint(Value, this.CtrPrp.RFonts.Hint));
this.raw_SetRFontsHint(Value);
}
},
raw_SetBold: function(Value) raw_SetBold: function(Value)
{ {
this.CtrPrp.Bold = Value; this.CtrPrp.Bold = Value;
this.RecalcInfo.bCtrPrp = true; this.NeedUpdate_CtrPrp();
if (null !== this.ParaMath)
this.ParaMath.SetNeedResize();
}, },
raw_SetItalic: function(Value) raw_SetItalic: function(Value)
{ {
this.CtrPrp.Italic = Value; this.CtrPrp.Italic = Value;
this.RecalcInfo.bCtrPrp = true; this.NeedUpdate_CtrPrp();
if (null !== this.ParaMath)
this.ParaMath.SetNeedResize();
}, },
raw_SetUnderline : function(Value) raw_SetUnderline : function(Value)
{ {
this.CtrPrp.Underline = Value; this.CtrPrp.Underline = Value;
this.RecalcInfo.bCtrPrp = true; this.NeedUpdate_CtrPrp();
if (null !== this.ParaMath)
this.ParaMath.SetNeedResize();
}, },
raw_SetStrikeout: function(Value) raw_SetStrikeout: function(Value)
{ {
this.CtrPrp.Strikeout = Value; this.CtrPrp.Strikeout = Value;
this.RecalcInfo.bCtrPrp = true; this.NeedUpdate_CtrPrp();
if (null !== this.ParaMath)
this.ParaMath.SetNeedResize();
}, },
raw_Set_DoubleStrikeout: function(Value) raw_Set_DoubleStrikeout: function(Value)
{ {
this.CtrPrp.DStrikeout = Value; this.CtrPrp.DStrikeout = Value;
this.RecalcInfo.bCtrPrp = true; this.NeedUpdate_CtrPrp();
if (null !== this.ParaMath)
this.ParaMath.SetNeedResize();
}, },
raw_SetFontSize : function(Value) raw_SetFontSize : function(Value)
{ {
this.CtrPrp.FontSize = Value; this.CtrPrp.FontSize = Value;
this.RecalcInfo.bCtrPrp = true; this.NeedUpdate_CtrPrp();
if (null !== this.ParaMath)
this.ParaMath.SetNeedResize();
}, },
raw_SetShd: function(Shd) raw_SetShd: function(Shd)
{ {
...@@ -884,28 +914,78 @@ CMathBase.prototype = ...@@ -884,28 +914,78 @@ CMathBase.prototype =
else else
this.CtrPrp.Shd = undefined; this.CtrPrp.Shd = undefined;
this.RecalcInfo.bCtrPrp = true; this.NeedUpdate_CtrPrp();
if(null !== this.ParaMath)
this.ParaMath.SetNeedResize();
}, },
raw_SetColor: function(Value) raw_SetColor: function(Value)
{ {
this.CtrPrp.Color = Value; this.CtrPrp.Color = Value;
this.NeedUpdate_CtrPrp();
this.RecalcInfo.bCtrPrp = true;
if(null !== this.ParaMath)
this.ParaMath.SetNeedResize();
}, },
raw_SetUnifill: function(Value) raw_SetUnifill: function(Value)
{ {
this.CtrPrp.Unifill = Value; this.CtrPrp.Unifill = Value;
this.NeedUpdate_CtrPrp();
},
raw_SetRFonts: function(RFonts)
{
if ( undefined != RFonts )
{
if ( undefined != RFonts.Ascii )
this.Set_RFonts_Ascii( RFonts.Ascii );
if ( undefined != RFonts.HAnsi )
this.Set_RFonts_HAnsi( RFonts.HAnsi );
if ( undefined != RFonts.CS )
this.Set_RFonts_CS( RFonts.CS );
if ( undefined != RFonts.EastAsia )
this.Set_RFonts_EastAsia( RFonts.EastAsia );
if ( undefined != RFonts.Hint )
this.Set_RFonts_Hint( RFonts.Hint );
}
else
{
this.Set_RFonts_Ascii( undefined );
this.Set_RFonts_HAnsi( undefined );
this.Set_RFonts_CS( undefined );
this.Set_RFonts_EastAsia( undefined );
this.Set_RFonts_Hint( undefined );
}
},
raw_SetRFontsAscii: function(Value)
{
this.CtrPrp.RFonts.Ascii = Value;
this.NeedUpdate_CtrPrp();
},
raw_SetRFontsHAnsi: function(Value)
{
this.CtrPrp.RFonts.HAnsi = Value;
this.NeedUpdate_CtrPrp();
},
raw_SetRFontsCS: function(Value)
{
this.CtrPrp.RFonts.CS = Value;
this.NeedUpdate_CtrPrp();
},
raw_SetRFontsEastAsia: function(Value)
{
this.CtrPrp.RFonts.EastAsia = Value;
this.NeedUpdate_CtrPrp();
},
raw_SetRFontsHint: function(Value)
{
this.CtrPrp.RFonts.Hint = Value;
this.NeedUpdate_CtrPrp();
},
NeedUpdate_CtrPrp: function()
{
this.RecalcInfo.bCtrPrp = true; this.RecalcInfo.bCtrPrp = true;
if(null !== this.ParaMath) if(null !== this.ParaMath)
this.ParaMath.SetNeedResize(); this.ParaMath.SetNeedResize();
}, },
SelectToParent: function(bCorrect) SelectToParent: function(bCorrect)
{ {
......
...@@ -13,8 +13,6 @@ ...@@ -13,8 +13,6 @@
var DIV_CENT = 0.1386; var DIV_CENT = 0.1386;
var StartTextElement = 0x2B1A; // Cambria Math var StartTextElement = 0x2B1A; // Cambria Math
function CMathSize() function CMathSize()
...@@ -42,10 +40,11 @@ function CMathText(bJDraw) ...@@ -42,10 +40,11 @@ function CMathText(bJDraw)
this.RecalcInfo = this.RecalcInfo =
{ {
//NewLetter: true, //NewLetter: true,
StyleCode: null, StyleCode: null,
bAccentIJ: false, bAccentIJ: false,
SpaceSpecial: false, bSpaceSpecial: false,
bApostrophe: false bApostrophe: false,
bSpecialOperator: false
}; };
this.Parent = null; this.Parent = null;
...@@ -85,7 +84,7 @@ CMathText.prototype = ...@@ -85,7 +84,7 @@ CMathText.prototype =
{ {
var code = this.value; var code = this.value;
var bMathText = this.bJDraw ? null : this.Parent.IsMathematicalText(); //var bMathText = this.bJDraw ? null : this.Parent.IsMathematicalText();
var bNormal = this.bJDraw ? null : this.Parent.IsNormalText(); var bNormal = this.bJDraw ? null : this.Parent.IsNormalText();
if(this.Type === para_Math_Placeholder || this.bJDraw || bNormal) if(this.Type === para_Math_Placeholder || this.bJDraw || bNormal)
...@@ -543,7 +542,7 @@ CMathText.prototype = ...@@ -543,7 +542,7 @@ CMathText.prototype =
this.Type = para_Math_Placeholder; this.Type = para_Math_Placeholder;
this.value = StartTextElement; this.value = StartTextElement;
}, },
Resize: function(oMeasure, RPI) Resize: function(oMeasure, RPI, TextPr)
{ {
/* /*
var metricsTxt = g_oTextMeasurer.Measure2Code(letter); var metricsTxt = g_oTextMeasurer.Measure2Code(letter);
...@@ -551,20 +550,66 @@ CMathText.prototype = ...@@ -551,20 +550,66 @@ CMathText.prototype =
height = g_oTextMeasurer.GetHeight(); height = g_oTextMeasurer.GetHeight();
*/ */
var letter = this.getCode(); //var bNormal = this.bJDraw ? null : this.Parent.IsNormalText();
var metricsTxt;
var bAccentIJ = this.bJDraw ? false : this.Parent.IsAccent(); // measure
bAccentIJ = bAccentIJ && (this.value == 0x69 || this.value == 0x6A); if(this.bJDraw)
{
// Font выставляется на соответствующей функции SetFont в родительском классе (в общем случае в CMathBase)
this.RecalcInfo.StyleCode = letter; this.RecalcInfo.StyleCode = this.value;
this.RecalcInfo.bAccentIJ = bAccentIJ; metricsTxt = oMeasure.Measure2Code(this.value);
if(bAccentIJ) }
oMeasure.SetStringGid(true); else
{
var letter = this.getCode();
var bNormalText = this.Parent.IsNormalText();
var metricsTxt; // в не математическом тексте i и j не подменяются на i и j без точек
var bAccentIJ = !bNormalText && this.Parent.IsAccent() && (this.value == 0x69 || this.value == 0x6A);
this.RecalcInfo.StyleCode = letter;
this.RecalcInfo.bAccentIJ = bAccentIJ;
if(bAccentIJ)
oMeasure.SetStringGid(true);
var ascent, width, height, descent;
var Hint = TextPr.RFonts.Hint;
var bCS = TextPr.CS;
var bRTL = TextPr.RTL;
var lcid = TextPr.Lang.EastAsia;
var Theme = this.Parent.Paragraph.Get_Theme();
this.RecalcInfo.bSpecialOperator = !this.Parent.IsNormalText() && (this.Is_SpecilalOperator() || this.IsPlaceholder()) /*&& Font.FontFamily.Name !== "Cambria Math"*/;
// в зависимости от шрифта
if(this.RecalcInfo.bSpecialOperator)
{
g_oTextMeasurer.SetTextPr( GetMathModifiedFont(MathFont_ForSpecialOperator, TextPr, this), Theme );
}
this.FontSlot = g_font_detector.Get_FontClass(this.value, Hint, lcid, bCS, bRTL); // возвращает fontslot_ASCII || fontslot_EastAsia || fontslot_CS || fontslot_HAnsi
g_oTextMeasurer.SetFontSlot(this.FontSlot, 1);
var ascent, width, height, descent;
metricsTxt = oMeasure.MeasureCode(letter);
// меняем обратно
if(this.RecalcInfo.bSpecialOperator)
{
g_oTextMeasurer.SetTextPr(TextPr, Theme);
}
if(bAccentIJ)
oMeasure.SetStringGid(false);
}
if(letter == 0x2061) if(letter == 0x2061)
{ {
...@@ -572,19 +617,10 @@ CMathText.prototype = ...@@ -572,19 +617,10 @@ CMathText.prototype =
height = 0; height = 0;
ascent = 0; ascent = 0;
this.RecalcInfo.SpaceSpecial = true; this.RecalcInfo.bSpaceSpecial = true;
} }
else else
{ {
if(this.bJDraw)
metricsTxt = oMeasure.Measure2Code(letter);
else
metricsTxt = oMeasure.MeasureCode(letter);
if(bAccentIJ)
oMeasure.SetStringGid(false);
// смещения // смещения
this.rasterOffsetX = metricsTxt.rasterOffsetX; this.rasterOffsetX = metricsTxt.rasterOffsetX;
this.rasterOffsetY = metricsTxt.rasterOffsetY; this.rasterOffsetY = metricsTxt.rasterOffsetY;
...@@ -617,7 +653,7 @@ CMathText.prototype = ...@@ -617,7 +653,7 @@ CMathText.prototype =
{ {
return this.size.width; return this.size.width;
}, },
draw: function(x, y, pGraphics) draw: function(x, y, pGraphics, TextPr)
{ {
var X = this.pos.x + x, var X = this.pos.x + x,
Y = this.pos.y + y; Y = this.pos.y + y;
...@@ -648,14 +684,30 @@ CMathText.prototype = ...@@ -648,14 +684,30 @@ CMathText.prototype =
pGraphics.transform(sx, shy, shx, sy, 0, 0);*/ pGraphics.transform(sx, shy, shx, sy, 0, 0);*/
if(this.RecalcInfo.SpaceSpecial == false) if(this.bJDraw)
{ {
pGraphics.FillTextCode(X, Y, this.RecalcInfo.StyleCode); //на отрисовку символа отправляем положение baseLine
}
else if(this.RecalcInfo.bSpaceSpecial == false)
{
if(this.RecalcInfo.bSpecialOperator)
{
pGraphics.SetTextPr( GetMathModifiedFont(MathFont_ForSpecialOperator, TextPr, this), this.Parent.Paragraph.Get_Theme() );
}
pGraphics.SetFontSlot(this.FontSlot, 1);
if(this.RecalcInfo.bAccentIJ || this.RecalcInfo.bApostrophe) if(this.RecalcInfo.bAccentIJ || this.RecalcInfo.bApostrophe)
pGraphics.tg(this.RecalcInfo.StyleCode, X, Y); pGraphics.tg(this.RecalcInfo.StyleCode, X, Y);
else else
pGraphics.FillTextCode(X, Y, this.RecalcInfo.StyleCode); //на отрисовку символа отправляем положение baseLine pGraphics.FillTextCode(X, Y, this.RecalcInfo.StyleCode); //на отрисовку символа отправляем положение baseLine
}
if(this.RecalcInfo.bSpecialOperator)
{
pGraphics.SetTextPr(TextPr, this.Parent.Paragraph.Get_Theme());
}
}
}, },
setPosition: function(pos) setPosition: function(pos)
{ {
...@@ -769,7 +821,7 @@ CMathText.prototype = ...@@ -769,7 +821,7 @@ CMathText.prototype =
Is_SpecilalOperator: function() Is_SpecilalOperator: function()
{ {
var val = this.value, var val = this.value,
bSpecialOperator = val == 0x21 || val == 0x23 || (val >= 0x28 && val <= 0x2F) || (val >= 0x3A && val <= 0x3F) || (val >=0x5B && val <= 0x5F) || (val >= 0x7B && val <= 0xA1) || val == 0xAC || val == 0xB1 || val == 0xB7 || val == 0xBF || val == 0xD7 || val == 0xF7 || (val >= 0x2010 && val <= 0x2014) || val == 0x2016 || (val >= 0x2020 && val <= 0x2022) || val == 0x2026 /*|| (val >= 0x2153 && val <= 0xA64D)*/, bSpecialOperator = val == 0x21 || val == 0x23 || (val >= 0x28 && val <= 0x2F) || (val >= 0x3A && val <= 0x3F) || (val >=0x5B && val <= 0x5F) || (val >= 0x7B && val <= 0xA1) || val == 0xAC || val == 0xB1 || val == 0xB7 || val == 0xBF || val == 0xD7 || val == 0xF7 || (val >= 0x2010 && val <= 0x2014) || val == 0x2016 || (val >= 0x2020 && val <= 0x2022) || val == 0x2026,
bSpecialArrow = val >= 0x2190 && val <= 0x21FF, bSpecialArrow = val >= 0x2190 && val <= 0x21FF,
bSpecialSymbols = val == 0x2200 || val == 0x2201 || val == 0x2203 || val == 0x2204 || val == 0x2206|| (val >= 0x2208 && val <= 0x220D) || (val >= 0x220F && val <= 0x221E) || (val >= 0x2223 && val <= 0x223E) || (val >= 0x223F && val <= 0x22BD) || (val >= 0x22C0 && val <= 0x22FF) || val == 0x2305 || val == 0x2306 || (val >= 0x2308 && val <= 0x230B) || (val >= 0x231C && val <= 0x231F) || val == 0x2322 || val == 0x2323 || val == 0x2329 || val == 0x232A ||val == 0x233F || val == 0x23B0 || val == 0x23B1, bSpecialSymbols = val == 0x2200 || val == 0x2201 || val == 0x2203 || val == 0x2204 || val == 0x2206|| (val >= 0x2208 && val <= 0x220D) || (val >= 0x220F && val <= 0x221E) || (val >= 0x2223 && val <= 0x223E) || (val >= 0x223F && val <= 0x22BD) || (val >= 0x22C0 && val <= 0x22FF) || val == 0x2305 || val == 0x2306 || (val >= 0x2308 && val <= 0x230B) || (val >= 0x231C && val <= 0x231F) || val == 0x2322 || val == 0x2323 || val == 0x2329 || val == 0x232A ||val == 0x233F || val == 0x23B0 || val == 0x23B1,
bOtherArrows = (val >= 0x27D1 && val <= 0x2980) || (val >= 0x2982 && val <= 0x299A) || (val >= 0x29B6 && val <= 0x29B9) || val == 0x29C0 || val == 0x29C1 || (val >= 0x29C4 && val <= 0x29C8) || (val >= 0x29CE && val <= 0x29DB) || val == 0x29DF || (val >= 0x29E1 && val <= 0x29E6) || val == 0x29EB || (val >= 0x29F4 && val <= 0x2AFF && val !== 0x2AE1 && val !== 0x2AF1) || (val >= 0x3014 && val <= 0x3017); bOtherArrows = (val >= 0x27D1 && val <= 0x2980) || (val >= 0x2982 && val <= 0x299A) || (val >= 0x29B6 && val <= 0x29B9) || val == 0x29C0 || val == 0x29C1 || (val >= 0x29C4 && val <= 0x29C8) || (val >= 0x29CE && val <= 0x29DB) || val == 0x29DF || (val >= 0x29E1 && val <= 0x29E6) || val == 0x29EB || (val >= 0x29F4 && val <= 0x2AFF && val !== 0x2AE1 && val !== 0x2AF1) || (val >= 0x3014 && val <= 0x3017);
...@@ -798,7 +850,6 @@ CMathText.prototype = ...@@ -798,7 +850,6 @@ CMathText.prototype =
Writer.WriteLong(this.Type); Writer.WriteLong(this.Type);
Writer.WriteLong(this.value) ; Writer.WriteLong(this.value) ;
}, },
Read_FromBinary : function(Reader) Read_FromBinary : function(Reader)
{ {
this.Type = Reader.GetLong(); this.Type = Reader.GetLong();
...@@ -825,11 +876,11 @@ function CMathAmp() ...@@ -825,11 +876,11 @@ function CMathAmp()
} }
CMathAmp.prototype = CMathAmp.prototype =
{ {
Resize: function(oMeasure, RPI) Resize: function(oMeasure, RPI, TextPr)
{ {
this.bEqqArray = RPI.bEqqArray; this.bEqqArray = RPI.bEqqArray;
this.AmpText.Resize(oMeasure, RPI); this.AmpText.Resize(oMeasure, RPI, TextPr);
if(this.bEqqArray) if(this.bEqqArray)
{ {
...@@ -930,3 +981,45 @@ CMathAmp.prototype = ...@@ -930,3 +981,45 @@ CMathAmp.prototype =
} }
var MathFont_ForMathText = 1;
var MathFont_ForSpecialOperator = 2;
function GetMathModifiedFont(type, TextPr, Class)
{
var NewMathTextPr = new CTextPr();
if(type == MathFont_ForMathText)
{
// RFonts влияют на отрисовку текста в формулах
NewMathTextPr.RFonts = TextPr.RFonts;
NewMathTextPr.FontFamily = TextPr.FontFamily;
NewMathTextPr.Bold = TextPr.Bold;
NewMathTextPr.Italic = TextPr.Italic;
NewMathTextPr.FontSize = MathApplyArgSize(TextPr.FontSize, Class.Parent.Compiled_ArgSz.value);
// скопируем эти свойства для SetFontSlot
// для SpecialOperator нужны уже скомпилированные для мат текста текстовые настройки, поэтому важно эи свойства скопировать именно здесь, а не передавать в MathText обычные текст. настройки
NewMathTextPr.CS = TextPr.CS;
NewMathTextPr.bRTL = TextPr.RTL;
NewMathTextPr.Lang = TextPr.Lang;
//if(Class.IsMathematicalText())
if(!Class.IsNormalText()) // выставляем false, чтобы не применился наклон к спец символам
{
NewMathTextPr.Italic = false;
NewMathTextPr.Bold = false;
}
}
else if(type == MathFont_ForSpecialOperator)
{
NewMathTextPr.FontFamily = {Name : "Cambria Math", Index : -1};
NewMathTextPr.RFonts.Set_All("Cambria Math",-1);
NewMathTextPr.FontSize = TextPr.FontSize;
NewMathTextPr.Bold = TextPr.Bold;
NewMathTextPr.Italic = TextPr.Italic;
//pGraphics.SetFont(FFont);
}
return NewMathTextPr;
}
\ No newline at end of file
...@@ -215,29 +215,35 @@ CMatrixBase.prototype.recalculateSize = function(oMeasure, RPI) ...@@ -215,29 +215,35 @@ CMatrixBase.prototype.recalculateSize = function(oMeasure, RPI)
if(this.nCol > 1) if(this.nCol > 1)
{ {
this.setRuleGap(this.spaceColumn, this.Pr.cGpRule, this.Pr.cGp, this.Pr.cSp); this.setRuleGap(this.spaceColumn, this.Pr.cGpRule, this.Pr.cGp, this.Pr.cSp);
}
if(this.kind == MATH_MATRIX)
{
// выставим выравнивание для столбцов // выставим выравнивание для столбцов
var lng = this.Pr.mcs.length; if(this.Pr.mcs !== undefined)
var col = 0;
this.alignment.wdt.length = 0;
for(var j = 0; j < lng; j++)
{ {
var mc = this.Pr.mcs[j], var lng = this.Pr.mcs.length;
count = mc.count; var col = 0;
this.alignment.wdt.length = 0;
for(var i = 0; i < count; i++) for(var j = 0; j < lng; j++)
{ {
this.alignment.wdt[col] = mc.mcJc; var mc = this.Pr.mcs[j],
col++; count = mc.count;
for(var i = 0; i < count; i++)
{
this.alignment.wdt[col] = mc.mcJc;
col++;
}
} }
} }
}
if(this.kind == MATH_MATRIX && this.Pr.plcHide)
this.hidePlaceholder(true); if(this.Pr.plcHide)
this.hidePlaceholder(true);
}
this.RecalcInfo.bProps = false; this.RecalcInfo.bProps = false;
} }
......
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