2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2013 Zynga Inc.
|
|
|
|
Copyright (c) 2013-2016 Chukong Technologies Inc.
|
|
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
2023-12-08 00:13:39 +08:00
|
|
|
Copyright (c) 2019-present Axmol Engine contributors (see AUTHORS.md).
|
2021-11-11 17:20:21 +08:00
|
|
|
|
2024-06-10 02:25:43 +08:00
|
|
|
https://axmol.dev/
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
|
2024-08-11 21:11:35 +08:00
|
|
|
#ifndef _AX_FONTATLAS_H_
|
|
|
|
#define _AX_FONTATLAS_H_
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/// @cond DO_NOT_SHOW
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <unordered_map>
|
|
|
|
|
2023-06-11 13:08:08 +08:00
|
|
|
#include "platform/PlatformMacros.h"
|
2024-05-03 22:15:08 +08:00
|
|
|
#include "base/Object.h"
|
2023-06-11 13:08:08 +08:00
|
|
|
#include "platform/StdC.h" // ssize_t on windows
|
|
|
|
#include "renderer/Texture2D.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2024-04-08 01:55:41 +08:00
|
|
|
#include "base/Map.h"
|
|
|
|
#include "2d/FontFreeType.h"
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_BEGIN
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
class Font;
|
|
|
|
class EventCustom;
|
|
|
|
class EventListenerCustom;
|
|
|
|
class FontFreeType;
|
|
|
|
|
|
|
|
struct FontLetterDefinition
|
|
|
|
{
|
|
|
|
float U;
|
|
|
|
float V;
|
|
|
|
float width;
|
|
|
|
float height;
|
|
|
|
float offsetX;
|
|
|
|
float offsetY;
|
|
|
|
int textureID;
|
|
|
|
bool validDefinition;
|
|
|
|
int xAdvance;
|
2020-01-06 09:35:52 +08:00
|
|
|
bool rotated;
|
2019-11-23 20:27:39 +08:00
|
|
|
};
|
|
|
|
|
2024-05-03 22:15:08 +08:00
|
|
|
class AX_DLL FontAtlas : public Object
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
static const int CacheTextureWidth;
|
|
|
|
static const int CacheTextureHeight;
|
|
|
|
static const char* CMD_PURGE_FONTATLAS;
|
|
|
|
static const char* CMD_RESET_FONTATLAS;
|
2023-09-26 01:33:06 +08:00
|
|
|
static void loadFontAtlas(std::string_view fontatlasFile, hlookup::string_map<FontAtlas*>& outAtlasMap);
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* @js ctor
|
|
|
|
*/
|
2021-11-11 17:20:21 +08:00
|
|
|
FontAtlas(Font* theFont);
|
2023-09-26 01:33:06 +08:00
|
|
|
FontAtlas(Font* theFont, int atlasWidth, int atlasHeight, float scaleFactor = 1.0f);
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
|
|
|
virtual ~FontAtlas();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
void addLetterDefinition(char32_t utf32Char, const FontLetterDefinition& letterDefinition);
|
|
|
|
bool getLetterDefinitionForChar(char32_t utf32Char, FontLetterDefinition& letterDefinition);
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
bool prepareLetterDefinitions(const std::u32string& utf16String);
|
|
|
|
|
2023-09-26 01:33:06 +08:00
|
|
|
const auto& getLetterDefinitions() const { return _letterDefinitions; }
|
|
|
|
|
2022-06-13 01:44:31 +08:00
|
|
|
const std::unordered_map<unsigned int, Texture2D*>& getTextures() const { return _atlasTextures; }
|
|
|
|
|
2023-09-26 01:33:06 +08:00
|
|
|
virtual void addNewPage();
|
|
|
|
|
|
|
|
void addNewPageWithData(const uint8_t* data, size_t size);
|
2022-06-13 01:44:31 +08:00
|
|
|
|
|
|
|
void setTexture(unsigned int slot, Texture2D* texture);
|
|
|
|
Texture2D* getTexture(int slot);
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
float getLineHeight() const { return _lineHeight; }
|
2021-12-25 10:04:45 +08:00
|
|
|
void setLineHeight(float newHeight);
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
std::string_view getFontName() const;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
const Font* getFont() const { return _font; }
|
|
|
|
|
|
|
|
/** listen the event that renderer was recreated on Android/WP8
|
|
|
|
It only has effect on Android and WP8.
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void listenRendererRecreated(EventCustom* event);
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Removes textures atlas.
|
|
|
|
It will purge the textures atlas and if multiple texture exist in the FontAtlas.
|
|
|
|
*/
|
|
|
|
void purgeTexturesAtlas();
|
|
|
|
|
|
|
|
/** sets font texture parameters:
|
|
|
|
- GL_TEXTURE_MIN_FILTER = GL_LINEAR
|
|
|
|
- GL_TEXTURE_MAG_FILTER = GL_LINEAR
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void setAntiAliasTexParameters();
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/** sets font texture parameters:
|
|
|
|
- GL_TEXTURE_MIN_FILTER = GL_NEAREST
|
|
|
|
- GL_TEXTURE_MAG_FILTER = GL_NEAREST
|
|
|
|
*/
|
|
|
|
void setAliasTexParameters();
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
protected:
|
2023-09-26 01:33:06 +08:00
|
|
|
void initWithSettings(void* opaque /*simdjson::ondemand::document*/);
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
void reset();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
void reinit();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
void releaseTextures();
|
|
|
|
|
2022-06-12 22:26:54 +08:00
|
|
|
void findNewCharacters(const std::u32string& u32Text, std::unordered_set<char32_t>& charCodeSet);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Scale each font letter by scaleFactor.
|
|
|
|
*
|
|
|
|
* @param scaleFactor A float scale factor for scaling font letter info.
|
|
|
|
*/
|
|
|
|
void scaleFontLetterDefinition(float scaleFactor);
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
void updateTextureContent(backend::PixelFormat format, int startY);
|
|
|
|
|
2022-06-13 01:44:31 +08:00
|
|
|
std::unordered_map<unsigned int, Texture2D*> _atlasTextures;
|
2019-11-23 20:27:39 +08:00
|
|
|
std::unordered_map<char32_t, FontLetterDefinition> _letterDefinitions;
|
2023-09-26 01:33:06 +08:00
|
|
|
|
2024-04-08 01:55:41 +08:00
|
|
|
StringMap<FontFreeType*> _missingFallbackFonts; // maybe style no needs?
|
|
|
|
std::unordered_map<char32_t, std::pair<FontFreeType*, unsigned int>> _missingGlyphFallbackFonts;
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
Font* _font = nullptr;
|
2019-11-23 20:27:39 +08:00
|
|
|
FontFreeType* _fontFreeType = nullptr;
|
|
|
|
|
2023-09-26 01:33:06 +08:00
|
|
|
int _width = 0; // atlas width
|
|
|
|
int _height = 0; // atlas height
|
|
|
|
float _scaleFactor = 1.0f;
|
|
|
|
|
|
|
|
float _lineHeight = 0.f;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// Dynamic GlyphCollection related stuff
|
2022-06-13 01:44:31 +08:00
|
|
|
int _currentPage = -1;
|
|
|
|
backend::PixelFormat _pixelFormat = backend::PixelFormat::NONE;
|
|
|
|
int _strideShift = 0;
|
|
|
|
uint8_t* _currentPageData = nullptr;
|
|
|
|
int _currentPageDataSize = 0;
|
2023-09-20 23:05:21 +08:00
|
|
|
|
2022-06-13 01:44:31 +08:00
|
|
|
float _currentPageOrigX = 0;
|
|
|
|
float _currentPageOrigY = 0;
|
|
|
|
int _letterPadding = 0;
|
|
|
|
int _letterEdgeExtend = 0;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
int _fontAscender = 0;
|
2019-11-23 20:27:39 +08:00
|
|
|
EventListenerCustom* _rendererRecreatedListener = nullptr;
|
2021-12-25 10:04:45 +08:00
|
|
|
bool _antialiasEnabled = true;
|
|
|
|
int _currLineHeight = 0;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
friend class Label;
|
|
|
|
};
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_END
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/// @endcond
|
2024-08-11 21:11:35 +08:00
|
|
|
#endif /* defined(_AX_FONTATLAS_H_) */
|