mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
Image_PixMap::ImgFormat - extend enumeration by ImgAlpha and ImgAlphaF. OpenGl_Workspace::setTextureParams() - specify GL_REPLACE for 1-component textures with disabled modulation. OpenGl_Texture::GetDataFormat() - return GL_LUMINANCE format for ImgGray format and GL_ALPHA for ImgAlpha. vmarkerstest - override pixel format for grayscale images to ImgAlpha. Add test case bugs/vis/bug25544_graytexture.
260 lines
8.4 KiB
C++
Executable File
260 lines
8.4 KiB
C++
Executable File
// Created on: 2013-01-28
|
|
// Created by: Kirill GAVRILOV
|
|
// Copyright (c) 2013-2014 OPEN CASCADE SAS
|
|
//
|
|
// This file is part of Open CASCADE Technology software library.
|
|
//
|
|
// This library is free software; you can redistribute it and/or modify it under
|
|
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
// by the Free Software Foundation, with special exception defined in the file
|
|
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
// distribution for complete text of the license and disclaimer of any warranty.
|
|
//
|
|
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
// commercial license or contractual agreement.
|
|
|
|
#include <Font_FTFont.hxx>
|
|
#include <Font_FontMgr.hxx>
|
|
#include <TCollection_AsciiString.hxx>
|
|
#include <TCollection_HAsciiString.hxx>
|
|
|
|
IMPLEMENT_STANDARD_HANDLE (Font_FTFont, Standard_Transient)
|
|
IMPLEMENT_STANDARD_RTTIEXT(Font_FTFont, Standard_Transient)
|
|
|
|
// =======================================================================
|
|
// function : Font_FTFont
|
|
// purpose :
|
|
// =======================================================================
|
|
Font_FTFont::Font_FTFont (const Handle(Font_FTLibrary)& theFTLib)
|
|
: myFTLib (theFTLib),
|
|
myFTFace (NULL),
|
|
myPointSize (0),
|
|
myLoadFlags (FT_LOAD_NO_HINTING | FT_LOAD_TARGET_NORMAL),
|
|
myUChar (0)
|
|
{
|
|
if (myFTLib.IsNull())
|
|
{
|
|
myFTLib = new Font_FTLibrary();
|
|
}
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : Font_FTFont
|
|
// purpose :
|
|
// =======================================================================
|
|
Font_FTFont::~Font_FTFont()
|
|
{
|
|
Release();
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : Font_FTFont
|
|
// purpose :
|
|
// =======================================================================
|
|
void Font_FTFont::Release()
|
|
{
|
|
myGlyphImg.Clear();
|
|
myFontPath.Clear();
|
|
myUChar = 0;
|
|
if (myFTFace != NULL)
|
|
{
|
|
FT_Done_Face (myFTFace);
|
|
myFTFace = NULL;
|
|
}
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : Init
|
|
// purpose :
|
|
// =======================================================================
|
|
bool Font_FTFont::Init (const NCollection_String& theFontPath,
|
|
const unsigned int thePointSize,
|
|
const unsigned int theResolution)
|
|
{
|
|
Release();
|
|
myFontPath = theFontPath;
|
|
myPointSize = thePointSize;
|
|
if (!myFTLib->IsValid())
|
|
{
|
|
//std::cerr << "FreeType library is unavailable!\n";
|
|
Release();
|
|
return false;
|
|
}
|
|
|
|
if (FT_New_Face (myFTLib->Instance(), myFontPath.ToCString(), 0, &myFTFace) != 0)
|
|
{
|
|
//std::cerr << "Font '" << myFontPath << "' fail to load!\n";
|
|
Release();
|
|
return false;
|
|
}
|
|
else if (FT_Select_Charmap (myFTFace, ft_encoding_unicode) != 0)
|
|
{
|
|
//std::cerr << "Font '" << myFontPath << "' doesn't contains Unicode charmap!\n";
|
|
Release();
|
|
return false;
|
|
}
|
|
else if (FT_Set_Char_Size (myFTFace, 0L, toFTPoints (thePointSize), theResolution, theResolution) != 0)
|
|
{
|
|
//std::cerr << "Font '" << myFontPath << "' doesn't contains Unicode charmap!\n";
|
|
Release();
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : Init
|
|
// purpose :
|
|
// =======================================================================
|
|
bool Font_FTFont::Init (const NCollection_String& theFontName,
|
|
const Font_FontAspect theFontAspect,
|
|
const unsigned int thePointSize,
|
|
const unsigned int theResolution)
|
|
{
|
|
Handle(Font_FontMgr) aFontMgr = Font_FontMgr::GetInstance();
|
|
const Handle(TCollection_HAsciiString) aFontName = new TCollection_HAsciiString (theFontName.ToCString());
|
|
Handle(Font_SystemFont) aRequestedFont = aFontMgr->FindFont (aFontName, theFontAspect, thePointSize);
|
|
return !aRequestedFont.IsNull()
|
|
&& Font_FTFont::Init (aRequestedFont->FontPath()->ToCString(), thePointSize, theResolution);
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : loadGlyph
|
|
// purpose :
|
|
// =======================================================================
|
|
bool Font_FTFont::loadGlyph (const Standard_Utf32Char theUChar)
|
|
{
|
|
if (myUChar == theUChar)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
myGlyphImg.Clear();
|
|
myUChar = 0;
|
|
if (theUChar == 0
|
|
|| FT_Load_Char (myFTFace, theUChar, myLoadFlags) != 0
|
|
|| myFTFace->glyph == NULL)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
myUChar = theUChar;
|
|
return true;
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : RenderGlyph
|
|
// purpose :
|
|
// =======================================================================
|
|
bool Font_FTFont::RenderGlyph (const Standard_Utf32Char theUChar)
|
|
{
|
|
myGlyphImg.Clear();
|
|
myUChar = 0;
|
|
if (theUChar == 0
|
|
|| FT_Load_Char (myFTFace, theUChar, myLoadFlags | FT_LOAD_RENDER) != 0
|
|
|| myFTFace->glyph == NULL
|
|
|| myFTFace->glyph->format != FT_GLYPH_FORMAT_BITMAP)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
FT_Bitmap aBitmap = myFTFace->glyph->bitmap;
|
|
if (aBitmap.pixel_mode != FT_PIXEL_MODE_GRAY
|
|
|| aBitmap.buffer == NULL || aBitmap.width <= 0 || aBitmap.rows <= 0)
|
|
{
|
|
return false;
|
|
}
|
|
if (!myGlyphImg.InitWrapper (Image_PixMap::ImgAlpha, aBitmap.buffer,
|
|
aBitmap.width, aBitmap.rows, Abs (aBitmap.pitch)))
|
|
{
|
|
return false;
|
|
}
|
|
myGlyphImg.SetTopDown (aBitmap.pitch > 0);
|
|
myUChar = theUChar;
|
|
return true;
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : GlyphMaxSizeX
|
|
// purpose :
|
|
// =======================================================================
|
|
unsigned int Font_FTFont::GlyphMaxSizeX() const
|
|
{
|
|
float aWidth = (FT_IS_SCALABLE(myFTFace) != 0)
|
|
? float(myFTFace->bbox.xMax - myFTFace->bbox.xMin) * (float(myFTFace->size->metrics.x_ppem) / float(myFTFace->units_per_EM))
|
|
: fromFTPoints<float> (myFTFace->size->metrics.max_advance);
|
|
return (unsigned int)(aWidth + 0.5f);
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : GlyphMaxSizeY
|
|
// purpose :
|
|
// =======================================================================
|
|
unsigned int Font_FTFont::GlyphMaxSizeY() const
|
|
{
|
|
float aHeight = (FT_IS_SCALABLE(myFTFace) != 0)
|
|
? float(myFTFace->bbox.yMax - myFTFace->bbox.yMin) * (float(myFTFace->size->metrics.y_ppem) / float(myFTFace->units_per_EM))
|
|
: fromFTPoints<float> (myFTFace->size->metrics.height);
|
|
return (unsigned int)(aHeight + 0.5f);
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : AdvanceX
|
|
// purpose :
|
|
// =======================================================================
|
|
float Font_FTFont::AdvanceX (const Standard_Utf32Char theUChar,
|
|
const Standard_Utf32Char theUCharNext)
|
|
{
|
|
loadGlyph (theUChar);
|
|
return AdvanceX (theUCharNext);
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : AdvanceY
|
|
// purpose :
|
|
// =======================================================================
|
|
float Font_FTFont::AdvanceY (const Standard_Utf32Char theUChar,
|
|
const Standard_Utf32Char theUCharNext)
|
|
{
|
|
loadGlyph (theUChar);
|
|
return AdvanceY (theUCharNext);
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : AdvanceX
|
|
// purpose :
|
|
// =======================================================================
|
|
float Font_FTFont::AdvanceX (const Standard_Utf32Char theUCharNext)
|
|
{
|
|
if (myUChar == 0)
|
|
{
|
|
return 0.0f;
|
|
}
|
|
|
|
if (FT_HAS_KERNING (myFTFace) == 0 || theUCharNext == 0
|
|
|| FT_Get_Kerning (myFTFace, myUChar, theUCharNext, FT_KERNING_UNFITTED, &myKernAdvance) != 0)
|
|
{
|
|
return fromFTPoints<float> (myFTFace->glyph->advance.x);
|
|
}
|
|
return fromFTPoints<float> (myKernAdvance.x + myFTFace->glyph->advance.x);
|
|
}
|
|
|
|
// =======================================================================
|
|
// function : AdvanceY
|
|
// purpose :
|
|
// =======================================================================
|
|
float Font_FTFont::AdvanceY (const Standard_Utf32Char theUCharNext)
|
|
{
|
|
if (myUChar == 0)
|
|
{
|
|
return 0.0f;
|
|
}
|
|
|
|
if (FT_HAS_KERNING (myFTFace) == 0 || theUCharNext == 0
|
|
|| FT_Get_Kerning (myFTFace, myUChar, theUCharNext, FT_KERNING_UNFITTED, &myKernAdvance) != 0)
|
|
{
|
|
return fromFTPoints<float> (myFTFace->glyph->advance.y);
|
|
}
|
|
return fromFTPoints<float> (myKernAdvance.y + myFTFace->glyph->advance.y);
|
|
}
|