Commit ae155c78 authored by Oleg Korshul's avatar Oleg Korshul Committed by Alexander.Trofimov

1) высоты шрифтов как в ворде и поуерпоинте. также изменения для экселя (опять...

1) высоты шрифтов как в ворде и поуерпоинте. также изменения для экселя (опять же высоты, разные режимы работы - разница видна на Cambria Math)
2) работа с самопальным болдом как в MS Office

ТРЕБУЕТ ТЩАТЕЛЬНОЙ ПРОВЕРКИ!!!
parent dd04e988
...@@ -161,10 +161,10 @@ ...@@ -161,10 +161,10 @@
// Теперь у нас 2 FontManager-а на весь документ + 1 для автофигур (а не на каждом листе свой) // Теперь у нас 2 FontManager-а на весь документ + 1 для автофигур (а не на каждом листе свой)
this.fmgrGraphics = []; // FontManager for draw (1 для обычного + 1 для поворотного текста) this.fmgrGraphics = []; // FontManager for draw (1 для обычного + 1 для поворотного текста)
this.fmgrGraphics.push(new AscFonts.CFontManager()); // Для обычного this.fmgrGraphics.push(new AscFonts.CFontManager({mode:"cell"})); // Для обычного
this.fmgrGraphics.push(new AscFonts.CFontManager()); // Для поворотного this.fmgrGraphics.push(new AscFonts.CFontManager({mode:"cell"})); // Для поворотного
this.fmgrGraphics.push(new AscFonts.CFontManager()); // Для автофигур this.fmgrGraphics.push(new AscFonts.CFontManager()); // Для автофигур
this.fmgrGraphics.push(new AscFonts.CFontManager()); // Для измерений this.fmgrGraphics.push(new AscFonts.CFontManager({mode:"cell"})); // Для измерений
this.fmgrGraphics[0].Initialize(true); // IE memory enable this.fmgrGraphics[0].Initialize(true); // IE memory enable
this.fmgrGraphics[1].Initialize(true); // IE memory enable this.fmgrGraphics[1].Initialize(true); // IE memory enable
......
...@@ -1101,7 +1101,7 @@ CFontInfo.prototype = ...@@ -1101,7 +1101,7 @@ CFontInfo.prototype =
if (bNeedItalic) if (bNeedItalic)
_ext += "nitalic"; _ext += "nitalic";
var pFontFile = fontManager.m_oFontsCache.LockFont(fontfile.stream_index, fontfile.Id, faceIndex, fEmSize, _ext); var pFontFile = fontManager.m_oFontsCache.LockFont(fontfile.stream_index, fontfile.Id, faceIndex, fEmSize, _ext, fontManager);
if (!pFontFile) if (!pFontFile)
pFontFile = fontManager.m_oDefaultFont.GetDefaultFont(bSrcBold, bSrcItalic); pFontFile = fontManager.m_oDefaultFont.GetDefaultFont(bSrcBold, bSrcItalic);
......
...@@ -343,7 +343,7 @@ CRasterHeapTotal.prototype = ...@@ -343,7 +343,7 @@ CRasterHeapTotal.prototype =
} }
}; };
function LoadFontFile(library, stream_index, name, faceindex) function LoadFontFile(library, stream_index, name, faceindex, fontManager)
{ {
var args = new FT_Open_Args(); var args = new FT_Open_Args();
args.flags = 0x02; args.flags = 0x02;
...@@ -360,29 +360,47 @@ function LoadFontFile(library, stream_index, name, faceindex) ...@@ -360,29 +360,47 @@ function LoadFontFile(library, stream_index, name, faceindex)
font.m_lDescender = face.descender; font.m_lDescender = face.descender;
font.m_lLineHeight = face.height; font.m_lLineHeight = face.height;
if (window["USE_FONTS_WIN_PARAMS"] === true && face.horizontal && face.os2 && face.os2.version != 0xFFFF) // flag for use always typo (os2 spec)
{ var bIsUseTypeAttack = ((face.os2.fsSelection & 128) == 128) ? true : false;
var bIsUseWin = false; if (fontManager.IsCellMode)
if (face.horizontal.Ascender == 0 || face.horizontal.Descender == 0) bIsUseTypeAttack = false;
bIsUseWin = true;
if (face.os2.sTypoAscender == 0 || face.os2.sTypoDescender == 0)
bIsUseWin = true;
var _h1 = face.horizontal.Ascender - face.horizontal.Descender + face.horizontal.Line_Gap; if (fontManager.IsUseWinOS2Params &&
var _h2 = face.os2.sTypoAscender - face.os2.sTypoDescender + face.os2.sTypoLineGap; face.os2 && face.os2.version != 0xFFFF &&
var _h3 = face.os2.usWinAscent + face.os2.usWinDescent; !bIsUseTypeAttack)
{
var _winAscent = face.os2.usWinAscent;
var _winDescent = -face.os2.usWinDescent;
if (_h1 != _h2 && _h2 != _h3 && _h1 != _h3 && (_h3 > _h1 && _h3 > _h2)) // experimantal: for cjk fonts lineheight *= 1.3
bIsUseWin = true; if ((face.os2.ulUnicodeRange2 & 0x2DF00000) != 0)
{
var _addidive = (0.3 * (_winAscent - _winDescent)) >> 0;
_winAscent += ((_addidive + 1) >> 1);
_winDescent -= (_addidive >> 1);
}
if (bIsUseWin) // TODO:
// https://www.microsoft.com/typography/otspec/recom.htm - hhea, not typo!!!
if (font.m_lLineHeight < (_winAscent - _winDescent))
{ {
font.m_lAscender = face.os2.usWinAscent; font.m_lAscender = _winAscent;
font.m_lDescender = -face.os2.usWinDescent; font.m_lDescender = _winDescent;
font.m_lLineHeight = face.os2.usWinAscent + face.os2.usWinDescent; font.m_lLineHeight = _winAscent - _winDescent;
} }
} }
/*
// что-то типо этого в экселе... пока выключаем
if (fontManager.IsCellMode)
{
var _addidive = (0.15 * font.m_lLineHeight) >> 0;
font.m_lAscender += ((_addidive + 1) >> 1);
font.m_lDescender -= (_addidive >> 1);
font.m_lLineHeight += _addidive;
}
*/
font.m_nNum_charmaps = face.num_charmaps; font.m_nNum_charmaps = face.num_charmaps;
//if (null == face.charmap && 0 != this.m_nNum_charmaps) //if (null == face.charmap && 0 != this.m_nNum_charmaps)
// alert('loadCharmap'); // alert('loadCharmap');
...@@ -416,7 +434,7 @@ function CFontFilesCache() ...@@ -416,7 +434,7 @@ function CFontFilesCache()
this.m_lCurrentSize = 0; this.m_lCurrentSize = 0;
this.Fonts = {}; this.Fonts = {};
this.LockFont = function(stream_index, fontName, faceIndex, fontSize, _ext) this.LockFont = function(stream_index, fontName, faceIndex, fontSize, _ext, fontManager)
{ {
var key = fontName + faceIndex + fontSize; var key = fontName + faceIndex + fontSize;
if (undefined !== _ext) if (undefined !== _ext)
...@@ -425,7 +443,7 @@ function CFontFilesCache() ...@@ -425,7 +443,7 @@ function CFontFilesCache()
if (pFontFile) if (pFontFile)
return pFontFile; return pFontFile;
pFontFile = this.Fonts[key] = LoadFontFile(this.m_oLibrary, stream_index, fontName, faceIndex); pFontFile = this.Fonts[key] = LoadFontFile(this.m_oLibrary, stream_index, fontName, faceIndex, fontManager);
return pFontFile; return pFontFile;
} }
} }
...@@ -821,7 +839,8 @@ function CGlyphString() ...@@ -821,7 +839,8 @@ function CGlyphString()
} }
} }
function CFontManager() // params: { mode: "cell" };
function CFontManager(params)
{ {
this.m_oLibrary = null; this.m_oLibrary = null;
...@@ -848,7 +867,9 @@ function CFontManager() ...@@ -848,7 +867,9 @@ function CFontManager()
this.LOAD_MODE = 40970; this.LOAD_MODE = 40970;
this.IsAdvanceNeedBoldFonts = true; this.IsCellMode = (params && params.mode == "cell") ? true : false;
this.IsAdvanceNeedBoldFonts = this.IsCellMode;
this.IsUseWinOS2Params = true;
this.AfterLoad = function() this.AfterLoad = function()
{ {
......
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