Initial commit: DayZ memory C++ port with DMA backend and overlay
This commit is contained in:
+11
@@ -0,0 +1,11 @@
|
|||||||
|
build/
|
||||||
|
cmake-build-*/
|
||||||
|
.idea/
|
||||||
|
.claude/
|
||||||
|
maps/
|
||||||
|
vpcc
|
||||||
|
out/
|
||||||
|
*.obj
|
||||||
|
*.exe
|
||||||
|
*.pdb
|
||||||
|
*.ilk
|
||||||
+312
@@ -0,0 +1,312 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.20)
|
||||||
|
project(dayz-memory-cpp CXX)
|
||||||
|
set(CMAKE_CXX_STANDARD 20)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
set(CMAKE_CXX_EXTENSIONS OFF)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Platform guard
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
if(NOT WIN32)
|
||||||
|
message(FATAL_ERROR "dayz-memory-cpp is Windows-only (requires VolkDMA / WinAPI)")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Paths to VolkDMA (sibling checkout)
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
set(VOLKDMA_ROOT "${CMAKE_CURRENT_SOURCE_DIR}/../dayz-dma/dma-dayz-cpp-master/VolkDMA")
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Dependencies — nlohmann/json, spdlog via FetchContent; ImGui from local copy
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
include(FetchContent)
|
||||||
|
|
||||||
|
FetchContent_Declare(json
|
||||||
|
URL https://github.com/nlohmann/json/releases/download/v3.11.3/json.tar.xz
|
||||||
|
URL_HASH SHA256=d6c65aca6b1ed68e7a182f4757257b107ae403032760ed6ef121c9d55e81757d
|
||||||
|
)
|
||||||
|
|
||||||
|
FetchContent_Declare(spdlog
|
||||||
|
GIT_REPOSITORY https://github.com/gabime/spdlog.git
|
||||||
|
GIT_TAG v1.14.1
|
||||||
|
GIT_SHALLOW TRUE
|
||||||
|
)
|
||||||
|
|
||||||
|
# cpp-httplib — header-only HTTP/1.1 server used by WebRadarServer
|
||||||
|
FetchContent_Declare(httplib
|
||||||
|
GIT_REPOSITORY https://github.com/yhirose/cpp-httplib.git
|
||||||
|
GIT_TAG v0.18.1
|
||||||
|
GIT_SHALLOW TRUE
|
||||||
|
)
|
||||||
|
|
||||||
|
# stb — single-file image load/write libraries
|
||||||
|
FetchContent_Declare(stb
|
||||||
|
GIT_REPOSITORY https://github.com/nothings/stb.git
|
||||||
|
GIT_TAG master
|
||||||
|
GIT_SHALLOW TRUE
|
||||||
|
)
|
||||||
|
|
||||||
|
FetchContent_MakeAvailable(json spdlog httplib stb)
|
||||||
|
|
||||||
|
# Vendored Lumin ImGui (1.91.3 + FreeType) and its menu framework.
|
||||||
|
set(LUMIN_DIR "${CMAKE_CURRENT_SOURCE_DIR}/external/lumin")
|
||||||
|
set(IMGUI_DIR "${LUMIN_DIR}/thirdparty/imgui")
|
||||||
|
set(FREETYPE_DIR "${LUMIN_DIR}/thirdparty/freetype")
|
||||||
|
set(FRAMEWORK_DIR "${LUMIN_DIR}/framework")
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# ImGui sources (Lumin's bundled ImGui + FreeType atlas builder)
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
set(IMGUI_SOURCES
|
||||||
|
"${IMGUI_DIR}/imgui.cpp"
|
||||||
|
"${IMGUI_DIR}/imgui_draw.cpp"
|
||||||
|
"${IMGUI_DIR}/imgui_tables.cpp"
|
||||||
|
"${IMGUI_DIR}/imgui_widgets.cpp"
|
||||||
|
"${IMGUI_DIR}/imgui_freetype.cpp"
|
||||||
|
"${IMGUI_DIR}/backends/imgui_impl_win32.cpp"
|
||||||
|
"${IMGUI_DIR}/backends/imgui_impl_dx11.cpp"
|
||||||
|
)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Lumin menu framework sources (the actual menu UI)
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
set(FRAMEWORK_SOURCES
|
||||||
|
"${FRAMEWORK_DIR}/gui.cpp"
|
||||||
|
"${FRAMEWORK_DIR}/helpers/draw.cpp"
|
||||||
|
"${FRAMEWORK_DIR}/helpers/fonts.cpp"
|
||||||
|
"${FRAMEWORK_DIR}/widgets/helpers.cpp"
|
||||||
|
"${FRAMEWORK_DIR}/widgets/notify.cpp"
|
||||||
|
"${FRAMEWORK_DIR}/widgets/text_field.cpp"
|
||||||
|
"${FRAMEWORK_DIR}/widgets/widgets.cpp"
|
||||||
|
"${FRAMEWORK_DIR}/widgets/window.cpp"
|
||||||
|
)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Sources — project + VolkDMA implementation files
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
file(GLOB_RECURSE PROJECT_SOURCES "src/*.cpp")
|
||||||
|
# Explicit list ensures new files are picked up without a CMake cache reset.
|
||||||
|
list(APPEND PROJECT_SOURCES
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/src/SigScanner/SigScanner.cpp"
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/src/Overlay/OverlayWindow.cpp"
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/src/Overlay/GameOverlay.cpp"
|
||||||
|
)
|
||||||
|
list(REMOVE_DUPLICATES PROJECT_SOURCES)
|
||||||
|
|
||||||
|
set(VOLKDMA_SOURCES
|
||||||
|
"${VOLKDMA_ROOT}/src/dma.cpp"
|
||||||
|
"${VOLKDMA_ROOT}/src/process.cpp"
|
||||||
|
"${VOLKDMA_ROOT}/src/inputstate.cpp"
|
||||||
|
)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Embed map PNGs as Windows RCDATA resources
|
||||||
|
#
|
||||||
|
# Maps present in maps/ at configure time are baked into the binary so the
|
||||||
|
# server works out-of-the-box without copying anything next to the exe.
|
||||||
|
# A PNG placed on disk at runtime (maps/<id>.png next to the exe) still
|
||||||
|
# takes priority, so maps can be updated without rebuilding.
|
||||||
|
#
|
||||||
|
# Re-run CMake if you add new PNGs to maps/ after the initial configure.
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
set(MAPS_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/maps")
|
||||||
|
set(EMBEDDED_MAPS_RC "${CMAKE_CURRENT_BINARY_DIR}/maps_embedded.rc")
|
||||||
|
set(EMBEDDED_MAPS_CPP "${CMAKE_CURRENT_BINARY_DIR}/EmbeddedMaps.cpp")
|
||||||
|
|
||||||
|
set(MAP_IDS chernarusplus livonia namalsk banov deadfall deerisle esseker lux sakhal takistan alteria)
|
||||||
|
set(MAP_RIDS 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011)
|
||||||
|
|
||||||
|
set(RC_LINES "")
|
||||||
|
set(CPP_CASES "")
|
||||||
|
foreach(MAP_ID MAP_RID IN ZIP_LISTS MAP_IDS MAP_RIDS)
|
||||||
|
if(EXISTS "${MAPS_SOURCE_DIR}/${MAP_ID}.png")
|
||||||
|
string(APPEND RC_LINES "${MAP_RID} RCDATA \"${MAPS_SOURCE_DIR}/${MAP_ID}.png\"\n")
|
||||||
|
string(APPEND CPP_CASES " if (mapId == \"${MAP_ID}\") return LoadRcData(${MAP_RID});\n")
|
||||||
|
message(STATUS "Embedding map: ${MAP_ID}")
|
||||||
|
else()
|
||||||
|
message(STATUS "Skipping map (not found): ${MAP_ID}")
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
file(WRITE "${EMBEDDED_MAPS_RC}" "// Auto-generated by CMake — do not edit.\n${RC_LINES}")
|
||||||
|
file(WRITE "${EMBEDDED_MAPS_CPP}"
|
||||||
|
"// Auto-generated by CMake — do not edit.
|
||||||
|
#ifndef WIN32_LEAN_AND_MEAN
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#endif
|
||||||
|
#include <Windows.h>
|
||||||
|
#include <cstdint>
|
||||||
|
#include <utility>
|
||||||
|
#include \"EmbeddedMaps.h\"
|
||||||
|
|
||||||
|
static std::pair<const uint8_t*, size_t> LoadRcData(int resourceId) {
|
||||||
|
HRSRC hRes = FindResource(nullptr, MAKEINTRESOURCE(resourceId), RT_RCDATA);
|
||||||
|
if (!hRes) return {nullptr, 0};
|
||||||
|
HGLOBAL hData = LoadResource(nullptr, hRes);
|
||||||
|
if (!hData) return {nullptr, 0};
|
||||||
|
const void* ptr = LockResource(hData);
|
||||||
|
DWORD sz = SizeofResource(nullptr, hRes);
|
||||||
|
if (!ptr || sz == 0) return {nullptr, 0};
|
||||||
|
return {static_cast<const uint8_t*>(ptr), sz};
|
||||||
|
}
|
||||||
|
|
||||||
|
std::pair<const uint8_t*, size_t> GetEmbeddedMap(const std::string& mapId) {
|
||||||
|
${CPP_CASES} return {nullptr, 0};
|
||||||
|
}
|
||||||
|
")
|
||||||
|
|
||||||
|
add_executable(dayz-memory-cpp
|
||||||
|
${PROJECT_SOURCES}
|
||||||
|
${VOLKDMA_SOURCES}
|
||||||
|
${IMGUI_SOURCES}
|
||||||
|
${FRAMEWORK_SOURCES}
|
||||||
|
)
|
||||||
|
|
||||||
|
# Wire in the generated RC + CPP files.
|
||||||
|
target_sources(dayz-memory-cpp PRIVATE
|
||||||
|
"${EMBEDDED_MAPS_RC}"
|
||||||
|
"${EMBEDDED_MAPS_CPP}"
|
||||||
|
)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Include directories
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
target_include_directories(dayz-memory-cpp PRIVATE
|
||||||
|
# Own source tree
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/src"
|
||||||
|
|
||||||
|
# ImGui core + Win32/DX11 backends
|
||||||
|
"${IMGUI_DIR}"
|
||||||
|
"${IMGUI_DIR}/backends"
|
||||||
|
|
||||||
|
# FreeType headers (atlas builder)
|
||||||
|
"${FREETYPE_DIR}/include"
|
||||||
|
|
||||||
|
# Lumin framework root — lets sources include "framework/headers/includes.h"
|
||||||
|
"${LUMIN_DIR}"
|
||||||
|
"${FRAMEWORK_DIR}"
|
||||||
|
|
||||||
|
# VolkDMA repo root — VolkDMA's own source files use paths like
|
||||||
|
# "include/VolkDMA/dma.hh" and "external/vmm/vmmdll.h" that are
|
||||||
|
# relative to this root, so this entry must come first.
|
||||||
|
"${VOLKDMA_ROOT}"
|
||||||
|
|
||||||
|
# VolkDMA public headers (provides <VolkDMA/dma.hh> etc.)
|
||||||
|
"${VOLKDMA_ROOT}/include"
|
||||||
|
|
||||||
|
# VolkLog (required by VolkDMA's dma.cpp / process.cpp)
|
||||||
|
"${VOLKDMA_ROOT}/external/VolkLog/include"
|
||||||
|
|
||||||
|
# Raw vmmdll / leechcore headers (used in VmmAccessor.cpp + VolkDMA sources)
|
||||||
|
"${VOLKDMA_ROOT}/external/vmm"
|
||||||
|
"${VOLKDMA_ROOT}/external/leechcore"
|
||||||
|
|
||||||
|
# cpp-httplib (header-only; FetchContent populates httplib_SOURCE_DIR)
|
||||||
|
"${httplib_SOURCE_DIR}"
|
||||||
|
|
||||||
|
# stb (header-only image library; stb_impl.cpp provides the implementation)
|
||||||
|
"${stb_SOURCE_DIR}"
|
||||||
|
)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Link directories
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
target_link_directories(dayz-memory-cpp PRIVATE
|
||||||
|
"${VOLKDMA_ROOT}/external/vmm"
|
||||||
|
"${VOLKDMA_ROOT}/external/leechcore"
|
||||||
|
)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Link libraries
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
target_link_libraries(dayz-memory-cpp PRIVATE
|
||||||
|
nlohmann_json::nlohmann_json
|
||||||
|
spdlog::spdlog
|
||||||
|
vmm
|
||||||
|
leechcore
|
||||||
|
# FreeType (prebuilt x64) — Lumin font atlas builder
|
||||||
|
"${FREETYPE_DIR}/win64/freetype.lib"
|
||||||
|
# DirectX 11 + DXGI (for ImGui DX11 window)
|
||||||
|
d3d11
|
||||||
|
dxgi
|
||||||
|
# WinSock2 — required by cpp-httplib on Windows
|
||||||
|
Ws2_32
|
||||||
|
)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Post-build: copy VolkDMA runtime DLLs next to the executable.
|
||||||
|
# Without these (vmm.dll, leechcore.dll, FTD3XX.dll) the process exits with
|
||||||
|
# 0xC0000135 (STATUS_DLL_NOT_FOUND) immediately on launch.
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
set(VOLKDMA_DLLS_DIR "${VOLKDMA_ROOT}/dlls")
|
||||||
|
foreach(DLL vmm.dll leechcore.dll FTD3XX.dll)
|
||||||
|
add_custom_command(TARGET dayz-memory-cpp POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different
|
||||||
|
"${VOLKDMA_DLLS_DIR}/${DLL}"
|
||||||
|
"$<TARGET_FILE_DIR:dayz-memory-cpp>/${DLL}"
|
||||||
|
COMMENT "Copying ${DLL} to output directory"
|
||||||
|
)
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
# Copy webroot/ directory next to the executable so the HTTP server can serve it.
|
||||||
|
add_custom_command(TARGET dayz-memory-cpp POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_directory
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/webroot"
|
||||||
|
"$<TARGET_FILE_DIR:dayz-memory-cpp>/webroot"
|
||||||
|
COMMENT "Copying webroot to output directory"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Copy the Lumin icon font next to the executable so the menu's tab icons load
|
||||||
|
# (flaticon_uicons_regular_rounded_path is resolved relative to the work dir).
|
||||||
|
add_custom_command(TARGET dayz-memory-cpp POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_directory
|
||||||
|
"${FRAMEWORK_DIR}/data/uicons"
|
||||||
|
"$<TARGET_FILE_DIR:dayz-memory-cpp>/data/uicons"
|
||||||
|
COMMENT "Copying Lumin uicons font to output directory"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Copy config/ directory next to the executable (config.cfg, item_filters.json).
|
||||||
|
add_custom_command(TARGET dayz-memory-cpp POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_directory
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/config"
|
||||||
|
"$<TARGET_FILE_DIR:dayz-memory-cpp>/config"
|
||||||
|
COMMENT "Copying config to output directory"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Copy maps/ directory next to the executable so MapTileService can find PNGs.
|
||||||
|
# maps/ is git-ignored (user-supplied), so only copy when it exists.
|
||||||
|
if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/maps")
|
||||||
|
add_custom_command(TARGET dayz-memory-cpp POST_BUILD
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_directory
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/maps"
|
||||||
|
"$<TARGET_FILE_DIR:dayz-memory-cpp>/maps"
|
||||||
|
COMMENT "Copying maps to output directory"
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# Compiler definitions
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
target_compile_definitions(dayz-memory-cpp PRIVATE
|
||||||
|
_WIN32_WINNT=0x0601
|
||||||
|
# Build the ImGui font atlas with FreeType (Lumin requirement; also set in
|
||||||
|
# the vendored imconfig.h, kept here so every TU agrees).
|
||||||
|
IMGUI_ENABLE_FREETYPE
|
||||||
|
IMGUI_DEFINE_MATH_OPERATORS
|
||||||
|
# WIN32_LEAN_AND_MEAN is intentionally NOT set globally: vmmdll.h requires
|
||||||
|
# NTSTATUS from <winternl.h>, which windows.h omits when LEAN_AND_MEAN is
|
||||||
|
# defined. Our own headers define it locally before including <Windows.h>.
|
||||||
|
NOMINMAX
|
||||||
|
)
|
||||||
|
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
# MSVC-specific flags
|
||||||
|
# -------------------------------------------------------------------------
|
||||||
|
if(MSVC)
|
||||||
|
target_compile_options(dayz-memory-cpp PRIVATE
|
||||||
|
/W4
|
||||||
|
/WX- # vmmdll / VolkDMA headers generate some W4 noise
|
||||||
|
/permissive-
|
||||||
|
/utf-8
|
||||||
|
)
|
||||||
|
endif()
|
||||||
@@ -0,0 +1,36 @@
|
|||||||
|
# DayZ Memory Reader — runtime config
|
||||||
|
# Lines starting with # are comments.
|
||||||
|
# Changes take effect on next launch.
|
||||||
|
|
||||||
|
# ---- Refresh intervals (milliseconds) ----
|
||||||
|
nearEntityRefreshMs = 50
|
||||||
|
farEntityRefreshMs = 100
|
||||||
|
slowEntityRefreshMs = 100
|
||||||
|
playersRefreshMs = 50
|
||||||
|
bulletRefreshMs = 50
|
||||||
|
itemRefreshMs = 200
|
||||||
|
scoreboardRefreshMs = 30000
|
||||||
|
networkMetadataRefreshMs = 30000
|
||||||
|
|
||||||
|
# ---- Batch sizes (entities processed per tick) ----
|
||||||
|
farEntityBatchSize = 64
|
||||||
|
slowEntityBatchSize = 64
|
||||||
|
itemBatchSize = 64
|
||||||
|
|
||||||
|
# ---- Main loop idle sleep (ms) — lower = more CPU, more responsive ----
|
||||||
|
liveLoopIdleMs = 1
|
||||||
|
|
||||||
|
# ---- VMM page-cache flush interval (ms) ----
|
||||||
|
# ForceRefresh flushes VMMDLL's internal page cache so stale physical-memory
|
||||||
|
# entries don't accumulate. Without this the tool stops working ~1 h into a
|
||||||
|
# session as the game heap reallocates and cached pages go stale.
|
||||||
|
# 30 s is a safe default; lower values increase DMA bus load slightly.
|
||||||
|
vmmRefreshMs = 30000
|
||||||
|
|
||||||
|
# ---- Reconnect behaviour ----
|
||||||
|
reconnectThreshold = 5 # consecutive failures before reconnect
|
||||||
|
reconnectGracePeriodMs = 5000 # ms to wait after session lost before reconnecting
|
||||||
|
|
||||||
|
# ---- Process ----
|
||||||
|
processName = DayZ_x64.exe
|
||||||
|
useMemoryMap = true
|
||||||
@@ -0,0 +1,41 @@
|
|||||||
|
{
|
||||||
|
"isHouse": {
|
||||||
|
"desc": "Structures and storage",
|
||||||
|
"Color": "#06b6d4",
|
||||||
|
"ModelName": [
|
||||||
|
"\\containers\\",
|
||||||
|
"\\camping\\",
|
||||||
|
"\\cooking\\",
|
||||||
|
"dex_storage\\data\\guncase\\dex_guncase.p3d",
|
||||||
|
"dex_storage\\data\\box",
|
||||||
|
"\\gear\\cultivation",
|
||||||
|
"tr_modules\\tr_models\\tr_garagedoor.p3d",
|
||||||
|
"tr_modules\\tr_models\\tr_shieldsmall.p3d",
|
||||||
|
"tr_modules\\tr_models\\tr_narrowdoor.p3d",
|
||||||
|
"tr_modules\\tr_models\\tr_mediumdoor.p3d",
|
||||||
|
"tr_fortification\\tr_models\\tr_fortification.p3d",
|
||||||
|
"oh_furniture_pvp_client\\lockercabin\\lockercabin.p3d",
|
||||||
|
"oh_furniture_pvp_client\\military_box\\",
|
||||||
|
"oh_furniture_pvp_client\\fridge_small\\ohfridge.p3d",
|
||||||
|
"oh_furniture_pvp_client\\big_locker\\big_locker.p3d",
|
||||||
|
"oh_furniture_pvp_client\\metal_shelving_barrel_big\\metal_shelving_barrel_big.p3d",
|
||||||
|
"oh_furniture_pvp_client\\singlelocker\\ohsingle_locker.p3d"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"isWeapon": {"desc": "Weapons", "Color": "#f43f5e", "TypeName": "weapon"},
|
||||||
|
"isAmmo": {"desc": "Ammo", "Color": "#f59e0b", "ModelName": "\\ammunition\\"},
|
||||||
|
"isFood": {"desc": "Food and drinks", "Color": "#22c55e", "ModelName": ["\\food\\", "\\drinks\\"]},
|
||||||
|
"isClothing": {"desc": "Clothing", "Color": "#eab308", "TypeName": "clothing"},
|
||||||
|
"isBackpack": {"desc": "Backpacks", "Color": "#84cc16", "ModelName": "\\characters\\vests\\", "TypeName": "backpack"},
|
||||||
|
"isMedical": {"desc": "Medical supplies", "Color": "#ec4899", "ModelName": "\\medical\\"},
|
||||||
|
"isVehiclePart": {"desc": "Vehicle parts", "Color": "#0ea5e9", "ModelName": ["\\vehicles\\parts\\", "\\vehicles\\wheeled\\", "bastard_framework\\proxy\\motobattery.p3d"], "TypeName": "carwheel"},
|
||||||
|
"isTool": {"desc": "Tools", "Color": "#14b8a6", "ModelName": "\\tools\\"},
|
||||||
|
"isCrafting": {"desc": "Crafting materials", "Color": "#c084fc", "ModelName": "\\crafting\\"},
|
||||||
|
"isConsumables": {"desc": "Consumables", "Color": "#f97316", "ModelName": ["\\consumables\\", "\\str_consumables\\"]},
|
||||||
|
"isOptics": {"desc": "Optics", "Color": "#d946ef", "TypeName": "itemoptics"},
|
||||||
|
"isMelee": {"desc": "Melee weapons", "Color": "#dc2626", "ModelName": "\\weapons\\melee\\", "TypeName": "weapon"},
|
||||||
|
"isWeaponAttachments": {"desc": "Weapon attachments", "Color": "#fbbf24", "ModelName": ["weapons\\attachments\\", "weapon_b\\attachments\\", "weapon_a\\attachments\\"]},
|
||||||
|
"isExplosives": {"desc": "Explosives", "Color": "#fb923c", "ModelName": "\\explosives\\"},
|
||||||
|
"isForBuilding": {"desc": "Base building", "Color": "#0891b2", "ModelName": "\\codelock\\"},
|
||||||
|
"isOtherLoot": {"desc": "Other loot", "Color": "#64748b"}
|
||||||
|
}
|
||||||
+57510
File diff suppressed because it is too large
Load Diff
+11
@@ -0,0 +1,11 @@
|
|||||||
|
Flaticon License
|
||||||
|
|
||||||
|
By means of these Terms, the Company grants the User a Flaticon License under which the User is authorized to download, use and modify the Flaticon Content on a device owned or controlled by the User on a non-transferable, limited, exclusive, revocable and worldwide basis for the entire duration of the rights and solely for the purposes and uses authorized under these Terms.
|
||||||
|
|
||||||
|
Without prejudice to the provisions set forth in paragraph 3 of this clause, the User of a Flaticon License may use the content in the Flaticon Content, provided that the Flaticon Content is not used in printed or electronic items (e.g. t-shirts, cups, postcards, birthday or greeting cards, invitations, calendars, web models or electronic devices, apps, NFTs, videogames, advertising spots, audiovisual animations) aimed to be resold, in which the Flaticon Content is the main element (because of size, relevance or any other cause, in case of doubt about whether the content is main element, it shall be deemed that the content is main element);
|
||||||
|
|
||||||
|
Furthermore, the authorization to use the content in the Flaticon Content shall be free of charge under the Flaticon License where any use thereof by the User is done by duly crediting said content to the Website/Company and, in any event, to the Collaborator, as stated by the Company from time to time. In order to benefit from the Service of using the Flaticon Content without the aforementioned crediting, the User must purchase a subscription (hereinafter the "Premium Subscription") from the Website and download the relevant Flaticon Content during the term of said Premium Subscription. The terms set forth in Section 9 shall apply to the purchase of the Premium Subscription.
|
||||||
|
|
||||||
|
Where any content of the Flaticon Content is marked or identified as being for editorial use, or where within the same there are distinctive signs, recognizable products, public buildings, public events or images taken in places where recognizable persons appear in the background, the User shall only be entitled to use it for such editorial use; in other words, for purposes related to exercising freedom of expression and the right to information or for academic or educational purposes. More specifically, this means that the User undertakes not to use said content in any way that could imply a link to any business activity, use in the course of trade or the advertising, promotion or marketing of any product or service. In addition, the User shall ensure that any use for educational purposes is allowed under any legislation which applies and shall fulfill any requirements set forth by such legislation, including, but not limited to, citation obligations or limitations on the extent or purpose of said use. The User shall be directly liable for, and the Company shall not assume any liability resulting from the use for commercial purposes by the User of any content in the Flaticon Content whose use must be limited to editorial use as set forth in this paragraph or as a consequence of any editorial use that is contrary to the legislation which applies.
|
||||||
|
|
||||||
|
More information about the Term and Conditions of use on https://www.freepikcompany.com/legal?#nav-flaticon
|
||||||
Binary file not shown.
Vendored
+597
@@ -0,0 +1,597 @@
|
|||||||
|
#include "headers/includes.h"
|
||||||
|
|
||||||
|
#include <Windows.h>
|
||||||
|
#include <array>
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include "Overlay/MenuBridge.h" // project header (src/ is on the include path)
|
||||||
|
|
||||||
|
// -------------------------------------------------------------------------
|
||||||
|
// DayZ overlay integration
|
||||||
|
//
|
||||||
|
// This is the original Lumin demo `gui.cpp`, stripped of the login screen and
|
||||||
|
// the placeholder "visual" feature panels. The window/sidebar/feature
|
||||||
|
// scaffolding is preserved verbatim; only the tab list and per-tab content
|
||||||
|
// were swapped to drive this project's real ESP state via `g_menu`
|
||||||
|
// (see src/Overlay/MenuBridge.h). https://discord.gg/jxqVWub6Dk
|
||||||
|
// -------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void sync_layout_preferences()
|
||||||
|
{
|
||||||
|
elements->padding = var->gui.compact_layout ? c_vec2(8, 8) : c_vec2(10, 10);
|
||||||
|
elements->window.rounding = var->gui.window_rounding;
|
||||||
|
}
|
||||||
|
|
||||||
|
static constexpr float visual_window_width = 900.f;
|
||||||
|
static constexpr float visual_window_height = 527.f;
|
||||||
|
static constexpr float visual_sidebar_width = 162.5f;
|
||||||
|
static constexpr float visual_outer_padding = 10.f;
|
||||||
|
static constexpr float visual_column_gap = 14.f;
|
||||||
|
static constexpr float visual_panel_scale = 1.0f;
|
||||||
|
static constexpr float visual_section_width_scale = 0.98f;
|
||||||
|
static constexpr float visual_feature_padding_x = 0.f;
|
||||||
|
static constexpr float visual_feature_padding_y = 0.f;
|
||||||
|
|
||||||
|
struct visual_panel_density_state
|
||||||
|
{
|
||||||
|
float dpi;
|
||||||
|
float font_scale;
|
||||||
|
};
|
||||||
|
|
||||||
|
static float unscale_visual(float value)
|
||||||
|
{
|
||||||
|
return value / ImMax(var->gui.dpi, 0.01f);
|
||||||
|
}
|
||||||
|
|
||||||
|
static float visual_section_height(int section_count)
|
||||||
|
{
|
||||||
|
const float content_height = unscale_visual(gui->content_avail().y);
|
||||||
|
const float gaps = visual_column_gap * static_cast<float>(ImMax(section_count - 1, 0));
|
||||||
|
return ImMax(220.f, (content_height - gaps) / static_cast<float>(ImMax(section_count, 1)));
|
||||||
|
}
|
||||||
|
|
||||||
|
extern c_vec4 g_pill_selected_rect;
|
||||||
|
extern c_vec4 g_sidebar_selected_rect;
|
||||||
|
|
||||||
|
static int g_panel_number = 0;
|
||||||
|
|
||||||
|
// ---- search filtering -----------------------------------------------------
|
||||||
|
|
||||||
|
static char visual_search_lower(char value)
|
||||||
|
{
|
||||||
|
return value >= 'A' && value <= 'Z' ? static_cast<char>(value - 'A' + 'a') : value;
|
||||||
|
}
|
||||||
|
|
||||||
|
static std::string visual_search_query()
|
||||||
|
{
|
||||||
|
std::string query = var->gui.feature_search;
|
||||||
|
size_t first = 0;
|
||||||
|
while (first < query.size() && (query[first] == ' ' || query[first] == '\t'))
|
||||||
|
first++;
|
||||||
|
|
||||||
|
size_t last = query.size();
|
||||||
|
while (last > first && (query[last - 1] == ' ' || query[last - 1] == '\t'))
|
||||||
|
last--;
|
||||||
|
|
||||||
|
return query.substr(first, last - first);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool visual_contains_ci(std::string_view text, std::string_view query)
|
||||||
|
{
|
||||||
|
if (query.empty())
|
||||||
|
return true;
|
||||||
|
|
||||||
|
if (query.size() > text.size())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
for (size_t i = 0; i <= text.size() - query.size(); i++)
|
||||||
|
{
|
||||||
|
size_t j = 0;
|
||||||
|
while (j < query.size() && visual_search_lower(text[i + j]) == visual_search_lower(query[j]))
|
||||||
|
j++;
|
||||||
|
|
||||||
|
if (j == query.size())
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool visual_search_matches(std::string_view name, std::string_view description = {})
|
||||||
|
{
|
||||||
|
const std::string query = visual_search_query();
|
||||||
|
if (query.empty())
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return visual_contains_ci(name, query) || visual_contains_ci(description, query);
|
||||||
|
}
|
||||||
|
|
||||||
|
struct visual_widget_filter
|
||||||
|
{
|
||||||
|
bool checkbox(std::string name, std::string description, bool* callback, title_status_icon status = title_status_none) const
|
||||||
|
{
|
||||||
|
if (!visual_search_matches(name, description))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return ::widgets->checkbox(name, description, callback, status);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool slider(std::string name, std::string description, float* callback, float vmin, float vmax, std::string format = "%.1f") const
|
||||||
|
{
|
||||||
|
if (!visual_search_matches(name, description))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return ::widgets->slider(name, description, callback, vmin, vmax, format);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// ---- section helpers ------------------------------------------------------
|
||||||
|
|
||||||
|
static void begin_visual_section(std::string_view name, float height)
|
||||||
|
{
|
||||||
|
const int panel_number = g_panel_number + 1;
|
||||||
|
const float section_width = elements->child_width * visual_section_width_scale;
|
||||||
|
const float content_padding_x = ImMax(0.f, section_width * 0.05f);
|
||||||
|
gui->begin_content(name, c_vec2(section_width, s_(height)), c_vec2(content_padding_x, s_(5)), s_(0, 0), window_flags_no_move | window_flags_no_scrollbar, child_flags_none);
|
||||||
|
c_window* window = gui->get_window();
|
||||||
|
draw->rect_filled(window->DrawList, window->Rect().Min, window->Rect().Max, draw->get_clr(clr->child), s_(14));
|
||||||
|
|
||||||
|
g_panel_number = panel_number;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void end_visual_section()
|
||||||
|
{
|
||||||
|
gui->end_content();
|
||||||
|
}
|
||||||
|
|
||||||
|
static visual_panel_density_state begin_visual_panel_density()
|
||||||
|
{
|
||||||
|
c_window* window = gui->get_window();
|
||||||
|
visual_panel_density_state state{ var->gui.dpi, window->FontWindowScale };
|
||||||
|
|
||||||
|
var->gui.dpi = ImMax(0.01f, state.dpi * visual_panel_scale);
|
||||||
|
ImGui::SetWindowFontScale(state.font_scale * visual_panel_scale);
|
||||||
|
return state;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void end_visual_panel_density(visual_panel_density_state state)
|
||||||
|
{
|
||||||
|
ImGui::SetWindowFontScale(state.font_scale);
|
||||||
|
var->gui.dpi = state.dpi;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void draw_visual_sidebar_glass(const c_rect& rect)
|
||||||
|
{
|
||||||
|
ImDrawList* draw_list = gui->get_window()->DrawList;
|
||||||
|
const float rounding = s_(14);
|
||||||
|
draw->rect_filled(draw_list, rect.Min, rect.Max, draw->get_clr(clr->child), rounding);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Full-width single-column panel (used by Info / Radar / Settings).
|
||||||
|
static void begin_full_section(std::string_view name, float height, bool scroll = false)
|
||||||
|
{
|
||||||
|
const float section_width = gui->content_avail().x;
|
||||||
|
const float content_padding_x = ImMax(0.f, section_width * 0.035f);
|
||||||
|
const window_flags flags = window_flags_no_move | (scroll ? 0 : window_flags_no_scrollbar);
|
||||||
|
gui->begin_content(name, c_vec2(section_width, s_(height)), c_vec2(content_padding_x, s_(10)), s_(0, 6), flags, child_flags_none);
|
||||||
|
c_window* window = gui->get_window();
|
||||||
|
draw->rect_filled(window->DrawList, window->Rect().Min, window->Rect().Max, draw->get_clr(clr->child), s_(14));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Accent section heading.
|
||||||
|
static void lumin_heading(const char* text)
|
||||||
|
{
|
||||||
|
c_window* w = gui->get_window();
|
||||||
|
const c_vec2 pos = w->DC.CursorPos;
|
||||||
|
const c_vec2 size = c_vec2(gui->content_avail().x, s_(22));
|
||||||
|
const c_rect rect(pos, pos + size);
|
||||||
|
gui->item_size(rect);
|
||||||
|
if (!gui->item_add(rect, w->GetID(text)))
|
||||||
|
return;
|
||||||
|
draw->text_clipped(w->DrawList, font->get(inter_semibold, 13), rect.Min, rect.Max, draw->get_clr(clr->accent), text, 0, 0, { 0.f, 0.5f });
|
||||||
|
}
|
||||||
|
|
||||||
|
// Muted single-line note.
|
||||||
|
static void lumin_note(const char* text)
|
||||||
|
{
|
||||||
|
c_window* w = gui->get_window();
|
||||||
|
const c_vec2 pos = w->DC.CursorPos;
|
||||||
|
const c_vec2 size = c_vec2(gui->content_avail().x, s_(16));
|
||||||
|
const c_rect rect(pos, pos + size);
|
||||||
|
gui->item_size(rect);
|
||||||
|
if (!gui->item_add(rect, w->GetID(text)))
|
||||||
|
return;
|
||||||
|
draw->text_clipped(w->DrawList, font->get(inter_medium, 11), rect.Min, rect.Max, draw->get_clr(clr->text), text, 0, 0, { 0.f, 0.5f });
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read-only "label .... value" row on a rounded widget background.
|
||||||
|
static void lumin_kv(const char* label, const std::string& value, const c_vec4& value_clr)
|
||||||
|
{
|
||||||
|
c_window* w = gui->get_window();
|
||||||
|
const c_vec2 pos = w->DC.CursorPos;
|
||||||
|
const c_vec2 size = c_vec2(gui->content_avail().x, s_(34));
|
||||||
|
const c_rect rect(pos, pos + size);
|
||||||
|
gui->item_size(rect);
|
||||||
|
if (!gui->item_add(rect, w->GetID(label)))
|
||||||
|
return;
|
||||||
|
draw->rect_filled(w->DrawList, rect.Min, rect.Max, draw->get_clr(clr->widget), s_(8));
|
||||||
|
draw->text_clipped(w->DrawList, font->get(inter_semibold, 12), rect.Min + s_(12, 0), rect.Max, draw->get_clr(clr->white), label, 0, 0, { 0.f, 0.5f });
|
||||||
|
draw->text_clipped(w->DrawList, font->get(inter_medium, 11), rect.Min, rect.Max - s_(12, 0), draw->get_clr(value_clr), value.data(), 0, 0, { 1.f, 0.5f });
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---- ESP / Items content --------------------------------------------------
|
||||||
|
|
||||||
|
static void render_esp_tab(const visual_widget_filter& w, float section_height)
|
||||||
|
{
|
||||||
|
if (!g_menu)
|
||||||
|
return;
|
||||||
|
|
||||||
|
gui->begin_group();
|
||||||
|
{
|
||||||
|
begin_visual_section("Entities", section_height);
|
||||||
|
w.checkbox("Players", "Show player ESP", g_menu->showPlayers, title_status_safe);
|
||||||
|
w.checkbox("Animals", "Show animal ESP", g_menu->showAnimals);
|
||||||
|
w.checkbox("Zombies", "Show infected ESP", g_menu->showZombies);
|
||||||
|
w.checkbox("Items", "Show loot ESP", g_menu->showItems);
|
||||||
|
w.checkbox("Corpses", "Show dead bodies", g_menu->showCorpses);
|
||||||
|
w.checkbox("Bounding Box", "Draw entity box", g_menu->showBox);
|
||||||
|
w.checkbox("Skeleton", "Draw bone skeleton", g_menu->showSkeleton);
|
||||||
|
w.checkbox("Head Circle", "Draw head highlight", g_menu->showHeadDot);
|
||||||
|
w.checkbox("Weapon In Hand", "Show held weapon name", g_menu->showWeapon);
|
||||||
|
w.checkbox("Health Bar", "Draw player health bar", g_menu->showHealthBar);
|
||||||
|
w.checkbox("Health Number", "Draw numeric health", g_menu->showHealthNumber);
|
||||||
|
w.checkbox("Skeleton Debug", "Label every named bone", g_menu->debugSkeleton, title_status_warning);
|
||||||
|
end_visual_section();
|
||||||
|
}
|
||||||
|
gui->end_group();
|
||||||
|
|
||||||
|
gui->sameline();
|
||||||
|
|
||||||
|
gui->begin_group();
|
||||||
|
{
|
||||||
|
begin_visual_section("Draw Distance", section_height);
|
||||||
|
w.slider("Players", "Max player draw distance", g_menu->playerMaxDist, 50.f, 1000.f, "%.0f m");
|
||||||
|
w.slider("Animals", "Max animal draw distance", g_menu->animalMaxDist, 50.f, 1000.f, "%.0f m");
|
||||||
|
w.slider("Zombies", "Max zombie draw distance", g_menu->zombieMaxDist, 50.f, 500.f, "%.0f m");
|
||||||
|
w.slider("Items", "Max loot draw distance", g_menu->itemMaxDist, 20.f, 200.f, "%.0f m");
|
||||||
|
end_visual_section();
|
||||||
|
}
|
||||||
|
gui->end_group();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void render_items_tab(const visual_widget_filter& w, float section_height)
|
||||||
|
{
|
||||||
|
if (!g_menu || !g_menu->itemCategories)
|
||||||
|
return;
|
||||||
|
|
||||||
|
struct cat_t { const char* key; const char* label; };
|
||||||
|
static const std::array<cat_t, 17> kCats = { {
|
||||||
|
{ "isWeapon", "Weapons" },
|
||||||
|
{ "isAmmo", "Ammo" },
|
||||||
|
{ "isMelee", "Melee" },
|
||||||
|
{ "isExplosives", "Explosives" },
|
||||||
|
{ "isMedical", "Medical" },
|
||||||
|
{ "isFood", "Food" },
|
||||||
|
{ "isConsumables", "Consumables" },
|
||||||
|
{ "isClothing", "Clothing" },
|
||||||
|
{ "isBackpack", "Backpacks" },
|
||||||
|
{ "isOptics", "Optics" },
|
||||||
|
{ "isWeaponAttachments", "Weapon Attachments" },
|
||||||
|
{ "isTool", "Tools" },
|
||||||
|
{ "isCrafting", "Crafting" },
|
||||||
|
{ "isVehiclePart", "Vehicle Parts" },
|
||||||
|
{ "isForBuilding", "Building" },
|
||||||
|
{ "isHouse", "House / Terrain" },
|
||||||
|
{ "isOtherLoot", "Other" },
|
||||||
|
} };
|
||||||
|
|
||||||
|
auto& cats = *g_menu->itemCategories;
|
||||||
|
|
||||||
|
auto draw_category = [&](const cat_t& c)
|
||||||
|
{
|
||||||
|
// Missing key defaults to enabled; widget mutates the map slot directly.
|
||||||
|
auto it = cats.find(c.key);
|
||||||
|
if (it == cats.end())
|
||||||
|
it = cats.emplace(c.key, true).first;
|
||||||
|
w.checkbox(c.label, "Toggle loot category", &it->second);
|
||||||
|
};
|
||||||
|
|
||||||
|
const size_t split = (kCats.size() + 1) / 2;
|
||||||
|
|
||||||
|
gui->begin_group();
|
||||||
|
{
|
||||||
|
begin_visual_section("Loot Categories", section_height);
|
||||||
|
for (size_t i = 0; i < split; i++)
|
||||||
|
draw_category(kCats[i]);
|
||||||
|
end_visual_section();
|
||||||
|
}
|
||||||
|
gui->end_group();
|
||||||
|
|
||||||
|
gui->sameline();
|
||||||
|
|
||||||
|
gui->begin_group();
|
||||||
|
{
|
||||||
|
begin_visual_section("Loot Categories##2", section_height);
|
||||||
|
for (size_t i = split; i < kCats.size(); i++)
|
||||||
|
draw_category(kCats[i]);
|
||||||
|
end_visual_section();
|
||||||
|
}
|
||||||
|
gui->end_group();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void render_info_tab(float section_height)
|
||||||
|
{
|
||||||
|
const c_vec4 green = c_col(75, 225, 145).Value;
|
||||||
|
const c_vec4 orange = c_col(255, 175, 75).Value;
|
||||||
|
|
||||||
|
begin_full_section("Info", section_height);
|
||||||
|
{
|
||||||
|
lumin_heading("Server");
|
||||||
|
if (g_menu && g_menu->connected)
|
||||||
|
{
|
||||||
|
lumin_kv("Status", "Connected", green);
|
||||||
|
if (!g_menu->serverName.empty()) lumin_kv("Server", g_menu->serverName, clr->white.Value);
|
||||||
|
if (!g_menu->mapName.empty()) lumin_kv("Map", g_menu->mapName, clr->white.Value);
|
||||||
|
if (g_menu->hasPos)
|
||||||
|
{
|
||||||
|
char pos[64];
|
||||||
|
ImFormatString(pos, IM_ARRAYSIZE(pos), "%.1f / %.1f / %.1f", g_menu->px, g_menu->py, g_menu->pz);
|
||||||
|
lumin_kv("Position", pos, clr->accent.Value);
|
||||||
|
}
|
||||||
|
|
||||||
|
gui->dummy(c_vec2(0, s_(6)));
|
||||||
|
lumin_heading("Entity Counts");
|
||||||
|
lumin_kv("Players", std::to_string(g_menu->nPlayers), clr->accent.Value);
|
||||||
|
lumin_kv("Animals", std::to_string(g_menu->nAnimals), clr->accent.Value);
|
||||||
|
lumin_kv("Zombies", std::to_string(g_menu->nZombies), clr->accent.Value);
|
||||||
|
lumin_kv("Vehicles", std::to_string(g_menu->nVehicles), clr->accent.Value);
|
||||||
|
lumin_kv("Items", std::to_string(g_menu->nItems), clr->accent.Value);
|
||||||
|
lumin_kv("Bullets", std::to_string(g_menu->nBullets), clr->accent.Value);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
lumin_kv("Status", (g_menu && !g_menu->status.empty()) ? g_menu->status : "Offline", orange);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end_visual_section();
|
||||||
|
}
|
||||||
|
|
||||||
|
static constexpr const char* kRadarDomain = "radar.charliecharliekirky.christmas";
|
||||||
|
|
||||||
|
static void render_radar_tab(float section_height)
|
||||||
|
{
|
||||||
|
begin_full_section("Radar", section_height, true);
|
||||||
|
{
|
||||||
|
lumin_heading("Web Radar");
|
||||||
|
lumin_note("Open this address in a browser:");
|
||||||
|
gui->dummy(c_vec2(0, s_(4)));
|
||||||
|
if (widgets->action_button(kRadarDomain, "copy"))
|
||||||
|
ImGui::SetClipboardText(kRadarDomain);
|
||||||
|
|
||||||
|
if (g_menu)
|
||||||
|
{
|
||||||
|
gui->dummy(c_vec2(0, s_(6)));
|
||||||
|
lumin_heading("Connection");
|
||||||
|
lumin_kv("Port", std::to_string(g_menu->webPort), clr->accent.Value);
|
||||||
|
lumin_kv("Password", "Set in config.cfg", clr->text.Value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end_visual_section();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void render_exit_tab(float section_height)
|
||||||
|
{
|
||||||
|
begin_full_section("Exit", section_height);
|
||||||
|
{
|
||||||
|
lumin_heading("Exit Application");
|
||||||
|
lumin_note("This will close the overlay and exit the program.");
|
||||||
|
gui->dummy(c_vec2(0, s_(10)));
|
||||||
|
|
||||||
|
const c_col saved_accent = clr->accent;
|
||||||
|
clr->accent = c_col(225, 70, 70);
|
||||||
|
if (widgets->primary_button("Exit", "back") && g_menu && g_menu->onExit)
|
||||||
|
g_menu->onExit();
|
||||||
|
clr->accent = saved_accent;
|
||||||
|
}
|
||||||
|
end_visual_section();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void render_settings_tab(float section_height)
|
||||||
|
{
|
||||||
|
if (!g_menu)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Persistent text buffers backing the four resolution fields. Seeded once
|
||||||
|
// from the live values, then treated as the source of truth (parsed back
|
||||||
|
// into the int pointers every frame).
|
||||||
|
static char ovr_w[8], ovr_h[8], rnd_w[8], rnd_h[8];
|
||||||
|
static bool buffers_ready = false;
|
||||||
|
if (!buffers_ready)
|
||||||
|
{
|
||||||
|
ImFormatString(ovr_w, IM_ARRAYSIZE(ovr_w), "%d", *g_menu->pendingW);
|
||||||
|
ImFormatString(ovr_h, IM_ARRAYSIZE(ovr_h), "%d", *g_menu->pendingH);
|
||||||
|
ImFormatString(rnd_w, IM_ARRAYSIZE(rnd_w), "%d", *g_menu->pendingRW);
|
||||||
|
ImFormatString(rnd_h, IM_ARRAYSIZE(rnd_h), "%d", *g_menu->pendingRH);
|
||||||
|
buffers_ready = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
begin_full_section("Settings", section_height, true);
|
||||||
|
{
|
||||||
|
lumin_heading("Overlay (Monitor) Resolution");
|
||||||
|
lumin_note("Set to your MONITOR size. 0 x 0 = auto-detect.");
|
||||||
|
gui->push_id("ovr_res");
|
||||||
|
widgets->text_field("Width", ovr_w, IM_ARRAYSIZE(ovr_w));
|
||||||
|
widgets->text_field("Height", ovr_h, IM_ARRAYSIZE(ovr_h));
|
||||||
|
gui->pop_id();
|
||||||
|
*g_menu->pendingW = ImMax(0, atoi(ovr_w));
|
||||||
|
*g_menu->pendingH = ImMax(0, atoi(ovr_h));
|
||||||
|
if (widgets->primary_button("Apply Monitor Resolution") && g_menu->onApplyDisplayRes)
|
||||||
|
g_menu->onApplyDisplayRes();
|
||||||
|
|
||||||
|
gui->dummy(c_vec2(0, s_(8)));
|
||||||
|
lumin_heading("Game Render Resolution");
|
||||||
|
lumin_note("Set to the in-game resolution when it differs from the");
|
||||||
|
lumin_note("monitor. 0 x 0 = no stretched-res correction.");
|
||||||
|
gui->push_id("rnd_res");
|
||||||
|
widgets->text_field("Width", rnd_w, IM_ARRAYSIZE(rnd_w));
|
||||||
|
widgets->text_field("Height", rnd_h, IM_ARRAYSIZE(rnd_h));
|
||||||
|
gui->pop_id();
|
||||||
|
*g_menu->pendingRW = ImMax(0, atoi(rnd_w));
|
||||||
|
*g_menu->pendingRH = ImMax(0, atoi(rnd_h));
|
||||||
|
widgets->checkbox("Stretch to fill", "GPU stretches game to fill the monitor", g_menu->stretchToFill);
|
||||||
|
if (widgets->primary_button("Apply Render Resolution") && g_menu->onApplyRenderRes)
|
||||||
|
g_menu->onApplyRenderRes();
|
||||||
|
|
||||||
|
gui->dummy(c_vec2(0, s_(10)));
|
||||||
|
lumin_heading("General");
|
||||||
|
lumin_note("Press INSERT to toggle this menu.");
|
||||||
|
gui->dummy(c_vec2(0, s_(4)));
|
||||||
|
if (widgets->primary_button("Save Config", "active") && g_menu->onSaveConfig)
|
||||||
|
g_menu->onSaveConfig();
|
||||||
|
}
|
||||||
|
end_visual_section();
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void c_gui::render()
|
||||||
|
{
|
||||||
|
gui->initialize();
|
||||||
|
sync_layout_preferences();
|
||||||
|
|
||||||
|
gui->easing(var->gui.tab_alpha, var->gui.tab != var->gui.tab_stored ? 0.f : 1.f, 7.f, static_easing);
|
||||||
|
if (var->gui.tab_alpha == 0)
|
||||||
|
var->gui.tab = var->gui.tab_stored;
|
||||||
|
|
||||||
|
const c_vec2 target(s_(visual_window_width), s_(visual_window_height));
|
||||||
|
gui->easing(elements->window.size.x, target.x, 24.f, dynamic_easing);
|
||||||
|
gui->easing(elements->window.size.y, target.y, 24.f, dynamic_easing);
|
||||||
|
|
||||||
|
const ImVec2 disp = ImGui::GetIO().DisplaySize;
|
||||||
|
gui->set_next_window_size(elements->window.size);
|
||||||
|
gui->set_next_window_pos(c_vec2(ImMax(0.f, (disp.x - elements->window.size.x) * 0.5f),
|
||||||
|
ImMax(0.f, (disp.y - elements->window.size.y) * 0.5f)));
|
||||||
|
|
||||||
|
gui->begin(elements->window.name, nullptr, window_flags_no_scrollbar | window_flags_no_scroll_with_mouse | window_flags_no_bring_to_front_on_focus | window_flags_no_focus_on_appearing | window_flags_no_background | window_flags_no_decoration | window_flags_no_move);
|
||||||
|
{
|
||||||
|
gui->set_style();
|
||||||
|
gui->draw_decorations();
|
||||||
|
|
||||||
|
const float top_row_y = visual_outer_padding;
|
||||||
|
const float top_row_height = 50.f;
|
||||||
|
const float top_row_gap = 2.f;
|
||||||
|
const float bottom_row_y = top_row_y + top_row_height + top_row_gap;
|
||||||
|
const float bottom_row_height = visual_window_height - bottom_row_y - visual_outer_padding;
|
||||||
|
const float sidebar_tabs_y = top_row_y + top_row_height;
|
||||||
|
const float sidebar_tabs_height = visual_window_height - sidebar_tabs_y - visual_outer_padding;
|
||||||
|
|
||||||
|
draw_visual_sidebar_glass(c_rect(c_vec2(s_(visual_outer_padding), s_(top_row_y)), c_vec2(s_(visual_outer_padding + visual_sidebar_width), s_(visual_window_height - visual_outer_padding))));
|
||||||
|
|
||||||
|
gui->set_pos(c_vec2(s_(visual_outer_padding), s_(top_row_y)), pos_all);
|
||||||
|
gui->begin_content("TopBrand", c_vec2(s_(visual_sidebar_width), s_(top_row_height)), s_(0, 0), s_(0, 0), window_flags_no_scrollbar | window_flags_no_background, child_flags_none);
|
||||||
|
{
|
||||||
|
widgets->brand_header("KarachiHook", var->gui.profile_name[0] != '\0' ? var->gui.profile_name : "DayZ Overlay");
|
||||||
|
}
|
||||||
|
gui->end_content();
|
||||||
|
|
||||||
|
gui->set_pos(c_vec2(s_(visual_outer_padding), s_(sidebar_tabs_y)), pos_all);
|
||||||
|
gui->begin_content("Tabs", c_vec2(s_(visual_sidebar_width), s_(sidebar_tabs_height)), s_(10, 10), s_(0, 4), window_flags_no_scrollbar | window_flags_no_background, child_flags_none);
|
||||||
|
{
|
||||||
|
var->gui.sidebar_glass = true;
|
||||||
|
|
||||||
|
{
|
||||||
|
c_window* tabs_inner_bg = gui->get_window();
|
||||||
|
static c_vec4 sidebar_overlay = c_vec4(0, 0, 0, 0);
|
||||||
|
gui->easing(sidebar_overlay, g_sidebar_selected_rect, 18.f, dynamic_easing);
|
||||||
|
if (sidebar_overlay.z > sidebar_overlay.x + 1.f)
|
||||||
|
{
|
||||||
|
draw->rect_filled(tabs_inner_bg->DrawList,
|
||||||
|
c_vec2(sidebar_overlay.x, sidebar_overlay.y), c_vec2(sidebar_overlay.z, sidebar_overlay.w),
|
||||||
|
draw->get_clr(clr->widget), s_(9.1f));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
widgets->tab_button("ESP", "visuals", 1);
|
||||||
|
widgets->tab_button("Items", "loot", 2);
|
||||||
|
widgets->tab_button("Radar", "world", 3);
|
||||||
|
widgets->tab_button("Settings", "polish", 4);
|
||||||
|
widgets->tab_button("Exit", "back", 5);
|
||||||
|
widgets->tab_button("Info", "stats", 6);
|
||||||
|
|
||||||
|
{
|
||||||
|
static c_vec4 sidebar_indicator = c_vec4(0, 0, 0, 0);
|
||||||
|
gui->easing(sidebar_indicator, g_sidebar_selected_rect, 18.f, dynamic_easing);
|
||||||
|
if (sidebar_indicator.w > sidebar_indicator.y + 1.f)
|
||||||
|
{
|
||||||
|
c_window* tabs_inner = gui->get_window();
|
||||||
|
const float bar_w = s_(2);
|
||||||
|
const float bar_inset_y = s_(6);
|
||||||
|
const float bar_x = sidebar_indicator.x + s_(2);
|
||||||
|
const c_vec2 bar_min = c_vec2(bar_x, sidebar_indicator.y + bar_inset_y);
|
||||||
|
const c_vec2 bar_max = c_vec2(bar_x + bar_w, sidebar_indicator.w - bar_inset_y);
|
||||||
|
draw->rect_filled(tabs_inner->DrawList, bar_min, bar_max,
|
||||||
|
draw->get_clr(clr->accent), bar_w * 0.5f);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
gui->easing(elements->tab_window_width, gui->get_window()->Size.x, 24.f, dynamic_easing);
|
||||||
|
var->gui.sidebar_glass = false;
|
||||||
|
}
|
||||||
|
gui->end_content();
|
||||||
|
|
||||||
|
gui->push_var(style_var_alpha, var->gui.tab_alpha);
|
||||||
|
|
||||||
|
const float feature_x = visual_outer_padding + visual_sidebar_width + visual_outer_padding;
|
||||||
|
const float feature_width = visual_window_width - feature_x - visual_outer_padding;
|
||||||
|
const float feature_header_height = top_row_height * 0.8f;
|
||||||
|
const float feature_header_y = top_row_y;
|
||||||
|
|
||||||
|
gui->set_pos(c_vec2(s_(feature_x), s_(feature_header_y) + s_(10) * (1.f - var->gui.tab_alpha)), pos_all);
|
||||||
|
{
|
||||||
|
const c_vec2 pill_pos = gui->get_window()->DC.CursorPos;
|
||||||
|
draw->rect_filled(gui->get_window()->DrawList, pill_pos, pill_pos + c_vec2(s_(feature_width), s_(feature_header_height)), draw->get_clr(clr->child), s_(14));
|
||||||
|
|
||||||
|
gui->begin_content("FeatureHeader", c_vec2(s_(feature_width), s_(feature_header_height)), s_(8, 4), s_(8, 0), window_flags_no_scrollbar | window_flags_no_background, child_flags_none);
|
||||||
|
{
|
||||||
|
const float search_width = s_(178.f);
|
||||||
|
widgets->search_field("Search", var->gui.feature_search, IM_ARRAYSIZE(var->gui.feature_search), c_vec2(search_width, s_(32.f)));
|
||||||
|
}
|
||||||
|
gui->end_content();
|
||||||
|
}
|
||||||
|
|
||||||
|
gui->set_pos(c_vec2(s_(feature_x), s_(bottom_row_y) + s_(10) * (1.f - var->gui.tab_alpha)), pos_all);
|
||||||
|
gui->begin_content("Features", c_vec2(s_(feature_width), s_(bottom_row_height)), s_(visual_feature_padding_x, visual_feature_padding_y), c_vec2(s_(visual_column_gap), 0.f), window_flags_no_scrollbar);
|
||||||
|
{
|
||||||
|
const visual_panel_density_state density_state = begin_visual_panel_density();
|
||||||
|
|
||||||
|
g_panel_number = 3;
|
||||||
|
gui->easing(elements->child_width, (gui->content_avail().x - s_(visual_column_gap)) / 2, 24.f, dynamic_easing);
|
||||||
|
const float section_height = visual_section_height(1);
|
||||||
|
const visual_widget_filter visual_widgets;
|
||||||
|
|
||||||
|
switch (var->gui.tab)
|
||||||
|
{
|
||||||
|
case 1: render_esp_tab(visual_widgets, section_height); break;
|
||||||
|
case 2: render_items_tab(visual_widgets, section_height); break;
|
||||||
|
case 3: render_radar_tab(section_height); break;
|
||||||
|
case 4: render_settings_tab(section_height); break;
|
||||||
|
case 5: render_exit_tab(section_height); break;
|
||||||
|
case 6: render_info_tab(section_height); break;
|
||||||
|
default: break;
|
||||||
|
}
|
||||||
|
|
||||||
|
end_visual_panel_density(density_state);
|
||||||
|
}
|
||||||
|
gui->end_content();
|
||||||
|
|
||||||
|
gui->pop_var();
|
||||||
|
}
|
||||||
|
gui->end();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Shim called by GameOverlay (declared in src/Overlay/MenuBridge.h).
|
||||||
|
void RenderLuminMenu()
|
||||||
|
{
|
||||||
|
gui->render();
|
||||||
|
}
|
||||||
+66
@@ -0,0 +1,66 @@
|
|||||||
|
#pragma once
|
||||||
|
#include "includes.h"
|
||||||
|
|
||||||
|
enum fade_direction : int
|
||||||
|
{
|
||||||
|
vertically,
|
||||||
|
horizontally,
|
||||||
|
diagonally,
|
||||||
|
diagonally_reversed,
|
||||||
|
};
|
||||||
|
|
||||||
|
class c_draw
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
ImU32 get_clr(const ImVec4& col, float alpha = 1.f);
|
||||||
|
|
||||||
|
ImU32 w_get_clr(style_col idx, float alpha = 1.f);
|
||||||
|
|
||||||
|
void text(ImDrawList* draw_list, const ImFont* font, float font_size, const ImVec2& pos, ImU32 col, const char* text_begin, const char* text_end = NULL, float wrap_width = 0.f, const ImVec4* cpu_fine_clip_rect = 0);
|
||||||
|
|
||||||
|
void text_clipped(ImDrawList* draw_list, ImFont* font, const ImVec2& pos_min, const ImVec2& pos_max, ImU32 color, const char* text, const char* text_display_end = NULL, const ImVec2* text_size_if_known = NULL, const ImVec2& align = ImVec2(0.f, 0.f), const ImRect* clip_rect = NULL);
|
||||||
|
|
||||||
|
void radial_gradient(ImDrawList* draw_list, const ImVec2& center, float radius, ImU32 col_in, ImU32 col_out);
|
||||||
|
|
||||||
|
void set_linear_color_alpha(ImDrawList* draw_list, int vert_start_idx, int vert_end_idx, ImVec2 gradient_p0, ImVec2 gradient_p1, ImU32 col0, ImU32 col1);
|
||||||
|
|
||||||
|
void line(ImDrawList* draw_list, const ImVec2& p1, const ImVec2& p2, ImU32 col, float thickness = 1.0f);
|
||||||
|
|
||||||
|
void rect(ImDrawList* draw_list, const ImVec2& p_min, const ImVec2& p_max, ImU32 col, float rounding = 0.0f, draw_flags flags = 0, float thickness = 1.0f);
|
||||||
|
|
||||||
|
void rect_filled(ImDrawList* draw_list, const ImVec2& p_min, const ImVec2& p_max, ImU32 col, float rounding = 0.0f, draw_flags flags = 0);
|
||||||
|
|
||||||
|
void rect_filled_multi_color(ImDrawList* draw, const ImVec2& p_min, const ImVec2& p_max, ImU32 col_upr_left, ImU32 col_upr_right, ImU32 col_bot_right, ImU32 col_bot_left, float rounding = 0.f, draw_flags flags = 0);
|
||||||
|
|
||||||
|
void fade_rect_filled(ImDrawList* draw, const ImVec2& pos_min, const ImVec2& pos_max, ImU32 col_one, ImU32 col_two, fade_direction direction, float rounding = 0.f, draw_flags flags = 0);
|
||||||
|
|
||||||
|
void shadow_rect(ImDrawList* draw_list, const ImVec2& obj_min, const ImVec2& obj_max, ImU32 shadow_col, float shadow_thickness, const ImVec2& shadow_offset, draw_flags flags = 0, float obj_rounding = 0.0f);
|
||||||
|
|
||||||
|
void circle(ImDrawList* draw_list, const ImVec2& center, float radius, ImU32 col, int num_segments = 0, float thickness = 1.0f);
|
||||||
|
|
||||||
|
void circle_filled(ImDrawList* draw_list, const ImVec2& center, float radius, ImU32 col, int num_segments = 0);
|
||||||
|
|
||||||
|
void shadow_circle(ImDrawList* draw_list, const ImVec2& obj_center, float obj_radius, ImU32 shadow_col, float shadow_thickness, const ImVec2& shadow_offset, draw_flags flags = 0, int obj_num_segments = 12);
|
||||||
|
|
||||||
|
void triangle(ImDrawList* draw_list, const ImVec2& p1, const ImVec2& p2, const ImVec2& p3, ImU32 col, float thickness = 1.f);
|
||||||
|
|
||||||
|
void triangle_filled(ImDrawList* draw_list, const ImVec2& p1, const ImVec2& p2, const ImVec2& p3, ImU32 col);
|
||||||
|
|
||||||
|
void image(ImDrawList* draw_list, ImTextureID user_texture_id, const ImVec2& p_min, const ImVec2& p_max, const ImVec2& uv_min = ImVec2(0, 0), const ImVec2& uv_max = ImVec2(1, 1), ImU32 col = IM_COL32_WHITE);
|
||||||
|
|
||||||
|
void image_rounded(ImDrawList* draw_list, ImTextureID user_texture_id, const ImVec2& p_min, const ImVec2& p_max, const ImVec2& uv_min = ImVec2(0, 0), const ImVec2& uv_max = ImVec2(1, 1), ImU32 col = IM_COL32_WHITE, float rounding = 1.f, draw_flags flags = 0);
|
||||||
|
|
||||||
|
void shadow_convex_poly(ImDrawList* draw_list, const ImVec2* points, int points_count, ImU32 shadow_col, float shadow_thickness, const ImVec2& shadow_offset, draw_flags flags = 0);
|
||||||
|
|
||||||
|
void shadow_ngon(ImDrawList* draw_list, const ImVec2& obj_center, float obj_radius, ImU32 shadow_col, float shadow_thickness, const ImVec2& shadow_offset, draw_flags flags, int obj_num_segments);
|
||||||
|
|
||||||
|
void rotate_start(ImDrawList* draw_list);
|
||||||
|
|
||||||
|
void rotate_end(ImDrawList* draw_list, float rad, ImVec2 center = ImVec2(0, 0));
|
||||||
|
|
||||||
|
void push_clip_rect(ImDrawList* draw_list, const ImVec2& clip_rect_min, const ImVec2& clip_rect_max, bool intersect_with_current_clip_rect = false);
|
||||||
|
|
||||||
|
void pop_clip_rect(ImDrawList* draw_list);
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::unique_ptr<c_draw> draw = std::make_unique<c_draw>();
|
||||||
+477
@@ -0,0 +1,477 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
typedef int style_var;
|
||||||
|
typedef int style_col;
|
||||||
|
typedef int window_flags;
|
||||||
|
typedef int child_flags;
|
||||||
|
typedef int gui_cond;
|
||||||
|
typedef int draw_flags;
|
||||||
|
typedef int mouse_button;
|
||||||
|
|
||||||
|
using c_text = std::string;
|
||||||
|
using c_vec4 = ImVec4;
|
||||||
|
using c_col = ImColor;
|
||||||
|
using c_vec2 = ImVec2;
|
||||||
|
using c_multi_string = std::vector<std::string>;
|
||||||
|
using c_multi_bool = std::vector<bool>;
|
||||||
|
using c_window = ImGuiWindow;
|
||||||
|
using c_id = ImGuiID;
|
||||||
|
using c_rect = ImRect;
|
||||||
|
using c_draw_list = ImDrawList;
|
||||||
|
|
||||||
|
enum style_var_
|
||||||
|
{
|
||||||
|
style_var_alpha,
|
||||||
|
style_var_disabled_alpha,
|
||||||
|
style_var_window_padding,
|
||||||
|
style_var_window_rounding,
|
||||||
|
style_var_window_border_size,
|
||||||
|
style_var_window_min_size,
|
||||||
|
style_var_window_title_align,
|
||||||
|
style_var_child_rounding,
|
||||||
|
style_var_child_border_size,
|
||||||
|
style_var_popup_rounding,
|
||||||
|
style_var_popup_border_size,
|
||||||
|
style_var_frame_padding,
|
||||||
|
style_var_frame_rounding,
|
||||||
|
style_var_frame_border_size,
|
||||||
|
style_var_item_spacing,
|
||||||
|
style_var_item_inner_spacing,
|
||||||
|
style_var_indent_spacing,
|
||||||
|
style_var_cell_padding,
|
||||||
|
style_var_scrollbar_size,
|
||||||
|
style_var_scrollbar_rounding,
|
||||||
|
style_var_grab_min_size,
|
||||||
|
style_var_grab_rounding,
|
||||||
|
style_var_tab_rounding,
|
||||||
|
style_var_tab_border_size,
|
||||||
|
style_var_tab_bar_border_size,
|
||||||
|
style_var_tab_bar_overline_size,
|
||||||
|
style_var_table_angled_headers_angle,
|
||||||
|
style_var_table_angled_headers_text_align,
|
||||||
|
style_var_button_text_align,
|
||||||
|
style_var_selectable_text_align,
|
||||||
|
style_var_separator_text_border_size,
|
||||||
|
style_var_separator_text_align,
|
||||||
|
style_var_separator_text_padding,
|
||||||
|
style_var_window_shadow_size,
|
||||||
|
style_var_window_shadow_offset,
|
||||||
|
style_var_scrollbar_border_padding,
|
||||||
|
style_var_scrollbar_content_padding,
|
||||||
|
style_var_count
|
||||||
|
};
|
||||||
|
|
||||||
|
enum style_col_
|
||||||
|
{
|
||||||
|
style_col_text,
|
||||||
|
style_col_text_disabled,
|
||||||
|
style_col_window_bg,
|
||||||
|
style_col_child_bg,
|
||||||
|
style_col_popup_bg,
|
||||||
|
style_col_border,
|
||||||
|
style_col_border_shadow,
|
||||||
|
style_col_frame_bg,
|
||||||
|
style_col_frame_bg_hovered,
|
||||||
|
style_col_frame_bg_active,
|
||||||
|
style_col_title_bg,
|
||||||
|
style_col_title_bg_active,
|
||||||
|
style_col_title_bg_collapsed,
|
||||||
|
style_col_menu_bar_bg,
|
||||||
|
style_col_scrollbar_bg,
|
||||||
|
style_col_scrollbar_grab,
|
||||||
|
style_col_scrollbar_grab_hovered,
|
||||||
|
style_col_scrollbar_grab_active,
|
||||||
|
style_col_check_mark,
|
||||||
|
style_col_slider_grab,
|
||||||
|
style_col_slider_grab_active,
|
||||||
|
style_col_button,
|
||||||
|
style_col_button_hovered,
|
||||||
|
style_col_button_active,
|
||||||
|
style_col_header,
|
||||||
|
style_col_header_hovered,
|
||||||
|
style_col_header_active,
|
||||||
|
style_col_separator,
|
||||||
|
style_col_separator_hovered,
|
||||||
|
style_col_separator_active,
|
||||||
|
style_col_resize_grip,
|
||||||
|
style_col_resize_grip_hovered,
|
||||||
|
style_col_resize_grip_active,
|
||||||
|
style_col_tab_hovered,
|
||||||
|
style_col_tab,
|
||||||
|
style_col_tab_selected,
|
||||||
|
style_col_tab_selected_overline,
|
||||||
|
style_col_tab_dimmed,
|
||||||
|
style_col_tab_dimmed_selected,
|
||||||
|
style_col_tab_dimmed_selected_overline,
|
||||||
|
style_col_plot_lines,
|
||||||
|
style_col_plot_lines_hovered,
|
||||||
|
style_col_plot_histogram,
|
||||||
|
style_col_plot_histogram_hovered,
|
||||||
|
style_col_table_header_bg,
|
||||||
|
style_col_table_border_strong,
|
||||||
|
style_col_table_border_light,
|
||||||
|
style_col_table_row_bg,
|
||||||
|
style_col_table_row_bg_alt,
|
||||||
|
style_col_text_link,
|
||||||
|
style_col_text_selected_bg,
|
||||||
|
style_col_drag_drop_target,
|
||||||
|
style_col_nav_highlight,
|
||||||
|
style_col_nav_windowing_highlight,
|
||||||
|
style_col_nav_windowing_dim_bg,
|
||||||
|
style_col_modal_window_dim_bg,
|
||||||
|
style_col_window_shadow,
|
||||||
|
style_col_count,
|
||||||
|
|
||||||
|
#ifndef IMGUI_DISABLE_OBSOLETE_FUNCTIONS
|
||||||
|
style_col_tab_active = style_col_tab_selected,
|
||||||
|
style_col_tab_unfocused = style_col_tab_dimmed,
|
||||||
|
style_col_tab_unfocused_active = style_col_tab_dimmed_selected,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
enum window_flags_
|
||||||
|
{
|
||||||
|
window_flags_none = 0,
|
||||||
|
window_flags_no_title_bar = 1 << 0,
|
||||||
|
window_flags_no_resize = 1 << 1,
|
||||||
|
window_flags_no_move = 1 << 2,
|
||||||
|
window_flags_no_scrollbar = 1 << 3,
|
||||||
|
window_flags_no_scroll_with_mouse = 1 << 4,
|
||||||
|
window_flags_no_collapse = 1 << 5,
|
||||||
|
window_flags_always_auto_resize = 1 << 6,
|
||||||
|
window_flags_no_background = 1 << 7,
|
||||||
|
window_flags_no_saved_settings = 1 << 8,
|
||||||
|
window_flags_no_mouse_inputs = 1 << 9,
|
||||||
|
window_flags_menu_bar = 1 << 10,
|
||||||
|
window_flags_horizontal_scrollbar = 1 << 11,
|
||||||
|
window_flags_no_focus_on_appearing = 1 << 12,
|
||||||
|
window_flags_no_bring_to_front_on_focus = 1 << 13,
|
||||||
|
window_flags_always_vertical_scrollbar = 1 << 14,
|
||||||
|
window_flags_always_horizontal_scrollbar = 1 << 15,
|
||||||
|
window_flags_no_nav_inputs = 1 << 16,
|
||||||
|
window_flags_no_nav_focus = 1 << 17,
|
||||||
|
window_flags_unsaved_document = 1 << 18,
|
||||||
|
window_flags_no_nav = window_flags_no_nav_inputs | window_flags_no_nav_focus,
|
||||||
|
window_flags_no_decoration = window_flags_no_title_bar | window_flags_no_resize | window_flags_no_scrollbar | window_flags_no_collapse,
|
||||||
|
window_flags_no_inputs = window_flags_no_mouse_inputs | window_flags_no_nav_inputs | window_flags_no_nav_focus,
|
||||||
|
|
||||||
|
window_flags_child_window = 1 << 24,
|
||||||
|
window_flags_tooltip = 1 << 25,
|
||||||
|
window_flags_popup = 1 << 26,
|
||||||
|
window_flags_modal = 1 << 27,
|
||||||
|
window_flags_child_menu = 1 << 28,
|
||||||
|
|
||||||
|
#ifndef IMGUI_DISABLE_OBSOLETE_FUNCTIONS
|
||||||
|
window_flags_always_use_window_padding = 1 << 30,
|
||||||
|
window_flags_nav_flattened = 1 << 31,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
enum child_flags_
|
||||||
|
{
|
||||||
|
child_flags_none = 0,
|
||||||
|
child_flags_borders = 1 << 0,
|
||||||
|
child_flags_always_use_window_padding = 1 << 1,
|
||||||
|
child_flags_resize_x = 1 << 2,
|
||||||
|
child_flags_resize_y = 1 << 3,
|
||||||
|
child_flags_auto_resize_x = 1 << 4,
|
||||||
|
child_flags_auto_resize_y = 1 << 5,
|
||||||
|
child_flags_always_auto_resize = 1 << 6,
|
||||||
|
child_flags_frame_style = 1 << 7,
|
||||||
|
child_flags_nav_flattened = 1 << 8,
|
||||||
|
|
||||||
|
#ifndef IMGUI_DISABLE_OBSOLETE_FUNCTIONS
|
||||||
|
child_flags_border = child_flags_borders,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
enum gui_cond_
|
||||||
|
{
|
||||||
|
gui_cond_none = 0,
|
||||||
|
gui_cond_always = 1 << 0,
|
||||||
|
gui_cond_once = 1 << 1,
|
||||||
|
gui_cond_first_use_ever = 1 << 2,
|
||||||
|
gui_cond_appearing = 1 << 3,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum draw_flags_
|
||||||
|
{
|
||||||
|
draw_flags_none = 0,
|
||||||
|
draw_flags_closed = 1 << 0,
|
||||||
|
draw_flags_round_corners_top_left = 1 << 4,
|
||||||
|
draw_flags_round_corners_top_right = 1 << 5,
|
||||||
|
draw_flags_round_corners_bottom_left = 1 << 6,
|
||||||
|
draw_flags_round_corners_bottom_right = 1 << 7,
|
||||||
|
draw_flags_round_corners_none = 1 << 8,
|
||||||
|
draw_flags_round_corners_top = draw_flags_round_corners_top_left | draw_flags_round_corners_top_right,
|
||||||
|
draw_flags_round_corners_bottom = draw_flags_round_corners_bottom_left | draw_flags_round_corners_bottom_right,
|
||||||
|
draw_flags_round_corners_left = draw_flags_round_corners_bottom_left | draw_flags_round_corners_top_left,
|
||||||
|
draw_flags_round_corners_right = draw_flags_round_corners_bottom_right | draw_flags_round_corners_top_right,
|
||||||
|
draw_flags_round_corners_all = draw_flags_round_corners_top_left | draw_flags_round_corners_top_right | draw_flags_round_corners_bottom_left | draw_flags_round_corners_bottom_right,
|
||||||
|
draw_flags_round_corners_default = draw_flags_round_corners_all,
|
||||||
|
draw_flags_round_corners_mask = draw_flags_round_corners_all | draw_flags_round_corners_none,
|
||||||
|
draw_flags_shadow_cut_out_shape_background = 1 << 9
|
||||||
|
};
|
||||||
|
|
||||||
|
enum mouse_button_
|
||||||
|
{
|
||||||
|
mouse_button_left = 0,
|
||||||
|
mouse_button_right = 1,
|
||||||
|
mouse_button_middle = 2,
|
||||||
|
mouse_button_count = 5
|
||||||
|
};
|
||||||
|
|
||||||
|
struct data_var_info
|
||||||
|
{
|
||||||
|
ImU32 count;
|
||||||
|
ImU32 offset;
|
||||||
|
void* get_var_ptr(void* parent) const { return (void*)((unsigned char*)parent + offset); }
|
||||||
|
};
|
||||||
|
|
||||||
|
struct gui_style
|
||||||
|
{
|
||||||
|
float alpha;
|
||||||
|
float disabled_alpha;
|
||||||
|
ImVec2 window_padding;
|
||||||
|
float window_rounding;
|
||||||
|
float window_border_size;
|
||||||
|
ImVec2 window_min_size;
|
||||||
|
ImVec2 window_title_align;
|
||||||
|
ImGuiDir window_menu_button_position;
|
||||||
|
float child_rounding;
|
||||||
|
float child_border_size;
|
||||||
|
float popup_rounding;
|
||||||
|
float popup_border_size;
|
||||||
|
ImVec2 frame_padding;
|
||||||
|
float frame_rounding;
|
||||||
|
float frame_border_size;
|
||||||
|
ImVec2 item_spacing;
|
||||||
|
ImVec2 item_inner_spacing;
|
||||||
|
ImVec2 cell_padding;
|
||||||
|
ImVec2 touch_extra_padding;
|
||||||
|
float indent_spacing;
|
||||||
|
float columns_min_spacing;
|
||||||
|
float scrollbar_size;
|
||||||
|
float scrollbar_rounding;
|
||||||
|
float grab_min_size;
|
||||||
|
float grab_rounding;
|
||||||
|
float log_slider_deadzone;
|
||||||
|
float tab_rounding;
|
||||||
|
float tab_border_size;
|
||||||
|
float tab_min_width_for_close_button;
|
||||||
|
float tab_bar_border_size;
|
||||||
|
float tab_bar_overline_size;
|
||||||
|
float table_angled_headers_angle;
|
||||||
|
ImVec2 table_angled_headers_text_align;
|
||||||
|
ImGuiDir color_button_position;
|
||||||
|
ImVec2 button_text_align;
|
||||||
|
ImVec2 selectable_text_align;
|
||||||
|
float separator_text_border_size;
|
||||||
|
ImVec2 separator_text_align;
|
||||||
|
ImVec2 separator_text_padding;
|
||||||
|
float window_shadow_size;
|
||||||
|
ImVec2 window_shadow_offset;
|
||||||
|
ImVec2 scrollbar_border_padding;
|
||||||
|
float scrollbar_content_padding;
|
||||||
|
ImVec2 display_window_padding;
|
||||||
|
ImVec2 display_safe_area_padding;
|
||||||
|
float mouse_cursor_scale;
|
||||||
|
bool anti_aliased_lines;
|
||||||
|
bool anti_aliased_lines_use_tex;
|
||||||
|
bool anti_aliased_fill;
|
||||||
|
float curve_tessellation_tol;
|
||||||
|
float circle_tessellation_max_error;
|
||||||
|
ImVec4 colors[ImGuiCol_COUNT];
|
||||||
|
|
||||||
|
float hover_stationary_delay;
|
||||||
|
float hover_delay_short;
|
||||||
|
float hover_delay_normal;
|
||||||
|
ImGuiHoveredFlags hover_flags_for_tooltip_mouse;
|
||||||
|
ImGuiHoveredFlags hover_flags_for_tooltip_nav;
|
||||||
|
|
||||||
|
gui_style();
|
||||||
|
};
|
||||||
|
|
||||||
|
inline gui_style::gui_style()
|
||||||
|
{
|
||||||
|
alpha = 1.0f;
|
||||||
|
disabled_alpha = 0.60f;
|
||||||
|
window_padding = ImVec2(8, 8);
|
||||||
|
window_rounding = 0.0f;
|
||||||
|
window_border_size = 1.0f;
|
||||||
|
window_min_size = ImVec2(32, 32);
|
||||||
|
window_title_align = ImVec2(0.0f, 0.5f);
|
||||||
|
window_menu_button_position = ImGuiDir_Left;
|
||||||
|
child_rounding = 0.0f;
|
||||||
|
child_border_size = 1.0f;
|
||||||
|
popup_rounding = 0.0f;
|
||||||
|
popup_border_size = 1.0f;
|
||||||
|
frame_padding = ImVec2(4, 3);
|
||||||
|
frame_rounding = 0.0f;
|
||||||
|
frame_border_size = 0.0f;
|
||||||
|
item_spacing = ImVec2(8, 4);
|
||||||
|
item_inner_spacing = ImVec2(4, 4);
|
||||||
|
cell_padding = ImVec2(4, 2);
|
||||||
|
touch_extra_padding = ImVec2(0, 0);
|
||||||
|
indent_spacing = 21.0f;
|
||||||
|
columns_min_spacing = 6.0f;
|
||||||
|
scrollbar_size = 14.0f;
|
||||||
|
scrollbar_rounding = 9.0f;
|
||||||
|
grab_min_size = 12.0f;
|
||||||
|
grab_rounding = 0.0f;
|
||||||
|
log_slider_deadzone = 4.0f;
|
||||||
|
tab_rounding = 4.0f;
|
||||||
|
tab_border_size = 0.0f;
|
||||||
|
tab_min_width_for_close_button = 0.0f;
|
||||||
|
tab_bar_border_size = 1.0f;
|
||||||
|
tab_bar_overline_size = 2.0f;
|
||||||
|
table_angled_headers_angle = 35.0f * (IM_PI / 180.0f);
|
||||||
|
table_angled_headers_text_align = ImVec2(0.5f, 0.0f);
|
||||||
|
color_button_position = ImGuiDir_Right;
|
||||||
|
button_text_align = ImVec2(0.5f, 0.5f);
|
||||||
|
selectable_text_align = ImVec2(0.0f, 0.0f);
|
||||||
|
separator_text_border_size = 3.0f;
|
||||||
|
separator_text_align = ImVec2(0.0f, 0.5f);
|
||||||
|
separator_text_padding = ImVec2(20.0f, 3.0f);
|
||||||
|
window_shadow_size = 100.0f;
|
||||||
|
window_shadow_offset = ImVec2(0, 0);
|
||||||
|
scrollbar_border_padding = ImVec2(6, 6);
|
||||||
|
scrollbar_content_padding = 6;
|
||||||
|
display_window_padding = ImVec2(19, 19);
|
||||||
|
display_safe_area_padding = ImVec2(3, 3);
|
||||||
|
mouse_cursor_scale = 1.0f;
|
||||||
|
anti_aliased_lines = true;
|
||||||
|
anti_aliased_lines_use_tex = true;
|
||||||
|
anti_aliased_fill = true;
|
||||||
|
curve_tessellation_tol = 1.25f;
|
||||||
|
circle_tessellation_max_error = 0.30f;
|
||||||
|
hover_stationary_delay = 0.15f;
|
||||||
|
hover_delay_short = 0.15f;
|
||||||
|
hover_delay_normal = 0.40f;
|
||||||
|
hover_flags_for_tooltip_mouse = ImGuiHoveredFlags_Stationary | ImGuiHoveredFlags_DelayShort | ImGuiHoveredFlags_AllowWhenDisabled;
|
||||||
|
hover_flags_for_tooltip_nav = ImGuiHoveredFlags_NoSharedDelay | ImGuiHoveredFlags_DelayNormal | ImGuiHoveredFlags_AllowWhenDisabled;
|
||||||
|
|
||||||
|
colors[style_col_text] = ImVec4(1.00f, 1.00f, 1.00f, 1.00f);
|
||||||
|
colors[style_col_text_disabled] = ImVec4(0.50f, 0.50f, 0.50f, 1.00f);
|
||||||
|
colors[style_col_window_bg] = ImVec4(0.06f, 0.06f, 0.06f, 0.94f);
|
||||||
|
colors[style_col_child_bg] = ImVec4(0.00f, 0.00f, 0.00f, 0.00f);
|
||||||
|
colors[style_col_popup_bg] = ImVec4(0.08f, 0.08f, 0.08f, 0.94f);
|
||||||
|
colors[style_col_border] = ImVec4(0.43f, 0.43f, 0.50f, 0.50f);
|
||||||
|
colors[style_col_border_shadow] = ImVec4(0.00f, 0.00f, 0.00f, 0.00f);
|
||||||
|
colors[style_col_frame_bg] = ImVec4(0.16f, 0.29f, 0.48f, 0.54f);
|
||||||
|
colors[style_col_frame_bg_hovered] = ImVec4(0.26f, 0.59f, 0.98f, 0.40f);
|
||||||
|
colors[style_col_frame_bg_active] = ImVec4(0.26f, 0.59f, 0.98f, 0.67f);
|
||||||
|
colors[style_col_title_bg] = ImVec4(0.04f, 0.04f, 0.04f, 1.00f);
|
||||||
|
colors[style_col_title_bg_active] = ImVec4(0.16f, 0.29f, 0.48f, 1.00f);
|
||||||
|
colors[style_col_title_bg_collapsed] = ImVec4(0.00f, 0.00f, 0.00f, 0.51f);
|
||||||
|
colors[style_col_menu_bar_bg] = ImVec4(0.14f, 0.14f, 0.14f, 1.00f);
|
||||||
|
colors[style_col_scrollbar_bg] = ImVec4(0.02f, 0.02f, 0.02f, 0.53f);
|
||||||
|
colors[style_col_scrollbar_grab] = ImVec4(0.31f, 0.31f, 0.31f, 1.00f);
|
||||||
|
colors[style_col_scrollbar_grab_hovered] = ImVec4(0.41f, 0.41f, 0.41f, 1.00f);
|
||||||
|
colors[style_col_scrollbar_grab_active] = ImVec4(0.51f, 0.51f, 0.51f, 1.00f);
|
||||||
|
colors[style_col_check_mark] = ImVec4(0.26f, 0.59f, 0.98f, 1.00f);
|
||||||
|
colors[style_col_slider_grab] = ImVec4(0.24f, 0.52f, 0.88f, 1.00f);
|
||||||
|
colors[style_col_slider_grab_active] = ImVec4(0.26f, 0.59f, 0.98f, 1.00f);
|
||||||
|
colors[style_col_button] = ImVec4(0.26f, 0.59f, 0.98f, 0.40f);
|
||||||
|
colors[style_col_button_hovered] = ImVec4(0.26f, 0.59f, 0.98f, 1.00f);
|
||||||
|
colors[style_col_button_active] = ImVec4(0.06f, 0.53f, 0.98f, 1.00f);
|
||||||
|
colors[style_col_header] = ImVec4(0.26f, 0.59f, 0.98f, 0.31f);
|
||||||
|
colors[style_col_header_hovered] = ImVec4(0.26f, 0.59f, 0.98f, 0.80f);
|
||||||
|
colors[style_col_header_active] = ImVec4(0.26f, 0.59f, 0.98f, 1.00f);
|
||||||
|
colors[style_col_separator] = colors[style_col_border];
|
||||||
|
colors[style_col_separator_hovered] = ImVec4(0.10f, 0.40f, 0.75f, 0.78f);
|
||||||
|
colors[style_col_separator_active] = ImVec4(0.10f, 0.40f, 0.75f, 1.00f);
|
||||||
|
colors[style_col_resize_grip] = ImVec4(0.26f, 0.59f, 0.98f, 0.20f);
|
||||||
|
colors[style_col_resize_grip_hovered] = ImVec4(0.26f, 0.59f, 0.98f, 0.67f);
|
||||||
|
colors[style_col_resize_grip_active] = ImVec4(0.26f, 0.59f, 0.98f, 0.95f);
|
||||||
|
colors[style_col_tab_hovered] = colors[style_col_header_hovered];
|
||||||
|
colors[style_col_tab] = ImLerp(colors[style_col_header], colors[style_col_title_bg_active], 0.80f);
|
||||||
|
colors[style_col_tab_selected] = ImLerp(colors[style_col_header_active], colors[style_col_title_bg_active], 0.60f);
|
||||||
|
colors[style_col_tab_selected_overline] = colors[style_col_header_active];
|
||||||
|
colors[style_col_tab_dimmed] = ImLerp(colors[style_col_tab], colors[style_col_title_bg], 0.80f);
|
||||||
|
colors[style_col_tab_dimmed_selected] = ImLerp(colors[style_col_tab_selected], colors[style_col_title_bg], 0.40f);
|
||||||
|
colors[style_col_tab_dimmed_selected_overline] = ImVec4(0.50f, 0.50f, 0.50f, 1.00f);
|
||||||
|
colors[style_col_plot_lines] = ImVec4(0.61f, 0.61f, 0.61f, 1.00f);
|
||||||
|
colors[style_col_plot_lines_hovered] = ImVec4(1.00f, 0.43f, 0.35f, 1.00f);
|
||||||
|
colors[style_col_plot_histogram] = ImVec4(0.90f, 0.70f, 0.00f, 1.00f);
|
||||||
|
colors[style_col_plot_histogram_hovered] = ImVec4(1.00f, 0.60f, 0.00f, 1.00f);
|
||||||
|
colors[style_col_table_header_bg] = ImVec4(0.19f, 0.19f, 0.20f, 1.00f);
|
||||||
|
colors[style_col_table_border_strong] = ImVec4(0.31f, 0.31f, 0.35f, 1.00f);
|
||||||
|
colors[style_col_table_border_light] = ImVec4(0.23f, 0.23f, 0.25f, 1.00f);
|
||||||
|
colors[style_col_table_row_bg] = ImVec4(0.00f, 0.00f, 0.00f, 0.00f);
|
||||||
|
colors[style_col_table_row_bg_alt] = ImVec4(1.00f, 1.00f, 1.00f, 0.06f);
|
||||||
|
colors[style_col_text_link] = colors[style_col_header_active];
|
||||||
|
colors[style_col_text_selected_bg] = ImVec4(0.26f, 0.59f, 0.98f, 0.35f);
|
||||||
|
colors[style_col_drag_drop_target] = ImVec4(1.00f, 1.00f, 0.00f, 0.90f);
|
||||||
|
colors[style_col_nav_highlight] = ImVec4(0.26f, 0.59f, 0.98f, 1.00f);
|
||||||
|
colors[style_col_nav_windowing_highlight] = ImVec4(1.00f, 1.00f, 1.00f, 0.70f);
|
||||||
|
colors[style_col_nav_windowing_dim_bg] = ImVec4(0.80f, 0.80f, 0.80f, 0.20f);
|
||||||
|
colors[style_col_modal_window_dim_bg] = ImVec4(0.80f, 0.80f, 0.80f, 0.35f);
|
||||||
|
colors[style_col_window_shadow] = ImVec4(0.08f, 0.08f, 0.08f, 0.35f);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static const data_var_info style_var_info[] =
|
||||||
|
{
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, alpha) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, disabled_alpha) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, window_padding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, window_rounding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, window_border_size) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, window_min_size) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, window_title_align) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, child_rounding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, child_border_size) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, popup_rounding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, popup_border_size) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, frame_padding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, frame_rounding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, frame_border_size) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, item_spacing) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, item_inner_spacing) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, indent_spacing) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, cell_padding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, scrollbar_size) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, scrollbar_rounding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, grab_min_size) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, grab_rounding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, tab_rounding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, tab_border_size) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, tab_bar_border_size) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, tab_bar_overline_size) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, table_angled_headers_angle) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, table_angled_headers_text_align) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, button_text_align) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, selectable_text_align) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, separator_text_border_size) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, separator_text_align) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, separator_text_padding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, window_shadow_size) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, window_shadow_offset) },
|
||||||
|
{ 2, (ImU32)offsetof(gui_style, scrollbar_border_padding) },
|
||||||
|
{ 1, (ImU32)offsetof(gui_style, scrollbar_content_padding) },
|
||||||
|
};
|
||||||
|
|
||||||
|
struct gui_style_mod
|
||||||
|
{
|
||||||
|
style_var var_idx;
|
||||||
|
union { int backup_int[2]; float backup_float[2]; };
|
||||||
|
gui_style_mod(style_var idx, int v) { var_idx = idx; backup_int[0] = v; }
|
||||||
|
gui_style_mod(style_var idx, float v) { var_idx = idx; backup_float[0] = v; }
|
||||||
|
gui_style_mod(style_var idx, ImVec2 v) { var_idx = idx; backup_float[0] = v.x; backup_float[1] = v.y; }
|
||||||
|
};
|
||||||
|
|
||||||
|
struct gui_color_mod
|
||||||
|
{
|
||||||
|
style_col col;
|
||||||
|
ImVec4 backup_value;
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::vector<gui_style_mod> style_var_stack;
|
||||||
|
inline std::vector<gui_color_mod> style_col_stack;
|
||||||
|
|
||||||
|
inline const data_var_info* get_style_var_info(style_var idx)
|
||||||
|
{
|
||||||
|
return &style_var_info[idx];
|
||||||
|
}
|
||||||
|
|
||||||
+34
@@ -0,0 +1,34 @@
|
|||||||
|
#pragma once
|
||||||
|
#include "includes.h"
|
||||||
|
|
||||||
|
// DayZ overlay integration: resolved relative to the executable's working
|
||||||
|
// directory. CMake copies framework/data/uicons next to the built binary.
|
||||||
|
inline constexpr const char* flaticon_uicons_regular_rounded_path = "data\\uicons\\uicons-regular-rounded.ttf";
|
||||||
|
|
||||||
|
class c_font
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
void update();
|
||||||
|
|
||||||
|
ImFont* get(const std::vector<unsigned char>& font_data, float size);
|
||||||
|
ImFont* get_file(const std::string& file_path, float size, bool private_glyphs = false);
|
||||||
|
|
||||||
|
private:
|
||||||
|
struct font_data
|
||||||
|
{
|
||||||
|
std::vector<unsigned char> data;
|
||||||
|
std::string file_path;
|
||||||
|
const void* source;
|
||||||
|
float size;
|
||||||
|
ImFont* font;
|
||||||
|
bool file;
|
||||||
|
bool private_glyphs;
|
||||||
|
};
|
||||||
|
|
||||||
|
void add(const std::vector<unsigned char>& font_data, float size);
|
||||||
|
void add_file(const std::string& file_path, float size, bool private_glyphs);
|
||||||
|
|
||||||
|
std::vector<font_data> data;
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::unique_ptr<c_font> font = std::make_unique<c_font>();
|
||||||
+253
@@ -0,0 +1,253 @@
|
|||||||
|
#pragma once
|
||||||
|
#include "includes.h"
|
||||||
|
#include <unordered_map>
|
||||||
|
#include "widgets.h"
|
||||||
|
#include "../headers/functions.h"
|
||||||
|
|
||||||
|
using namespace ImGui;
|
||||||
|
|
||||||
|
#define s_(...) scale_impl(__VA_ARGS__, var->gui.dpi)
|
||||||
|
|
||||||
|
inline ImVec2 scale_impl(const ImVec2& vec, float dpi) {
|
||||||
|
return ImVec2(roundf(vec.x * dpi), roundf(vec.y * dpi));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline ImVec2 scale_impl(float x, float y, float dpi) {
|
||||||
|
return ImVec2(roundf(x * dpi), roundf(y * dpi));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline float scale_impl(float var, float dpi) {
|
||||||
|
return roundf(var * dpi);
|
||||||
|
}
|
||||||
|
|
||||||
|
enum positions
|
||||||
|
{
|
||||||
|
pos_all,
|
||||||
|
pos_x,
|
||||||
|
pos_y
|
||||||
|
};
|
||||||
|
|
||||||
|
enum easing_type
|
||||||
|
{
|
||||||
|
static_easing,
|
||||||
|
dynamic_easing
|
||||||
|
};
|
||||||
|
|
||||||
|
class c_gui
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
std::unordered_map<ImGuiID, void*> m_anim_states;
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
T* anim_container(ImGuiID id)
|
||||||
|
{
|
||||||
|
auto it = m_anim_states.find(id);
|
||||||
|
if (it != m_anim_states.end())
|
||||||
|
return static_cast<T*>(it->second);
|
||||||
|
|
||||||
|
T* new_state = new T();
|
||||||
|
m_anim_states[id] = new_state;
|
||||||
|
return new_state;
|
||||||
|
}
|
||||||
|
|
||||||
|
float fixed_speed(float speed) { return speed / ImGui::GetIO().Framerate; }
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
T easing(T& value, T val, float speed, int type, bool dynamic_round = false)
|
||||||
|
{
|
||||||
|
if (type == static_easing)
|
||||||
|
{
|
||||||
|
if constexpr (std::is_same<T, ImVec4>::value)
|
||||||
|
{
|
||||||
|
return { 1.f, 1.f, 1.f, 1.f };
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
T step = fixed_speed(speed);
|
||||||
|
|
||||||
|
if (value < val)
|
||||||
|
{
|
||||||
|
value += step;
|
||||||
|
if (value > val) value = val;
|
||||||
|
}
|
||||||
|
else if (value > val)
|
||||||
|
{
|
||||||
|
value -= step;
|
||||||
|
if (value < val) value = val;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (type == dynamic_easing)
|
||||||
|
{
|
||||||
|
if constexpr (std::is_same<T, ImVec4>::value)
|
||||||
|
{
|
||||||
|
value = ImLerp(value, val, fixed_speed(speed));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
value = ImLerp(value, val + (dynamic_round ? 0.5f : 0.f), fixed_speed(speed));
|
||||||
|
}
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool begin(std::string_view name, bool* p_open = nullptr, window_flags flags = window_flags_none);
|
||||||
|
|
||||||
|
void end();
|
||||||
|
|
||||||
|
void push_color(style_col idx, ImU32 col);
|
||||||
|
|
||||||
|
void pop_color(int count = 1);
|
||||||
|
|
||||||
|
void push_var(style_var idx, float val);
|
||||||
|
|
||||||
|
void push_var(style_var idx, const ImVec2& val);
|
||||||
|
|
||||||
|
void pop_var(int count = 1);
|
||||||
|
|
||||||
|
void push_font(ImFont* font);
|
||||||
|
|
||||||
|
void pop_font();
|
||||||
|
|
||||||
|
void set_pos(const ImVec2& pos, int type);
|
||||||
|
|
||||||
|
void set_pos(float pos, int type);
|
||||||
|
|
||||||
|
ImVec2 get_pos();
|
||||||
|
|
||||||
|
void set_screen_pos(const ImVec2& pos, int type);
|
||||||
|
|
||||||
|
void set_screen_pos(float pos, int type);
|
||||||
|
|
||||||
|
ImVec2 get_screen_pos();
|
||||||
|
|
||||||
|
void begin_group();
|
||||||
|
|
||||||
|
void end_group();
|
||||||
|
|
||||||
|
void begin_content(std::string_view id, const ImVec2& size, const ImVec2& padding = ImVec2(0, 0), const ImVec2& spacing = ImVec2(0, 0), window_flags window_flags__ = 0, child_flags child_flags__ = 0);
|
||||||
|
|
||||||
|
void end_content();
|
||||||
|
|
||||||
|
void sameline(float offset_from_start_x = 0.f, float spacing_w = -1.f);
|
||||||
|
|
||||||
|
void dummy(const ImVec2& size);
|
||||||
|
|
||||||
|
bool begin_def_child(std::string_view name, const ImVec2& size_arg = ImVec2(0, 0), child_flags child_flags = 0, window_flags window_flags = 0);
|
||||||
|
|
||||||
|
void end_def_child();
|
||||||
|
|
||||||
|
void set_next_window_pos(const ImVec2& pos, gui_cond cond = 0, const ImVec2& pivot = ImVec2(0, 0));
|
||||||
|
|
||||||
|
void set_next_window_size(const ImVec2& size, gui_cond cond = 0);
|
||||||
|
|
||||||
|
ImVec2 text_size(ImFont* font, const char* text, const char* text_end = nullptr, bool hide_text_after_double_hash = false, float wrap_width = -1.f);
|
||||||
|
|
||||||
|
ImVec2 window_size();
|
||||||
|
|
||||||
|
float window_width();
|
||||||
|
|
||||||
|
float window_height();
|
||||||
|
|
||||||
|
ImDrawList* window_drawlist();
|
||||||
|
|
||||||
|
ImDrawList* foreground_drawlist();
|
||||||
|
|
||||||
|
ImDrawList* background_drawlist();
|
||||||
|
|
||||||
|
ImVec2 window_pos();
|
||||||
|
|
||||||
|
ImGuiWindow* get_window();
|
||||||
|
|
||||||
|
void push_id(const char* str_id);
|
||||||
|
|
||||||
|
void push_id(const char* str_id_begin, const char* str_id_end);
|
||||||
|
|
||||||
|
void push_id(const void* ptr_id);
|
||||||
|
|
||||||
|
void push_id(int int_id);
|
||||||
|
|
||||||
|
void pop_id();
|
||||||
|
|
||||||
|
ImGuiID get_id(const char* str, const char* str_end);
|
||||||
|
|
||||||
|
ImGuiID get_id(const void* ptr);
|
||||||
|
|
||||||
|
ImGuiID get_id(int n);
|
||||||
|
|
||||||
|
ImVec2 content_avail();
|
||||||
|
|
||||||
|
ImVec2 content_max();
|
||||||
|
|
||||||
|
void item_size(const ImVec2& size, float text_baseline_y = -1.f);
|
||||||
|
|
||||||
|
void item_size(const ImRect& bb, float text_baseline_y = -1.f);
|
||||||
|
|
||||||
|
bool item_add(const ImRect& bb, ImGuiID id, const ImRect* nav_bb_arg = NULL, ImGuiItemFlags extra_flags = 0);
|
||||||
|
|
||||||
|
bool is_window_hovered(ImGuiHoveredFlags flags);
|
||||||
|
|
||||||
|
bool is_window_focused(ImGuiFocusedFlags flags);
|
||||||
|
|
||||||
|
void set_window_focus();
|
||||||
|
|
||||||
|
void set_window_focus(const char* name);
|
||||||
|
|
||||||
|
bool is_rect_visible(const ImVec2& size);
|
||||||
|
|
||||||
|
bool is_rect_visible(const ImRect& rect);
|
||||||
|
|
||||||
|
ImVec2 adjust_window_pos(const ImVec2& rect, const ImVec2& window_size);
|
||||||
|
|
||||||
|
bool button_behavior(const ImRect& bb, ImGuiID id, bool* out_hovered, bool* out_held, ImGuiButtonFlags flags = 0);
|
||||||
|
|
||||||
|
bool invisible_button(const char* str_id, const ImVec2& size_arg, mouse_button flags = 0);
|
||||||
|
|
||||||
|
ImVec4 u32_to_float4(ImU32 in);
|
||||||
|
|
||||||
|
ImU32 float4_to_u32(const ImVec4& in);
|
||||||
|
|
||||||
|
void rgb_to_hsv(float r, float g, float b, float& out_h, float& out_s, float& out_v);
|
||||||
|
|
||||||
|
void hsv_to_rgb(float h, float s, float v, float& out_r, float& out_g, float& out_b);
|
||||||
|
|
||||||
|
bool item_hoverable(const ImRect& bb, ImGuiID id, ImGuiItemFlags item_flags = 0);
|
||||||
|
|
||||||
|
bool is_item_hovered(ImGuiHoveredFlags flags);
|
||||||
|
|
||||||
|
bool is_item_active();
|
||||||
|
|
||||||
|
bool is_item_clicked(mouse_button mouse_button);
|
||||||
|
|
||||||
|
bool mouse_down(mouse_button button);
|
||||||
|
|
||||||
|
bool mouse_clicked(mouse_button button, bool repeat = false);
|
||||||
|
|
||||||
|
bool mouse_released(mouse_button button);
|
||||||
|
|
||||||
|
bool mouse_double_clicked(mouse_button button);
|
||||||
|
|
||||||
|
const char* text_end(const char* text);
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
const char* get_fmt(char* text, T* value, std::string_view fmt)
|
||||||
|
{
|
||||||
|
ImFormatString(text, IM_ARRAYSIZE(text), fmt.data(), *value);
|
||||||
|
return text + strlen(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool is_window_cond(ImGuiWindow* window, const std::vector<std::string>& names);
|
||||||
|
|
||||||
|
ImVec2 mouse_pos();
|
||||||
|
|
||||||
|
void set_style();
|
||||||
|
|
||||||
|
void draw_decorations();
|
||||||
|
|
||||||
|
void initialize();
|
||||||
|
|
||||||
|
void render();
|
||||||
|
|
||||||
|
ImRect get_item_rect();
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::unique_ptr<c_gui> gui = std::make_unique<c_gui>();
|
||||||
+17
@@ -0,0 +1,17 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#define IMGUI_DEFINE_MATH_OPERATORS
|
||||||
|
|
||||||
|
#include "imgui.h"
|
||||||
|
#include "imgui_internal.h"
|
||||||
|
#include <vector>
|
||||||
|
#include <sstream>
|
||||||
|
#include <string>
|
||||||
|
#include "flags.h"
|
||||||
|
#include "../settings/colors.h"
|
||||||
|
#include "../settings/elements.h"
|
||||||
|
#include "../settings/variables.h"
|
||||||
|
#include "fonts.h"
|
||||||
|
#include "draw.h"
|
||||||
|
#include "functions.h"
|
||||||
|
#include "../data/fonts.h"
|
||||||
+107
@@ -0,0 +1,107 @@
|
|||||||
|
#pragma once
|
||||||
|
#include "includes.h"
|
||||||
|
|
||||||
|
#define IMGUI_DEFINE_MATH_OPERATORS
|
||||||
|
|
||||||
|
struct custom_slider_t
|
||||||
|
{
|
||||||
|
bool held;
|
||||||
|
c_rect rect;
|
||||||
|
c_rect active;
|
||||||
|
c_vec2 circle_pos;
|
||||||
|
};
|
||||||
|
|
||||||
|
enum title_status_icon
|
||||||
|
{
|
||||||
|
title_status_none = 0,
|
||||||
|
title_status_danger,
|
||||||
|
title_status_warning,
|
||||||
|
title_status_safe
|
||||||
|
};
|
||||||
|
|
||||||
|
enum keybind_mode
|
||||||
|
{
|
||||||
|
keybind_mode_hold = 0,
|
||||||
|
keybind_mode_toggle,
|
||||||
|
keybind_mode_always
|
||||||
|
};
|
||||||
|
|
||||||
|
struct keybind_t
|
||||||
|
{
|
||||||
|
int key = ImGuiKey_None;
|
||||||
|
bool ctrl = false;
|
||||||
|
bool shift = false;
|
||||||
|
bool alt = false;
|
||||||
|
bool super = false;
|
||||||
|
int mode = keybind_mode_hold;
|
||||||
|
bool capturing = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
class c_widgets
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
bool tab_button(std::string name, std::string icon, int tab);
|
||||||
|
bool sub_tab_button(std::string name, std::string icon, int tab, float width = 0.f);
|
||||||
|
void brand_header(std::string name, std::string subtitle);
|
||||||
|
bool profile_dropdown(std::string name, std::string status);
|
||||||
|
bool primary_button(std::string name, std::string icon = "");
|
||||||
|
bool action_button(std::string name, std::string icon = "");
|
||||||
|
bool card_button(std::string name, std::string description, std::string button_text = "Run");
|
||||||
|
bool category_button(std::string name, std::string description, bool* callback);
|
||||||
|
bool child(std::string name);
|
||||||
|
void end_child();
|
||||||
|
bool checkbox(std::string name, std::string description, bool* callback, title_status_icon status = title_status_none);
|
||||||
|
bool keybind(std::string name, std::string description, keybind_t* bind);
|
||||||
|
bool dropdown(std::string name, std::string description, int* callback, std::vector<std::string> variants);
|
||||||
|
bool slider(std::string name, std::string description, float* callback, float vmin, float vmax, std::string format = "%.1f");
|
||||||
|
custom_slider_t custom_slider(std::string name, float* callback, float vmin, float vmax, float width);
|
||||||
|
bool color_picker(std::string name, c_vec4* color);
|
||||||
|
bool text_field(std::string name, char* buf, int buf_size, bool password = false, std::string icon = "");
|
||||||
|
bool search_field(std::string name, char* buf, int buf_size, const c_vec2& size);
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::unique_ptr<c_widgets> widgets = std::make_unique<c_widgets>();
|
||||||
|
|
||||||
|
enum notify_type
|
||||||
|
{
|
||||||
|
success = 0,
|
||||||
|
warning = 1,
|
||||||
|
error = 2
|
||||||
|
};
|
||||||
|
|
||||||
|
struct notify_state
|
||||||
|
{
|
||||||
|
int notify_id;
|
||||||
|
std::string title;
|
||||||
|
std::string text;
|
||||||
|
notify_type type{ success };
|
||||||
|
|
||||||
|
ImVec2 window_size{ 0, 0 };
|
||||||
|
float notify_alpha{ 0 };
|
||||||
|
bool active_notify{ true };
|
||||||
|
float notify_timer{ 0 };
|
||||||
|
float notify_pos{ 0 };
|
||||||
|
float notify_slide{ 28 };
|
||||||
|
};
|
||||||
|
|
||||||
|
class c_notify
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
void setup_notify();
|
||||||
|
|
||||||
|
void add_notify(std::string title, std::string text, notify_type type);
|
||||||
|
|
||||||
|
private:
|
||||||
|
ImVec2 render_notify(float notify_alpha, float notify_percentage, float notify_pos, float notify_slide, const std::string& title, const std::string& text, notify_type type);
|
||||||
|
|
||||||
|
float notify_time{ 2.65f };
|
||||||
|
int notify_count{ 0 };
|
||||||
|
|
||||||
|
float notify_spacing{ 8 };
|
||||||
|
ImVec2 notify_padding{ 16, 16 };
|
||||||
|
|
||||||
|
std::vector<notify_state> notifications;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::unique_ptr<c_notify> notify = std::make_unique<c_notify>();
|
||||||
+1208
File diff suppressed because it is too large
Load Diff
+112
@@ -0,0 +1,112 @@
|
|||||||
|
#include "../headers/includes.h"
|
||||||
|
#include "../../thirdparty/imgui/imgui_freetype.h"
|
||||||
|
#include "imgui_impl_dx11.h"
|
||||||
|
|
||||||
|
static const ImWchar* get_private_icon_ranges()
|
||||||
|
{
|
||||||
|
static const ImWchar ranges[] =
|
||||||
|
{
|
||||||
|
0x26A0, 0x26A0, // warning sign
|
||||||
|
0x26D4, 0x26D4, // no entry
|
||||||
|
0x2714, 0x2714, // heavy check mark
|
||||||
|
0xE70D, 0xE70E, // Segoe MDL2 chevrons
|
||||||
|
0xF1E7, 0xF1E7, // fi-rr-backpack
|
||||||
|
0xF309, 0xF309, // fi-rr-bullseye
|
||||||
|
0xF3A2, 0xF3A2, // fi-rr-chart-histogram
|
||||||
|
0xF5F8, 0xF5F8, // fi-rr-eye
|
||||||
|
0xF71C, 0xF71C, // fi-rr-grid
|
||||||
|
0xF87D, 0xF87D, // fi-rr-layout-fluid
|
||||||
|
0xF8E1, 0xF8E1, // fi-rr-magic-wand
|
||||||
|
0xFB7C, 0xFB7C, // fi-rr-running
|
||||||
|
0xFD32, 0xFD32, // fi-rr-sword
|
||||||
|
0xFD5F, 0xFD5F, // fi-rr-target
|
||||||
|
0xFE19, 0xFE19, // fi-rr-treasure-chest
|
||||||
|
0xFEA0, 0xFEA0, // fi-rr-user
|
||||||
|
0xFEA6, 0xFEA6, // fi-rr-users
|
||||||
|
0xFF21, 0xFF21, // fi-rr-world
|
||||||
|
0
|
||||||
|
};
|
||||||
|
return ranges;
|
||||||
|
}
|
||||||
|
|
||||||
|
void c_font::update()
|
||||||
|
{
|
||||||
|
if (var->gui.dpi_changed)
|
||||||
|
{
|
||||||
|
var->gui.dpi = var->gui.stored_dpi / 100.f;
|
||||||
|
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
ImGui_ImplDX11_InvalidateDeviceObjects();
|
||||||
|
io.Fonts->Clear();
|
||||||
|
|
||||||
|
for (auto& font_t : data)
|
||||||
|
{
|
||||||
|
ImFontConfig cfg;
|
||||||
|
|
||||||
|
if (font_t.file)
|
||||||
|
{
|
||||||
|
cfg.FontBuilderFlags = ImGuiFreeTypeBuilderFlags_ForceAutoHint;
|
||||||
|
const ImWchar* ranges = font_t.private_glyphs ? get_private_icon_ranges() : io.Fonts->GetGlyphRangesCyrillic();
|
||||||
|
font_t.font = io.Fonts->AddFontFromFileTTF(font_t.file_path.c_str(), s_(font_t.size), &cfg, ranges);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cfg.FontBuilderFlags = ImGuiFreeTypeBuilderFlags_ForceAutoHint | ImGuiFreeTypeBuilderFlags_Bitmap;
|
||||||
|
cfg.FontDataOwnedByAtlas = false;
|
||||||
|
font_t.font = io.Fonts->AddFontFromMemoryTTF(font_t.data.data(), font_t.data.size(), s_(font_t.size), &cfg, io.Fonts->GetGlyphRangesCyrillic());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
io.Fonts->Build();
|
||||||
|
ImGui_ImplDX11_CreateDeviceObjects();
|
||||||
|
|
||||||
|
var->gui.dpi_changed = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ImFont* c_font::get(const std::vector<unsigned char>& font_data, float size)
|
||||||
|
{
|
||||||
|
const void* source = font_data.empty() ? nullptr : font_data.data();
|
||||||
|
|
||||||
|
for (auto& font_t : data)
|
||||||
|
{
|
||||||
|
if (!font_t.file && font_t.source == source && font_t.size == size)
|
||||||
|
{
|
||||||
|
return font_t.font;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
add(font_data, size);
|
||||||
|
|
||||||
|
var->gui.dpi_changed = true;
|
||||||
|
|
||||||
|
return get(font_data, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
ImFont* c_font::get_file(const std::string& file_path, float size, bool private_glyphs)
|
||||||
|
{
|
||||||
|
for (auto& font_t : data)
|
||||||
|
{
|
||||||
|
if (font_t.file && font_t.file_path == file_path && font_t.size == size && font_t.private_glyphs == private_glyphs)
|
||||||
|
{
|
||||||
|
return font_t.font;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
add_file(file_path, size, private_glyphs);
|
||||||
|
|
||||||
|
var->gui.dpi_changed = true;
|
||||||
|
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
void c_font::add(const std::vector<unsigned char>& font_data, float size)
|
||||||
|
{
|
||||||
|
const void* source = font_data.empty() ? nullptr : font_data.data();
|
||||||
|
data.push_back({ font_data, "", source, size, nullptr, false, false });
|
||||||
|
}
|
||||||
|
|
||||||
|
void c_font::add_file(const std::string& file_path, float size, bool private_glyphs)
|
||||||
|
{
|
||||||
|
data.push_back({ {}, file_path, nullptr, size, nullptr, true, private_glyphs });
|
||||||
|
}
|
||||||
+20
@@ -0,0 +1,20 @@
|
|||||||
|
#pragma once
|
||||||
|
#include "../headers/includes.h"
|
||||||
|
#include "../headers/flags.h"
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
class c_colors
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
c_col layout{ 25, 25, 28 };
|
||||||
|
c_col white{ 255, 255, 255 };
|
||||||
|
c_col black{ 0, 0, 0 };
|
||||||
|
c_col accent{ 176, 180, 255 };
|
||||||
|
c_col child{ 28, 28, 33 };
|
||||||
|
c_col widget{ 33, 33, 40 };
|
||||||
|
c_col text{ 110, 110, 129 };
|
||||||
|
c_col cirlce{ 50, 50, 63 };
|
||||||
|
c_col border{ 35, 35, 44 };
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::unique_ptr<c_colors> clr = std::make_unique<c_colors>();
|
||||||
+24
@@ -0,0 +1,24 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <string>
|
||||||
|
#include "imgui.h"
|
||||||
|
|
||||||
|
class c_elements
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
c_vec2 padding{ 10, 10 };
|
||||||
|
|
||||||
|
float child_width;
|
||||||
|
float tab_window_width;
|
||||||
|
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
c_text name{ "Lumin" };
|
||||||
|
c_vec2 size{ 570, 354 };
|
||||||
|
float rounding{ 12 };
|
||||||
|
} window;
|
||||||
|
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::unique_ptr<c_elements> elements = std::make_unique<c_elements>();
|
||||||
+47
@@ -0,0 +1,47 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
#include "imgui.h"
|
||||||
|
#include "../headers/flags.h"
|
||||||
|
|
||||||
|
|
||||||
|
class c_variables
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
float dpi = 1.f; // DayZ overlay: 1:1 scale so ESP fonts map to real px
|
||||||
|
int stored_dpi = 100;
|
||||||
|
bool dpi_changed = true;
|
||||||
|
|
||||||
|
int tab = 1; // DayZ overlay: start on the first feature tab (no login)
|
||||||
|
int tab_stored = 1;
|
||||||
|
float tab_alpha = 1.f;
|
||||||
|
|
||||||
|
int sub_tab = 1;
|
||||||
|
int sub_tab_stored = 1;
|
||||||
|
|
||||||
|
bool login_loading = false;
|
||||||
|
float login_loading_timer = 0.f;
|
||||||
|
float login_loading_alpha = 0.f;
|
||||||
|
std::string login_loading_description = "Please wait, account verification";
|
||||||
|
|
||||||
|
bool license_invalid = false;
|
||||||
|
float license_invalid_timer = 0.f;
|
||||||
|
std::string license_error_message = "";
|
||||||
|
|
||||||
|
bool compact_layout = false;
|
||||||
|
bool sidebar_glass = false;
|
||||||
|
float window_rounding = 12.f;
|
||||||
|
bool strict_license = true;
|
||||||
|
bool verification_animation = true;
|
||||||
|
char profile_name[64] = "Active user";
|
||||||
|
char feature_search[96] = "";
|
||||||
|
} gui;
|
||||||
|
|
||||||
|
gui_style style;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
inline std::unique_ptr<c_variables> var = std::make_unique<c_variables>();
|
||||||
+1242
File diff suppressed because it is too large
Load Diff
+164
@@ -0,0 +1,164 @@
|
|||||||
|
#include "../headers/functions.h"
|
||||||
|
#include "../headers/widgets.h"
|
||||||
|
|
||||||
|
static constexpr float notify_visual_scale = 0.81f;
|
||||||
|
|
||||||
|
static float notify_s(float value)
|
||||||
|
{
|
||||||
|
return s_(value * notify_visual_scale);
|
||||||
|
}
|
||||||
|
|
||||||
|
static c_vec2 notify_s(float x, float y)
|
||||||
|
{
|
||||||
|
return s_(x * notify_visual_scale, y * notify_visual_scale);
|
||||||
|
}
|
||||||
|
|
||||||
|
static c_vec4 notify_color(notify_type type)
|
||||||
|
{
|
||||||
|
if (type == error)
|
||||||
|
return c_col(245, 70, 86).Value;
|
||||||
|
|
||||||
|
return type == warning ? clr->text.Value : clr->accent.Value;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const char* notify_badge_text(notify_type type)
|
||||||
|
{
|
||||||
|
if (type == warning)
|
||||||
|
return "DISABLED";
|
||||||
|
if (type == error)
|
||||||
|
return "ERROR";
|
||||||
|
|
||||||
|
return "ENABLED";
|
||||||
|
}
|
||||||
|
|
||||||
|
static void draw_notify_check_icon(ImDrawList* draw_list, const c_vec2& center, ImU32 color)
|
||||||
|
{
|
||||||
|
if ((color & IM_COL32_A_MASK) == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
const c_vec2 points[] =
|
||||||
|
{
|
||||||
|
center + notify_s(-6.2f, -0.4f),
|
||||||
|
center + notify_s(-4.7f, -1.9f),
|
||||||
|
center + notify_s(-1.7f, 1.0f),
|
||||||
|
center + notify_s(5.5f, -6.3f),
|
||||||
|
center + notify_s(7.0f, -4.8f),
|
||||||
|
center + notify_s(-1.5f, 4.1f),
|
||||||
|
};
|
||||||
|
draw_list->AddConcavePolyFilled(points, IM_ARRAYSIZE(points), color);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void draw_notify_minus_icon(ImDrawList* draw_list, const c_vec2& center, ImU32 color)
|
||||||
|
{
|
||||||
|
const float half_width = ImMax(2.0f, notify_s(5.8f));
|
||||||
|
const float half_height = ImMax(1.35f, notify_s(1.15f));
|
||||||
|
draw->rect_filled(draw_list, center - c_vec2(half_width, half_height), center + c_vec2(half_width, half_height), color, half_height);
|
||||||
|
}
|
||||||
|
|
||||||
|
void c_notify::add_notify(std::string title, std::string text, notify_type type)
|
||||||
|
{
|
||||||
|
if (!notifications.empty())
|
||||||
|
{
|
||||||
|
notify_state& last = notifications.back();
|
||||||
|
if (last.title == title && last.text == text && last.type == type && last.notify_timer < 0.22f)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
notifications.push_back({ notify_count++, std::move(title), std::move(text), type });
|
||||||
|
}
|
||||||
|
|
||||||
|
void c_notify::setup_notify()
|
||||||
|
{
|
||||||
|
float accumulated_height = notify_padding.y;
|
||||||
|
|
||||||
|
for (int i = 0; i < static_cast<int>(notifications.size()); )
|
||||||
|
{
|
||||||
|
notify_state& notification = notifications[i];
|
||||||
|
|
||||||
|
if (notification.active_notify)
|
||||||
|
notification.notify_timer += ImGui::GetIO().DeltaTime;
|
||||||
|
|
||||||
|
if (notification.notify_timer >= notify_time)
|
||||||
|
notification.active_notify = false;
|
||||||
|
|
||||||
|
gui->easing(notification.notify_alpha, notification.active_notify ? 1.f : 0.f, 14.f, dynamic_easing);
|
||||||
|
gui->easing(notification.notify_slide, notification.active_notify ? 0.f : 28.f, 18.f, dynamic_easing);
|
||||||
|
gui->easing(notification.notify_pos, accumulated_height, 14.f, dynamic_easing);
|
||||||
|
|
||||||
|
if (!notification.active_notify && notification.notify_alpha <= 0.015f)
|
||||||
|
{
|
||||||
|
notifications.erase(notifications.begin() + i);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (notification.notify_alpha > 0.01f)
|
||||||
|
{
|
||||||
|
ImVec2 window_size = render_notify(notification.notify_alpha, notification.notify_timer / notify_time,
|
||||||
|
notification.notify_pos, notification.notify_slide, notification.title, notification.text, notification.type);
|
||||||
|
accumulated_height += window_size.y + notify_spacing;
|
||||||
|
}
|
||||||
|
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ImVec2 c_notify::render_notify(float notify_alpha, float notify_percentage, float notify_pos, float notify_slide, const std::string& title, const std::string& text, notify_type type)
|
||||||
|
{
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
ImDrawList* draw_list = gui->foreground_drawlist();
|
||||||
|
|
||||||
|
const c_vec4 status_color = notify_color(type);
|
||||||
|
const c_vec4 accent = clr->accent.Value;
|
||||||
|
const bool disabled = type == warning;
|
||||||
|
const c_vec2 size = notify_s(288, 76);
|
||||||
|
const c_vec2 pos = c_vec2(io.DisplaySize.x - notify_padding.x - size.x + notify_s(notify_slide), notify_pos);
|
||||||
|
const c_rect rect(pos, pos + size);
|
||||||
|
const float alpha = notify_alpha;
|
||||||
|
const float rounding = notify_s(12);
|
||||||
|
const float progress = ImSaturate(1.f - notify_percentage);
|
||||||
|
|
||||||
|
draw->shadow_rect(draw_list, rect.Min, rect.Max, draw->get_clr(clr->black, 0.30f * alpha), notify_s(20), notify_s(0, 8), 0, rounding);
|
||||||
|
draw->rect_filled(draw_list, rect.Min, rect.Max, draw->get_clr(clr->child, 0.98f * alpha), rounding);
|
||||||
|
draw->rect_filled_multi_color(draw_list, rect.Min, rect.Max,
|
||||||
|
draw->get_clr(clr->white, 0.040f * alpha), draw->get_clr(accent, 0.030f * alpha),
|
||||||
|
draw->get_clr(clr->black, 0.035f * alpha), draw->get_clr(clr->black, 0.035f * alpha), rounding);
|
||||||
|
draw->rect(draw_list, rect.Min, rect.Max, draw->get_clr(clr->border, 0.96f * alpha), rounding, 0, notify_s(1));
|
||||||
|
|
||||||
|
const c_rect badge(rect.Min + notify_s(13, 15), rect.Min + notify_s(49, 51));
|
||||||
|
draw->shadow_rect(draw_list, badge.Min + notify_s(1, 2), badge.Max - notify_s(1, 0), draw->get_clr(status_color, disabled ? 0.08f * alpha : 0.16f * alpha), notify_s(12), c_vec2(0, 0), 0, notify_s(9));
|
||||||
|
draw->rect_filled(draw_list, badge.Min, badge.Max, draw->get_clr(clr->widget, 0.94f * alpha), notify_s(9));
|
||||||
|
draw->rect_filled_multi_color(draw_list, badge.Min, badge.Max,
|
||||||
|
draw->get_clr(clr->white, 0.060f * alpha), draw->get_clr(status_color, disabled ? 0.020f * alpha : 0.070f * alpha),
|
||||||
|
draw->get_clr(clr->black, 0.025f * alpha), draw->get_clr(clr->black, 0.025f * alpha), notify_s(9));
|
||||||
|
draw->rect(draw_list, badge.Min, badge.Max, draw->get_clr(status_color, disabled ? 0.30f * alpha : 0.44f * alpha), notify_s(9), 0, notify_s(1));
|
||||||
|
|
||||||
|
const c_vec2 mark_center = badge.GetCenter() + notify_s(0, -0.5f);
|
||||||
|
if (disabled)
|
||||||
|
{
|
||||||
|
draw_notify_minus_icon(draw_list, mark_center, draw->get_clr(status_color, 0.95f * alpha));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
draw_notify_check_icon(draw_list, mark_center, draw->get_clr(status_color, alpha));
|
||||||
|
}
|
||||||
|
|
||||||
|
const c_rect pill(rect.Max - notify_s(84, 60), rect.Max - notify_s(13, 42));
|
||||||
|
draw->rect_filled(draw_list, pill.Min, pill.Max, draw->get_clr(status_color, disabled ? 0.075f * alpha : 0.12f * alpha), notify_s(999));
|
||||||
|
draw->rect(draw_list, pill.Min, pill.Max, draw->get_clr(status_color, disabled ? 0.22f * alpha : 0.36f * alpha), notify_s(999), 0, notify_s(1));
|
||||||
|
draw->text_clipped(draw_list, font->get(inter_semibold, 8.f * notify_visual_scale), pill.Min, pill.Max, draw->get_clr(status_color, alpha),
|
||||||
|
notify_badge_text(type), 0, 0, { 0.5f, 0.5f });
|
||||||
|
|
||||||
|
draw->text_clipped(draw_list, font->get(inter_semibold, 12.f * notify_visual_scale), rect.Min + notify_s(60, 14), rect.Max - notify_s(91, 0),
|
||||||
|
draw->get_clr(clr->white, alpha), title.data(), 0, 0, { 0, 0 });
|
||||||
|
draw->text_clipped(draw_list, font->get(inter_medium, 10.f * notify_visual_scale), rect.Min + notify_s(60, 33), rect.Max - notify_s(15, 0),
|
||||||
|
draw->get_clr(clr->text, 0.96f * alpha), text.data(), 0, 0, { 0, 0 });
|
||||||
|
|
||||||
|
draw->line(draw_list, rect.Min + notify_s(60, 54), rect.Max - notify_s(15, 22), draw->get_clr(clr->border, 0.55f * alpha));
|
||||||
|
|
||||||
|
const c_rect track(rect.Min + notify_s(13, 64), rect.Max - notify_s(13, 8));
|
||||||
|
draw->rect_filled(draw_list, track.Min, track.Max, draw->get_clr(clr->widget, 0.78f * alpha), notify_s(999));
|
||||||
|
draw->rect_filled(draw_list, track.Min, c_vec2(track.Min.x + track.GetWidth() * progress, track.Max.y),
|
||||||
|
draw->get_clr(status_color, disabled ? 0.40f * alpha : 0.88f * alpha), notify_s(999));
|
||||||
|
|
||||||
|
return size;
|
||||||
|
}
|
||||||
+1501
File diff suppressed because it is too large
Load Diff
+1850
File diff suppressed because it is too large
Load Diff
+1666
File diff suppressed because it is too large
Load Diff
+169
@@ -0,0 +1,169 @@
|
|||||||
|
The FreeType Project LICENSE
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
2006-Jan-27
|
||||||
|
|
||||||
|
Copyright 1996-2002, 2006 by
|
||||||
|
David Turner, Robert Wilhelm, and Werner Lemberg
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Introduction
|
||||||
|
============
|
||||||
|
|
||||||
|
The FreeType Project is distributed in several archive packages;
|
||||||
|
some of them may contain, in addition to the FreeType font engine,
|
||||||
|
various tools and contributions which rely on, or relate to, the
|
||||||
|
FreeType Project.
|
||||||
|
|
||||||
|
This license applies to all files found in such packages, and
|
||||||
|
which do not fall under their own explicit license. The license
|
||||||
|
affects thus the FreeType font engine, the test programs,
|
||||||
|
documentation and makefiles, at the very least.
|
||||||
|
|
||||||
|
This license was inspired by the BSD, Artistic, and IJG
|
||||||
|
(Independent JPEG Group) licenses, which all encourage inclusion
|
||||||
|
and use of free software in commercial and freeware products
|
||||||
|
alike. As a consequence, its main points are that:
|
||||||
|
|
||||||
|
o We don't promise that this software works. However, we will be
|
||||||
|
interested in any kind of bug reports. (`as is' distribution)
|
||||||
|
|
||||||
|
o You can use this software for whatever you want, in parts or
|
||||||
|
full form, without having to pay us. (`royalty-free' usage)
|
||||||
|
|
||||||
|
o You may not pretend that you wrote this software. If you use
|
||||||
|
it, or only parts of it, in a program, you must acknowledge
|
||||||
|
somewhere in your documentation that you have used the
|
||||||
|
FreeType code. (`credits')
|
||||||
|
|
||||||
|
We specifically permit and encourage the inclusion of this
|
||||||
|
software, with or without modifications, in commercial products.
|
||||||
|
We disclaim all warranties covering The FreeType Project and
|
||||||
|
assume no liability related to The FreeType Project.
|
||||||
|
|
||||||
|
|
||||||
|
Finally, many people asked us for a preferred form for a
|
||||||
|
credit/disclaimer to use in compliance with this license. We thus
|
||||||
|
encourage you to use the following text:
|
||||||
|
|
||||||
|
"""
|
||||||
|
Portions of this software are copyright © <year> The FreeType
|
||||||
|
Project (www.freetype.org). All rights reserved.
|
||||||
|
"""
|
||||||
|
|
||||||
|
Please replace <year> with the value from the FreeType version you
|
||||||
|
actually use.
|
||||||
|
|
||||||
|
|
||||||
|
Legal Terms
|
||||||
|
===========
|
||||||
|
|
||||||
|
0. Definitions
|
||||||
|
--------------
|
||||||
|
|
||||||
|
Throughout this license, the terms `package', `FreeType Project',
|
||||||
|
and `FreeType archive' refer to the set of files originally
|
||||||
|
distributed by the authors (David Turner, Robert Wilhelm, and
|
||||||
|
Werner Lemberg) as the `FreeType Project', be they named as alpha,
|
||||||
|
beta or final release.
|
||||||
|
|
||||||
|
`You' refers to the licensee, or person using the project, where
|
||||||
|
`using' is a generic term including compiling the project's source
|
||||||
|
code as well as linking it to form a `program' or `executable'.
|
||||||
|
This program is referred to as `a program using the FreeType
|
||||||
|
engine'.
|
||||||
|
|
||||||
|
This license applies to all files distributed in the original
|
||||||
|
FreeType Project, including all source code, binaries and
|
||||||
|
documentation, unless otherwise stated in the file in its
|
||||||
|
original, unmodified form as distributed in the original archive.
|
||||||
|
If you are unsure whether or not a particular file is covered by
|
||||||
|
this license, you must contact us to verify this.
|
||||||
|
|
||||||
|
The FreeType Project is copyright (C) 1996-2000 by David Turner,
|
||||||
|
Robert Wilhelm, and Werner Lemberg. All rights reserved except as
|
||||||
|
specified below.
|
||||||
|
|
||||||
|
1. No Warranty
|
||||||
|
--------------
|
||||||
|
|
||||||
|
THE FREETYPE PROJECT IS PROVIDED `AS IS' WITHOUT WARRANTY OF ANY
|
||||||
|
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
PURPOSE. IN NO EVENT WILL ANY OF THE AUTHORS OR COPYRIGHT HOLDERS
|
||||||
|
BE LIABLE FOR ANY DAMAGES CAUSED BY THE USE OR THE INABILITY TO
|
||||||
|
USE, OF THE FREETYPE PROJECT.
|
||||||
|
|
||||||
|
2. Redistribution
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
This license grants a worldwide, royalty-free, perpetual and
|
||||||
|
irrevocable right and license to use, execute, perform, compile,
|
||||||
|
display, copy, create derivative works of, distribute and
|
||||||
|
sublicense the FreeType Project (in both source and object code
|
||||||
|
forms) and derivative works thereof for any purpose; and to
|
||||||
|
authorize others to exercise some or all of the rights granted
|
||||||
|
herein, subject to the following conditions:
|
||||||
|
|
||||||
|
o Redistribution of source code must retain this license file
|
||||||
|
(`FTL.TXT') unaltered; any additions, deletions or changes to
|
||||||
|
the original files must be clearly indicated in accompanying
|
||||||
|
documentation. The copyright notices of the unaltered,
|
||||||
|
original files must be preserved in all copies of source
|
||||||
|
files.
|
||||||
|
|
||||||
|
o Redistribution in binary form must provide a disclaimer that
|
||||||
|
states that the software is based in part of the work of the
|
||||||
|
FreeType Team, in the distribution documentation. We also
|
||||||
|
encourage you to put an URL to the FreeType web page in your
|
||||||
|
documentation, though this isn't mandatory.
|
||||||
|
|
||||||
|
These conditions apply to any software derived from or based on
|
||||||
|
the FreeType Project, not just the unmodified files. If you use
|
||||||
|
our work, you must acknowledge us. However, no fee need be paid
|
||||||
|
to us.
|
||||||
|
|
||||||
|
3. Advertising
|
||||||
|
--------------
|
||||||
|
|
||||||
|
Neither the FreeType authors and contributors nor you shall use
|
||||||
|
the name of the other for commercial, advertising, or promotional
|
||||||
|
purposes without specific prior written permission.
|
||||||
|
|
||||||
|
We suggest, but do not require, that you use one or more of the
|
||||||
|
following phrases to refer to this software in your documentation
|
||||||
|
or advertising materials: `FreeType Project', `FreeType Engine',
|
||||||
|
`FreeType library', or `FreeType Distribution'.
|
||||||
|
|
||||||
|
As you have not signed this license, you are not required to
|
||||||
|
accept it. However, as the FreeType Project is copyrighted
|
||||||
|
material, only this license, or another one contracted with the
|
||||||
|
authors, grants you the right to use, distribute, and modify it.
|
||||||
|
Therefore, by using, distributing, or modifying the FreeType
|
||||||
|
Project, you indicate that you understand and accept all the terms
|
||||||
|
of this license.
|
||||||
|
|
||||||
|
4. Contacts
|
||||||
|
-----------
|
||||||
|
|
||||||
|
There are two mailing lists related to FreeType:
|
||||||
|
|
||||||
|
o freetype@nongnu.org
|
||||||
|
|
||||||
|
Discusses general use and applications of FreeType, as well as
|
||||||
|
future and wanted additions to the library and distribution.
|
||||||
|
If you are looking for support, start in this list if you
|
||||||
|
haven't found anything to help you in the documentation.
|
||||||
|
|
||||||
|
o freetype-devel@nongnu.org
|
||||||
|
|
||||||
|
Discusses bugs, as well as engine internals, design issues,
|
||||||
|
specific licenses, porting, etc.
|
||||||
|
|
||||||
|
Our home page can be found at
|
||||||
|
|
||||||
|
https://www.freetype.org
|
||||||
|
|
||||||
|
|
||||||
|
--- end of FTL.TXT ---
|
||||||
+42
@@ -0,0 +1,42 @@
|
|||||||
|
FREETYPE LICENSES
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
The FreeType 2 font engine is copyrighted work and cannot be used
|
||||||
|
legally without a software license. In order to make this project
|
||||||
|
usable to a vast majority of developers, we distribute it under two
|
||||||
|
mutually exclusive open-source licenses.
|
||||||
|
|
||||||
|
This means that *you* must choose *one* of the two licenses described
|
||||||
|
below, then obey all its terms and conditions when using FreeType 2 in
|
||||||
|
any of your projects or products.
|
||||||
|
|
||||||
|
- The FreeType License, found in the file `docs/FTL.TXT`, which is
|
||||||
|
similar to the original BSD license *with* an advertising clause
|
||||||
|
that forces you to explicitly cite the FreeType project in your
|
||||||
|
product's documentation. All details are in the license file.
|
||||||
|
This license is suited to products which don't use the GNU General
|
||||||
|
Public License.
|
||||||
|
|
||||||
|
Note that this license is compatible to the GNU General Public
|
||||||
|
License version 3, but not version 2.
|
||||||
|
|
||||||
|
- The GNU General Public License version 2, found in
|
||||||
|
`docs/GPLv2.TXT` (any later version can be used also), for
|
||||||
|
programs which already use the GPL. Note that the FTL is
|
||||||
|
incompatible with GPLv2 due to its advertisement clause.
|
||||||
|
|
||||||
|
The contributed BDF and PCF drivers come with a license similar to
|
||||||
|
that of the X Window System. It is compatible to the above two
|
||||||
|
licenses (see files `src/bdf/README` and `src/pcf/README`). The same
|
||||||
|
holds for the source code files `src/base/fthash.c` and
|
||||||
|
`include/freetype/internal/fthash.h`; they wer part of the BDF driver
|
||||||
|
in earlier FreeType versions.
|
||||||
|
|
||||||
|
The gzip module uses the zlib license (see `src/gzip/zlib.h`) which
|
||||||
|
too is compatible to the above two licenses.
|
||||||
|
|
||||||
|
The MD5 checksum support (only used for debugging in development
|
||||||
|
builds) is in the public domain.
|
||||||
|
|
||||||
|
|
||||||
|
--- end of LICENSE.TXT ---
|
||||||
@@ -0,0 +1,51 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftconfig.h
|
||||||
|
*
|
||||||
|
* ANSI-specific configuration file (specification only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* This header file contains a number of macro definitions that are used by
|
||||||
|
* the rest of the engine. Most of the macros here are automatically
|
||||||
|
* determined at compile time, and you should not need to change it to port
|
||||||
|
* FreeType, except to compile the library with a non-ANSI compiler.
|
||||||
|
*
|
||||||
|
* Note however that if some specific modifications are needed, we advise
|
||||||
|
* you to place a modified copy in your build directory.
|
||||||
|
*
|
||||||
|
* The build directory is usually `builds/<system>`, and contains
|
||||||
|
* system-specific files that are always included first when building the
|
||||||
|
* library.
|
||||||
|
*
|
||||||
|
* This ANSI version should stay in `include/config/`.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef FTCONFIG_H_
|
||||||
|
#define FTCONFIG_H_
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_CONFIG_OPTIONS_H
|
||||||
|
#include FT_CONFIG_STANDARD_LIBRARY_H
|
||||||
|
|
||||||
|
#include <freetype/config/integer-types.h>
|
||||||
|
#include <freetype/config/public-macros.h>
|
||||||
|
#include <freetype/config/mac-support.h>
|
||||||
|
|
||||||
|
#endif /* FTCONFIG_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,836 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftheader.h
|
||||||
|
*
|
||||||
|
* Build macros of the FreeType 2 library.
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef FTHEADER_H_
|
||||||
|
#define FTHEADER_H_
|
||||||
|
|
||||||
|
|
||||||
|
/*@***********************************************************************/
|
||||||
|
/* */
|
||||||
|
/* <Macro> */
|
||||||
|
/* FT_BEGIN_HEADER */
|
||||||
|
/* */
|
||||||
|
/* <Description> */
|
||||||
|
/* This macro is used in association with @FT_END_HEADER in header */
|
||||||
|
/* files to ensure that the declarations within are properly */
|
||||||
|
/* encapsulated in an `extern "C" { .. }` block when included from a */
|
||||||
|
/* C++ compiler. */
|
||||||
|
/* */
|
||||||
|
#ifndef FT_BEGIN_HEADER
|
||||||
|
# ifdef __cplusplus
|
||||||
|
# define FT_BEGIN_HEADER extern "C" {
|
||||||
|
# else
|
||||||
|
# define FT_BEGIN_HEADER /* nothing */
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*@***********************************************************************/
|
||||||
|
/* */
|
||||||
|
/* <Macro> */
|
||||||
|
/* FT_END_HEADER */
|
||||||
|
/* */
|
||||||
|
/* <Description> */
|
||||||
|
/* This macro is used in association with @FT_BEGIN_HEADER in header */
|
||||||
|
/* files to ensure that the declarations within are properly */
|
||||||
|
/* encapsulated in an `extern "C" { .. }` block when included from a */
|
||||||
|
/* C++ compiler. */
|
||||||
|
/* */
|
||||||
|
#ifndef FT_END_HEADER
|
||||||
|
# ifdef __cplusplus
|
||||||
|
# define FT_END_HEADER }
|
||||||
|
# else
|
||||||
|
# define FT_END_HEADER /* nothing */
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* Aliases for the FreeType 2 public and configuration files.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* header_file_macros
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Header File Macros
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Macro definitions used to `#include` specific header files.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* In addition to the normal scheme of including header files like
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* #include <freetype/freetype.h>
|
||||||
|
* #include <freetype/ftmm.h>
|
||||||
|
* #include <freetype/ftglyph.h>
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* it is possible to used named macros instead. They can be used
|
||||||
|
* directly in `#include` statements as in
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* #include FT_FREETYPE_H
|
||||||
|
* #include FT_MULTIPLE_MASTERS_H
|
||||||
|
* #include FT_GLYPH_H
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* These macros were introduced to overcome the infamous 8.3~naming rule
|
||||||
|
* required by DOS (and `FT_MULTIPLE_MASTERS_H` is a lot more meaningful
|
||||||
|
* than `ftmm.h`).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* configuration files */
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_CONFIG_CONFIG_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing
|
||||||
|
* FreeType~2 configuration data.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef FT_CONFIG_CONFIG_H
|
||||||
|
#define FT_CONFIG_CONFIG_H <freetype/config/ftconfig.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_CONFIG_STANDARD_LIBRARY_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing
|
||||||
|
* FreeType~2 interface to the standard C library functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef FT_CONFIG_STANDARD_LIBRARY_H
|
||||||
|
#define FT_CONFIG_STANDARD_LIBRARY_H <freetype/config/ftstdlib.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_CONFIG_OPTIONS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing
|
||||||
|
* FreeType~2 project-specific configuration options.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef FT_CONFIG_OPTIONS_H
|
||||||
|
#define FT_CONFIG_OPTIONS_H <freetype/config/ftoption.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_CONFIG_MODULES_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* list of FreeType~2 modules that are statically linked to new library
|
||||||
|
* instances in @FT_Init_FreeType.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef FT_CONFIG_MODULES_H
|
||||||
|
#define FT_CONFIG_MODULES_H <freetype/config/ftmodule.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
/* public headers */
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_FREETYPE_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* base FreeType~2 API.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_FREETYPE_H <freetype/freetype.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_ERRORS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* list of FreeType~2 error codes (and messages).
|
||||||
|
*
|
||||||
|
* It is included by @FT_FREETYPE_H.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_ERRORS_H <freetype/fterrors.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_MODULE_ERRORS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* list of FreeType~2 module error offsets (and messages).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_MODULE_ERRORS_H <freetype/ftmoderr.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_SYSTEM_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 interface to low-level operations (i.e., memory management
|
||||||
|
* and stream i/o).
|
||||||
|
*
|
||||||
|
* It is included by @FT_FREETYPE_H.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_SYSTEM_H <freetype/ftsystem.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_IMAGE_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing type
|
||||||
|
* definitions related to glyph images (i.e., bitmaps, outlines,
|
||||||
|
* scan-converter parameters).
|
||||||
|
*
|
||||||
|
* It is included by @FT_FREETYPE_H.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_IMAGE_H <freetype/ftimage.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_TYPES_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* basic data types defined by FreeType~2.
|
||||||
|
*
|
||||||
|
* It is included by @FT_FREETYPE_H.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_TYPES_H <freetype/fttypes.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_LIST_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* list management API of FreeType~2.
|
||||||
|
*
|
||||||
|
* (Most applications will never need to include this file.)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_LIST_H <freetype/ftlist.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_OUTLINE_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* scalable outline management API of FreeType~2.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_OUTLINE_H <freetype/ftoutln.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_SIZES_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* API which manages multiple @FT_Size objects per face.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_SIZES_H <freetype/ftsizes.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_MODULE_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* module management API of FreeType~2.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_MODULE_H <freetype/ftmodapi.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_RENDER_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* renderer module management API of FreeType~2.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_RENDER_H <freetype/ftrender.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_DRIVER_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing
|
||||||
|
* structures and macros related to the driver modules.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_DRIVER_H <freetype/ftdriver.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_AUTOHINTER_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing
|
||||||
|
* structures and macros related to the auto-hinting module.
|
||||||
|
*
|
||||||
|
* Deprecated since version~2.9; use @FT_DRIVER_H instead.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_AUTOHINTER_H FT_DRIVER_H
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_CFF_DRIVER_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing
|
||||||
|
* structures and macros related to the CFF driver module.
|
||||||
|
*
|
||||||
|
* Deprecated since version~2.9; use @FT_DRIVER_H instead.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_CFF_DRIVER_H FT_DRIVER_H
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_TRUETYPE_DRIVER_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing
|
||||||
|
* structures and macros related to the TrueType driver module.
|
||||||
|
*
|
||||||
|
* Deprecated since version~2.9; use @FT_DRIVER_H instead.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_TRUETYPE_DRIVER_H FT_DRIVER_H
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_PCF_DRIVER_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing
|
||||||
|
* structures and macros related to the PCF driver module.
|
||||||
|
*
|
||||||
|
* Deprecated since version~2.9; use @FT_DRIVER_H instead.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PCF_DRIVER_H FT_DRIVER_H
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_TYPE1_TABLES_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* types and API specific to the Type~1 format.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_TYPE1_TABLES_H <freetype/t1tables.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_TRUETYPE_IDS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* enumeration values which identify name strings, languages, encodings,
|
||||||
|
* etc. This file really contains a _large_ set of constant macro
|
||||||
|
* definitions, taken from the TrueType and OpenType specifications.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_TRUETYPE_IDS_H <freetype/ttnameid.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_TRUETYPE_TABLES_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* types and API specific to the TrueType (as well as OpenType) format.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_TRUETYPE_TABLES_H <freetype/tttables.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_TRUETYPE_TAGS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* definitions of TrueType four-byte 'tags' which identify blocks in
|
||||||
|
* SFNT-based font formats (i.e., TrueType and OpenType).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_TRUETYPE_TAGS_H <freetype/tttags.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_BDF_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* definitions of an API which accesses BDF-specific strings from a face.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_BDF_H <freetype/ftbdf.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_CID_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* definitions of an API which access CID font information from a face.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_CID_H <freetype/ftcid.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_GZIP_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* definitions of an API which supports gzip-compressed files.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_GZIP_H <freetype/ftgzip.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_LZW_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* definitions of an API which supports LZW-compressed files.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_LZW_H <freetype/ftlzw.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_BZIP2_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* definitions of an API which supports bzip2-compressed files.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_BZIP2_H <freetype/ftbzip2.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_WINFONTS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* definitions of an API which supports Windows FNT files.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_WINFONTS_H <freetype/ftwinfnt.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_GLYPH_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* API of the optional glyph management component.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_GLYPH_H <freetype/ftglyph.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_BITMAP_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* API of the optional bitmap conversion component.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_BITMAP_H <freetype/ftbitmap.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_BBOX_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* API of the optional exact bounding box computation routines.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_BBOX_H <freetype/ftbbox.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_CACHE_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* API of the optional FreeType~2 cache sub-system.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_CACHE_H <freetype/ftcache.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_MAC_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* Macintosh-specific FreeType~2 API. The latter is used to access fonts
|
||||||
|
* embedded in resource forks.
|
||||||
|
*
|
||||||
|
* This header file must be explicitly included by client applications
|
||||||
|
* compiled on the Mac (note that the base API still works though).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_MAC_H <freetype/ftmac.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_MULTIPLE_MASTERS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* optional multiple-masters management API of FreeType~2.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_MULTIPLE_MASTERS_H <freetype/ftmm.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_SFNT_NAMES_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* optional FreeType~2 API which accesses embedded 'name' strings in
|
||||||
|
* SFNT-based font formats (i.e., TrueType and OpenType).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_SFNT_NAMES_H <freetype/ftsnames.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_OPENTYPE_VALIDATE_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* optional FreeType~2 API which validates OpenType tables ('BASE',
|
||||||
|
* 'GDEF', 'GPOS', 'GSUB', 'JSTF').
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_OPENTYPE_VALIDATE_H <freetype/ftotval.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_GX_VALIDATE_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* optional FreeType~2 API which validates TrueTypeGX/AAT tables ('feat',
|
||||||
|
* 'mort', 'morx', 'bsln', 'just', 'kern', 'opbd', 'trak', 'prop').
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_GX_VALIDATE_H <freetype/ftgxval.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_PFR_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which accesses PFR-specific data.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PFR_H <freetype/ftpfr.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_STROKER_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which provides functions to stroke outline paths.
|
||||||
|
*/
|
||||||
|
#define FT_STROKER_H <freetype/ftstroke.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_SYNTHESIS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which performs artificial obliquing and emboldening.
|
||||||
|
*/
|
||||||
|
#define FT_SYNTHESIS_H <freetype/ftsynth.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_FONT_FORMATS_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which provides functions specific to font formats.
|
||||||
|
*/
|
||||||
|
#define FT_FONT_FORMATS_H <freetype/ftfntfmt.h>
|
||||||
|
|
||||||
|
/* deprecated */
|
||||||
|
#define FT_XFREE86_H FT_FONT_FORMATS_H
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_TRIGONOMETRY_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which performs trigonometric computations (e.g.,
|
||||||
|
* cosines and arc tangents).
|
||||||
|
*/
|
||||||
|
#define FT_TRIGONOMETRY_H <freetype/fttrigon.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_LCD_FILTER_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which performs color filtering for subpixel rendering.
|
||||||
|
*/
|
||||||
|
#define FT_LCD_FILTER_H <freetype/ftlcdfil.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_INCREMENTAL_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which performs incremental glyph loading.
|
||||||
|
*/
|
||||||
|
#define FT_INCREMENTAL_H <freetype/ftincrem.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_GASP_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which returns entries from the TrueType GASP table.
|
||||||
|
*/
|
||||||
|
#define FT_GASP_H <freetype/ftgasp.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_ADVANCES_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which returns individual and ranged glyph advances.
|
||||||
|
*/
|
||||||
|
#define FT_ADVANCES_H <freetype/ftadvanc.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_COLOR_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which handles the OpenType 'CPAL' table.
|
||||||
|
*/
|
||||||
|
#define FT_COLOR_H <freetype/ftcolor.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_OTSVG_H
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro used in `#include` statements to name the file containing the
|
||||||
|
* FreeType~2 API which handles the OpenType 'SVG~' glyphs.
|
||||||
|
*/
|
||||||
|
#define FT_OTSVG_H <freetype/otsvg.h>
|
||||||
|
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
/* These header files don't need to be included by the user. */
|
||||||
|
#define FT_ERROR_DEFINITIONS_H <freetype/fterrdef.h>
|
||||||
|
#define FT_PARAMETER_TAGS_H <freetype/ftparams.h>
|
||||||
|
|
||||||
|
/* Deprecated macros. */
|
||||||
|
#define FT_UNPATENTED_HINTING_H <freetype/ftparams.h>
|
||||||
|
#define FT_TRUETYPE_UNPATENTED_H <freetype/ftparams.h>
|
||||||
|
|
||||||
|
/* `FT_CACHE_H` is the only header file needed for the cache subsystem. */
|
||||||
|
#define FT_CACHE_IMAGE_H FT_CACHE_H
|
||||||
|
#define FT_CACHE_SMALL_BITMAPS_H FT_CACHE_H
|
||||||
|
#define FT_CACHE_CHARMAP_H FT_CACHE_H
|
||||||
|
|
||||||
|
/* The internals of the cache sub-system are no longer exposed. We */
|
||||||
|
/* default to `FT_CACHE_H` at the moment just in case, but we know */
|
||||||
|
/* of no rogue client that uses them. */
|
||||||
|
/* */
|
||||||
|
#define FT_CACHE_MANAGER_H FT_CACHE_H
|
||||||
|
#define FT_CACHE_INTERNAL_MRU_H FT_CACHE_H
|
||||||
|
#define FT_CACHE_INTERNAL_MANAGER_H FT_CACHE_H
|
||||||
|
#define FT_CACHE_INTERNAL_CACHE_H FT_CACHE_H
|
||||||
|
#define FT_CACHE_INTERNAL_GLYPH_H FT_CACHE_H
|
||||||
|
#define FT_CACHE_INTERNAL_IMAGE_H FT_CACHE_H
|
||||||
|
#define FT_CACHE_INTERNAL_SBITS_H FT_CACHE_H
|
||||||
|
|
||||||
|
/* TODO(david): Move this section below to a different header */
|
||||||
|
#ifdef FT2_BUILD_LIBRARY
|
||||||
|
#if defined( _MSC_VER ) /* Visual C++ (and Intel C++) */
|
||||||
|
|
||||||
|
/* We disable the warning `conditional expression is constant' here */
|
||||||
|
/* in order to compile cleanly with the maximum level of warnings. */
|
||||||
|
/* In particular, the warning complains about stuff like `while(0)' */
|
||||||
|
/* which is very useful in macro definitions. There is no benefit */
|
||||||
|
/* in having it enabled. */
|
||||||
|
#pragma warning( disable : 4127 )
|
||||||
|
|
||||||
|
#endif /* _MSC_VER */
|
||||||
|
#endif /* FT2_BUILD_LIBRARY */
|
||||||
|
|
||||||
|
#endif /* FTHEADER_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
* This file registers the FreeType modules compiled into the library.
|
||||||
|
*
|
||||||
|
* If you use GNU make, this file IS NOT USED! Instead, it is created in
|
||||||
|
* the objects directory (normally `<topdir>/objs/`) based on information
|
||||||
|
* from `<topdir>/modules.cfg`.
|
||||||
|
*
|
||||||
|
* Please read `docs/INSTALL.ANY` and `docs/CUSTOMIZE` how to compile
|
||||||
|
* FreeType without GNU make.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
FT_USE_MODULE( FT_Module_Class, autofit_module_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, tt_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, t1_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, cff_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, t1cid_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, pfr_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, t42_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, winfnt_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, pcf_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Driver_ClassRec, bdf_driver_class )
|
||||||
|
FT_USE_MODULE( FT_Module_Class, psaux_module_class )
|
||||||
|
FT_USE_MODULE( FT_Module_Class, psnames_module_class )
|
||||||
|
FT_USE_MODULE( FT_Module_Class, pshinter_module_class )
|
||||||
|
FT_USE_MODULE( FT_Module_Class, sfnt_module_class )
|
||||||
|
FT_USE_MODULE( FT_Renderer_Class, ft_smooth_renderer_class )
|
||||||
|
FT_USE_MODULE( FT_Renderer_Class, ft_raster1_renderer_class )
|
||||||
|
FT_USE_MODULE( FT_Renderer_Class, ft_sdf_renderer_class )
|
||||||
|
FT_USE_MODULE( FT_Renderer_Class, ft_bitmap_sdf_renderer_class )
|
||||||
|
FT_USE_MODULE( FT_Renderer_Class, ft_svg_renderer_class )
|
||||||
|
|
||||||
|
/* EOF */
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,185 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftstdlib.h
|
||||||
|
*
|
||||||
|
* ANSI-specific library and header configuration file (specification
|
||||||
|
* only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* This file is used to group all `#includes` to the ANSI~C library that
|
||||||
|
* FreeType normally requires. It also defines macros to rename the
|
||||||
|
* standard functions within the FreeType source code.
|
||||||
|
*
|
||||||
|
* Load a file which defines `FTSTDLIB_H_` before this one to override it.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTSTDLIB_H_
|
||||||
|
#define FTSTDLIB_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
#define ft_ptrdiff_t ptrdiff_t
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* integer limits
|
||||||
|
*
|
||||||
|
* `UINT_MAX` and `ULONG_MAX` are used to automatically compute the size of
|
||||||
|
* `int` and `long` in bytes at compile-time. So far, this works for all
|
||||||
|
* platforms the library has been tested on. We also check `ULLONG_MAX`
|
||||||
|
* to see whether we can use 64-bit `long long` later on.
|
||||||
|
*
|
||||||
|
* Note that on the extremely rare platforms that do not provide integer
|
||||||
|
* types that are _exactly_ 16 and 32~bits wide (e.g., some old Crays where
|
||||||
|
* `int` is 36~bits), we do not make any guarantee about the correct
|
||||||
|
* behaviour of FreeType~2 with all fonts.
|
||||||
|
*
|
||||||
|
* In these cases, `ftconfig.h` will refuse to compile anyway with a
|
||||||
|
* message like 'couldn't find 32-bit type' or something similar.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <limits.h>
|
||||||
|
|
||||||
|
#define FT_CHAR_BIT CHAR_BIT
|
||||||
|
#define FT_USHORT_MAX USHRT_MAX
|
||||||
|
#define FT_INT_MAX INT_MAX
|
||||||
|
#define FT_INT_MIN INT_MIN
|
||||||
|
#define FT_UINT_MAX UINT_MAX
|
||||||
|
#define FT_LONG_MIN LONG_MIN
|
||||||
|
#define FT_LONG_MAX LONG_MAX
|
||||||
|
#define FT_ULONG_MAX ULONG_MAX
|
||||||
|
#ifdef LLONG_MAX
|
||||||
|
#define FT_LLONG_MAX LLONG_MAX
|
||||||
|
#endif
|
||||||
|
#ifdef LLONG_MIN
|
||||||
|
#define FT_LLONG_MIN LLONG_MIN
|
||||||
|
#endif
|
||||||
|
#ifdef ULLONG_MAX
|
||||||
|
#define FT_ULLONG_MAX ULLONG_MAX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* character and string processing
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#define ft_memchr memchr
|
||||||
|
#define ft_memcmp memcmp
|
||||||
|
#define ft_memcpy memcpy
|
||||||
|
#define ft_memmove memmove
|
||||||
|
#define ft_memset memset
|
||||||
|
#define ft_strcat strcat
|
||||||
|
#define ft_strcmp strcmp
|
||||||
|
#define ft_strcpy strcpy
|
||||||
|
#define ft_strlen strlen
|
||||||
|
#define ft_strncmp strncmp
|
||||||
|
#define ft_strncpy strncpy
|
||||||
|
#define ft_strrchr strrchr
|
||||||
|
#define ft_strstr strstr
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* file handling
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#define FT_FILE FILE
|
||||||
|
#define ft_fclose fclose
|
||||||
|
#define ft_fopen fopen
|
||||||
|
#define ft_fread fread
|
||||||
|
#define ft_fseek fseek
|
||||||
|
#define ft_ftell ftell
|
||||||
|
#define ft_sprintf sprintf
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* sorting
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#define ft_qsort qsort
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* memory allocation
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#define ft_scalloc calloc
|
||||||
|
#define ft_sfree free
|
||||||
|
#define ft_smalloc malloc
|
||||||
|
#define ft_srealloc realloc
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* miscellaneous
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#define ft_strtol strtol
|
||||||
|
#define ft_getenv getenv
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* execution control
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <setjmp.h>
|
||||||
|
|
||||||
|
#define ft_jmp_buf jmp_buf /* note: this cannot be a typedef since */
|
||||||
|
/* `jmp_buf` is defined as a macro */
|
||||||
|
/* on certain platforms */
|
||||||
|
|
||||||
|
#define ft_longjmp longjmp
|
||||||
|
#define ft_setjmp( b ) setjmp( *(ft_jmp_buf*) &(b) ) /* same thing here */
|
||||||
|
|
||||||
|
|
||||||
|
/* The following is only used for debugging purposes, i.e., if */
|
||||||
|
/* `FT_DEBUG_LEVEL_ERROR` or `FT_DEBUG_LEVEL_TRACE` are defined. */
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* FTSTDLIB_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,250 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* config/integer-types.h
|
||||||
|
*
|
||||||
|
* FreeType integer types definitions.
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef FREETYPE_CONFIG_INTEGER_TYPES_H_
|
||||||
|
#define FREETYPE_CONFIG_INTEGER_TYPES_H_
|
||||||
|
|
||||||
|
/* There are systems (like the Texas Instruments 'C54x) where a `char` */
|
||||||
|
/* has 16~bits. ANSI~C says that `sizeof(char)` is always~1. Since an */
|
||||||
|
/* `int` has 16~bits also for this system, `sizeof(int)` gives~1 which */
|
||||||
|
/* is probably unexpected. */
|
||||||
|
/* */
|
||||||
|
/* `CHAR_BIT` (defined in `limits.h`) gives the number of bits in a */
|
||||||
|
/* `char` type. */
|
||||||
|
|
||||||
|
#ifndef FT_CHAR_BIT
|
||||||
|
#define FT_CHAR_BIT CHAR_BIT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef FT_SIZEOF_INT
|
||||||
|
|
||||||
|
/* The size of an `int` type. */
|
||||||
|
#if FT_UINT_MAX == 0xFFFFUL
|
||||||
|
#define FT_SIZEOF_INT ( 16 / FT_CHAR_BIT )
|
||||||
|
#elif FT_UINT_MAX == 0xFFFFFFFFUL
|
||||||
|
#define FT_SIZEOF_INT ( 32 / FT_CHAR_BIT )
|
||||||
|
#elif FT_UINT_MAX > 0xFFFFFFFFUL && FT_UINT_MAX == 0xFFFFFFFFFFFFFFFFUL
|
||||||
|
#define FT_SIZEOF_INT ( 64 / FT_CHAR_BIT )
|
||||||
|
#else
|
||||||
|
#error "Unsupported size of `int' type!"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* !defined(FT_SIZEOF_INT) */
|
||||||
|
|
||||||
|
#ifndef FT_SIZEOF_LONG
|
||||||
|
|
||||||
|
/* The size of a `long` type. A five-byte `long` (as used e.g. on the */
|
||||||
|
/* DM642) is recognized but avoided. */
|
||||||
|
#if FT_ULONG_MAX == 0xFFFFFFFFUL
|
||||||
|
#define FT_SIZEOF_LONG ( 32 / FT_CHAR_BIT )
|
||||||
|
#elif FT_ULONG_MAX > 0xFFFFFFFFUL && FT_ULONG_MAX == 0xFFFFFFFFFFUL
|
||||||
|
#define FT_SIZEOF_LONG ( 32 / FT_CHAR_BIT )
|
||||||
|
#elif FT_ULONG_MAX > 0xFFFFFFFFUL && FT_ULONG_MAX == 0xFFFFFFFFFFFFFFFFUL
|
||||||
|
#define FT_SIZEOF_LONG ( 64 / FT_CHAR_BIT )
|
||||||
|
#else
|
||||||
|
#error "Unsupported size of `long' type!"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* !defined(FT_SIZEOF_LONG) */
|
||||||
|
|
||||||
|
#ifndef FT_SIZEOF_LONG_LONG
|
||||||
|
|
||||||
|
/* The size of a `long long` type if available */
|
||||||
|
#if defined( FT_ULLONG_MAX ) && FT_ULLONG_MAX >= 0xFFFFFFFFFFFFFFFFULL
|
||||||
|
#define FT_SIZEOF_LONG_LONG ( 64 / FT_CHAR_BIT )
|
||||||
|
#else
|
||||||
|
#define FT_SIZEOF_LONG_LONG 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* !defined(FT_SIZEOF_LONG_LONG) */
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* basic_types
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Int16
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for a 16bit signed integer type.
|
||||||
|
*/
|
||||||
|
typedef signed short FT_Int16;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_UInt16
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for a 16bit unsigned integer type.
|
||||||
|
*/
|
||||||
|
typedef unsigned short FT_UInt16;
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
/* this #if 0 ... #endif clause is for documentation purposes */
|
||||||
|
#if 0
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Int32
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for a 32bit signed integer type. The size depends on the
|
||||||
|
* configuration.
|
||||||
|
*/
|
||||||
|
typedef signed XXX FT_Int32;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_UInt32
|
||||||
|
*
|
||||||
|
* A typedef for a 32bit unsigned integer type. The size depends on the
|
||||||
|
* configuration.
|
||||||
|
*/
|
||||||
|
typedef unsigned XXX FT_UInt32;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Int64
|
||||||
|
*
|
||||||
|
* A typedef for a 64bit signed integer type. The size depends on the
|
||||||
|
* configuration. Only defined if there is real 64bit support;
|
||||||
|
* otherwise, it gets emulated with a structure (if necessary).
|
||||||
|
*/
|
||||||
|
typedef signed XXX FT_Int64;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_UInt64
|
||||||
|
*
|
||||||
|
* A typedef for a 64bit unsigned integer type. The size depends on the
|
||||||
|
* configuration. Only defined if there is real 64bit support;
|
||||||
|
* otherwise, it gets emulated with a structure (if necessary).
|
||||||
|
*/
|
||||||
|
typedef unsigned XXX FT_UInt64;
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if FT_SIZEOF_INT == ( 32 / FT_CHAR_BIT )
|
||||||
|
|
||||||
|
typedef signed int FT_Int32;
|
||||||
|
typedef unsigned int FT_UInt32;
|
||||||
|
|
||||||
|
#elif FT_SIZEOF_LONG == ( 32 / FT_CHAR_BIT )
|
||||||
|
|
||||||
|
typedef signed long FT_Int32;
|
||||||
|
typedef unsigned long FT_UInt32;
|
||||||
|
|
||||||
|
#else
|
||||||
|
#error "no 32bit type found -- please check your configuration files"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* look up an integer type that is at least 32~bits */
|
||||||
|
#if FT_SIZEOF_INT >= ( 32 / FT_CHAR_BIT )
|
||||||
|
|
||||||
|
typedef int FT_Fast;
|
||||||
|
typedef unsigned int FT_UFast;
|
||||||
|
|
||||||
|
#elif FT_SIZEOF_LONG >= ( 32 / FT_CHAR_BIT )
|
||||||
|
|
||||||
|
typedef long FT_Fast;
|
||||||
|
typedef unsigned long FT_UFast;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* determine whether we have a 64-bit integer type */
|
||||||
|
#if FT_SIZEOF_LONG == ( 64 / FT_CHAR_BIT )
|
||||||
|
|
||||||
|
#define FT_INT64 long
|
||||||
|
#define FT_UINT64 unsigned long
|
||||||
|
|
||||||
|
#elif FT_SIZEOF_LONG_LONG >= ( 64 / FT_CHAR_BIT )
|
||||||
|
|
||||||
|
#define FT_INT64 long long int
|
||||||
|
#define FT_UINT64 unsigned long long int
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* A 64-bit data type may create compilation problems if you compile in
|
||||||
|
* strict ANSI mode. To avoid them, we disable other 64-bit data types if
|
||||||
|
* `__STDC__` is defined. You can however ignore this rule by defining the
|
||||||
|
* `FT_CONFIG_OPTION_FORCE_INT64` configuration macro.
|
||||||
|
*/
|
||||||
|
#elif !defined( __STDC__ ) || defined( FT_CONFIG_OPTION_FORCE_INT64 )
|
||||||
|
|
||||||
|
#if defined( _MSC_VER ) && _MSC_VER >= 900 /* Visual C++ (and Intel C++) */
|
||||||
|
|
||||||
|
/* this compiler provides the `__int64` type */
|
||||||
|
#define FT_INT64 __int64
|
||||||
|
#define FT_UINT64 unsigned __int64
|
||||||
|
|
||||||
|
#elif defined( __BORLANDC__ ) /* Borland C++ */
|
||||||
|
|
||||||
|
/* XXXX: We should probably check the value of `__BORLANDC__` in order */
|
||||||
|
/* to test the compiler version. */
|
||||||
|
|
||||||
|
/* this compiler provides the `__int64` type */
|
||||||
|
#define FT_INT64 __int64
|
||||||
|
#define FT_UINT64 unsigned __int64
|
||||||
|
|
||||||
|
#elif defined( __WATCOMC__ ) && __WATCOMC__ >= 1100 /* Watcom C++ */
|
||||||
|
|
||||||
|
#define FT_INT64 long long int
|
||||||
|
#define FT_UINT64 unsigned long long int
|
||||||
|
|
||||||
|
#elif defined( __MWERKS__ ) /* Metrowerks CodeWarrior */
|
||||||
|
|
||||||
|
#define FT_INT64 long long int
|
||||||
|
#define FT_UINT64 unsigned long long int
|
||||||
|
|
||||||
|
#elif defined( __GNUC__ )
|
||||||
|
|
||||||
|
/* GCC provides the `long long` type */
|
||||||
|
#define FT_INT64 long long int
|
||||||
|
#define FT_UINT64 unsigned long long int
|
||||||
|
|
||||||
|
#endif /* !__STDC__ */
|
||||||
|
|
||||||
|
#endif /* FT_SIZEOF_LONG == (64 / FT_CHAR_BIT) */
|
||||||
|
|
||||||
|
#ifdef FT_INT64
|
||||||
|
typedef FT_INT64 FT_Int64;
|
||||||
|
typedef FT_UINT64 FT_UInt64;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* FREETYPE_CONFIG_INTEGER_TYPES_H_ */
|
||||||
@@ -0,0 +1,49 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* config/mac-support.h
|
||||||
|
*
|
||||||
|
* Mac/OS X support configuration header.
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef FREETYPE_CONFIG_MAC_SUPPORT_H_
|
||||||
|
#define FREETYPE_CONFIG_MAC_SUPPORT_H_
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* Mac support
|
||||||
|
*
|
||||||
|
* This is the only necessary change, so it is defined here instead
|
||||||
|
* providing a new configuration file.
|
||||||
|
*/
|
||||||
|
#if defined( __APPLE__ ) || ( defined( __MWERKS__ ) && defined( macintosh ) )
|
||||||
|
/* No Carbon frameworks for 64bit 10.4.x. */
|
||||||
|
/* `AvailabilityMacros.h` is available since Mac OS X 10.2, */
|
||||||
|
/* so guess the system version by maximum errno before inclusion. */
|
||||||
|
#include <errno.h>
|
||||||
|
#ifdef ECANCELED /* defined since 10.2 */
|
||||||
|
#include "AvailabilityMacros.h"
|
||||||
|
#endif
|
||||||
|
#if defined( __LP64__ ) && \
|
||||||
|
( MAC_OS_X_VERSION_MIN_REQUIRED <= MAC_OS_X_VERSION_10_4 )
|
||||||
|
#undef FT_MACINTOSH
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#elif defined( __SC__ ) || defined( __MRC__ )
|
||||||
|
/* Classic MacOS compilers */
|
||||||
|
#include "ConditionalMacros.h"
|
||||||
|
#if TARGET_OS_MAC
|
||||||
|
#define FT_MACINTOSH 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* Mac support */
|
||||||
|
|
||||||
|
#endif /* FREETYPE_CONFIG_MAC_SUPPORT_H_ */
|
||||||
@@ -0,0 +1,138 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* config/public-macros.h
|
||||||
|
*
|
||||||
|
* Define a set of compiler macros used in public FreeType headers.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2020-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The definitions in this file are used by the public FreeType headers
|
||||||
|
* and thus should be considered part of the public API.
|
||||||
|
*
|
||||||
|
* Other compiler-specific macro definitions that are not exposed by the
|
||||||
|
* FreeType API should go into
|
||||||
|
* `include/freetype/internal/compiler-macros.h` instead.
|
||||||
|
*/
|
||||||
|
#ifndef FREETYPE_CONFIG_PUBLIC_MACROS_H_
|
||||||
|
#define FREETYPE_CONFIG_PUBLIC_MACROS_H_
|
||||||
|
|
||||||
|
/*
|
||||||
|
* `FT_BEGIN_HEADER` and `FT_END_HEADER` might have already been defined
|
||||||
|
* by `freetype/config/ftheader.h`, but we don't want to include this
|
||||||
|
* header here, so redefine the macros here only when needed. Their
|
||||||
|
* definition is very stable, so keeping them in sync with the ones in the
|
||||||
|
* header should not be a maintenance issue.
|
||||||
|
*/
|
||||||
|
#ifndef FT_BEGIN_HEADER
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define FT_BEGIN_HEADER extern "C" {
|
||||||
|
#else
|
||||||
|
#define FT_BEGIN_HEADER /* empty */
|
||||||
|
#endif
|
||||||
|
#endif /* FT_BEGIN_HEADER */
|
||||||
|
|
||||||
|
#ifndef FT_END_HEADER
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define FT_END_HEADER }
|
||||||
|
#else
|
||||||
|
#define FT_END_HEADER /* empty */
|
||||||
|
#endif
|
||||||
|
#endif /* FT_END_HEADER */
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Mark a function declaration as public. This ensures it will be
|
||||||
|
* properly exported to client code. Place this before a function
|
||||||
|
* declaration.
|
||||||
|
*
|
||||||
|
* NOTE: This macro should be considered an internal implementation
|
||||||
|
* detail, and not part of the FreeType API. It is only defined here
|
||||||
|
* because it is needed by `FT_EXPORT`.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Visual C, mingw */
|
||||||
|
#if defined( _WIN32 )
|
||||||
|
|
||||||
|
#if defined( FT2_BUILD_LIBRARY ) && defined( DLL_EXPORT )
|
||||||
|
#define FT_PUBLIC_FUNCTION_ATTRIBUTE __declspec( dllexport )
|
||||||
|
#elif defined( DLL_IMPORT )
|
||||||
|
#define FT_PUBLIC_FUNCTION_ATTRIBUTE __declspec( dllimport )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* gcc, clang */
|
||||||
|
#elif ( defined( __GNUC__ ) && __GNUC__ >= 4 ) || defined( __clang__ )
|
||||||
|
#define FT_PUBLIC_FUNCTION_ATTRIBUTE \
|
||||||
|
__attribute__(( visibility( "default" ) ))
|
||||||
|
|
||||||
|
/* Sun */
|
||||||
|
#elif defined( __SUNPRO_C ) && __SUNPRO_C >= 0x550
|
||||||
|
#define FT_PUBLIC_FUNCTION_ATTRIBUTE __global
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FT_PUBLIC_FUNCTION_ATTRIBUTE
|
||||||
|
#define FT_PUBLIC_FUNCTION_ATTRIBUTE /* empty */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Define a public FreeType API function. This ensures it is properly
|
||||||
|
* exported or imported at build time. The macro parameter is the
|
||||||
|
* function's return type as in:
|
||||||
|
*
|
||||||
|
* FT_EXPORT( FT_Bool )
|
||||||
|
* FT_Object_Method( FT_Object obj,
|
||||||
|
* ... );
|
||||||
|
*
|
||||||
|
* NOTE: This requires that all `FT_EXPORT` uses are inside
|
||||||
|
* `FT_BEGIN_HEADER ... FT_END_HEADER` blocks. This guarantees that the
|
||||||
|
* functions are exported with C linkage, even when the header is included
|
||||||
|
* by a C++ source file.
|
||||||
|
*/
|
||||||
|
#define FT_EXPORT( x ) FT_PUBLIC_FUNCTION_ATTRIBUTE extern x
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* `FT_UNUSED` indicates that a given parameter is not used -- this is
|
||||||
|
* only used to get rid of unpleasant compiler warnings.
|
||||||
|
*
|
||||||
|
* Technically, this was not meant to be part of the public API, but some
|
||||||
|
* third-party code depends on it.
|
||||||
|
*/
|
||||||
|
#ifndef FT_UNUSED
|
||||||
|
#define FT_UNUSED( arg ) ( (arg) = (arg) )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Support for casts in both C and C++.
|
||||||
|
*/
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define FT_STATIC_CAST( type, var ) static_cast<type>(var)
|
||||||
|
#define FT_REINTERPRET_CAST( type, var ) reinterpret_cast<type>(var)
|
||||||
|
|
||||||
|
#define FT_STATIC_BYTE_CAST( type, var ) \
|
||||||
|
static_cast<type>( static_cast<unsigned char>( var ) )
|
||||||
|
#else
|
||||||
|
#define FT_STATIC_CAST( type, var ) (type)(var)
|
||||||
|
#define FT_REINTERPRET_CAST( type, var ) (type)(var)
|
||||||
|
|
||||||
|
#define FT_STATIC_BYTE_CAST( type, var ) (type)(unsigned char)(var)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FREETYPE_CONFIG_PUBLIC_MACROS_H_ */
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,188 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftadvanc.h
|
||||||
|
*
|
||||||
|
* Quick computation of advance widths (specification only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2008-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTADVANC_H_
|
||||||
|
#define FTADVANC_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* quick_advance
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Quick retrieval of advance values
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Retrieve horizontal and vertical advance values without processing
|
||||||
|
* glyph outlines, if possible.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains functions to quickly extract advance values
|
||||||
|
* without handling glyph outlines, if possible.
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* FT_Get_Advance
|
||||||
|
* FT_Get_Advances
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_ADVANCE_FLAG_FAST_ONLY
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A bit-flag to be OR-ed with the `flags` parameter of the
|
||||||
|
* @FT_Get_Advance and @FT_Get_Advances functions.
|
||||||
|
*
|
||||||
|
* If set, it indicates that you want these functions to fail if the
|
||||||
|
* corresponding hinting mode or font driver doesn't allow for very quick
|
||||||
|
* advance computation.
|
||||||
|
*
|
||||||
|
* Typically, glyphs that are either unscaled, unhinted, bitmapped, or
|
||||||
|
* light-hinted can have their advance width computed very quickly.
|
||||||
|
*
|
||||||
|
* Normal and bytecode hinted modes that require loading, scaling, and
|
||||||
|
* hinting of the glyph outline, are extremely slow by comparison.
|
||||||
|
*/
|
||||||
|
#define FT_ADVANCE_FLAG_FAST_ONLY 0x20000000L
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Advance
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the advance value of a given glyph outline in an @FT_Face.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* The source @FT_Face handle.
|
||||||
|
*
|
||||||
|
* gindex ::
|
||||||
|
* The glyph index.
|
||||||
|
*
|
||||||
|
* load_flags ::
|
||||||
|
* A set of bit flags similar to those used when calling
|
||||||
|
* @FT_Load_Glyph, used to determine what kind of advances you need.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* padvance ::
|
||||||
|
* The advance value. If scaling is performed (based on the value of
|
||||||
|
* `load_flags`), the advance value is in 16.16 format. Otherwise, it
|
||||||
|
* is in font units.
|
||||||
|
*
|
||||||
|
* If @FT_LOAD_VERTICAL_LAYOUT is set, this is the vertical advance
|
||||||
|
* corresponding to a vertical layout. Otherwise, it is the horizontal
|
||||||
|
* advance in a horizontal layout.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0 means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function may fail if you use @FT_ADVANCE_FLAG_FAST_ONLY and if
|
||||||
|
* the corresponding font backend doesn't have a quick way to retrieve
|
||||||
|
* the advances.
|
||||||
|
*
|
||||||
|
* A scaled advance is returned in 16.16 format but isn't transformed by
|
||||||
|
* the affine transformation specified by @FT_Set_Transform.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Advance( FT_Face face,
|
||||||
|
FT_UInt gindex,
|
||||||
|
FT_Int32 load_flags,
|
||||||
|
FT_Fixed *padvance );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Advances
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the advance values of several glyph outlines in an @FT_Face.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* The source @FT_Face handle.
|
||||||
|
*
|
||||||
|
* start ::
|
||||||
|
* The first glyph index.
|
||||||
|
*
|
||||||
|
* count ::
|
||||||
|
* The number of advance values you want to retrieve.
|
||||||
|
*
|
||||||
|
* load_flags ::
|
||||||
|
* A set of bit flags similar to those used when calling
|
||||||
|
* @FT_Load_Glyph.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* padvance ::
|
||||||
|
* The advance values. This array, to be provided by the caller, must
|
||||||
|
* contain at least `count` elements.
|
||||||
|
*
|
||||||
|
* If scaling is performed (based on the value of `load_flags`), the
|
||||||
|
* advance values are in 16.16 format. Otherwise, they are in font
|
||||||
|
* units.
|
||||||
|
*
|
||||||
|
* If @FT_LOAD_VERTICAL_LAYOUT is set, these are the vertical advances
|
||||||
|
* corresponding to a vertical layout. Otherwise, they are the
|
||||||
|
* horizontal advances in a horizontal layout.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0 means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function may fail if you use @FT_ADVANCE_FLAG_FAST_ONLY and if
|
||||||
|
* the corresponding font backend doesn't have a quick way to retrieve
|
||||||
|
* the advances.
|
||||||
|
*
|
||||||
|
* Scaled advances are returned in 16.16 format but aren't transformed by
|
||||||
|
* the affine transformation specified by @FT_Set_Transform.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Advances( FT_Face face,
|
||||||
|
FT_UInt start,
|
||||||
|
FT_UInt count,
|
||||||
|
FT_Int32 load_flags,
|
||||||
|
FT_Fixed *padvances );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTADVANC_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,101 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftbbox.h
|
||||||
|
*
|
||||||
|
* FreeType exact bbox computation (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* This component has a _single_ role: to compute exact outline bounding
|
||||||
|
* boxes.
|
||||||
|
*
|
||||||
|
* It is separated from the rest of the engine for various technical
|
||||||
|
* reasons. It may well be integrated in 'ftoutln' later.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTBBOX_H_
|
||||||
|
#define FTBBOX_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* outline_processing
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Get_BBox
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Compute the exact bounding box of an outline. This is slower than
|
||||||
|
* computing the control box. However, it uses an advanced algorithm
|
||||||
|
* that returns _very_ quickly when the two boxes coincide. Otherwise,
|
||||||
|
* the outline Bezier arcs are traversed to extract their extrema.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the source outline.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* abbox ::
|
||||||
|
* The outline's exact bounding box.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If the font is tricky and the glyph has been loaded with
|
||||||
|
* @FT_LOAD_NO_SCALE, the resulting BBox is meaningless. To get
|
||||||
|
* reasonable values for the BBox it is necessary to load the glyph at a
|
||||||
|
* large ppem value (so that the hinting instructions can properly shift
|
||||||
|
* and scale the subglyphs), then extracting the BBox, which can be
|
||||||
|
* eventually converted back to font units.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_Get_BBox( FT_Outline* outline,
|
||||||
|
FT_BBox *abbox );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTBBOX_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
|
|
||||||
|
|
||||||
|
/* Local Variables: */
|
||||||
|
/* coding: utf-8 */
|
||||||
|
/* End: */
|
||||||
@@ -0,0 +1,212 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftbdf.h
|
||||||
|
*
|
||||||
|
* FreeType API for accessing BDF-specific strings (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTBDF_H_
|
||||||
|
#define FTBDF_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* bdf_fonts
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* BDF and PCF Files
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* BDF and PCF specific API.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the declaration of functions specific to BDF and
|
||||||
|
* PCF fonts.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* BDF_PropertyType
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of BDF property types.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* BDF_PROPERTY_TYPE_NONE ::
|
||||||
|
* Value~0 is used to indicate a missing property.
|
||||||
|
*
|
||||||
|
* BDF_PROPERTY_TYPE_ATOM ::
|
||||||
|
* Property is a string atom.
|
||||||
|
*
|
||||||
|
* BDF_PROPERTY_TYPE_INTEGER ::
|
||||||
|
* Property is a 32-bit signed integer.
|
||||||
|
*
|
||||||
|
* BDF_PROPERTY_TYPE_CARDINAL ::
|
||||||
|
* Property is a 32-bit unsigned integer.
|
||||||
|
*/
|
||||||
|
typedef enum BDF_PropertyType_
|
||||||
|
{
|
||||||
|
BDF_PROPERTY_TYPE_NONE = 0,
|
||||||
|
BDF_PROPERTY_TYPE_ATOM = 1,
|
||||||
|
BDF_PROPERTY_TYPE_INTEGER = 2,
|
||||||
|
BDF_PROPERTY_TYPE_CARDINAL = 3
|
||||||
|
|
||||||
|
} BDF_PropertyType;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* BDF_Property
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to a @BDF_PropertyRec structure to model a given BDF/PCF
|
||||||
|
* property.
|
||||||
|
*/
|
||||||
|
typedef struct BDF_PropertyRec_* BDF_Property;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* BDF_PropertyRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This structure models a given BDF/PCF property.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* type ::
|
||||||
|
* The property type.
|
||||||
|
*
|
||||||
|
* u.atom ::
|
||||||
|
* The atom string, if type is @BDF_PROPERTY_TYPE_ATOM. May be
|
||||||
|
* `NULL`, indicating an empty string.
|
||||||
|
*
|
||||||
|
* u.integer ::
|
||||||
|
* A signed integer, if type is @BDF_PROPERTY_TYPE_INTEGER.
|
||||||
|
*
|
||||||
|
* u.cardinal ::
|
||||||
|
* An unsigned integer, if type is @BDF_PROPERTY_TYPE_CARDINAL.
|
||||||
|
*/
|
||||||
|
typedef struct BDF_PropertyRec_
|
||||||
|
{
|
||||||
|
BDF_PropertyType type;
|
||||||
|
union {
|
||||||
|
const char* atom;
|
||||||
|
FT_Int32 integer;
|
||||||
|
FT_UInt32 cardinal;
|
||||||
|
|
||||||
|
} u;
|
||||||
|
|
||||||
|
} BDF_PropertyRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_BDF_Charset_ID
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve a BDF font character set identity, according to the BDF
|
||||||
|
* specification.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* acharset_encoding ::
|
||||||
|
* Charset encoding, as a C~string, owned by the face.
|
||||||
|
*
|
||||||
|
* acharset_registry ::
|
||||||
|
* Charset registry, as a C~string, owned by the face.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function only works with BDF faces, returning an error otherwise.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_BDF_Charset_ID( FT_Face face,
|
||||||
|
const char* *acharset_encoding,
|
||||||
|
const char* *acharset_registry );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_BDF_Property
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve a BDF property from a BDF or PCF font file.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* name ::
|
||||||
|
* The property name.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* aproperty ::
|
||||||
|
* The property.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function works with BDF _and_ PCF fonts. It returns an error
|
||||||
|
* otherwise. It also returns an error if the property is not in the
|
||||||
|
* font.
|
||||||
|
*
|
||||||
|
* A 'property' is a either key-value pair within the STARTPROPERTIES
|
||||||
|
* ... ENDPROPERTIES block of a BDF font or a key-value pair from the
|
||||||
|
* `info->props` array within a `FontRec` structure of a PCF font.
|
||||||
|
*
|
||||||
|
* Integer properties are always stored as 'signed' within PCF fonts;
|
||||||
|
* consequently, @BDF_PROPERTY_TYPE_CARDINAL is a possible return value
|
||||||
|
* for BDF fonts only.
|
||||||
|
*
|
||||||
|
* In case of error, `aproperty->type` is always set to
|
||||||
|
* @BDF_PROPERTY_TYPE_NONE.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_BDF_Property( FT_Face face,
|
||||||
|
const char* prop_name,
|
||||||
|
BDF_PropertyRec *aproperty );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTBDF_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,329 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftbitmap.h
|
||||||
|
*
|
||||||
|
* FreeType utility functions for bitmaps (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2004-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTBITMAP_H_
|
||||||
|
#define FTBITMAP_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
#include <freetype/ftcolor.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* bitmap_handling
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Bitmap Handling
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Handling FT_Bitmap objects.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains functions for handling @FT_Bitmap objects,
|
||||||
|
* automatically adjusting the target's bitmap buffer size as needed.
|
||||||
|
*
|
||||||
|
* Note that none of the functions changes the bitmap's 'flow' (as
|
||||||
|
* indicated by the sign of the `pitch` field in @FT_Bitmap).
|
||||||
|
*
|
||||||
|
* To set the flow, assign an appropriate positive or negative value to
|
||||||
|
* the `pitch` field of the target @FT_Bitmap object after calling
|
||||||
|
* @FT_Bitmap_Init but before calling any of the other functions
|
||||||
|
* described here.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Bitmap_Init
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Initialize a pointer to an @FT_Bitmap structure.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* abitmap ::
|
||||||
|
* A pointer to the bitmap structure.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* A deprecated name for the same function is `FT_Bitmap_New`.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Bitmap_Init( FT_Bitmap *abitmap );
|
||||||
|
|
||||||
|
|
||||||
|
/* deprecated */
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Bitmap_New( FT_Bitmap *abitmap );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Bitmap_Copy
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Copy a bitmap into another one.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to a library object.
|
||||||
|
*
|
||||||
|
* source ::
|
||||||
|
* A handle to the source bitmap.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* target ::
|
||||||
|
* A handle to the target bitmap.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* `source->buffer` and `target->buffer` must neither be equal nor
|
||||||
|
* overlap.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Bitmap_Copy( FT_Library library,
|
||||||
|
const FT_Bitmap *source,
|
||||||
|
FT_Bitmap *target );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Bitmap_Embolden
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Embolden a bitmap. The new bitmap will be about `xStrength` pixels
|
||||||
|
* wider and `yStrength` pixels higher. The left and bottom borders are
|
||||||
|
* kept unchanged.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to a library object.
|
||||||
|
*
|
||||||
|
* xStrength ::
|
||||||
|
* How strong the glyph is emboldened horizontally. Expressed in 26.6
|
||||||
|
* pixel format.
|
||||||
|
*
|
||||||
|
* yStrength ::
|
||||||
|
* How strong the glyph is emboldened vertically. Expressed in 26.6
|
||||||
|
* pixel format.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* bitmap ::
|
||||||
|
* A handle to the target bitmap.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The current implementation restricts `xStrength` to be less than or
|
||||||
|
* equal to~8 if bitmap is of pixel_mode @FT_PIXEL_MODE_MONO.
|
||||||
|
*
|
||||||
|
* If you want to embolden the bitmap owned by a @FT_GlyphSlotRec, you
|
||||||
|
* should call @FT_GlyphSlot_Own_Bitmap on the slot first.
|
||||||
|
*
|
||||||
|
* Bitmaps in @FT_PIXEL_MODE_GRAY2 and @FT_PIXEL_MODE_GRAY@ format are
|
||||||
|
* converted to @FT_PIXEL_MODE_GRAY format (i.e., 8bpp).
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Bitmap_Embolden( FT_Library library,
|
||||||
|
FT_Bitmap* bitmap,
|
||||||
|
FT_Pos xStrength,
|
||||||
|
FT_Pos yStrength );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Bitmap_Convert
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Convert a bitmap object with depth 1bpp, 2bpp, 4bpp, 8bpp or 32bpp to
|
||||||
|
* a bitmap object with depth 8bpp, making the number of used bytes per
|
||||||
|
* line (a.k.a. the 'pitch') a multiple of `alignment`.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to a library object.
|
||||||
|
*
|
||||||
|
* source ::
|
||||||
|
* The source bitmap.
|
||||||
|
*
|
||||||
|
* alignment ::
|
||||||
|
* The pitch of the bitmap is a multiple of this argument. Common
|
||||||
|
* values are 1, 2, or 4.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* target ::
|
||||||
|
* The target bitmap.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* It is possible to call @FT_Bitmap_Convert multiple times without
|
||||||
|
* calling @FT_Bitmap_Done (the memory is simply reallocated).
|
||||||
|
*
|
||||||
|
* Use @FT_Bitmap_Done to finally remove the bitmap object.
|
||||||
|
*
|
||||||
|
* The `library` argument is taken to have access to FreeType's memory
|
||||||
|
* handling functions.
|
||||||
|
*
|
||||||
|
* `source->buffer` and `target->buffer` must neither be equal nor
|
||||||
|
* overlap.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Bitmap_Convert( FT_Library library,
|
||||||
|
const FT_Bitmap *source,
|
||||||
|
FT_Bitmap *target,
|
||||||
|
FT_Int alignment );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Bitmap_Blend
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Blend a bitmap onto another bitmap, using a given color.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to a library object.
|
||||||
|
*
|
||||||
|
* source ::
|
||||||
|
* The source bitmap, which can have any @FT_Pixel_Mode format.
|
||||||
|
*
|
||||||
|
* source_offset ::
|
||||||
|
* The offset vector to the upper left corner of the source bitmap in
|
||||||
|
* 26.6 pixel format. It should represent an integer offset; the
|
||||||
|
* function will set the lowest six bits to zero to enforce that.
|
||||||
|
*
|
||||||
|
* color ::
|
||||||
|
* The color used to draw `source` onto `target`.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* target ::
|
||||||
|
* A handle to an `FT_Bitmap` object. It should be either initialized
|
||||||
|
* as empty with a call to @FT_Bitmap_Init, or it should be of type
|
||||||
|
* @FT_PIXEL_MODE_BGRA.
|
||||||
|
*
|
||||||
|
* atarget_offset ::
|
||||||
|
* The offset vector to the upper left corner of the target bitmap in
|
||||||
|
* 26.6 pixel format. It should represent an integer offset; the
|
||||||
|
* function will set the lowest six bits to zero to enforce that.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function doesn't perform clipping.
|
||||||
|
*
|
||||||
|
* The bitmap in `target` gets allocated or reallocated as needed; the
|
||||||
|
* vector `atarget_offset` is updated accordingly.
|
||||||
|
*
|
||||||
|
* In case of allocation or reallocation, the bitmap's pitch is set to
|
||||||
|
* `4 * width`. Both `source` and `target` must have the same bitmap
|
||||||
|
* flow (as indicated by the sign of the `pitch` field).
|
||||||
|
*
|
||||||
|
* `source->buffer` and `target->buffer` must neither be equal nor
|
||||||
|
* overlap.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.10
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Bitmap_Blend( FT_Library library,
|
||||||
|
const FT_Bitmap* source,
|
||||||
|
const FT_Vector source_offset,
|
||||||
|
FT_Bitmap* target,
|
||||||
|
FT_Vector *atarget_offset,
|
||||||
|
FT_Color color );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_GlyphSlot_Own_Bitmap
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Make sure that a glyph slot owns `slot->bitmap`.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* slot ::
|
||||||
|
* The glyph slot.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function is to be used in combination with @FT_Bitmap_Embolden.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_GlyphSlot_Own_Bitmap( FT_GlyphSlot slot );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Bitmap_Done
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Destroy a bitmap object initialized with @FT_Bitmap_Init.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to a library object.
|
||||||
|
*
|
||||||
|
* bitmap ::
|
||||||
|
* The bitmap object to be freed.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The `library` argument is taken to have access to FreeType's memory
|
||||||
|
* handling functions.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Bitmap_Done( FT_Library library,
|
||||||
|
FT_Bitmap *bitmap );
|
||||||
|
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTBITMAP_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,102 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftbzip2.h
|
||||||
|
*
|
||||||
|
* Bzip2-compressed stream support.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2010-2022 by
|
||||||
|
* Joel Klinghed.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTBZIP2_H_
|
||||||
|
#define FTBZIP2_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* bzip2
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* BZIP2 Streams
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Using bzip2-compressed font files.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* In certain builds of the library, bzip2 compression recognition is
|
||||||
|
* automatically handled when calling @FT_New_Face or @FT_Open_Face.
|
||||||
|
* This means that if no font driver is capable of handling the raw
|
||||||
|
* compressed file, the library will try to open a bzip2 compressed
|
||||||
|
* stream from it and re-open the face with it.
|
||||||
|
*
|
||||||
|
* The stream implementation is very basic and resets the decompression
|
||||||
|
* process each time seeking backwards is needed within the stream,
|
||||||
|
* which significantly undermines the performance.
|
||||||
|
*
|
||||||
|
* This section contains the declaration of Bzip2-specific functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stream_OpenBzip2
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Open a new stream to parse bzip2-compressed font files. This is
|
||||||
|
* mainly used to support the compressed `*.pcf.bz2` fonts that come with
|
||||||
|
* XFree86.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stream ::
|
||||||
|
* The target embedding stream.
|
||||||
|
*
|
||||||
|
* source ::
|
||||||
|
* The source stream.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The source stream must be opened _before_ calling this function.
|
||||||
|
*
|
||||||
|
* Calling the internal function `FT_Stream_Close` on the new stream will
|
||||||
|
* **not** call `FT_Stream_Close` on the source stream. None of the
|
||||||
|
* stream objects will be released to the heap.
|
||||||
|
*
|
||||||
|
* This function may return `FT_Err_Unimplemented_Feature` if your build
|
||||||
|
* of FreeType was not compiled with bzip2 support.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stream_OpenBzip2( FT_Stream stream,
|
||||||
|
FT_Stream source );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTBZIP2_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,149 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* This file defines the structure of the FreeType reference.
|
||||||
|
* It is used by the python script that generates the HTML files.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @chapter:
|
||||||
|
* general_remarks
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* General Remarks
|
||||||
|
*
|
||||||
|
* @sections:
|
||||||
|
* preamble
|
||||||
|
* header_inclusion
|
||||||
|
* user_allocation
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @chapter:
|
||||||
|
* core_api
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Core API
|
||||||
|
*
|
||||||
|
* @sections:
|
||||||
|
* version
|
||||||
|
* basic_types
|
||||||
|
* base_interface
|
||||||
|
* glyph_variants
|
||||||
|
* color_management
|
||||||
|
* layer_management
|
||||||
|
* glyph_management
|
||||||
|
* mac_specific
|
||||||
|
* sizes_management
|
||||||
|
* header_file_macros
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @chapter:
|
||||||
|
* format_specific
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Format-Specific API
|
||||||
|
*
|
||||||
|
* @sections:
|
||||||
|
* multiple_masters
|
||||||
|
* truetype_tables
|
||||||
|
* type1_tables
|
||||||
|
* sfnt_names
|
||||||
|
* bdf_fonts
|
||||||
|
* cid_fonts
|
||||||
|
* pfr_fonts
|
||||||
|
* winfnt_fonts
|
||||||
|
* svg_fonts
|
||||||
|
* font_formats
|
||||||
|
* gasp_table
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @chapter:
|
||||||
|
* module_specific
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Controlling FreeType Modules
|
||||||
|
*
|
||||||
|
* @sections:
|
||||||
|
* auto_hinter
|
||||||
|
* cff_driver
|
||||||
|
* t1_cid_driver
|
||||||
|
* tt_driver
|
||||||
|
* pcf_driver
|
||||||
|
* ot_svg_driver
|
||||||
|
* properties
|
||||||
|
* parameter_tags
|
||||||
|
* lcd_rendering
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @chapter:
|
||||||
|
* cache_subsystem
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Cache Sub-System
|
||||||
|
*
|
||||||
|
* @sections:
|
||||||
|
* cache_subsystem
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @chapter:
|
||||||
|
* support_api
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Support API
|
||||||
|
*
|
||||||
|
* @sections:
|
||||||
|
* computations
|
||||||
|
* list_processing
|
||||||
|
* outline_processing
|
||||||
|
* quick_advance
|
||||||
|
* bitmap_handling
|
||||||
|
* raster
|
||||||
|
* glyph_stroker
|
||||||
|
* system_interface
|
||||||
|
* module_management
|
||||||
|
* gzip
|
||||||
|
* lzw
|
||||||
|
* bzip2
|
||||||
|
* debugging_apis
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @chapter:
|
||||||
|
* error_codes
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Error Codes
|
||||||
|
*
|
||||||
|
* @sections:
|
||||||
|
* error_enumerations
|
||||||
|
* error_code_values
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,167 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftcid.h
|
||||||
|
*
|
||||||
|
* FreeType API for accessing CID font information (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2007-2022 by
|
||||||
|
* Dereg Clegg and Michael Toftdal.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTCID_H_
|
||||||
|
#define FTCID_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* cid_fonts
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* CID Fonts
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* CID-keyed font-specific API.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the declaration of CID-keyed font-specific
|
||||||
|
* functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_CID_Registry_Ordering_Supplement
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the Registry/Ordering/Supplement triple (also known as the
|
||||||
|
* "R/O/S") from a CID-keyed font.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* registry ::
|
||||||
|
* The registry, as a C~string, owned by the face.
|
||||||
|
*
|
||||||
|
* ordering ::
|
||||||
|
* The ordering, as a C~string, owned by the face.
|
||||||
|
*
|
||||||
|
* supplement ::
|
||||||
|
* The supplement.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function only works with CID faces, returning an error
|
||||||
|
* otherwise.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.3.6
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_CID_Registry_Ordering_Supplement( FT_Face face,
|
||||||
|
const char* *registry,
|
||||||
|
const char* *ordering,
|
||||||
|
FT_Int *supplement );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_CID_Is_Internally_CID_Keyed
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the type of the input face, CID keyed or not. In contrast
|
||||||
|
* to the @FT_IS_CID_KEYED macro this function returns successfully also
|
||||||
|
* for CID-keyed fonts in an SFNT wrapper.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* is_cid ::
|
||||||
|
* The type of the face as an @FT_Bool.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function only works with CID faces and OpenType fonts, returning
|
||||||
|
* an error otherwise.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.3.9
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_CID_Is_Internally_CID_Keyed( FT_Face face,
|
||||||
|
FT_Bool *is_cid );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_CID_From_Glyph_Index
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the CID of the input glyph index.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* glyph_index ::
|
||||||
|
* The input glyph index.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* cid ::
|
||||||
|
* The CID as an @FT_UInt.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function only works with CID faces and OpenType fonts, returning
|
||||||
|
* an error otherwise.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.3.9
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_CID_From_Glyph_Index( FT_Face face,
|
||||||
|
FT_UInt glyph_index,
|
||||||
|
FT_UInt *cid );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTCID_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,283 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* fterrdef.h
|
||||||
|
*
|
||||||
|
* FreeType error codes (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* error_code_values
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Error Code Values
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* All possible error codes returned by FreeType functions.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The list below is taken verbatim from the file `fterrdef.h` (loaded
|
||||||
|
* automatically by including `FT_FREETYPE_H`). The first argument of the
|
||||||
|
* `FT_ERROR_DEF_` macro is the error label; by default, the prefix
|
||||||
|
* `FT_Err_` gets added so that you get error names like
|
||||||
|
* `FT_Err_Cannot_Open_Resource`. The second argument is the error code,
|
||||||
|
* and the last argument an error string, which is not used by FreeType.
|
||||||
|
*
|
||||||
|
* Within your application you should **only** use error names and
|
||||||
|
* **never** its numeric values! The latter might (and actually do)
|
||||||
|
* change in forthcoming FreeType versions.
|
||||||
|
*
|
||||||
|
* Macro `FT_NOERRORDEF_` defines `FT_Err_Ok`, which is always zero. See
|
||||||
|
* the 'Error Enumerations' subsection how to automatically generate a
|
||||||
|
* list of error strings.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_Err_XXX
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* generic errors */
|
||||||
|
|
||||||
|
FT_NOERRORDEF_( Ok, 0x00,
|
||||||
|
"no error" )
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Cannot_Open_Resource, 0x01,
|
||||||
|
"cannot open resource" )
|
||||||
|
FT_ERRORDEF_( Unknown_File_Format, 0x02,
|
||||||
|
"unknown file format" )
|
||||||
|
FT_ERRORDEF_( Invalid_File_Format, 0x03,
|
||||||
|
"broken file" )
|
||||||
|
FT_ERRORDEF_( Invalid_Version, 0x04,
|
||||||
|
"invalid FreeType version" )
|
||||||
|
FT_ERRORDEF_( Lower_Module_Version, 0x05,
|
||||||
|
"module version is too low" )
|
||||||
|
FT_ERRORDEF_( Invalid_Argument, 0x06,
|
||||||
|
"invalid argument" )
|
||||||
|
FT_ERRORDEF_( Unimplemented_Feature, 0x07,
|
||||||
|
"unimplemented feature" )
|
||||||
|
FT_ERRORDEF_( Invalid_Table, 0x08,
|
||||||
|
"broken table" )
|
||||||
|
FT_ERRORDEF_( Invalid_Offset, 0x09,
|
||||||
|
"broken offset within table" )
|
||||||
|
FT_ERRORDEF_( Array_Too_Large, 0x0A,
|
||||||
|
"array allocation size too large" )
|
||||||
|
FT_ERRORDEF_( Missing_Module, 0x0B,
|
||||||
|
"missing module" )
|
||||||
|
FT_ERRORDEF_( Missing_Property, 0x0C,
|
||||||
|
"missing property" )
|
||||||
|
|
||||||
|
/* glyph/character errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Invalid_Glyph_Index, 0x10,
|
||||||
|
"invalid glyph index" )
|
||||||
|
FT_ERRORDEF_( Invalid_Character_Code, 0x11,
|
||||||
|
"invalid character code" )
|
||||||
|
FT_ERRORDEF_( Invalid_Glyph_Format, 0x12,
|
||||||
|
"unsupported glyph image format" )
|
||||||
|
FT_ERRORDEF_( Cannot_Render_Glyph, 0x13,
|
||||||
|
"cannot render this glyph format" )
|
||||||
|
FT_ERRORDEF_( Invalid_Outline, 0x14,
|
||||||
|
"invalid outline" )
|
||||||
|
FT_ERRORDEF_( Invalid_Composite, 0x15,
|
||||||
|
"invalid composite glyph" )
|
||||||
|
FT_ERRORDEF_( Too_Many_Hints, 0x16,
|
||||||
|
"too many hints" )
|
||||||
|
FT_ERRORDEF_( Invalid_Pixel_Size, 0x17,
|
||||||
|
"invalid pixel size" )
|
||||||
|
FT_ERRORDEF_( Invalid_SVG_Document, 0x18,
|
||||||
|
"invalid SVG document" )
|
||||||
|
|
||||||
|
/* handle errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Invalid_Handle, 0x20,
|
||||||
|
"invalid object handle" )
|
||||||
|
FT_ERRORDEF_( Invalid_Library_Handle, 0x21,
|
||||||
|
"invalid library handle" )
|
||||||
|
FT_ERRORDEF_( Invalid_Driver_Handle, 0x22,
|
||||||
|
"invalid module handle" )
|
||||||
|
FT_ERRORDEF_( Invalid_Face_Handle, 0x23,
|
||||||
|
"invalid face handle" )
|
||||||
|
FT_ERRORDEF_( Invalid_Size_Handle, 0x24,
|
||||||
|
"invalid size handle" )
|
||||||
|
FT_ERRORDEF_( Invalid_Slot_Handle, 0x25,
|
||||||
|
"invalid glyph slot handle" )
|
||||||
|
FT_ERRORDEF_( Invalid_CharMap_Handle, 0x26,
|
||||||
|
"invalid charmap handle" )
|
||||||
|
FT_ERRORDEF_( Invalid_Cache_Handle, 0x27,
|
||||||
|
"invalid cache manager handle" )
|
||||||
|
FT_ERRORDEF_( Invalid_Stream_Handle, 0x28,
|
||||||
|
"invalid stream handle" )
|
||||||
|
|
||||||
|
/* driver errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Too_Many_Drivers, 0x30,
|
||||||
|
"too many modules" )
|
||||||
|
FT_ERRORDEF_( Too_Many_Extensions, 0x31,
|
||||||
|
"too many extensions" )
|
||||||
|
|
||||||
|
/* memory errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Out_Of_Memory, 0x40,
|
||||||
|
"out of memory" )
|
||||||
|
FT_ERRORDEF_( Unlisted_Object, 0x41,
|
||||||
|
"unlisted object" )
|
||||||
|
|
||||||
|
/* stream errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Cannot_Open_Stream, 0x51,
|
||||||
|
"cannot open stream" )
|
||||||
|
FT_ERRORDEF_( Invalid_Stream_Seek, 0x52,
|
||||||
|
"invalid stream seek" )
|
||||||
|
FT_ERRORDEF_( Invalid_Stream_Skip, 0x53,
|
||||||
|
"invalid stream skip" )
|
||||||
|
FT_ERRORDEF_( Invalid_Stream_Read, 0x54,
|
||||||
|
"invalid stream read" )
|
||||||
|
FT_ERRORDEF_( Invalid_Stream_Operation, 0x55,
|
||||||
|
"invalid stream operation" )
|
||||||
|
FT_ERRORDEF_( Invalid_Frame_Operation, 0x56,
|
||||||
|
"invalid frame operation" )
|
||||||
|
FT_ERRORDEF_( Nested_Frame_Access, 0x57,
|
||||||
|
"nested frame access" )
|
||||||
|
FT_ERRORDEF_( Invalid_Frame_Read, 0x58,
|
||||||
|
"invalid frame read" )
|
||||||
|
|
||||||
|
/* raster errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Raster_Uninitialized, 0x60,
|
||||||
|
"raster uninitialized" )
|
||||||
|
FT_ERRORDEF_( Raster_Corrupted, 0x61,
|
||||||
|
"raster corrupted" )
|
||||||
|
FT_ERRORDEF_( Raster_Overflow, 0x62,
|
||||||
|
"raster overflow" )
|
||||||
|
FT_ERRORDEF_( Raster_Negative_Height, 0x63,
|
||||||
|
"negative height while rastering" )
|
||||||
|
|
||||||
|
/* cache errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Too_Many_Caches, 0x70,
|
||||||
|
"too many registered caches" )
|
||||||
|
|
||||||
|
/* TrueType and SFNT errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Invalid_Opcode, 0x80,
|
||||||
|
"invalid opcode" )
|
||||||
|
FT_ERRORDEF_( Too_Few_Arguments, 0x81,
|
||||||
|
"too few arguments" )
|
||||||
|
FT_ERRORDEF_( Stack_Overflow, 0x82,
|
||||||
|
"stack overflow" )
|
||||||
|
FT_ERRORDEF_( Code_Overflow, 0x83,
|
||||||
|
"code overflow" )
|
||||||
|
FT_ERRORDEF_( Bad_Argument, 0x84,
|
||||||
|
"bad argument" )
|
||||||
|
FT_ERRORDEF_( Divide_By_Zero, 0x85,
|
||||||
|
"division by zero" )
|
||||||
|
FT_ERRORDEF_( Invalid_Reference, 0x86,
|
||||||
|
"invalid reference" )
|
||||||
|
FT_ERRORDEF_( Debug_OpCode, 0x87,
|
||||||
|
"found debug opcode" )
|
||||||
|
FT_ERRORDEF_( ENDF_In_Exec_Stream, 0x88,
|
||||||
|
"found ENDF opcode in execution stream" )
|
||||||
|
FT_ERRORDEF_( Nested_DEFS, 0x89,
|
||||||
|
"nested DEFS" )
|
||||||
|
FT_ERRORDEF_( Invalid_CodeRange, 0x8A,
|
||||||
|
"invalid code range" )
|
||||||
|
FT_ERRORDEF_( Execution_Too_Long, 0x8B,
|
||||||
|
"execution context too long" )
|
||||||
|
FT_ERRORDEF_( Too_Many_Function_Defs, 0x8C,
|
||||||
|
"too many function definitions" )
|
||||||
|
FT_ERRORDEF_( Too_Many_Instruction_Defs, 0x8D,
|
||||||
|
"too many instruction definitions" )
|
||||||
|
FT_ERRORDEF_( Table_Missing, 0x8E,
|
||||||
|
"SFNT font table missing" )
|
||||||
|
FT_ERRORDEF_( Horiz_Header_Missing, 0x8F,
|
||||||
|
"horizontal header (hhea) table missing" )
|
||||||
|
FT_ERRORDEF_( Locations_Missing, 0x90,
|
||||||
|
"locations (loca) table missing" )
|
||||||
|
FT_ERRORDEF_( Name_Table_Missing, 0x91,
|
||||||
|
"name table missing" )
|
||||||
|
FT_ERRORDEF_( CMap_Table_Missing, 0x92,
|
||||||
|
"character map (cmap) table missing" )
|
||||||
|
FT_ERRORDEF_( Hmtx_Table_Missing, 0x93,
|
||||||
|
"horizontal metrics (hmtx) table missing" )
|
||||||
|
FT_ERRORDEF_( Post_Table_Missing, 0x94,
|
||||||
|
"PostScript (post) table missing" )
|
||||||
|
FT_ERRORDEF_( Invalid_Horiz_Metrics, 0x95,
|
||||||
|
"invalid horizontal metrics" )
|
||||||
|
FT_ERRORDEF_( Invalid_CharMap_Format, 0x96,
|
||||||
|
"invalid character map (cmap) format" )
|
||||||
|
FT_ERRORDEF_( Invalid_PPem, 0x97,
|
||||||
|
"invalid ppem value" )
|
||||||
|
FT_ERRORDEF_( Invalid_Vert_Metrics, 0x98,
|
||||||
|
"invalid vertical metrics" )
|
||||||
|
FT_ERRORDEF_( Could_Not_Find_Context, 0x99,
|
||||||
|
"could not find context" )
|
||||||
|
FT_ERRORDEF_( Invalid_Post_Table_Format, 0x9A,
|
||||||
|
"invalid PostScript (post) table format" )
|
||||||
|
FT_ERRORDEF_( Invalid_Post_Table, 0x9B,
|
||||||
|
"invalid PostScript (post) table" )
|
||||||
|
FT_ERRORDEF_( DEF_In_Glyf_Bytecode, 0x9C,
|
||||||
|
"found FDEF or IDEF opcode in glyf bytecode" )
|
||||||
|
FT_ERRORDEF_( Missing_Bitmap, 0x9D,
|
||||||
|
"missing bitmap in strike" )
|
||||||
|
FT_ERRORDEF_( Missing_SVG_Hooks, 0x9E,
|
||||||
|
"SVG hooks have not been set" )
|
||||||
|
|
||||||
|
/* CFF, CID, and Type 1 errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Syntax_Error, 0xA0,
|
||||||
|
"opcode syntax error" )
|
||||||
|
FT_ERRORDEF_( Stack_Underflow, 0xA1,
|
||||||
|
"argument stack underflow" )
|
||||||
|
FT_ERRORDEF_( Ignore, 0xA2,
|
||||||
|
"ignore" )
|
||||||
|
FT_ERRORDEF_( No_Unicode_Glyph_Name, 0xA3,
|
||||||
|
"no Unicode glyph name found" )
|
||||||
|
FT_ERRORDEF_( Glyph_Too_Big, 0xA4,
|
||||||
|
"glyph too big for hinting" )
|
||||||
|
|
||||||
|
/* BDF errors */
|
||||||
|
|
||||||
|
FT_ERRORDEF_( Missing_Startfont_Field, 0xB0,
|
||||||
|
"`STARTFONT' field missing" )
|
||||||
|
FT_ERRORDEF_( Missing_Font_Field, 0xB1,
|
||||||
|
"`FONT' field missing" )
|
||||||
|
FT_ERRORDEF_( Missing_Size_Field, 0xB2,
|
||||||
|
"`SIZE' field missing" )
|
||||||
|
FT_ERRORDEF_( Missing_Fontboundingbox_Field, 0xB3,
|
||||||
|
"`FONTBOUNDINGBOX' field missing" )
|
||||||
|
FT_ERRORDEF_( Missing_Chars_Field, 0xB4,
|
||||||
|
"`CHARS' field missing" )
|
||||||
|
FT_ERRORDEF_( Missing_Startchar_Field, 0xB5,
|
||||||
|
"`STARTCHAR' field missing" )
|
||||||
|
FT_ERRORDEF_( Missing_Encoding_Field, 0xB6,
|
||||||
|
"`ENCODING' field missing" )
|
||||||
|
FT_ERRORDEF_( Missing_Bbx_Field, 0xB7,
|
||||||
|
"`BBX' field missing" )
|
||||||
|
FT_ERRORDEF_( Bbx_Too_Big, 0xB8,
|
||||||
|
"`BBX' too big" )
|
||||||
|
FT_ERRORDEF_( Corrupted_Font_Header, 0xB9,
|
||||||
|
"Font header corrupted or missing fields" )
|
||||||
|
FT_ERRORDEF_( Corrupted_Font_Glyphs, 0xBA,
|
||||||
|
"Font glyphs corrupted or missing fields" )
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,296 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* fterrors.h
|
||||||
|
*
|
||||||
|
* FreeType error code handling (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* error_enumerations
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Error Enumerations
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* How to handle errors and error strings.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The header file `fterrors.h` (which is automatically included by
|
||||||
|
* `freetype.h` defines the handling of FreeType's enumeration
|
||||||
|
* constants. It can also be used to generate error message strings
|
||||||
|
* with a small macro trick explained below.
|
||||||
|
*
|
||||||
|
* **Error Formats**
|
||||||
|
*
|
||||||
|
* The configuration macro `FT_CONFIG_OPTION_USE_MODULE_ERRORS` can be
|
||||||
|
* defined in `ftoption.h` in order to make the higher byte indicate the
|
||||||
|
* module where the error has happened (this is not compatible with
|
||||||
|
* standard builds of FreeType~2, however). See the file `ftmoderr.h`
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* **Error Message Strings**
|
||||||
|
*
|
||||||
|
* Error definitions are set up with special macros that allow client
|
||||||
|
* applications to build a table of error message strings. The strings
|
||||||
|
* are not included in a normal build of FreeType~2 to save space (most
|
||||||
|
* client applications do not use them).
|
||||||
|
*
|
||||||
|
* To do so, you have to define the following macros before including
|
||||||
|
* this file.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_ERROR_START_LIST
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* This macro is called before anything else to define the start of the
|
||||||
|
* error list. It is followed by several `FT_ERROR_DEF` calls.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_ERROR_DEF( e, v, s )
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* This macro is called to define one single error. 'e' is the error
|
||||||
|
* code identifier (e.g., `Invalid_Argument`), 'v' is the error's
|
||||||
|
* numerical value, and 's' is the corresponding error string.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_ERROR_END_LIST
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* This macro ends the list.
|
||||||
|
*
|
||||||
|
* Additionally, you have to undefine `FTERRORS_H_` before #including
|
||||||
|
* this file.
|
||||||
|
*
|
||||||
|
* Here is a simple example.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* #undef FTERRORS_H_
|
||||||
|
* #define FT_ERRORDEF( e, v, s ) { e, s },
|
||||||
|
* #define FT_ERROR_START_LIST {
|
||||||
|
* #define FT_ERROR_END_LIST { 0, NULL } };
|
||||||
|
*
|
||||||
|
* const struct
|
||||||
|
* {
|
||||||
|
* int err_code;
|
||||||
|
* const char* err_msg;
|
||||||
|
* } ft_errors[] =
|
||||||
|
*
|
||||||
|
* #include <freetype/fterrors.h>
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* An alternative to using an array is a switch statement.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* #undef FTERRORS_H_
|
||||||
|
* #define FT_ERROR_START_LIST switch ( error_code ) {
|
||||||
|
* #define FT_ERRORDEF( e, v, s ) case v: return s;
|
||||||
|
* #define FT_ERROR_END_LIST }
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* If you use `FT_CONFIG_OPTION_USE_MODULE_ERRORS`, `error_code` should
|
||||||
|
* be replaced with `FT_ERROR_BASE(error_code)` in the last example.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
/* In previous FreeType versions we used `__FTERRORS_H__`. However, */
|
||||||
|
/* using two successive underscores in a non-system symbol name */
|
||||||
|
/* violates the C (and C++) standard, so it was changed to the */
|
||||||
|
/* current form. In spite of this, we have to make */
|
||||||
|
/* */
|
||||||
|
/* ``` */
|
||||||
|
/* #undefine __FTERRORS_H__ */
|
||||||
|
/* ``` */
|
||||||
|
/* */
|
||||||
|
/* work for backward compatibility. */
|
||||||
|
/* */
|
||||||
|
#if !( defined( FTERRORS_H_ ) && defined ( __FTERRORS_H__ ) )
|
||||||
|
#define FTERRORS_H_
|
||||||
|
#define __FTERRORS_H__
|
||||||
|
|
||||||
|
|
||||||
|
/* include module base error codes */
|
||||||
|
#include <freetype/ftmoderr.h>
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
/***** *****/
|
||||||
|
/***** SETUP MACROS *****/
|
||||||
|
/***** *****/
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#undef FT_NEED_EXTERN_C
|
||||||
|
|
||||||
|
|
||||||
|
/* FT_ERR_PREFIX is used as a prefix for error identifiers. */
|
||||||
|
/* By default, we use `FT_Err_`. */
|
||||||
|
/* */
|
||||||
|
#ifndef FT_ERR_PREFIX
|
||||||
|
#define FT_ERR_PREFIX FT_Err_
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* FT_ERR_BASE is used as the base for module-specific errors. */
|
||||||
|
/* */
|
||||||
|
#ifdef FT_CONFIG_OPTION_USE_MODULE_ERRORS
|
||||||
|
|
||||||
|
#ifndef FT_ERR_BASE
|
||||||
|
#define FT_ERR_BASE FT_Mod_Err_Base
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#undef FT_ERR_BASE
|
||||||
|
#define FT_ERR_BASE 0
|
||||||
|
|
||||||
|
#endif /* FT_CONFIG_OPTION_USE_MODULE_ERRORS */
|
||||||
|
|
||||||
|
|
||||||
|
/* If FT_ERRORDEF is not defined, we need to define a simple */
|
||||||
|
/* enumeration type. */
|
||||||
|
/* */
|
||||||
|
#ifndef FT_ERRORDEF
|
||||||
|
|
||||||
|
#define FT_INCLUDE_ERR_PROTOS
|
||||||
|
|
||||||
|
#define FT_ERRORDEF( e, v, s ) e = v,
|
||||||
|
#define FT_ERROR_START_LIST enum {
|
||||||
|
#define FT_ERROR_END_LIST FT_ERR_CAT( FT_ERR_PREFIX, Max ) };
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define FT_NEED_EXTERN_C
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* !FT_ERRORDEF */
|
||||||
|
|
||||||
|
|
||||||
|
/* this macro is used to define an error */
|
||||||
|
#define FT_ERRORDEF_( e, v, s ) \
|
||||||
|
FT_ERRORDEF( FT_ERR_CAT( FT_ERR_PREFIX, e ), v + FT_ERR_BASE, s )
|
||||||
|
|
||||||
|
/* this is only used for <module>_Err_Ok, which must be 0! */
|
||||||
|
#define FT_NOERRORDEF_( e, v, s ) \
|
||||||
|
FT_ERRORDEF( FT_ERR_CAT( FT_ERR_PREFIX, e ), v, s )
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_ERROR_START_LIST
|
||||||
|
FT_ERROR_START_LIST
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* now include the error codes */
|
||||||
|
#include <freetype/fterrdef.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_ERROR_END_LIST
|
||||||
|
FT_ERROR_END_LIST
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
/***** *****/
|
||||||
|
/***** SIMPLE CLEANUP *****/
|
||||||
|
/***** *****/
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
|
||||||
|
#ifdef FT_NEED_EXTERN_C
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef FT_ERROR_START_LIST
|
||||||
|
#undef FT_ERROR_END_LIST
|
||||||
|
|
||||||
|
#undef FT_ERRORDEF
|
||||||
|
#undef FT_ERRORDEF_
|
||||||
|
#undef FT_NOERRORDEF_
|
||||||
|
|
||||||
|
#undef FT_NEED_EXTERN_C
|
||||||
|
#undef FT_ERR_BASE
|
||||||
|
|
||||||
|
/* FT_ERR_PREFIX is needed internally */
|
||||||
|
#ifndef FT2_BUILD_LIBRARY
|
||||||
|
#undef FT_ERR_PREFIX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* FT_INCLUDE_ERR_PROTOS: Control whether function prototypes should be */
|
||||||
|
/* included with */
|
||||||
|
/* */
|
||||||
|
/* #include <freetype/fterrors.h> */
|
||||||
|
/* */
|
||||||
|
/* This is only true where `FT_ERRORDEF` is */
|
||||||
|
/* undefined. */
|
||||||
|
/* */
|
||||||
|
/* FT_ERR_PROTOS_DEFINED: Actual multiple-inclusion protection of */
|
||||||
|
/* `fterrors.h`. */
|
||||||
|
#ifdef FT_INCLUDE_ERR_PROTOS
|
||||||
|
#undef FT_INCLUDE_ERR_PROTOS
|
||||||
|
|
||||||
|
#ifndef FT_ERR_PROTOS_DEFINED
|
||||||
|
#define FT_ERR_PROTOS_DEFINED
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Error_String
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the description of a valid FreeType error code.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* error_code ::
|
||||||
|
* A valid FreeType error code.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* A C~string or `NULL`, if any error occurred.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* FreeType has to be compiled with `FT_CONFIG_OPTION_ERROR_STRINGS` or
|
||||||
|
* `FT_DEBUG_LEVEL_ERROR` to get meaningful descriptions.
|
||||||
|
* 'error_string' will be `NULL` otherwise.
|
||||||
|
*
|
||||||
|
* Module identification will be ignored:
|
||||||
|
*
|
||||||
|
* ```c
|
||||||
|
* strcmp( FT_Error_String( FT_Err_Unknown_File_Format ),
|
||||||
|
* FT_Error_String( BDF_Err_Unknown_File_Format ) ) == 0;
|
||||||
|
* ```
|
||||||
|
*/
|
||||||
|
FT_EXPORT( const char* )
|
||||||
|
FT_Error_String( FT_Error error_code );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* FT_ERR_PROTOS_DEFINED */
|
||||||
|
|
||||||
|
#endif /* FT_INCLUDE_ERR_PROTOS */
|
||||||
|
|
||||||
|
#endif /* !(FTERRORS_H_ && __FTERRORS_H__) */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,93 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftfntfmt.h
|
||||||
|
*
|
||||||
|
* Support functions for font formats.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTFNTFMT_H_
|
||||||
|
#define FTFNTFMT_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* font_formats
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Font Formats
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Getting the font format.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The single function in this section can be used to get the font format.
|
||||||
|
* Note that this information is not needed normally; however, there are
|
||||||
|
* special cases (like in PDF devices) where it is important to
|
||||||
|
* differentiate, in spite of FreeType's uniform API.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Font_Format
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return a string describing the format of a given face. Possible values
|
||||||
|
* are 'TrueType', 'Type~1', 'BDF', 'PCF', 'Type~42', 'CID~Type~1', 'CFF',
|
||||||
|
* 'PFR', and 'Windows~FNT'.
|
||||||
|
*
|
||||||
|
* The return value is suitable to be used as an X11 FONT_PROPERTY.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* Input face handle.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* Font format string. `NULL` in case of error.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* A deprecated name for the same function is `FT_Get_X11_Font_Format`.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( const char* )
|
||||||
|
FT_Get_Font_Format( FT_Face face );
|
||||||
|
|
||||||
|
|
||||||
|
/* deprecated */
|
||||||
|
FT_EXPORT( const char* )
|
||||||
|
FT_Get_X11_Font_Format( FT_Face face );
|
||||||
|
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTFNTFMT_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,143 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftgasp.h
|
||||||
|
*
|
||||||
|
* Access of TrueType's 'gasp' table (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2007-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTGASP_H_
|
||||||
|
#define FTGASP_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* gasp_table
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Gasp Table
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Retrieving TrueType 'gasp' table entries.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The function @FT_Get_Gasp can be used to query a TrueType or OpenType
|
||||||
|
* font for specific entries in its 'gasp' table, if any. This is mainly
|
||||||
|
* useful when implementing native TrueType hinting with the bytecode
|
||||||
|
* interpreter to duplicate the Windows text rendering results.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_GASP_XXX
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of values and/or bit-flags returned by the @FT_Get_Gasp
|
||||||
|
* function.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_GASP_NO_TABLE ::
|
||||||
|
* This special value means that there is no GASP table in this face.
|
||||||
|
* It is up to the client to decide what to do.
|
||||||
|
*
|
||||||
|
* FT_GASP_DO_GRIDFIT ::
|
||||||
|
* Grid-fitting and hinting should be performed at the specified ppem.
|
||||||
|
* This **really** means TrueType bytecode interpretation. If this bit
|
||||||
|
* is not set, no hinting gets applied.
|
||||||
|
*
|
||||||
|
* FT_GASP_DO_GRAY ::
|
||||||
|
* Anti-aliased rendering should be performed at the specified ppem.
|
||||||
|
* If not set, do monochrome rendering.
|
||||||
|
*
|
||||||
|
* FT_GASP_SYMMETRIC_SMOOTHING ::
|
||||||
|
* If set, smoothing along multiple axes must be used with ClearType.
|
||||||
|
*
|
||||||
|
* FT_GASP_SYMMETRIC_GRIDFIT ::
|
||||||
|
* Grid-fitting must be used with ClearType's symmetric smoothing.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The bit-flags `FT_GASP_DO_GRIDFIT` and `FT_GASP_DO_GRAY` are to be
|
||||||
|
* used for standard font rasterization only. Independently of that,
|
||||||
|
* `FT_GASP_SYMMETRIC_SMOOTHING` and `FT_GASP_SYMMETRIC_GRIDFIT` are to
|
||||||
|
* be used if ClearType is enabled (and `FT_GASP_DO_GRIDFIT` and
|
||||||
|
* `FT_GASP_DO_GRAY` are consequently ignored).
|
||||||
|
*
|
||||||
|
* 'ClearType' is Microsoft's implementation of LCD rendering, partly
|
||||||
|
* protected by patents.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.3.0
|
||||||
|
*/
|
||||||
|
#define FT_GASP_NO_TABLE -1
|
||||||
|
#define FT_GASP_DO_GRIDFIT 0x01
|
||||||
|
#define FT_GASP_DO_GRAY 0x02
|
||||||
|
#define FT_GASP_SYMMETRIC_GRIDFIT 0x04
|
||||||
|
#define FT_GASP_SYMMETRIC_SMOOTHING 0x08
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Gasp
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* For a TrueType or OpenType font file, return the rasterizer behaviour
|
||||||
|
* flags from the font's 'gasp' table corresponding to a given character
|
||||||
|
* pixel size.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* The source face handle.
|
||||||
|
*
|
||||||
|
* ppem ::
|
||||||
|
* The vertical character pixel size.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* Bit flags (see @FT_GASP_XXX), or @FT_GASP_NO_TABLE if there is no
|
||||||
|
* 'gasp' table in the face.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If you want to use the MM functionality of OpenType variation fonts
|
||||||
|
* (i.e., using @FT_Set_Var_Design_Coordinates and friends), call this
|
||||||
|
* function **after** setting an instance since the return values can
|
||||||
|
* change.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.3.0
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Int )
|
||||||
|
FT_Get_Gasp( FT_Face face,
|
||||||
|
FT_UInt ppem );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTGASP_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,750 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftglyph.h
|
||||||
|
*
|
||||||
|
* FreeType convenience functions to handle glyphs (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* This file contains the definition of several convenience functions that
|
||||||
|
* can be used by client applications to easily retrieve glyph bitmaps and
|
||||||
|
* outlines from a given face.
|
||||||
|
*
|
||||||
|
* These functions should be optional if you are writing a font server or
|
||||||
|
* text layout engine on top of FreeType. However, they are pretty handy
|
||||||
|
* for many other simple uses of the library.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTGLYPH_H_
|
||||||
|
#define FTGLYPH_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* glyph_management
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Glyph Management
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Generic interface to manage individual glyph data.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains definitions used to manage glyph data through
|
||||||
|
* generic @FT_Glyph objects. Each of them can contain a bitmap,
|
||||||
|
* a vector outline, or even images in other formats. These objects are
|
||||||
|
* detached from @FT_Face, contrary to @FT_GlyphSlot.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* forward declaration to a private type */
|
||||||
|
typedef struct FT_Glyph_Class_ FT_Glyph_Class;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Glyph
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Handle to an object used to model generic glyph images. It is a
|
||||||
|
* pointer to the @FT_GlyphRec structure and can contain a glyph bitmap
|
||||||
|
* or pointer.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Glyph objects are not owned by the library. You must thus release
|
||||||
|
* them manually (through @FT_Done_Glyph) _before_ calling
|
||||||
|
* @FT_Done_FreeType.
|
||||||
|
*/
|
||||||
|
typedef struct FT_GlyphRec_* FT_Glyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_GlyphRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The root glyph structure contains a given glyph image plus its advance
|
||||||
|
* width in 16.16 fixed-point format.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* library ::
|
||||||
|
* A handle to the FreeType library object.
|
||||||
|
*
|
||||||
|
* clazz ::
|
||||||
|
* A pointer to the glyph's class. Private.
|
||||||
|
*
|
||||||
|
* format ::
|
||||||
|
* The format of the glyph's image.
|
||||||
|
*
|
||||||
|
* advance ::
|
||||||
|
* A 16.16 vector that gives the glyph's advance width.
|
||||||
|
*/
|
||||||
|
typedef struct FT_GlyphRec_
|
||||||
|
{
|
||||||
|
FT_Library library;
|
||||||
|
const FT_Glyph_Class* clazz;
|
||||||
|
FT_Glyph_Format format;
|
||||||
|
FT_Vector advance;
|
||||||
|
|
||||||
|
} FT_GlyphRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_BitmapGlyph
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to an object used to model a bitmap glyph image. This is a
|
||||||
|
* 'sub-class' of @FT_Glyph, and a pointer to @FT_BitmapGlyphRec.
|
||||||
|
*/
|
||||||
|
typedef struct FT_BitmapGlyphRec_* FT_BitmapGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_BitmapGlyphRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used for bitmap glyph images. This really is a
|
||||||
|
* 'sub-class' of @FT_GlyphRec.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* root ::
|
||||||
|
* The root fields of @FT_Glyph.
|
||||||
|
*
|
||||||
|
* left ::
|
||||||
|
* The left-side bearing, i.e., the horizontal distance from the
|
||||||
|
* current pen position to the left border of the glyph bitmap.
|
||||||
|
*
|
||||||
|
* top ::
|
||||||
|
* The top-side bearing, i.e., the vertical distance from the current
|
||||||
|
* pen position to the top border of the glyph bitmap. This distance
|
||||||
|
* is positive for upwards~y!
|
||||||
|
*
|
||||||
|
* bitmap ::
|
||||||
|
* A descriptor for the bitmap.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You can typecast an @FT_Glyph to @FT_BitmapGlyph if you have
|
||||||
|
* `glyph->format == FT_GLYPH_FORMAT_BITMAP`. This lets you access the
|
||||||
|
* bitmap's contents easily.
|
||||||
|
*
|
||||||
|
* The corresponding pixel buffer is always owned by @FT_BitmapGlyph and
|
||||||
|
* is thus created and destroyed with it.
|
||||||
|
*/
|
||||||
|
typedef struct FT_BitmapGlyphRec_
|
||||||
|
{
|
||||||
|
FT_GlyphRec root;
|
||||||
|
FT_Int left;
|
||||||
|
FT_Int top;
|
||||||
|
FT_Bitmap bitmap;
|
||||||
|
|
||||||
|
} FT_BitmapGlyphRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_OutlineGlyph
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to an object used to model an outline glyph image. This is a
|
||||||
|
* 'sub-class' of @FT_Glyph, and a pointer to @FT_OutlineGlyphRec.
|
||||||
|
*/
|
||||||
|
typedef struct FT_OutlineGlyphRec_* FT_OutlineGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_OutlineGlyphRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used for outline (vectorial) glyph images. This really is
|
||||||
|
* a 'sub-class' of @FT_GlyphRec.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* root ::
|
||||||
|
* The root @FT_Glyph fields.
|
||||||
|
*
|
||||||
|
* outline ::
|
||||||
|
* A descriptor for the outline.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You can typecast an @FT_Glyph to @FT_OutlineGlyph if you have
|
||||||
|
* `glyph->format == FT_GLYPH_FORMAT_OUTLINE`. This lets you access the
|
||||||
|
* outline's content easily.
|
||||||
|
*
|
||||||
|
* As the outline is extracted from a glyph slot, its coordinates are
|
||||||
|
* expressed normally in 26.6 pixels, unless the flag @FT_LOAD_NO_SCALE
|
||||||
|
* was used in @FT_Load_Glyph or @FT_Load_Char.
|
||||||
|
*
|
||||||
|
* The outline's tables are always owned by the object and are destroyed
|
||||||
|
* with it.
|
||||||
|
*/
|
||||||
|
typedef struct FT_OutlineGlyphRec_
|
||||||
|
{
|
||||||
|
FT_GlyphRec root;
|
||||||
|
FT_Outline outline;
|
||||||
|
|
||||||
|
} FT_OutlineGlyphRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_SvgGlyph
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to an object used to model an SVG glyph. This is a
|
||||||
|
* 'sub-class' of @FT_Glyph, and a pointer to @FT_SvgGlyphRec.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.12
|
||||||
|
*/
|
||||||
|
typedef struct FT_SvgGlyphRec_* FT_SvgGlyph;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_SvgGlyphRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used for OT-SVG glyphs. This is a 'sub-class' of
|
||||||
|
* @FT_GlyphRec.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* root ::
|
||||||
|
* The root @FT_GlyphRec fields.
|
||||||
|
*
|
||||||
|
* svg_document ::
|
||||||
|
* A pointer to the SVG document.
|
||||||
|
*
|
||||||
|
* svg_document_length ::
|
||||||
|
* The length of `svg_document`.
|
||||||
|
*
|
||||||
|
* glyph_index ::
|
||||||
|
* The index of the glyph to be rendered.
|
||||||
|
*
|
||||||
|
* metrics ::
|
||||||
|
* A metrics object storing the size information.
|
||||||
|
*
|
||||||
|
* units_per_EM ::
|
||||||
|
* The size of the EM square.
|
||||||
|
*
|
||||||
|
* start_glyph_id ::
|
||||||
|
* The first glyph ID in the glyph range covered by this document.
|
||||||
|
*
|
||||||
|
* end_glyph_id ::
|
||||||
|
* The last glyph ID in the glyph range covered by this document.
|
||||||
|
*
|
||||||
|
* transform ::
|
||||||
|
* A 2x2 transformation matrix to apply to the glyph while rendering
|
||||||
|
* it.
|
||||||
|
*
|
||||||
|
* delta ::
|
||||||
|
* Translation to apply to the glyph while rendering.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The Glyph Management API requires @FT_Glyph or its 'sub-class' to have
|
||||||
|
* all the information needed to completely define the glyph's rendering.
|
||||||
|
* Outline-based glyphs can directly apply transformations to the outline
|
||||||
|
* but this is not possible for an SVG document that hasn't been parsed.
|
||||||
|
* Therefore, the transformation is stored along with the document. In
|
||||||
|
* the absence of a 'ViewBox' or 'Width'/'Height' attribute, the size of
|
||||||
|
* the ViewPort should be assumed to be 'units_per_EM'.
|
||||||
|
*/
|
||||||
|
typedef struct FT_SvgGlyphRec_
|
||||||
|
{
|
||||||
|
FT_GlyphRec root;
|
||||||
|
|
||||||
|
FT_Byte* svg_document;
|
||||||
|
FT_ULong svg_document_length;
|
||||||
|
|
||||||
|
FT_UInt glyph_index;
|
||||||
|
|
||||||
|
FT_Size_Metrics metrics;
|
||||||
|
FT_UShort units_per_EM;
|
||||||
|
|
||||||
|
FT_UShort start_glyph_id;
|
||||||
|
FT_UShort end_glyph_id;
|
||||||
|
|
||||||
|
FT_Matrix transform;
|
||||||
|
FT_Vector delta;
|
||||||
|
|
||||||
|
} FT_SvgGlyphRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_New_Glyph
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to create a new empty glyph image. Note that the
|
||||||
|
* created @FT_Glyph object must be released with @FT_Done_Glyph.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the FreeType library object.
|
||||||
|
*
|
||||||
|
* format ::
|
||||||
|
* The format of the glyph's image.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* aglyph ::
|
||||||
|
* A handle to the glyph object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.10
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_New_Glyph( FT_Library library,
|
||||||
|
FT_Glyph_Format format,
|
||||||
|
FT_Glyph *aglyph );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Glyph
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to extract a glyph image from a slot. Note that the
|
||||||
|
* created @FT_Glyph object must be released with @FT_Done_Glyph.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* slot ::
|
||||||
|
* A handle to the source glyph slot.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* aglyph ::
|
||||||
|
* A handle to the glyph object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Because `*aglyph->advance.x` and `*aglyph->advance.y` are 16.16
|
||||||
|
* fixed-point numbers, `slot->advance.x` and `slot->advance.y` (which
|
||||||
|
* are in 26.6 fixed-point format) must be in the range ]-32768;32768[.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Glyph( FT_GlyphSlot slot,
|
||||||
|
FT_Glyph *aglyph );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Glyph_Copy
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to copy a glyph image. Note that the created
|
||||||
|
* @FT_Glyph object must be released with @FT_Done_Glyph.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* source ::
|
||||||
|
* A handle to the source glyph object.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* target ::
|
||||||
|
* A handle to the target glyph object. 0~in case of error.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Glyph_Copy( FT_Glyph source,
|
||||||
|
FT_Glyph *target );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Glyph_Transform
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Transform a glyph image if its format is scalable.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* glyph ::
|
||||||
|
* A handle to the target glyph object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* matrix ::
|
||||||
|
* A pointer to a 2x2 matrix to apply.
|
||||||
|
*
|
||||||
|
* delta ::
|
||||||
|
* A pointer to a 2d vector to apply. Coordinates are expressed in
|
||||||
|
* 1/64th of a pixel.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code (if not 0, the glyph format is not scalable).
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The 2x2 transformation matrix is also applied to the glyph's advance
|
||||||
|
* vector.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Glyph_Transform( FT_Glyph glyph,
|
||||||
|
const FT_Matrix* matrix,
|
||||||
|
const FT_Vector* delta );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_Glyph_BBox_Mode
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The mode how the values of @FT_Glyph_Get_CBox are returned.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_GLYPH_BBOX_UNSCALED ::
|
||||||
|
* Return unscaled font units.
|
||||||
|
*
|
||||||
|
* FT_GLYPH_BBOX_SUBPIXELS ::
|
||||||
|
* Return unfitted 26.6 coordinates.
|
||||||
|
*
|
||||||
|
* FT_GLYPH_BBOX_GRIDFIT ::
|
||||||
|
* Return grid-fitted 26.6 coordinates.
|
||||||
|
*
|
||||||
|
* FT_GLYPH_BBOX_TRUNCATE ::
|
||||||
|
* Return coordinates in integer pixels.
|
||||||
|
*
|
||||||
|
* FT_GLYPH_BBOX_PIXELS ::
|
||||||
|
* Return grid-fitted pixel coordinates.
|
||||||
|
*/
|
||||||
|
typedef enum FT_Glyph_BBox_Mode_
|
||||||
|
{
|
||||||
|
FT_GLYPH_BBOX_UNSCALED = 0,
|
||||||
|
FT_GLYPH_BBOX_SUBPIXELS = 0,
|
||||||
|
FT_GLYPH_BBOX_GRIDFIT = 1,
|
||||||
|
FT_GLYPH_BBOX_TRUNCATE = 2,
|
||||||
|
FT_GLYPH_BBOX_PIXELS = 3
|
||||||
|
|
||||||
|
} FT_Glyph_BBox_Mode;
|
||||||
|
|
||||||
|
|
||||||
|
/* these constants are deprecated; use the corresponding */
|
||||||
|
/* `FT_Glyph_BBox_Mode` values instead */
|
||||||
|
#define ft_glyph_bbox_unscaled FT_GLYPH_BBOX_UNSCALED
|
||||||
|
#define ft_glyph_bbox_subpixels FT_GLYPH_BBOX_SUBPIXELS
|
||||||
|
#define ft_glyph_bbox_gridfit FT_GLYPH_BBOX_GRIDFIT
|
||||||
|
#define ft_glyph_bbox_truncate FT_GLYPH_BBOX_TRUNCATE
|
||||||
|
#define ft_glyph_bbox_pixels FT_GLYPH_BBOX_PIXELS
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Glyph_Get_CBox
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return a glyph's 'control box'. The control box encloses all the
|
||||||
|
* outline's points, including Bezier control points. Though it
|
||||||
|
* coincides with the exact bounding box for most glyphs, it can be
|
||||||
|
* slightly larger in some situations (like when rotating an outline that
|
||||||
|
* contains Bezier outside arcs).
|
||||||
|
*
|
||||||
|
* Computing the control box is very fast, while getting the bounding box
|
||||||
|
* can take much more time as it needs to walk over all segments and arcs
|
||||||
|
* in the outline. To get the latter, you can use the 'ftbbox'
|
||||||
|
* component, which is dedicated to this single task.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* glyph ::
|
||||||
|
* A handle to the source glyph object.
|
||||||
|
*
|
||||||
|
* mode ::
|
||||||
|
* The mode that indicates how to interpret the returned bounding box
|
||||||
|
* values.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* acbox ::
|
||||||
|
* The glyph coordinate bounding box. Coordinates are expressed in
|
||||||
|
* 1/64th of pixels if it is grid-fitted.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Coordinates are relative to the glyph origin, using the y~upwards
|
||||||
|
* convention.
|
||||||
|
*
|
||||||
|
* If the glyph has been loaded with @FT_LOAD_NO_SCALE, `bbox_mode` must
|
||||||
|
* be set to @FT_GLYPH_BBOX_UNSCALED to get unscaled font units in 26.6
|
||||||
|
* pixel format. The value @FT_GLYPH_BBOX_SUBPIXELS is another name for
|
||||||
|
* this constant.
|
||||||
|
*
|
||||||
|
* If the font is tricky and the glyph has been loaded with
|
||||||
|
* @FT_LOAD_NO_SCALE, the resulting CBox is meaningless. To get
|
||||||
|
* reasonable values for the CBox it is necessary to load the glyph at a
|
||||||
|
* large ppem value (so that the hinting instructions can properly shift
|
||||||
|
* and scale the subglyphs), then extracting the CBox, which can be
|
||||||
|
* eventually converted back to font units.
|
||||||
|
*
|
||||||
|
* Note that the maximum coordinates are exclusive, which means that one
|
||||||
|
* can compute the width and height of the glyph image (be it in integer
|
||||||
|
* or 26.6 pixels) as:
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* width = bbox.xMax - bbox.xMin;
|
||||||
|
* height = bbox.yMax - bbox.yMin;
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Note also that for 26.6 coordinates, if `bbox_mode` is set to
|
||||||
|
* @FT_GLYPH_BBOX_GRIDFIT, the coordinates will also be grid-fitted,
|
||||||
|
* which corresponds to:
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* bbox.xMin = FLOOR(bbox.xMin);
|
||||||
|
* bbox.yMin = FLOOR(bbox.yMin);
|
||||||
|
* bbox.xMax = CEILING(bbox.xMax);
|
||||||
|
* bbox.yMax = CEILING(bbox.yMax);
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* To get the bbox in pixel coordinates, set `bbox_mode` to
|
||||||
|
* @FT_GLYPH_BBOX_TRUNCATE.
|
||||||
|
*
|
||||||
|
* To get the bbox in grid-fitted pixel coordinates, set `bbox_mode` to
|
||||||
|
* @FT_GLYPH_BBOX_PIXELS.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Glyph_Get_CBox( FT_Glyph glyph,
|
||||||
|
FT_UInt bbox_mode,
|
||||||
|
FT_BBox *acbox );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Glyph_To_Bitmap
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Convert a given glyph object to a bitmap glyph object.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* the_glyph ::
|
||||||
|
* A pointer to a handle to the target glyph.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* render_mode ::
|
||||||
|
* An enumeration that describes how the data is rendered.
|
||||||
|
*
|
||||||
|
* origin ::
|
||||||
|
* A pointer to a vector used to translate the glyph image before
|
||||||
|
* rendering. Can be~0 (if no translation). The origin is expressed
|
||||||
|
* in 26.6 pixels.
|
||||||
|
*
|
||||||
|
* destroy ::
|
||||||
|
* A boolean that indicates that the original glyph image should be
|
||||||
|
* destroyed by this function. It is never destroyed in case of error.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function does nothing if the glyph format isn't scalable.
|
||||||
|
*
|
||||||
|
* The glyph image is translated with the `origin` vector before
|
||||||
|
* rendering.
|
||||||
|
*
|
||||||
|
* The first parameter is a pointer to an @FT_Glyph handle that will be
|
||||||
|
* _replaced_ by this function (with newly allocated data). Typically,
|
||||||
|
* you would do something like the following (omitting error handling).
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_Glyph glyph;
|
||||||
|
* FT_BitmapGlyph glyph_bitmap;
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* // load glyph
|
||||||
|
* error = FT_Load_Char( face, glyph_index, FT_LOAD_DEFAULT );
|
||||||
|
*
|
||||||
|
* // extract glyph image
|
||||||
|
* error = FT_Get_Glyph( face->glyph, &glyph );
|
||||||
|
*
|
||||||
|
* // convert to a bitmap (default render mode + destroying old)
|
||||||
|
* if ( glyph->format != FT_GLYPH_FORMAT_BITMAP )
|
||||||
|
* {
|
||||||
|
* error = FT_Glyph_To_Bitmap( &glyph, FT_RENDER_MODE_NORMAL,
|
||||||
|
* 0, 1 );
|
||||||
|
* if ( error ) // `glyph' unchanged
|
||||||
|
* ...
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* // access bitmap content by typecasting
|
||||||
|
* glyph_bitmap = (FT_BitmapGlyph)glyph;
|
||||||
|
*
|
||||||
|
* // do funny stuff with it, like blitting/drawing
|
||||||
|
* ...
|
||||||
|
*
|
||||||
|
* // discard glyph image (bitmap or not)
|
||||||
|
* FT_Done_Glyph( glyph );
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Here is another example, again without error handling.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_Glyph glyphs[MAX_GLYPHS]
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* ...
|
||||||
|
*
|
||||||
|
* for ( idx = 0; i < MAX_GLYPHS; i++ )
|
||||||
|
* error = FT_Load_Glyph( face, idx, FT_LOAD_DEFAULT ) ||
|
||||||
|
* FT_Get_Glyph ( face->glyph, &glyphs[idx] );
|
||||||
|
*
|
||||||
|
* ...
|
||||||
|
*
|
||||||
|
* for ( idx = 0; i < MAX_GLYPHS; i++ )
|
||||||
|
* {
|
||||||
|
* FT_Glyph bitmap = glyphs[idx];
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* ...
|
||||||
|
*
|
||||||
|
* // after this call, `bitmap' no longer points into
|
||||||
|
* // the `glyphs' array (and the old value isn't destroyed)
|
||||||
|
* FT_Glyph_To_Bitmap( &bitmap, FT_RENDER_MODE_MONO, 0, 0 );
|
||||||
|
*
|
||||||
|
* ...
|
||||||
|
*
|
||||||
|
* FT_Done_Glyph( bitmap );
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* ...
|
||||||
|
*
|
||||||
|
* for ( idx = 0; i < MAX_GLYPHS; i++ )
|
||||||
|
* FT_Done_Glyph( glyphs[idx] );
|
||||||
|
* ```
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Glyph_To_Bitmap( FT_Glyph* the_glyph,
|
||||||
|
FT_Render_Mode render_mode,
|
||||||
|
const FT_Vector* origin,
|
||||||
|
FT_Bool destroy );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Done_Glyph
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Destroy a given glyph.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* glyph ::
|
||||||
|
* A handle to the target glyph object.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Done_Glyph( FT_Glyph glyph );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
/* other helpful functions */
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* computations
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Matrix_Multiply
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Perform the matrix operation `b = a*b`.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* a ::
|
||||||
|
* A pointer to matrix `a`.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* b ::
|
||||||
|
* A pointer to matrix `b`.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The result is undefined if either `a` or `b` is zero.
|
||||||
|
*
|
||||||
|
* Since the function uses wrap-around arithmetic, results become
|
||||||
|
* meaningless if the arguments are very large.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Matrix_Multiply( const FT_Matrix* a,
|
||||||
|
FT_Matrix* b );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Matrix_Invert
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Invert a 2x2 matrix. Return an error if it can't be inverted.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* matrix ::
|
||||||
|
* A pointer to the target matrix. Remains untouched in case of error.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Matrix_Invert( FT_Matrix* matrix );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTGLYPH_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
|
|
||||||
|
|
||||||
|
/* Local Variables: */
|
||||||
|
/* coding: utf-8 */
|
||||||
|
/* End: */
|
||||||
@@ -0,0 +1,354 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftgxval.h
|
||||||
|
*
|
||||||
|
* FreeType API for validating TrueTypeGX/AAT tables (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2004-2022 by
|
||||||
|
* Masatake YAMATO, Redhat K.K,
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* gxvalid is derived from both gxlayout module and otvalid module.
|
||||||
|
* Development of gxlayout is supported by the Information-technology
|
||||||
|
* Promotion Agency(IPA), Japan.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTGXVAL_H_
|
||||||
|
#define FTGXVAL_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* gx_validation
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* TrueTypeGX/AAT Validation
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* An API to validate TrueTypeGX/AAT tables.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the declaration of functions to validate some
|
||||||
|
* TrueTypeGX tables (feat, mort, morx, bsln, just, kern, opbd, trak,
|
||||||
|
* prop, lcar).
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* FT_TrueTypeGX_Validate
|
||||||
|
* FT_TrueTypeGX_Free
|
||||||
|
*
|
||||||
|
* FT_ClassicKern_Validate
|
||||||
|
* FT_ClassicKern_Free
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_GX_LENGTH
|
||||||
|
* FT_VALIDATE_GXXXX
|
||||||
|
* FT_VALIDATE_CKERNXXX
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* Warning: Use `FT_VALIDATE_XXX` to validate a table.
|
||||||
|
* Following definitions are for gxvalid developers.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define FT_VALIDATE_feat_INDEX 0
|
||||||
|
#define FT_VALIDATE_mort_INDEX 1
|
||||||
|
#define FT_VALIDATE_morx_INDEX 2
|
||||||
|
#define FT_VALIDATE_bsln_INDEX 3
|
||||||
|
#define FT_VALIDATE_just_INDEX 4
|
||||||
|
#define FT_VALIDATE_kern_INDEX 5
|
||||||
|
#define FT_VALIDATE_opbd_INDEX 6
|
||||||
|
#define FT_VALIDATE_trak_INDEX 7
|
||||||
|
#define FT_VALIDATE_prop_INDEX 8
|
||||||
|
#define FT_VALIDATE_lcar_INDEX 9
|
||||||
|
#define FT_VALIDATE_GX_LAST_INDEX FT_VALIDATE_lcar_INDEX
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_VALIDATE_GX_LENGTH
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The number of tables checked in this module. Use it as a parameter
|
||||||
|
* for the `table-length` argument of function @FT_TrueTypeGX_Validate.
|
||||||
|
*/
|
||||||
|
#define FT_VALIDATE_GX_LENGTH ( FT_VALIDATE_GX_LAST_INDEX + 1 )
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
/* Up to 0x1000 is used by otvalid.
|
||||||
|
Ox2xxx is reserved for feature OT extension. */
|
||||||
|
#define FT_VALIDATE_GX_START 0x4000
|
||||||
|
#define FT_VALIDATE_GX_BITFIELD( tag ) \
|
||||||
|
( FT_VALIDATE_GX_START << FT_VALIDATE_##tag##_INDEX )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_VALIDATE_GXXXX
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of bit-field constants used with @FT_TrueTypeGX_Validate to
|
||||||
|
* indicate which TrueTypeGX/AAT Type tables should be validated.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_VALIDATE_feat ::
|
||||||
|
* Validate 'feat' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_mort ::
|
||||||
|
* Validate 'mort' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_morx ::
|
||||||
|
* Validate 'morx' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_bsln ::
|
||||||
|
* Validate 'bsln' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_just ::
|
||||||
|
* Validate 'just' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_kern ::
|
||||||
|
* Validate 'kern' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_opbd ::
|
||||||
|
* Validate 'opbd' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_trak ::
|
||||||
|
* Validate 'trak' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_prop ::
|
||||||
|
* Validate 'prop' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_lcar ::
|
||||||
|
* Validate 'lcar' table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_GX ::
|
||||||
|
* Validate all TrueTypeGX tables (feat, mort, morx, bsln, just, kern,
|
||||||
|
* opbd, trak, prop and lcar).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define FT_VALIDATE_feat FT_VALIDATE_GX_BITFIELD( feat )
|
||||||
|
#define FT_VALIDATE_mort FT_VALIDATE_GX_BITFIELD( mort )
|
||||||
|
#define FT_VALIDATE_morx FT_VALIDATE_GX_BITFIELD( morx )
|
||||||
|
#define FT_VALIDATE_bsln FT_VALIDATE_GX_BITFIELD( bsln )
|
||||||
|
#define FT_VALIDATE_just FT_VALIDATE_GX_BITFIELD( just )
|
||||||
|
#define FT_VALIDATE_kern FT_VALIDATE_GX_BITFIELD( kern )
|
||||||
|
#define FT_VALIDATE_opbd FT_VALIDATE_GX_BITFIELD( opbd )
|
||||||
|
#define FT_VALIDATE_trak FT_VALIDATE_GX_BITFIELD( trak )
|
||||||
|
#define FT_VALIDATE_prop FT_VALIDATE_GX_BITFIELD( prop )
|
||||||
|
#define FT_VALIDATE_lcar FT_VALIDATE_GX_BITFIELD( lcar )
|
||||||
|
|
||||||
|
#define FT_VALIDATE_GX ( FT_VALIDATE_feat | \
|
||||||
|
FT_VALIDATE_mort | \
|
||||||
|
FT_VALIDATE_morx | \
|
||||||
|
FT_VALIDATE_bsln | \
|
||||||
|
FT_VALIDATE_just | \
|
||||||
|
FT_VALIDATE_kern | \
|
||||||
|
FT_VALIDATE_opbd | \
|
||||||
|
FT_VALIDATE_trak | \
|
||||||
|
FT_VALIDATE_prop | \
|
||||||
|
FT_VALIDATE_lcar )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_TrueTypeGX_Validate
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Validate various TrueTypeGX tables to assure that all offsets and
|
||||||
|
* indices are valid. The idea is that a higher-level library that
|
||||||
|
* actually does the text layout can access those tables without error
|
||||||
|
* checking (which can be quite time consuming).
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* validation_flags ::
|
||||||
|
* A bit field that specifies the tables to be validated. See
|
||||||
|
* @FT_VALIDATE_GXXXX for possible values.
|
||||||
|
*
|
||||||
|
* table_length ::
|
||||||
|
* The size of the `tables` array. Normally, @FT_VALIDATE_GX_LENGTH
|
||||||
|
* should be passed.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* tables ::
|
||||||
|
* The array where all validated sfnt tables are stored. The array
|
||||||
|
* itself must be allocated by a client.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function only works with TrueTypeGX fonts, returning an error
|
||||||
|
* otherwise.
|
||||||
|
*
|
||||||
|
* After use, the application should deallocate the buffers pointed to by
|
||||||
|
* each `tables` element, by calling @FT_TrueTypeGX_Free. A `NULL` value
|
||||||
|
* indicates that the table either doesn't exist in the font, the
|
||||||
|
* application hasn't asked for validation, or the validator doesn't have
|
||||||
|
* the ability to validate the sfnt table.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_TrueTypeGX_Validate( FT_Face face,
|
||||||
|
FT_UInt validation_flags,
|
||||||
|
FT_Bytes tables[FT_VALIDATE_GX_LENGTH],
|
||||||
|
FT_UInt table_length );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_TrueTypeGX_Free
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Free the buffer allocated by TrueTypeGX validator.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* table ::
|
||||||
|
* The pointer to the buffer allocated by @FT_TrueTypeGX_Validate.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function must be used to free the buffer allocated by
|
||||||
|
* @FT_TrueTypeGX_Validate only.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_TrueTypeGX_Free( FT_Face face,
|
||||||
|
FT_Bytes table );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_VALIDATE_CKERNXXX
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of bit-field constants used with @FT_ClassicKern_Validate to
|
||||||
|
* indicate the classic kern dialect or dialects. If the selected type
|
||||||
|
* doesn't fit, @FT_ClassicKern_Validate regards the table as invalid.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_VALIDATE_MS ::
|
||||||
|
* Handle the 'kern' table as a classic Microsoft kern table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_APPLE ::
|
||||||
|
* Handle the 'kern' table as a classic Apple kern table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_CKERN ::
|
||||||
|
* Handle the 'kern' as either classic Apple or Microsoft kern table.
|
||||||
|
*/
|
||||||
|
#define FT_VALIDATE_MS ( FT_VALIDATE_GX_START << 0 )
|
||||||
|
#define FT_VALIDATE_APPLE ( FT_VALIDATE_GX_START << 1 )
|
||||||
|
|
||||||
|
#define FT_VALIDATE_CKERN ( FT_VALIDATE_MS | FT_VALIDATE_APPLE )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_ClassicKern_Validate
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Validate classic (16-bit format) kern table to assure that the
|
||||||
|
* offsets and indices are valid. The idea is that a higher-level
|
||||||
|
* library that actually does the text layout can access those tables
|
||||||
|
* without error checking (which can be quite time consuming).
|
||||||
|
*
|
||||||
|
* The 'kern' table validator in @FT_TrueTypeGX_Validate deals with both
|
||||||
|
* the new 32-bit format and the classic 16-bit format, while
|
||||||
|
* FT_ClassicKern_Validate only supports the classic 16-bit format.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* validation_flags ::
|
||||||
|
* A bit field that specifies the dialect to be validated. See
|
||||||
|
* @FT_VALIDATE_CKERNXXX for possible values.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* ckern_table ::
|
||||||
|
* A pointer to the kern table.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* After use, the application should deallocate the buffers pointed to by
|
||||||
|
* `ckern_table`, by calling @FT_ClassicKern_Free. A `NULL` value
|
||||||
|
* indicates that the table doesn't exist in the font.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_ClassicKern_Validate( FT_Face face,
|
||||||
|
FT_UInt validation_flags,
|
||||||
|
FT_Bytes *ckern_table );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_ClassicKern_Free
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Free the buffer allocated by classic Kern validator.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* table ::
|
||||||
|
* The pointer to the buffer that is allocated by
|
||||||
|
* @FT_ClassicKern_Validate.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function must be used to free the buffer allocated by
|
||||||
|
* @FT_ClassicKern_Validate only.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_ClassicKern_Free( FT_Face face,
|
||||||
|
FT_Bytes table );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTGXVAL_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,151 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftgzip.h
|
||||||
|
*
|
||||||
|
* Gzip-compressed stream support.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTGZIP_H_
|
||||||
|
#define FTGZIP_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* gzip
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* GZIP Streams
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Using gzip-compressed font files.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* In certain builds of the library, gzip compression recognition is
|
||||||
|
* automatically handled when calling @FT_New_Face or @FT_Open_Face.
|
||||||
|
* This means that if no font driver is capable of handling the raw
|
||||||
|
* compressed file, the library will try to open a gzipped stream from it
|
||||||
|
* and re-open the face with it.
|
||||||
|
*
|
||||||
|
* The stream implementation is very basic and resets the decompression
|
||||||
|
* process each time seeking backwards is needed within the stream,
|
||||||
|
* which significantly undermines the performance.
|
||||||
|
*
|
||||||
|
* This section contains the declaration of Gzip-specific functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stream_OpenGzip
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Open a new stream to parse gzip-compressed font files. This is mainly
|
||||||
|
* used to support the compressed `*.pcf.gz` fonts that come with
|
||||||
|
* XFree86.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stream ::
|
||||||
|
* The target embedding stream.
|
||||||
|
*
|
||||||
|
* source ::
|
||||||
|
* The source stream.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The source stream must be opened _before_ calling this function.
|
||||||
|
*
|
||||||
|
* Calling the internal function `FT_Stream_Close` on the new stream will
|
||||||
|
* **not** call `FT_Stream_Close` on the source stream. None of the
|
||||||
|
* stream objects will be released to the heap.
|
||||||
|
*
|
||||||
|
* This function may return `FT_Err_Unimplemented_Feature` if your build
|
||||||
|
* of FreeType was not compiled with zlib support.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stream_OpenGzip( FT_Stream stream,
|
||||||
|
FT_Stream source );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Gzip_Uncompress
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Decompress a zipped input buffer into an output buffer. This function
|
||||||
|
* is modeled after zlib's `uncompress` function.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* memory ::
|
||||||
|
* A FreeType memory handle.
|
||||||
|
*
|
||||||
|
* input ::
|
||||||
|
* The input buffer.
|
||||||
|
*
|
||||||
|
* input_len ::
|
||||||
|
* The length of the input buffer.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* output ::
|
||||||
|
* The output buffer.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* output_len ::
|
||||||
|
* Before calling the function, this is the total size of the output
|
||||||
|
* buffer, which must be large enough to hold the entire uncompressed
|
||||||
|
* data (so the size of the uncompressed data must be known in
|
||||||
|
* advance). After calling the function, `output_len` is the size of
|
||||||
|
* the used data in `output`.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function may return `FT_Err_Unimplemented_Feature` if your build
|
||||||
|
* of FreeType was not compiled with zlib support.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.5.1
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Gzip_Uncompress( FT_Memory memory,
|
||||||
|
FT_Byte* output,
|
||||||
|
FT_ULong* output_len,
|
||||||
|
const FT_Byte* input,
|
||||||
|
FT_ULong input_len );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTGZIP_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,348 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftincrem.h
|
||||||
|
*
|
||||||
|
* FreeType incremental loading (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTINCREM_H_
|
||||||
|
#define FTINCREM_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
#include <freetype/ftparams.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* incremental
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Incremental Loading
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Custom Glyph Loading.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains various functions used to perform so-called
|
||||||
|
* 'incremental' glyph loading. This is a mode where all glyphs loaded
|
||||||
|
* from a given @FT_Face are provided by the client application.
|
||||||
|
*
|
||||||
|
* Apart from that, all other tables are loaded normally from the font
|
||||||
|
* file. This mode is useful when FreeType is used within another
|
||||||
|
* engine, e.g., a PostScript Imaging Processor.
|
||||||
|
*
|
||||||
|
* To enable this mode, you must use @FT_Open_Face, passing an
|
||||||
|
* @FT_Parameter with the @FT_PARAM_TAG_INCREMENTAL tag and an
|
||||||
|
* @FT_Incremental_Interface value. See the comments for
|
||||||
|
* @FT_Incremental_InterfaceRec for an example.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Incremental
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An opaque type describing a user-provided object used to implement
|
||||||
|
* 'incremental' glyph loading within FreeType. This is used to support
|
||||||
|
* embedded fonts in certain environments (e.g., PostScript
|
||||||
|
* interpreters), where the glyph data isn't in the font file, or must be
|
||||||
|
* overridden by different values.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* It is up to client applications to create and implement
|
||||||
|
* @FT_Incremental objects, as long as they provide implementations for
|
||||||
|
* the methods @FT_Incremental_GetGlyphDataFunc,
|
||||||
|
* @FT_Incremental_FreeGlyphDataFunc and
|
||||||
|
* @FT_Incremental_GetGlyphMetricsFunc.
|
||||||
|
*
|
||||||
|
* See the description of @FT_Incremental_InterfaceRec to understand how
|
||||||
|
* to use incremental objects with FreeType.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct FT_IncrementalRec_* FT_Incremental;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Incremental_MetricsRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A small structure used to contain the basic glyph metrics returned by
|
||||||
|
* the @FT_Incremental_GetGlyphMetricsFunc method.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* bearing_x ::
|
||||||
|
* Left bearing, in font units.
|
||||||
|
*
|
||||||
|
* bearing_y ::
|
||||||
|
* Top bearing, in font units.
|
||||||
|
*
|
||||||
|
* advance ::
|
||||||
|
* Horizontal component of glyph advance, in font units.
|
||||||
|
*
|
||||||
|
* advance_v ::
|
||||||
|
* Vertical component of glyph advance, in font units.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* These correspond to horizontal or vertical metrics depending on the
|
||||||
|
* value of the `vertical` argument to the function
|
||||||
|
* @FT_Incremental_GetGlyphMetricsFunc.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct FT_Incremental_MetricsRec_
|
||||||
|
{
|
||||||
|
FT_Long bearing_x;
|
||||||
|
FT_Long bearing_y;
|
||||||
|
FT_Long advance;
|
||||||
|
FT_Long advance_v; /* since 2.3.12 */
|
||||||
|
|
||||||
|
} FT_Incremental_MetricsRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Incremental_Metrics
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to an @FT_Incremental_MetricsRec structure.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct FT_Incremental_MetricsRec_* FT_Incremental_Metrics;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Incremental_GetGlyphDataFunc
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function called by FreeType to access a given glyph's data bytes
|
||||||
|
* during @FT_Load_Glyph or @FT_Load_Char if incremental loading is
|
||||||
|
* enabled.
|
||||||
|
*
|
||||||
|
* Note that the format of the glyph's data bytes depends on the font
|
||||||
|
* file format. For TrueType, it must correspond to the raw bytes within
|
||||||
|
* the 'glyf' table. For PostScript formats, it must correspond to the
|
||||||
|
* **unencrypted** charstring bytes, without any `lenIV` header. It is
|
||||||
|
* undefined for any other format.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* incremental ::
|
||||||
|
* Handle to an opaque @FT_Incremental handle provided by the client
|
||||||
|
* application.
|
||||||
|
*
|
||||||
|
* glyph_index ::
|
||||||
|
* Index of relevant glyph.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* adata ::
|
||||||
|
* A structure describing the returned glyph data bytes (which will be
|
||||||
|
* accessed as a read-only byte block).
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If this function returns successfully the method
|
||||||
|
* @FT_Incremental_FreeGlyphDataFunc will be called later to release the
|
||||||
|
* data bytes.
|
||||||
|
*
|
||||||
|
* Nested calls to @FT_Incremental_GetGlyphDataFunc can happen for
|
||||||
|
* compound glyphs.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Incremental_GetGlyphDataFunc)( FT_Incremental incremental,
|
||||||
|
FT_UInt glyph_index,
|
||||||
|
FT_Data* adata );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Incremental_FreeGlyphDataFunc
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to release the glyph data bytes returned by a
|
||||||
|
* successful call to @FT_Incremental_GetGlyphDataFunc.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* incremental ::
|
||||||
|
* A handle to an opaque @FT_Incremental handle provided by the client
|
||||||
|
* application.
|
||||||
|
*
|
||||||
|
* data ::
|
||||||
|
* A structure describing the glyph data bytes (which will be accessed
|
||||||
|
* as a read-only byte block).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*FT_Incremental_FreeGlyphDataFunc)( FT_Incremental incremental,
|
||||||
|
FT_Data* data );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Incremental_GetGlyphMetricsFunc
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to retrieve the basic metrics of a given glyph index
|
||||||
|
* before accessing its data. This allows for handling font types such
|
||||||
|
* as PCL~XL Format~1, Class~2 downloaded TrueType fonts, where the glyph
|
||||||
|
* metrics (`hmtx` and `vmtx` tables) are permitted to be omitted from
|
||||||
|
* the font, and the relevant metrics included in the header of the glyph
|
||||||
|
* outline data. Importantly, this is not intended to allow custom glyph
|
||||||
|
* metrics (for example, Postscript Metrics dictionaries), because that
|
||||||
|
* conflicts with the requirements of outline hinting. Such custom
|
||||||
|
* metrics must be handled separately, by the calling application.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* incremental ::
|
||||||
|
* A handle to an opaque @FT_Incremental handle provided by the client
|
||||||
|
* application.
|
||||||
|
*
|
||||||
|
* glyph_index ::
|
||||||
|
* Index of relevant glyph.
|
||||||
|
*
|
||||||
|
* vertical ::
|
||||||
|
* If true, return vertical metrics.
|
||||||
|
*
|
||||||
|
* ametrics ::
|
||||||
|
* This parameter is used for both input and output. The original
|
||||||
|
* glyph metrics, if any, in font units. If metrics are not available
|
||||||
|
* all the values must be set to zero.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* ametrics ::
|
||||||
|
* The glyph metrics in font units.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Incremental_GetGlyphMetricsFunc)
|
||||||
|
( FT_Incremental incremental,
|
||||||
|
FT_UInt glyph_index,
|
||||||
|
FT_Bool vertical,
|
||||||
|
FT_Incremental_MetricsRec *ametrics );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Incremental_FuncsRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A table of functions for accessing fonts that load data incrementally.
|
||||||
|
* Used in @FT_Incremental_InterfaceRec.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* get_glyph_data ::
|
||||||
|
* The function to get glyph data. Must not be null.
|
||||||
|
*
|
||||||
|
* free_glyph_data ::
|
||||||
|
* The function to release glyph data. Must not be null.
|
||||||
|
*
|
||||||
|
* get_glyph_metrics ::
|
||||||
|
* The function to get glyph metrics. May be null if the font does not
|
||||||
|
* require it.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct FT_Incremental_FuncsRec_
|
||||||
|
{
|
||||||
|
FT_Incremental_GetGlyphDataFunc get_glyph_data;
|
||||||
|
FT_Incremental_FreeGlyphDataFunc free_glyph_data;
|
||||||
|
FT_Incremental_GetGlyphMetricsFunc get_glyph_metrics;
|
||||||
|
|
||||||
|
} FT_Incremental_FuncsRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Incremental_InterfaceRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to be used with @FT_Open_Face to indicate that the user
|
||||||
|
* wants to support incremental glyph loading. You should use it with
|
||||||
|
* @FT_PARAM_TAG_INCREMENTAL as in the following example:
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_Incremental_InterfaceRec inc_int;
|
||||||
|
* FT_Parameter parameter;
|
||||||
|
* FT_Open_Args open_args;
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* // set up incremental descriptor
|
||||||
|
* inc_int.funcs = my_funcs;
|
||||||
|
* inc_int.object = my_object;
|
||||||
|
*
|
||||||
|
* // set up optional parameter
|
||||||
|
* parameter.tag = FT_PARAM_TAG_INCREMENTAL;
|
||||||
|
* parameter.data = &inc_int;
|
||||||
|
*
|
||||||
|
* // set up FT_Open_Args structure
|
||||||
|
* open_args.flags = FT_OPEN_PATHNAME | FT_OPEN_PARAMS;
|
||||||
|
* open_args.pathname = my_font_pathname;
|
||||||
|
* open_args.num_params = 1;
|
||||||
|
* open_args.params = ¶meter; // we use one optional argument
|
||||||
|
*
|
||||||
|
* // open the font
|
||||||
|
* error = FT_Open_Face( library, &open_args, index, &face );
|
||||||
|
* ...
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct FT_Incremental_InterfaceRec_
|
||||||
|
{
|
||||||
|
const FT_Incremental_FuncsRec* funcs;
|
||||||
|
FT_Incremental object;
|
||||||
|
|
||||||
|
} FT_Incremental_InterfaceRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Incremental_Interface
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A pointer to an @FT_Incremental_InterfaceRec structure.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef FT_Incremental_InterfaceRec* FT_Incremental_Interface;
|
||||||
|
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTINCREM_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,323 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftlcdfil.h
|
||||||
|
*
|
||||||
|
* FreeType API for color filtering of subpixel bitmap glyphs
|
||||||
|
* (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2006-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTLCDFIL_H_
|
||||||
|
#define FTLCDFIL_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
#include <freetype/ftparams.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* lcd_rendering
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Subpixel Rendering
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* API to control subpixel rendering.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* FreeType provides two alternative subpixel rendering technologies.
|
||||||
|
* Should you define `FT_CONFIG_OPTION_SUBPIXEL_RENDERING` in your
|
||||||
|
* `ftoption.h` file, this enables ClearType-style rendering.
|
||||||
|
* Otherwise, Harmony LCD rendering is enabled. These technologies are
|
||||||
|
* controlled differently and API described below, although always
|
||||||
|
* available, performs its function when appropriate method is enabled
|
||||||
|
* and does nothing otherwise.
|
||||||
|
*
|
||||||
|
* ClearType-style LCD rendering exploits the color-striped structure of
|
||||||
|
* LCD pixels, increasing the available resolution in the direction of
|
||||||
|
* the stripe (usually horizontal RGB) by a factor of~3. Using the
|
||||||
|
* subpixel coverages unfiltered can create severe color fringes
|
||||||
|
* especially when rendering thin features. Indeed, to produce
|
||||||
|
* black-on-white text, the nearby color subpixels must be dimmed
|
||||||
|
* evenly. Therefore, an equalizing 5-tap FIR filter should be applied
|
||||||
|
* to subpixel coverages regardless of pixel boundaries and should have
|
||||||
|
* these properties:
|
||||||
|
*
|
||||||
|
* 1. It should be symmetrical, like {~a, b, c, b, a~}, to avoid
|
||||||
|
* any shifts in appearance.
|
||||||
|
*
|
||||||
|
* 2. It should be color-balanced, meaning a~+ b~=~c, to reduce color
|
||||||
|
* fringes by distributing the computed coverage for one subpixel to
|
||||||
|
* all subpixels equally.
|
||||||
|
*
|
||||||
|
* 3. It should be normalized, meaning 2a~+ 2b~+ c~=~1.0 to maintain
|
||||||
|
* overall brightness.
|
||||||
|
*
|
||||||
|
* Boxy 3-tap filter {0, 1/3, 1/3, 1/3, 0} is sharper but is less
|
||||||
|
* forgiving of non-ideal gamma curves of a screen (and viewing angles),
|
||||||
|
* beveled filters are fuzzier but more tolerant.
|
||||||
|
*
|
||||||
|
* Use the @FT_Library_SetLcdFilter or @FT_Library_SetLcdFilterWeights
|
||||||
|
* API to specify a low-pass filter, which is then applied to
|
||||||
|
* subpixel-rendered bitmaps generated through @FT_Render_Glyph.
|
||||||
|
*
|
||||||
|
* Harmony LCD rendering is suitable to panels with any regular subpixel
|
||||||
|
* structure, not just monitors with 3 color striped subpixels, as long
|
||||||
|
* as the color subpixels have fixed positions relative to the pixel
|
||||||
|
* center. In this case, each color channel can be rendered separately
|
||||||
|
* after shifting the outline opposite to the subpixel shift so that the
|
||||||
|
* coverage maps are aligned. This method is immune to color fringes
|
||||||
|
* because the shifts do not change integral coverage.
|
||||||
|
*
|
||||||
|
* The subpixel geometry must be specified by xy-coordinates for each
|
||||||
|
* subpixel. By convention they may come in the RGB order: {{-1/3, 0},
|
||||||
|
* {0, 0}, {1/3, 0}} for standard RGB striped panel or {{-1/6, 1/4},
|
||||||
|
* {-1/6, -1/4}, {1/3, 0}} for a certain PenTile panel.
|
||||||
|
*
|
||||||
|
* Use the @FT_Library_SetLcdGeometry API to specify subpixel positions.
|
||||||
|
* If one follows the RGB order convention, the same order applies to the
|
||||||
|
* resulting @FT_PIXEL_MODE_LCD and @FT_PIXEL_MODE_LCD_V bitmaps. Note,
|
||||||
|
* however, that the coordinate frame for the latter must be rotated
|
||||||
|
* clockwise. Harmony with default LCD geometry is equivalent to
|
||||||
|
* ClearType with light filter.
|
||||||
|
*
|
||||||
|
* As a result of ClearType filtering or Harmony shifts, the resulting
|
||||||
|
* dimensions of LCD bitmaps can be slightly wider or taller than the
|
||||||
|
* dimensions the original outline with regard to the pixel grid.
|
||||||
|
* For example, for @FT_RENDER_MODE_LCD, the filter adds 2~subpixels to
|
||||||
|
* the left, and 2~subpixels to the right. The bitmap offset values are
|
||||||
|
* adjusted accordingly, so clients shouldn't need to modify their layout
|
||||||
|
* and glyph positioning code when enabling the filter.
|
||||||
|
*
|
||||||
|
* The ClearType and Harmony rendering is applicable to glyph bitmaps
|
||||||
|
* rendered through @FT_Render_Glyph, @FT_Load_Glyph, @FT_Load_Char, and
|
||||||
|
* @FT_Glyph_To_Bitmap, when @FT_RENDER_MODE_LCD or @FT_RENDER_MODE_LCD_V
|
||||||
|
* is specified. This API does not control @FT_Outline_Render and
|
||||||
|
* @FT_Outline_Get_Bitmap.
|
||||||
|
*
|
||||||
|
* The described algorithms can completely remove color artefacts when
|
||||||
|
* combined with gamma-corrected alpha blending in linear space. Each of
|
||||||
|
* the 3~alpha values (subpixels) must by independently used to blend one
|
||||||
|
* color channel. That is, red alpha blends the red channel of the text
|
||||||
|
* color with the red channel of the background pixel.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_LcdFilter
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of values to identify various types of LCD filters.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_LCD_FILTER_NONE ::
|
||||||
|
* Do not perform filtering. When used with subpixel rendering, this
|
||||||
|
* results in sometimes severe color fringes.
|
||||||
|
*
|
||||||
|
* FT_LCD_FILTER_DEFAULT ::
|
||||||
|
* This is a beveled, normalized, and color-balanced five-tap filter
|
||||||
|
* with weights of [0x08 0x4D 0x56 0x4D 0x08] in 1/256th units.
|
||||||
|
*
|
||||||
|
* FT_LCD_FILTER_LIGHT ::
|
||||||
|
* this is a boxy, normalized, and color-balanced three-tap filter with
|
||||||
|
* weights of [0x00 0x55 0x56 0x55 0x00] in 1/256th units.
|
||||||
|
*
|
||||||
|
* FT_LCD_FILTER_LEGACY ::
|
||||||
|
* FT_LCD_FILTER_LEGACY1 ::
|
||||||
|
* This filter corresponds to the original libXft color filter. It
|
||||||
|
* provides high contrast output but can exhibit really bad color
|
||||||
|
* fringes if glyphs are not extremely well hinted to the pixel grid.
|
||||||
|
* This filter is only provided for comparison purposes, and might be
|
||||||
|
* disabled or stay unsupported in the future. The second value is
|
||||||
|
* provided for compatibility with FontConfig, which historically used
|
||||||
|
* different enumeration, sometimes incorrectly forwarded to FreeType.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.3.0 (`FT_LCD_FILTER_LEGACY1` since 2.6.2)
|
||||||
|
*/
|
||||||
|
typedef enum FT_LcdFilter_
|
||||||
|
{
|
||||||
|
FT_LCD_FILTER_NONE = 0,
|
||||||
|
FT_LCD_FILTER_DEFAULT = 1,
|
||||||
|
FT_LCD_FILTER_LIGHT = 2,
|
||||||
|
FT_LCD_FILTER_LEGACY1 = 3,
|
||||||
|
FT_LCD_FILTER_LEGACY = 16,
|
||||||
|
|
||||||
|
FT_LCD_FILTER_MAX /* do not remove */
|
||||||
|
|
||||||
|
} FT_LcdFilter;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Library_SetLcdFilter
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This function is used to change filter applied to LCD decimated
|
||||||
|
* bitmaps, like the ones used when calling @FT_Render_Glyph with
|
||||||
|
* @FT_RENDER_MODE_LCD or @FT_RENDER_MODE_LCD_V.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the target library instance.
|
||||||
|
*
|
||||||
|
* filter ::
|
||||||
|
* The filter type.
|
||||||
|
*
|
||||||
|
* You can use @FT_LCD_FILTER_NONE here to disable this feature, or
|
||||||
|
* @FT_LCD_FILTER_DEFAULT to use a default filter that should work well
|
||||||
|
* on most LCD screens.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Since 2.10.3 the LCD filtering is enabled with @FT_LCD_FILTER_DEFAULT.
|
||||||
|
* It is no longer necessary to call this function explicitly except
|
||||||
|
* to choose a different filter or disable filtering altogether with
|
||||||
|
* @FT_LCD_FILTER_NONE.
|
||||||
|
*
|
||||||
|
* This function does nothing but returns `FT_Err_Unimplemented_Feature`
|
||||||
|
* if the configuration macro `FT_CONFIG_OPTION_SUBPIXEL_RENDERING` is
|
||||||
|
* not defined in your build of the library.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.3.0
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Library_SetLcdFilter( FT_Library library,
|
||||||
|
FT_LcdFilter filter );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Library_SetLcdFilterWeights
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This function can be used to enable LCD filter with custom weights,
|
||||||
|
* instead of using presets in @FT_Library_SetLcdFilter.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the target library instance.
|
||||||
|
*
|
||||||
|
* weights ::
|
||||||
|
* A pointer to an array; the function copies the first five bytes and
|
||||||
|
* uses them to specify the filter weights in 1/256th units.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function does nothing but returns `FT_Err_Unimplemented_Feature`
|
||||||
|
* if the configuration macro `FT_CONFIG_OPTION_SUBPIXEL_RENDERING` is
|
||||||
|
* not defined in your build of the library.
|
||||||
|
*
|
||||||
|
* LCD filter weights can also be set per face using @FT_Face_Properties
|
||||||
|
* with @FT_PARAM_TAG_LCD_FILTER_WEIGHTS.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.4.0
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Library_SetLcdFilterWeights( FT_Library library,
|
||||||
|
unsigned char *weights );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_LcdFiveTapFilter
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for passing the five LCD filter weights to
|
||||||
|
* @FT_Face_Properties within an @FT_Parameter structure.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_LCD_FILTER_FIVE_TAPS 5
|
||||||
|
|
||||||
|
typedef FT_Byte FT_LcdFiveTapFilter[FT_LCD_FILTER_FIVE_TAPS];
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Library_SetLcdGeometry
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This function can be used to modify default positions of color
|
||||||
|
* subpixels, which controls Harmony LCD rendering.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the target library instance.
|
||||||
|
*
|
||||||
|
* sub ::
|
||||||
|
* A pointer to an array of 3 vectors in 26.6 fractional pixel format;
|
||||||
|
* the function modifies the default values, see the note below.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Subpixel geometry examples:
|
||||||
|
*
|
||||||
|
* - {{-21, 0}, {0, 0}, {21, 0}} is the default, corresponding to 3 color
|
||||||
|
* stripes shifted by a third of a pixel. This could be an RGB panel.
|
||||||
|
*
|
||||||
|
* - {{21, 0}, {0, 0}, {-21, 0}} looks the same as the default but can
|
||||||
|
* specify a BGR panel instead, while keeping the bitmap in the same
|
||||||
|
* RGB888 format.
|
||||||
|
*
|
||||||
|
* - {{0, 21}, {0, 0}, {0, -21}} is the vertical RGB, but the bitmap
|
||||||
|
* stays RGB888 as a result.
|
||||||
|
*
|
||||||
|
* - {{-11, 16}, {-11, -16}, {22, 0}} is a certain PenTile arrangement.
|
||||||
|
*
|
||||||
|
* This function does nothing and returns `FT_Err_Unimplemented_Feature`
|
||||||
|
* in the context of ClearType-style subpixel rendering when
|
||||||
|
* `FT_CONFIG_OPTION_SUBPIXEL_RENDERING` is defined in your build of the
|
||||||
|
* library.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.10.0
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Library_SetLcdGeometry( FT_Library library,
|
||||||
|
FT_Vector sub[3] );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTLCDFIL_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,296 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftlist.h
|
||||||
|
*
|
||||||
|
* Generic list support for FreeType (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* This file implements functions relative to list processing. Its data
|
||||||
|
* structures are defined in `freetype.h`.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTLIST_H_
|
||||||
|
#define FTLIST_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* list_processing
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* List Processing
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Simple management of lists.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains various definitions related to list processing
|
||||||
|
* using doubly-linked nodes.
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* FT_List
|
||||||
|
* FT_ListNode
|
||||||
|
* FT_ListRec
|
||||||
|
* FT_ListNodeRec
|
||||||
|
*
|
||||||
|
* FT_List_Add
|
||||||
|
* FT_List_Insert
|
||||||
|
* FT_List_Find
|
||||||
|
* FT_List_Remove
|
||||||
|
* FT_List_Up
|
||||||
|
* FT_List_Iterate
|
||||||
|
* FT_List_Iterator
|
||||||
|
* FT_List_Finalize
|
||||||
|
* FT_List_Destructor
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_List_Find
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Find the list node for a given listed object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* list ::
|
||||||
|
* A pointer to the parent list.
|
||||||
|
* data ::
|
||||||
|
* The address of the listed object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* List node. `NULL` if it wasn't found.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_ListNode )
|
||||||
|
FT_List_Find( FT_List list,
|
||||||
|
void* data );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_List_Add
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Append an element to the end of a list.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* list ::
|
||||||
|
* A pointer to the parent list.
|
||||||
|
* node ::
|
||||||
|
* The node to append.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_List_Add( FT_List list,
|
||||||
|
FT_ListNode node );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_List_Insert
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Insert an element at the head of a list.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* list ::
|
||||||
|
* A pointer to parent list.
|
||||||
|
* node ::
|
||||||
|
* The node to insert.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_List_Insert( FT_List list,
|
||||||
|
FT_ListNode node );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_List_Remove
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Remove a node from a list. This function doesn't check whether the
|
||||||
|
* node is in the list!
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* node ::
|
||||||
|
* The node to remove.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* list ::
|
||||||
|
* A pointer to the parent list.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_List_Remove( FT_List list,
|
||||||
|
FT_ListNode node );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_List_Up
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Move a node to the head/top of a list. Used to maintain LRU lists.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* list ::
|
||||||
|
* A pointer to the parent list.
|
||||||
|
* node ::
|
||||||
|
* The node to move.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_List_Up( FT_List list,
|
||||||
|
FT_ListNode node );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_List_Iterator
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An FT_List iterator function that is called during a list parse by
|
||||||
|
* @FT_List_Iterate.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* node ::
|
||||||
|
* The current iteration list node.
|
||||||
|
*
|
||||||
|
* user ::
|
||||||
|
* A typeless pointer passed to @FT_List_Iterate. Can be used to point
|
||||||
|
* to the iteration's state.
|
||||||
|
*/
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_List_Iterator)( FT_ListNode node,
|
||||||
|
void* user );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_List_Iterate
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Parse a list and calls a given iterator function on each element.
|
||||||
|
* Note that parsing is stopped as soon as one of the iterator calls
|
||||||
|
* returns a non-zero value.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* list ::
|
||||||
|
* A handle to the list.
|
||||||
|
* iterator ::
|
||||||
|
* An iterator function, called on each node of the list.
|
||||||
|
* user ::
|
||||||
|
* A user-supplied field that is passed as the second argument to the
|
||||||
|
* iterator.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The result (a FreeType error code) of the last iterator call.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_List_Iterate( FT_List list,
|
||||||
|
FT_List_Iterator iterator,
|
||||||
|
void* user );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_List_Destructor
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An @FT_List iterator function that is called during a list
|
||||||
|
* finalization by @FT_List_Finalize to destroy all elements in a given
|
||||||
|
* list.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* system ::
|
||||||
|
* The current system object.
|
||||||
|
*
|
||||||
|
* data ::
|
||||||
|
* The current object to destroy.
|
||||||
|
*
|
||||||
|
* user ::
|
||||||
|
* A typeless pointer passed to @FT_List_Iterate. It can be used to
|
||||||
|
* point to the iteration's state.
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*FT_List_Destructor)( FT_Memory memory,
|
||||||
|
void* data,
|
||||||
|
void* user );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_List_Finalize
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Destroy all elements in the list as well as the list itself.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* list ::
|
||||||
|
* A handle to the list.
|
||||||
|
*
|
||||||
|
* destroy ::
|
||||||
|
* A list destructor that will be applied to each element of the list.
|
||||||
|
* Set this to `NULL` if not needed.
|
||||||
|
*
|
||||||
|
* memory ::
|
||||||
|
* The current memory object that handles deallocation.
|
||||||
|
*
|
||||||
|
* user ::
|
||||||
|
* A user-supplied field that is passed as the last argument to the
|
||||||
|
* destructor.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function expects that all nodes added by @FT_List_Add or
|
||||||
|
* @FT_List_Insert have been dynamically allocated.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_List_Finalize( FT_List list,
|
||||||
|
FT_List_Destructor destroy,
|
||||||
|
FT_Memory memory,
|
||||||
|
void* user );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTLIST_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,184 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftlogging.h
|
||||||
|
*
|
||||||
|
* Additional debugging APIs.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2020-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTLOGGING_H_
|
||||||
|
#define FTLOGGING_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_CONFIG_CONFIG_H
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* debugging_apis
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* External Debugging APIs
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Public APIs to control the `FT_DEBUG_LOGGING` macro.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the declarations of public functions that
|
||||||
|
* enables fine control of what the `FT_DEBUG_LOGGING` macro outputs.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Trace_Set_Level
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Change the levels of tracing components of FreeType at run time.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* tracing_level ::
|
||||||
|
* New tracing value.
|
||||||
|
*
|
||||||
|
* @example:
|
||||||
|
* The following call makes FreeType trace everything but the 'memory'
|
||||||
|
* component.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_Trace_Set_Level( "any:7 memory:0 );
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function does nothing if compilation option `FT_DEBUG_LOGGING`
|
||||||
|
* isn't set.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.11
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Trace_Set_Level( const char* tracing_level );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Trace_Set_Default_Level
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Reset tracing value of FreeType's components to the default value
|
||||||
|
* (i.e., to the value of the `FT2_DEBUG` environment value or to NULL
|
||||||
|
* if `FT2_DEBUG` is not set).
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function does nothing if compilation option `FT_DEBUG_LOGGING`
|
||||||
|
* isn't set.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.11
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Trace_Set_Default_Level( void );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Custom_Log_Handler
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function typedef that is used to handle the logging of tracing and
|
||||||
|
* debug messages on a file system.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* ft_component ::
|
||||||
|
* The name of `FT_COMPONENT` from which the current debug or error
|
||||||
|
* message is produced.
|
||||||
|
*
|
||||||
|
* fmt ::
|
||||||
|
* Actual debug or tracing message.
|
||||||
|
*
|
||||||
|
* args::
|
||||||
|
* Arguments of debug or tracing messages.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.11
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*FT_Custom_Log_Handler)( const char* ft_component,
|
||||||
|
const char* fmt,
|
||||||
|
va_list args );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_Log_Handler
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function to set a custom log handler.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* handler ::
|
||||||
|
* New logging function.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function does nothing if compilation option `FT_DEBUG_LOGGING`
|
||||||
|
* isn't set.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.11
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Set_Log_Handler( FT_Custom_Log_Handler handler );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_Default_Log_Handler
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function to undo the effect of @FT_Set_Log_Handler, resetting the
|
||||||
|
* log handler to FreeType's built-in version.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function does nothing if compilation option `FT_DEBUG_LOGGING`
|
||||||
|
* isn't set.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.11
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Set_Default_Log_Handler( void );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTLOGGING_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,100 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftlzw.h
|
||||||
|
*
|
||||||
|
* LZW-compressed stream support.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2004-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTLZW_H_
|
||||||
|
#define FTLZW_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* lzw
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* LZW Streams
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Using LZW-compressed font files.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* In certain builds of the library, LZW compression recognition is
|
||||||
|
* automatically handled when calling @FT_New_Face or @FT_Open_Face.
|
||||||
|
* This means that if no font driver is capable of handling the raw
|
||||||
|
* compressed file, the library will try to open a LZW stream from it and
|
||||||
|
* re-open the face with it.
|
||||||
|
*
|
||||||
|
* The stream implementation is very basic and resets the decompression
|
||||||
|
* process each time seeking backwards is needed within the stream,
|
||||||
|
* which significantly undermines the performance.
|
||||||
|
*
|
||||||
|
* This section contains the declaration of LZW-specific functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stream_OpenLZW
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Open a new stream to parse LZW-compressed font files. This is mainly
|
||||||
|
* used to support the compressed `*.pcf.Z` fonts that come with XFree86.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stream ::
|
||||||
|
* The target embedding stream.
|
||||||
|
*
|
||||||
|
* source ::
|
||||||
|
* The source stream.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The source stream must be opened _before_ calling this function.
|
||||||
|
*
|
||||||
|
* Calling the internal function `FT_Stream_Close` on the new stream will
|
||||||
|
* **not** call `FT_Stream_Close` on the source stream. None of the
|
||||||
|
* stream objects will be released to the heap.
|
||||||
|
*
|
||||||
|
* This function may return `FT_Err_Unimplemented_Feature` if your build
|
||||||
|
* of FreeType was not compiled with LZW support.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stream_OpenLZW( FT_Stream stream,
|
||||||
|
FT_Stream source );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTLZW_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,289 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftmac.h
|
||||||
|
*
|
||||||
|
* Additional Mac-specific API.
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* Just van Rossum, David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* NOTE: Include this file after `FT_FREETYPE_H` and after any
|
||||||
|
* Mac-specific headers (because this header uses Mac types such as
|
||||||
|
* 'Handle', 'FSSpec', 'FSRef', etc.)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTMAC_H_
|
||||||
|
#define FTMAC_H_
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/* gcc-3.1 and later can warn about functions tagged as deprecated */
|
||||||
|
#ifndef FT_DEPRECATED_ATTRIBUTE
|
||||||
|
#if defined( __GNUC__ ) && \
|
||||||
|
( ( __GNUC__ >= 4 ) || \
|
||||||
|
( ( __GNUC__ == 3 ) && ( __GNUC_MINOR__ >= 1 ) ) )
|
||||||
|
#define FT_DEPRECATED_ATTRIBUTE __attribute__(( deprecated ))
|
||||||
|
#else
|
||||||
|
#define FT_DEPRECATED_ATTRIBUTE
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* mac_specific
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Mac Specific Interface
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Only available on the Macintosh.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The following definitions are only available if FreeType is compiled
|
||||||
|
* on a Macintosh.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_New_Face_From_FOND
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Create a new face object from a FOND resource.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library resource.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* fond ::
|
||||||
|
* A FOND resource.
|
||||||
|
*
|
||||||
|
* face_index ::
|
||||||
|
* Only supported for the -1 'sanity check' special case.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* aface ::
|
||||||
|
* A handle to a new face object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @example:
|
||||||
|
* This function can be used to create @FT_Face objects from fonts that
|
||||||
|
* are installed in the system as follows.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* fond = GetResource( 'FOND', fontName );
|
||||||
|
* error = FT_New_Face_From_FOND( library, fond, 0, &face );
|
||||||
|
* ```
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_New_Face_From_FOND( FT_Library library,
|
||||||
|
Handle fond,
|
||||||
|
FT_Long face_index,
|
||||||
|
FT_Face *aface )
|
||||||
|
FT_DEPRECATED_ATTRIBUTE;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_GetFile_From_Mac_Name
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return an FSSpec for the disk file containing the named font.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* fontName ::
|
||||||
|
* Mac OS name of the font (e.g., Times New Roman Bold).
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* pathSpec ::
|
||||||
|
* FSSpec to the file. For passing to @FT_New_Face_From_FSSpec.
|
||||||
|
*
|
||||||
|
* face_index ::
|
||||||
|
* Index of the face. For passing to @FT_New_Face_From_FSSpec.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_GetFile_From_Mac_Name( const char* fontName,
|
||||||
|
FSSpec* pathSpec,
|
||||||
|
FT_Long* face_index )
|
||||||
|
FT_DEPRECATED_ATTRIBUTE;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_GetFile_From_Mac_ATS_Name
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return an FSSpec for the disk file containing the named font.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* fontName ::
|
||||||
|
* Mac OS name of the font in ATS framework.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* pathSpec ::
|
||||||
|
* FSSpec to the file. For passing to @FT_New_Face_From_FSSpec.
|
||||||
|
*
|
||||||
|
* face_index ::
|
||||||
|
* Index of the face. For passing to @FT_New_Face_From_FSSpec.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_GetFile_From_Mac_ATS_Name( const char* fontName,
|
||||||
|
FSSpec* pathSpec,
|
||||||
|
FT_Long* face_index )
|
||||||
|
FT_DEPRECATED_ATTRIBUTE;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_GetFilePath_From_Mac_ATS_Name
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return a pathname of the disk file and face index for given font name
|
||||||
|
* that is handled by ATS framework.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* fontName ::
|
||||||
|
* Mac OS name of the font in ATS framework.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* path ::
|
||||||
|
* Buffer to store pathname of the file. For passing to @FT_New_Face.
|
||||||
|
* The client must allocate this buffer before calling this function.
|
||||||
|
*
|
||||||
|
* maxPathSize ::
|
||||||
|
* Lengths of the buffer `path` that client allocated.
|
||||||
|
*
|
||||||
|
* face_index ::
|
||||||
|
* Index of the face. For passing to @FT_New_Face.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_GetFilePath_From_Mac_ATS_Name( const char* fontName,
|
||||||
|
UInt8* path,
|
||||||
|
UInt32 maxPathSize,
|
||||||
|
FT_Long* face_index )
|
||||||
|
FT_DEPRECATED_ATTRIBUTE;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_New_Face_From_FSSpec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Create a new face object from a given resource and typeface index
|
||||||
|
* using an FSSpec to the font file.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library resource.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* spec ::
|
||||||
|
* FSSpec to the font file.
|
||||||
|
*
|
||||||
|
* face_index ::
|
||||||
|
* The index of the face within the resource. The first face has
|
||||||
|
* index~0.
|
||||||
|
* @output:
|
||||||
|
* aface ::
|
||||||
|
* A handle to a new face object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* @FT_New_Face_From_FSSpec is identical to @FT_New_Face except it
|
||||||
|
* accepts an FSSpec instead of a path.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_New_Face_From_FSSpec( FT_Library library,
|
||||||
|
const FSSpec *spec,
|
||||||
|
FT_Long face_index,
|
||||||
|
FT_Face *aface )
|
||||||
|
FT_DEPRECATED_ATTRIBUTE;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_New_Face_From_FSRef
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Create a new face object from a given resource and typeface index
|
||||||
|
* using an FSRef to the font file.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library resource.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* spec ::
|
||||||
|
* FSRef to the font file.
|
||||||
|
*
|
||||||
|
* face_index ::
|
||||||
|
* The index of the face within the resource. The first face has
|
||||||
|
* index~0.
|
||||||
|
* @output:
|
||||||
|
* aface ::
|
||||||
|
* A handle to a new face object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* @FT_New_Face_From_FSRef is identical to @FT_New_Face except it accepts
|
||||||
|
* an FSRef instead of a path.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_New_Face_From_FSRef( FT_Library library,
|
||||||
|
const FSRef *ref,
|
||||||
|
FT_Long face_index,
|
||||||
|
FT_Face *aface )
|
||||||
|
FT_DEPRECATED_ATTRIBUTE;
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* FTMAC_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,755 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftmm.h
|
||||||
|
*
|
||||||
|
* FreeType Multiple Master font interface (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTMM_H_
|
||||||
|
#define FTMM_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/t1tables.h>
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* multiple_masters
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Multiple Masters
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* How to manage Multiple Masters fonts.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The following types and functions are used to manage Multiple Master
|
||||||
|
* fonts, i.e., the selection of specific design instances by setting
|
||||||
|
* design axis coordinates.
|
||||||
|
*
|
||||||
|
* Besides Adobe MM fonts, the interface supports Apple's TrueType GX and
|
||||||
|
* OpenType variation fonts. Some of the routines only work with Adobe
|
||||||
|
* MM fonts, others will work with all three types. They are similar
|
||||||
|
* enough that a consistent interface makes sense.
|
||||||
|
*
|
||||||
|
* For Adobe MM fonts, macro @FT_IS_SFNT returns false. For GX and
|
||||||
|
* OpenType variation fonts, it returns true.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_MM_Axis
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a given axis in design space for Multiple Masters
|
||||||
|
* fonts.
|
||||||
|
*
|
||||||
|
* This structure can't be used for TrueType GX or OpenType variation
|
||||||
|
* fonts.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* name ::
|
||||||
|
* The axis's name.
|
||||||
|
*
|
||||||
|
* minimum ::
|
||||||
|
* The axis's minimum design coordinate.
|
||||||
|
*
|
||||||
|
* maximum ::
|
||||||
|
* The axis's maximum design coordinate.
|
||||||
|
*/
|
||||||
|
typedef struct FT_MM_Axis_
|
||||||
|
{
|
||||||
|
FT_String* name;
|
||||||
|
FT_Long minimum;
|
||||||
|
FT_Long maximum;
|
||||||
|
|
||||||
|
} FT_MM_Axis;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Multi_Master
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model the axes and space of a Multiple Masters font.
|
||||||
|
*
|
||||||
|
* This structure can't be used for TrueType GX or OpenType variation
|
||||||
|
* fonts.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* num_axis ::
|
||||||
|
* Number of axes. Cannot exceed~4.
|
||||||
|
*
|
||||||
|
* num_designs ::
|
||||||
|
* Number of designs; should be normally 2^num_axis even though the
|
||||||
|
* Type~1 specification strangely allows for intermediate designs to be
|
||||||
|
* present. This number cannot exceed~16.
|
||||||
|
*
|
||||||
|
* axis ::
|
||||||
|
* A table of axis descriptors.
|
||||||
|
*/
|
||||||
|
typedef struct FT_Multi_Master_
|
||||||
|
{
|
||||||
|
FT_UInt num_axis;
|
||||||
|
FT_UInt num_designs;
|
||||||
|
FT_MM_Axis axis[T1_MAX_MM_AXIS];
|
||||||
|
|
||||||
|
} FT_Multi_Master;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Var_Axis
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a given axis in design space for Multiple
|
||||||
|
* Masters, TrueType GX, and OpenType variation fonts.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* name ::
|
||||||
|
* The axis's name. Not always meaningful for TrueType GX or OpenType
|
||||||
|
* variation fonts.
|
||||||
|
*
|
||||||
|
* minimum ::
|
||||||
|
* The axis's minimum design coordinate.
|
||||||
|
*
|
||||||
|
* def ::
|
||||||
|
* The axis's default design coordinate. FreeType computes meaningful
|
||||||
|
* default values for Adobe MM fonts.
|
||||||
|
*
|
||||||
|
* maximum ::
|
||||||
|
* The axis's maximum design coordinate.
|
||||||
|
*
|
||||||
|
* tag ::
|
||||||
|
* The axis's tag (the equivalent to 'name' for TrueType GX and
|
||||||
|
* OpenType variation fonts). FreeType provides default values for
|
||||||
|
* Adobe MM fonts if possible.
|
||||||
|
*
|
||||||
|
* strid ::
|
||||||
|
* The axis name entry in the font's 'name' table. This is another
|
||||||
|
* (and often better) version of the 'name' field for TrueType GX or
|
||||||
|
* OpenType variation fonts. Not meaningful for Adobe MM fonts.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The fields `minimum`, `def`, and `maximum` are 16.16 fractional values
|
||||||
|
* for TrueType GX and OpenType variation fonts. For Adobe MM fonts, the
|
||||||
|
* values are integers.
|
||||||
|
*/
|
||||||
|
typedef struct FT_Var_Axis_
|
||||||
|
{
|
||||||
|
FT_String* name;
|
||||||
|
|
||||||
|
FT_Fixed minimum;
|
||||||
|
FT_Fixed def;
|
||||||
|
FT_Fixed maximum;
|
||||||
|
|
||||||
|
FT_ULong tag;
|
||||||
|
FT_UInt strid;
|
||||||
|
|
||||||
|
} FT_Var_Axis;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Var_Named_Style
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a named instance in a TrueType GX or OpenType
|
||||||
|
* variation font.
|
||||||
|
*
|
||||||
|
* This structure can't be used for Adobe MM fonts.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* coords ::
|
||||||
|
* The design coordinates for this instance. This is an array with one
|
||||||
|
* entry for each axis.
|
||||||
|
*
|
||||||
|
* strid ::
|
||||||
|
* The entry in 'name' table identifying this instance.
|
||||||
|
*
|
||||||
|
* psid ::
|
||||||
|
* The entry in 'name' table identifying a PostScript name for this
|
||||||
|
* instance. Value 0xFFFF indicates a missing entry.
|
||||||
|
*/
|
||||||
|
typedef struct FT_Var_Named_Style_
|
||||||
|
{
|
||||||
|
FT_Fixed* coords;
|
||||||
|
FT_UInt strid;
|
||||||
|
FT_UInt psid; /* since 2.7.1 */
|
||||||
|
|
||||||
|
} FT_Var_Named_Style;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_MM_Var
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model the axes and space of an Adobe MM, TrueType GX,
|
||||||
|
* or OpenType variation font.
|
||||||
|
*
|
||||||
|
* Some fields are specific to one format and not to the others.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* num_axis ::
|
||||||
|
* The number of axes. The maximum value is~4 for Adobe MM fonts; no
|
||||||
|
* limit in TrueType GX or OpenType variation fonts.
|
||||||
|
*
|
||||||
|
* num_designs ::
|
||||||
|
* The number of designs; should be normally 2^num_axis for Adobe MM
|
||||||
|
* fonts. Not meaningful for TrueType GX or OpenType variation fonts
|
||||||
|
* (where every glyph could have a different number of designs).
|
||||||
|
*
|
||||||
|
* num_namedstyles ::
|
||||||
|
* The number of named styles; a 'named style' is a tuple of design
|
||||||
|
* coordinates that has a string ID (in the 'name' table) associated
|
||||||
|
* with it. The font can tell the user that, for example,
|
||||||
|
* [Weight=1.5,Width=1.1] is 'Bold'. Another name for 'named style' is
|
||||||
|
* 'named instance'.
|
||||||
|
*
|
||||||
|
* For Adobe Multiple Masters fonts, this value is always zero because
|
||||||
|
* the format does not support named styles.
|
||||||
|
*
|
||||||
|
* axis ::
|
||||||
|
* An axis descriptor table. TrueType GX and OpenType variation fonts
|
||||||
|
* contain slightly more data than Adobe MM fonts. Memory management
|
||||||
|
* of this pointer is done internally by FreeType.
|
||||||
|
*
|
||||||
|
* namedstyle ::
|
||||||
|
* A named style (instance) table. Only meaningful for TrueType GX and
|
||||||
|
* OpenType variation fonts. Memory management of this pointer is done
|
||||||
|
* internally by FreeType.
|
||||||
|
*/
|
||||||
|
typedef struct FT_MM_Var_
|
||||||
|
{
|
||||||
|
FT_UInt num_axis;
|
||||||
|
FT_UInt num_designs;
|
||||||
|
FT_UInt num_namedstyles;
|
||||||
|
FT_Var_Axis* axis;
|
||||||
|
FT_Var_Named_Style* namedstyle;
|
||||||
|
|
||||||
|
} FT_MM_Var;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Multi_Master
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve a variation descriptor of a given Adobe MM font.
|
||||||
|
*
|
||||||
|
* This function can't be used with TrueType GX or OpenType variation
|
||||||
|
* fonts.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* amaster ::
|
||||||
|
* The Multiple Masters descriptor.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Multi_Master( FT_Face face,
|
||||||
|
FT_Multi_Master *amaster );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_MM_Var
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve a variation descriptor for a given font.
|
||||||
|
*
|
||||||
|
* This function works with all supported variation formats.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* amaster ::
|
||||||
|
* The variation descriptor. Allocates a data structure, which the
|
||||||
|
* user must deallocate with a call to @FT_Done_MM_Var after use.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_MM_Var( FT_Face face,
|
||||||
|
FT_MM_Var* *amaster );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Done_MM_Var
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Free the memory allocated by @FT_Get_MM_Var.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle of the face's parent library object that was used in the
|
||||||
|
* call to @FT_Get_MM_Var to create `amaster`.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Done_MM_Var( FT_Library library,
|
||||||
|
FT_MM_Var *amaster );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_MM_Design_Coordinates
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* For Adobe MM fonts, choose an interpolated font design through design
|
||||||
|
* coordinates.
|
||||||
|
*
|
||||||
|
* This function can't be used with TrueType GX or OpenType variation
|
||||||
|
* fonts.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* num_coords ::
|
||||||
|
* The number of available design coordinates. If it is larger than
|
||||||
|
* the number of axes, ignore the excess values. If it is smaller than
|
||||||
|
* the number of axes, use default values for the remaining axes.
|
||||||
|
*
|
||||||
|
* coords ::
|
||||||
|
* An array of design coordinates.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* [Since 2.8.1] To reset all axes to the default values, call the
|
||||||
|
* function with `num_coords` set to zero and `coords` set to `NULL`.
|
||||||
|
*
|
||||||
|
* [Since 2.9] If `num_coords` is larger than zero, this function sets
|
||||||
|
* the @FT_FACE_FLAG_VARIATION bit in @FT_Face's `face_flags` field
|
||||||
|
* (i.e., @FT_IS_VARIATION will return true). If `num_coords` is zero,
|
||||||
|
* this bit flag gets unset.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Set_MM_Design_Coordinates( FT_Face face,
|
||||||
|
FT_UInt num_coords,
|
||||||
|
FT_Long* coords );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_Var_Design_Coordinates
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Choose an interpolated font design through design coordinates.
|
||||||
|
*
|
||||||
|
* This function works with all supported variation formats.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* num_coords ::
|
||||||
|
* The number of available design coordinates. If it is larger than
|
||||||
|
* the number of axes, ignore the excess values. If it is smaller than
|
||||||
|
* the number of axes, use default values for the remaining axes.
|
||||||
|
*
|
||||||
|
* coords ::
|
||||||
|
* An array of design coordinates.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* [Since 2.8.1] To reset all axes to the default values, call the
|
||||||
|
* function with `num_coords` set to zero and `coords` set to `NULL`.
|
||||||
|
* [Since 2.9] 'Default values' means the currently selected named
|
||||||
|
* instance (or the base font if no named instance is selected).
|
||||||
|
*
|
||||||
|
* [Since 2.9] If `num_coords` is larger than zero, this function sets
|
||||||
|
* the @FT_FACE_FLAG_VARIATION bit in @FT_Face's `face_flags` field
|
||||||
|
* (i.e., @FT_IS_VARIATION will return true). If `num_coords` is zero,
|
||||||
|
* this bit flag gets unset.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Set_Var_Design_Coordinates( FT_Face face,
|
||||||
|
FT_UInt num_coords,
|
||||||
|
FT_Fixed* coords );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Var_Design_Coordinates
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Get the design coordinates of the currently selected interpolated
|
||||||
|
* font.
|
||||||
|
*
|
||||||
|
* This function works with all supported variation formats.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* num_coords ::
|
||||||
|
* The number of design coordinates to retrieve. If it is larger than
|
||||||
|
* the number of axes, set the excess values to~0.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* coords ::
|
||||||
|
* The design coordinates array.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.7.1
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Var_Design_Coordinates( FT_Face face,
|
||||||
|
FT_UInt num_coords,
|
||||||
|
FT_Fixed* coords );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_MM_Blend_Coordinates
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Choose an interpolated font design through normalized blend
|
||||||
|
* coordinates.
|
||||||
|
*
|
||||||
|
* This function works with all supported variation formats.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* num_coords ::
|
||||||
|
* The number of available design coordinates. If it is larger than
|
||||||
|
* the number of axes, ignore the excess values. If it is smaller than
|
||||||
|
* the number of axes, use default values for the remaining axes.
|
||||||
|
*
|
||||||
|
* coords ::
|
||||||
|
* The design coordinates array (each element must be between 0 and 1.0
|
||||||
|
* for Adobe MM fonts, and between -1.0 and 1.0 for TrueType GX and
|
||||||
|
* OpenType variation fonts).
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* [Since 2.8.1] To reset all axes to the default values, call the
|
||||||
|
* function with `num_coords` set to zero and `coords` set to `NULL`.
|
||||||
|
* [Since 2.9] 'Default values' means the currently selected named
|
||||||
|
* instance (or the base font if no named instance is selected).
|
||||||
|
*
|
||||||
|
* [Since 2.9] If `num_coords` is larger than zero, this function sets
|
||||||
|
* the @FT_FACE_FLAG_VARIATION bit in @FT_Face's `face_flags` field
|
||||||
|
* (i.e., @FT_IS_VARIATION will return true). If `num_coords` is zero,
|
||||||
|
* this bit flag gets unset.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Set_MM_Blend_Coordinates( FT_Face face,
|
||||||
|
FT_UInt num_coords,
|
||||||
|
FT_Fixed* coords );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_MM_Blend_Coordinates
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Get the normalized blend coordinates of the currently selected
|
||||||
|
* interpolated font.
|
||||||
|
*
|
||||||
|
* This function works with all supported variation formats.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* num_coords ::
|
||||||
|
* The number of normalized blend coordinates to retrieve. If it is
|
||||||
|
* larger than the number of axes, set the excess values to~0.5 for
|
||||||
|
* Adobe MM fonts, and to~0 for TrueType GX and OpenType variation
|
||||||
|
* fonts.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* coords ::
|
||||||
|
* The normalized blend coordinates array.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.7.1
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_MM_Blend_Coordinates( FT_Face face,
|
||||||
|
FT_UInt num_coords,
|
||||||
|
FT_Fixed* coords );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_Var_Blend_Coordinates
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This is another name of @FT_Set_MM_Blend_Coordinates.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Set_Var_Blend_Coordinates( FT_Face face,
|
||||||
|
FT_UInt num_coords,
|
||||||
|
FT_Fixed* coords );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Var_Blend_Coordinates
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This is another name of @FT_Get_MM_Blend_Coordinates.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.7.1
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Var_Blend_Coordinates( FT_Face face,
|
||||||
|
FT_UInt num_coords,
|
||||||
|
FT_Fixed* coords );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_MM_WeightVector
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* For Adobe MM fonts, choose an interpolated font design by directly
|
||||||
|
* setting the weight vector.
|
||||||
|
*
|
||||||
|
* This function can't be used with TrueType GX or OpenType variation
|
||||||
|
* fonts.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* len ::
|
||||||
|
* The length of the weight vector array. If it is larger than the
|
||||||
|
* number of designs, the extra values are ignored. If it is less than
|
||||||
|
* the number of designs, the remaining values are set to zero.
|
||||||
|
*
|
||||||
|
* weightvector ::
|
||||||
|
* An array representing the weight vector.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Adobe Multiple Master fonts limit the number of designs, and thus the
|
||||||
|
* length of the weight vector to~16.
|
||||||
|
*
|
||||||
|
* If `len` is zero and `weightvector` is `NULL`, the weight vector array
|
||||||
|
* is reset to the default values.
|
||||||
|
*
|
||||||
|
* The Adobe documentation also states that the values in the
|
||||||
|
* WeightVector array must total 1.0 +/-~0.001. In practice this does
|
||||||
|
* not seem to be enforced, so is not enforced here, either.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.10
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Set_MM_WeightVector( FT_Face face,
|
||||||
|
FT_UInt len,
|
||||||
|
FT_Fixed* weightvector );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_MM_WeightVector
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* For Adobe MM fonts, retrieve the current weight vector of the font.
|
||||||
|
*
|
||||||
|
* This function can't be used with TrueType GX or OpenType variation
|
||||||
|
* fonts.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* len ::
|
||||||
|
* A pointer to the size of the array to be filled. If the size of the
|
||||||
|
* array is less than the number of designs, `FT_Err_Invalid_Argument`
|
||||||
|
* is returned, and `len` is set to the required size (the number of
|
||||||
|
* designs). If the size of the array is greater than the number of
|
||||||
|
* designs, the remaining entries are set to~0. On successful
|
||||||
|
* completion, `len` is set to the number of designs (i.e., the number
|
||||||
|
* of values written to the array).
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* weightvector ::
|
||||||
|
* An array to be filled.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Adobe Multiple Master fonts limit the number of designs, and thus the
|
||||||
|
* length of the WeightVector to~16.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.10
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_MM_WeightVector( FT_Face face,
|
||||||
|
FT_UInt* len,
|
||||||
|
FT_Fixed* weightvector );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_VAR_AXIS_FLAG_XXX
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of bit flags used in the return value of
|
||||||
|
* @FT_Get_Var_Axis_Flags.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_VAR_AXIS_FLAG_HIDDEN ::
|
||||||
|
* The variation axis should not be exposed to user interfaces.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8.1
|
||||||
|
*/
|
||||||
|
#define FT_VAR_AXIS_FLAG_HIDDEN 1
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Var_Axis_Flags
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Get the 'flags' field of an OpenType Variation Axis Record.
|
||||||
|
*
|
||||||
|
* Not meaningful for Adobe MM fonts (`*flags` is always zero).
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* master ::
|
||||||
|
* The variation descriptor.
|
||||||
|
*
|
||||||
|
* axis_index ::
|
||||||
|
* The index of the requested variation axis.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* flags ::
|
||||||
|
* The 'flags' field. See @FT_VAR_AXIS_FLAG_XXX for possible values.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8.1
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Var_Axis_Flags( FT_MM_Var* master,
|
||||||
|
FT_UInt axis_index,
|
||||||
|
FT_UInt* flags );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_Named_Instance
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Set or change the current named instance.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* instance_index ::
|
||||||
|
* The index of the requested instance, starting with value 1. If set
|
||||||
|
* to value 0, FreeType switches to font access without a named
|
||||||
|
* instance.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The function uses the value of `instance_index` to set bits 16-30 of
|
||||||
|
* the face's `face_index` field. It also resets any variation applied
|
||||||
|
* to the font, and the @FT_FACE_FLAG_VARIATION bit of the face's
|
||||||
|
* `face_flags` field gets reset to zero (i.e., @FT_IS_VARIATION will
|
||||||
|
* return false).
|
||||||
|
*
|
||||||
|
* For Adobe MM fonts (which don't have named instances) this function
|
||||||
|
* simply resets the current face to the default instance.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.9
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Set_Named_Instance( FT_Face face,
|
||||||
|
FT_UInt instance_index );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTMM_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,807 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftmodapi.h
|
||||||
|
*
|
||||||
|
* FreeType modules public interface (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTMODAPI_H_
|
||||||
|
#define FTMODAPI_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* module_management
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Module Management
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* How to add, upgrade, remove, and control modules from FreeType.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The definitions below are used to manage modules within FreeType.
|
||||||
|
* Internal and external modules can be added, upgraded, and removed at
|
||||||
|
* runtime. For example, an alternative renderer or proprietary font
|
||||||
|
* driver can be registered and prioritized. Additionally, some module
|
||||||
|
* properties can also be controlled.
|
||||||
|
*
|
||||||
|
* Here is a list of existing values of the `module_name` field in the
|
||||||
|
* @FT_Module_Class structure.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* autofitter
|
||||||
|
* bdf
|
||||||
|
* cff
|
||||||
|
* gxvalid
|
||||||
|
* otvalid
|
||||||
|
* pcf
|
||||||
|
* pfr
|
||||||
|
* psaux
|
||||||
|
* pshinter
|
||||||
|
* psnames
|
||||||
|
* raster1
|
||||||
|
* sfnt
|
||||||
|
* smooth
|
||||||
|
* truetype
|
||||||
|
* type1
|
||||||
|
* type42
|
||||||
|
* t1cid
|
||||||
|
* winfonts
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Note that the FreeType Cache sub-system is not a FreeType module.
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* FT_Module
|
||||||
|
* FT_Module_Constructor
|
||||||
|
* FT_Module_Destructor
|
||||||
|
* FT_Module_Requester
|
||||||
|
* FT_Module_Class
|
||||||
|
*
|
||||||
|
* FT_Add_Module
|
||||||
|
* FT_Get_Module
|
||||||
|
* FT_Remove_Module
|
||||||
|
* FT_Add_Default_Modules
|
||||||
|
*
|
||||||
|
* FT_FACE_DRIVER_NAME
|
||||||
|
* FT_Property_Set
|
||||||
|
* FT_Property_Get
|
||||||
|
* FT_Set_Default_Properties
|
||||||
|
*
|
||||||
|
* FT_New_Library
|
||||||
|
* FT_Done_Library
|
||||||
|
* FT_Reference_Library
|
||||||
|
*
|
||||||
|
* FT_Renderer
|
||||||
|
* FT_Renderer_Class
|
||||||
|
*
|
||||||
|
* FT_Get_Renderer
|
||||||
|
* FT_Set_Renderer
|
||||||
|
*
|
||||||
|
* FT_Set_Debug_Hook
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* module bit flags */
|
||||||
|
#define FT_MODULE_FONT_DRIVER 1 /* this module is a font driver */
|
||||||
|
#define FT_MODULE_RENDERER 2 /* this module is a renderer */
|
||||||
|
#define FT_MODULE_HINTER 4 /* this module is a glyph hinter */
|
||||||
|
#define FT_MODULE_STYLER 8 /* this module is a styler */
|
||||||
|
|
||||||
|
#define FT_MODULE_DRIVER_SCALABLE 0x100 /* the driver supports */
|
||||||
|
/* scalable fonts */
|
||||||
|
#define FT_MODULE_DRIVER_NO_OUTLINES 0x200 /* the driver does not */
|
||||||
|
/* support vector outlines */
|
||||||
|
#define FT_MODULE_DRIVER_HAS_HINTER 0x400 /* the driver provides its */
|
||||||
|
/* own hinter */
|
||||||
|
#define FT_MODULE_DRIVER_HINTS_LIGHTLY 0x800 /* the driver's hinter */
|
||||||
|
/* produces LIGHT hints */
|
||||||
|
|
||||||
|
|
||||||
|
/* deprecated values */
|
||||||
|
#define ft_module_font_driver FT_MODULE_FONT_DRIVER
|
||||||
|
#define ft_module_renderer FT_MODULE_RENDERER
|
||||||
|
#define ft_module_hinter FT_MODULE_HINTER
|
||||||
|
#define ft_module_styler FT_MODULE_STYLER
|
||||||
|
|
||||||
|
#define ft_module_driver_scalable FT_MODULE_DRIVER_SCALABLE
|
||||||
|
#define ft_module_driver_no_outlines FT_MODULE_DRIVER_NO_OUTLINES
|
||||||
|
#define ft_module_driver_has_hinter FT_MODULE_DRIVER_HAS_HINTER
|
||||||
|
#define ft_module_driver_hints_lightly FT_MODULE_DRIVER_HINTS_LIGHTLY
|
||||||
|
|
||||||
|
|
||||||
|
typedef FT_Pointer FT_Module_Interface;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Module_Constructor
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to initialize (not create) a new module object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* module ::
|
||||||
|
* The module to initialize.
|
||||||
|
*/
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Module_Constructor)( FT_Module module );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Module_Destructor
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to finalize (not destroy) a given module object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* module ::
|
||||||
|
* The module to finalize.
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*FT_Module_Destructor)( FT_Module module );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Module_Requester
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to query a given module for a specific interface.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* module ::
|
||||||
|
* The module to be searched.
|
||||||
|
*
|
||||||
|
* name ::
|
||||||
|
* The name of the interface in the module.
|
||||||
|
*/
|
||||||
|
typedef FT_Module_Interface
|
||||||
|
(*FT_Module_Requester)( FT_Module module,
|
||||||
|
const char* name );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Module_Class
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The module class descriptor. While being a public structure necessary
|
||||||
|
* for FreeType's module bookkeeping, most of the fields are essentially
|
||||||
|
* internal, not to be used directly by an application.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* module_flags ::
|
||||||
|
* Bit flags describing the module.
|
||||||
|
*
|
||||||
|
* module_size ::
|
||||||
|
* The size of one module object/instance in bytes.
|
||||||
|
*
|
||||||
|
* module_name ::
|
||||||
|
* The name of the module.
|
||||||
|
*
|
||||||
|
* module_version ::
|
||||||
|
* The version, as a 16.16 fixed number (major.minor).
|
||||||
|
*
|
||||||
|
* module_requires ::
|
||||||
|
* The version of FreeType this module requires, as a 16.16 fixed
|
||||||
|
* number (major.minor). Starts at version 2.0, i.e., 0x20000.
|
||||||
|
*
|
||||||
|
* module_interface ::
|
||||||
|
* A typeless pointer to a structure (which varies between different
|
||||||
|
* modules) that holds the module's interface functions. This is
|
||||||
|
* essentially what `get_interface` returns.
|
||||||
|
*
|
||||||
|
* module_init ::
|
||||||
|
* The initializing function.
|
||||||
|
*
|
||||||
|
* module_done ::
|
||||||
|
* The finalizing function.
|
||||||
|
*
|
||||||
|
* get_interface ::
|
||||||
|
* The interface requesting function.
|
||||||
|
*/
|
||||||
|
typedef struct FT_Module_Class_
|
||||||
|
{
|
||||||
|
FT_ULong module_flags;
|
||||||
|
FT_Long module_size;
|
||||||
|
const FT_String* module_name;
|
||||||
|
FT_Fixed module_version;
|
||||||
|
FT_Fixed module_requires;
|
||||||
|
|
||||||
|
const void* module_interface;
|
||||||
|
|
||||||
|
FT_Module_Constructor module_init;
|
||||||
|
FT_Module_Destructor module_done;
|
||||||
|
FT_Module_Requester get_interface;
|
||||||
|
|
||||||
|
} FT_Module_Class;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Add_Module
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Add a new module to a given library instance.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* clazz ::
|
||||||
|
* A pointer to class descriptor for the module.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* An error will be returned if a module already exists by that name, or
|
||||||
|
* if the module requires a version of FreeType that is too great.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Add_Module( FT_Library library,
|
||||||
|
const FT_Module_Class* clazz );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Module
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Find a module by its name.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library object.
|
||||||
|
*
|
||||||
|
* module_name ::
|
||||||
|
* The module's name (as an ASCII string).
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* A module handle. 0~if none was found.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* FreeType's internal modules aren't documented very well, and you
|
||||||
|
* should look up the source code for details.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Module )
|
||||||
|
FT_Get_Module( FT_Library library,
|
||||||
|
const char* module_name );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Remove_Module
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Remove a given module from a library instance.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to a library object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* module ::
|
||||||
|
* A handle to a module object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The module object is destroyed by the function in case of success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Remove_Module( FT_Library library,
|
||||||
|
FT_Module module );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_FACE_DRIVER_NAME
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A macro that retrieves the name of a font driver from a face object.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The font driver name is a valid `module_name` for @FT_Property_Set
|
||||||
|
* and @FT_Property_Get. This is not the same as @FT_Get_Font_Format.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.11
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_FACE_DRIVER_NAME( face ) \
|
||||||
|
( ( *FT_REINTERPRET_CAST( FT_Module_Class**, \
|
||||||
|
( face )->driver ) )->module_name )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Property_Set
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Set a property for a given module.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library the module is part of.
|
||||||
|
*
|
||||||
|
* module_name ::
|
||||||
|
* The module name.
|
||||||
|
*
|
||||||
|
* property_name ::
|
||||||
|
* The property name. Properties are described in section
|
||||||
|
* @properties.
|
||||||
|
*
|
||||||
|
* Note that only a few modules have properties.
|
||||||
|
*
|
||||||
|
* value ::
|
||||||
|
* A generic pointer to a variable or structure that gives the new
|
||||||
|
* value of the property. The exact definition of `value` is
|
||||||
|
* dependent on the property; see section @properties.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If `module_name` isn't a valid module name, or `property_name`
|
||||||
|
* doesn't specify a valid property, or if `value` doesn't represent a
|
||||||
|
* valid value for the given property, an error is returned.
|
||||||
|
*
|
||||||
|
* The following example sets property 'bar' (a simple integer) in
|
||||||
|
* module 'foo' to value~1.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_UInt bar;
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* bar = 1;
|
||||||
|
* FT_Property_Set( library, "foo", "bar", &bar );
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Note that the FreeType Cache sub-system doesn't recognize module
|
||||||
|
* property changes. To avoid glyph lookup confusion within the cache
|
||||||
|
* you should call @FTC_Manager_Reset to completely flush the cache if a
|
||||||
|
* module property gets changed after @FTC_Manager_New has been called.
|
||||||
|
*
|
||||||
|
* It is not possible to set properties of the FreeType Cache sub-system
|
||||||
|
* itself with FT_Property_Set; use @FTC_Property_Set instead.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.4.11
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Property_Set( FT_Library library,
|
||||||
|
const FT_String* module_name,
|
||||||
|
const FT_String* property_name,
|
||||||
|
const void* value );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Property_Get
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Get a module's property value.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library the module is part of.
|
||||||
|
*
|
||||||
|
* module_name ::
|
||||||
|
* The module name.
|
||||||
|
*
|
||||||
|
* property_name ::
|
||||||
|
* The property name. Properties are described in section
|
||||||
|
* @properties.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* value ::
|
||||||
|
* A generic pointer to a variable or structure that gives the value
|
||||||
|
* of the property. The exact definition of `value` is dependent on
|
||||||
|
* the property; see section @properties.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If `module_name` isn't a valid module name, or `property_name`
|
||||||
|
* doesn't specify a valid property, or if `value` doesn't represent a
|
||||||
|
* valid value for the given property, an error is returned.
|
||||||
|
*
|
||||||
|
* The following example gets property 'baz' (a range) in module 'foo'.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* typedef range_
|
||||||
|
* {
|
||||||
|
* FT_Int32 min;
|
||||||
|
* FT_Int32 max;
|
||||||
|
*
|
||||||
|
* } range;
|
||||||
|
*
|
||||||
|
* range baz;
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* FT_Property_Get( library, "foo", "baz", &baz );
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* It is not possible to retrieve properties of the FreeType Cache
|
||||||
|
* sub-system with FT_Property_Get; use @FTC_Property_Get instead.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.4.11
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Property_Get( FT_Library library,
|
||||||
|
const FT_String* module_name,
|
||||||
|
const FT_String* property_name,
|
||||||
|
void* value );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_Default_Properties
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* If compilation option `FT_CONFIG_OPTION_ENVIRONMENT_PROPERTIES` is
|
||||||
|
* set, this function reads the `FREETYPE_PROPERTIES` environment
|
||||||
|
* variable to control driver properties. See section @properties for
|
||||||
|
* more.
|
||||||
|
*
|
||||||
|
* If the compilation option is not set, this function does nothing.
|
||||||
|
*
|
||||||
|
* `FREETYPE_PROPERTIES` has the following syntax form (broken here into
|
||||||
|
* multiple lines for better readability).
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* <optional whitespace>
|
||||||
|
* <module-name1> ':'
|
||||||
|
* <property-name1> '=' <property-value1>
|
||||||
|
* <whitespace>
|
||||||
|
* <module-name2> ':'
|
||||||
|
* <property-name2> '=' <property-value2>
|
||||||
|
* ...
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FREETYPE_PROPERTIES=truetype:interpreter-version=35 \
|
||||||
|
* cff:no-stem-darkening=0
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to a new library object.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Set_Default_Properties( FT_Library library );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Reference_Library
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A counter gets initialized to~1 at the time an @FT_Library structure
|
||||||
|
* is created. This function increments the counter. @FT_Done_Library
|
||||||
|
* then only destroys a library if the counter is~1, otherwise it simply
|
||||||
|
* decrements the counter.
|
||||||
|
*
|
||||||
|
* This function helps in managing life-cycles of structures that
|
||||||
|
* reference @FT_Library objects.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to a target library object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.4.2
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Reference_Library( FT_Library library );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_New_Library
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This function is used to create a new FreeType library instance from a
|
||||||
|
* given memory object. It is thus possible to use libraries with
|
||||||
|
* distinct memory allocators within the same program. Note, however,
|
||||||
|
* that the used @FT_Memory structure is expected to remain valid for the
|
||||||
|
* life of the @FT_Library object.
|
||||||
|
*
|
||||||
|
* Normally, you would call this function (followed by a call to
|
||||||
|
* @FT_Add_Default_Modules or a series of calls to @FT_Add_Module, and a
|
||||||
|
* call to @FT_Set_Default_Properties) instead of @FT_Init_FreeType to
|
||||||
|
* initialize the FreeType library.
|
||||||
|
*
|
||||||
|
* Don't use @FT_Done_FreeType but @FT_Done_Library to destroy a library
|
||||||
|
* instance.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* memory ::
|
||||||
|
* A handle to the original memory object.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* alibrary ::
|
||||||
|
* A pointer to handle of a new library object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* See the discussion of reference counters in the description of
|
||||||
|
* @FT_Reference_Library.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_New_Library( FT_Memory memory,
|
||||||
|
FT_Library *alibrary );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Done_Library
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Discard a given library object. This closes all drivers and discards
|
||||||
|
* all resource objects.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the target library.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* See the discussion of reference counters in the description of
|
||||||
|
* @FT_Reference_Library.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Done_Library( FT_Library library );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_DebugHook_Func
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A drop-in replacement (or rather a wrapper) for the bytecode or
|
||||||
|
* charstring interpreter's main loop function.
|
||||||
|
*
|
||||||
|
* Its job is essentially
|
||||||
|
*
|
||||||
|
* - to activate debug mode to enforce single-stepping,
|
||||||
|
*
|
||||||
|
* - to call the main loop function to interpret the next opcode, and
|
||||||
|
*
|
||||||
|
* - to show the changed context to the user.
|
||||||
|
*
|
||||||
|
* An example for such a main loop function is `TT_RunIns` (declared in
|
||||||
|
* FreeType's internal header file `src/truetype/ttinterp.h`).
|
||||||
|
*
|
||||||
|
* Have a look at the source code of the `ttdebug` FreeType demo program
|
||||||
|
* for an example of a drop-in replacement.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* arg ::
|
||||||
|
* A typeless pointer, to be cast to the main loop function's data
|
||||||
|
* structure (which depends on the font module). For TrueType fonts
|
||||||
|
* it is bytecode interpreter's execution context, `TT_ExecContext`,
|
||||||
|
* which is declared in FreeType's internal header file `tttypes.h`.
|
||||||
|
*/
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_DebugHook_Func)( void* arg );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_DEBUG_HOOK_XXX
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of named debug hook indices.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_DEBUG_HOOK_TRUETYPE::
|
||||||
|
* This hook index identifies the TrueType bytecode debugger.
|
||||||
|
*/
|
||||||
|
#define FT_DEBUG_HOOK_TRUETYPE 0
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_Debug_Hook
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Set a debug hook function for debugging the interpreter of a font
|
||||||
|
* format.
|
||||||
|
*
|
||||||
|
* While this is a public API function, an application needs access to
|
||||||
|
* FreeType's internal header files to do something useful.
|
||||||
|
*
|
||||||
|
* Have a look at the source code of the `ttdebug` FreeType demo program
|
||||||
|
* for an example of its usage.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* hook_index ::
|
||||||
|
* The index of the debug hook. You should use defined enumeration
|
||||||
|
* macros like @FT_DEBUG_HOOK_TRUETYPE.
|
||||||
|
*
|
||||||
|
* debug_hook ::
|
||||||
|
* The function used to debug the interpreter.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Currently, four debug hook slots are available, but only one (for the
|
||||||
|
* TrueType interpreter) is defined.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Set_Debug_Hook( FT_Library library,
|
||||||
|
FT_UInt hook_index,
|
||||||
|
FT_DebugHook_Func debug_hook );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Add_Default_Modules
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Add the set of default drivers to a given library object. This is
|
||||||
|
* only useful when you create a library object with @FT_New_Library
|
||||||
|
* (usually to plug a custom memory manager).
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to a new library object.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Add_Default_Modules( FT_Library library );
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* truetype_engine
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* The TrueType Engine
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* TrueType bytecode support.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains a function used to query the level of TrueType
|
||||||
|
* bytecode support compiled in this version of the library.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_TrueTypeEngineType
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of values describing which kind of TrueType bytecode engine is
|
||||||
|
* implemented in a given FT_Library instance. It is used by the
|
||||||
|
* @FT_Get_TrueType_Engine_Type function.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_TRUETYPE_ENGINE_TYPE_NONE ::
|
||||||
|
* The library doesn't implement any kind of bytecode interpreter.
|
||||||
|
*
|
||||||
|
* FT_TRUETYPE_ENGINE_TYPE_UNPATENTED ::
|
||||||
|
* Deprecated and removed.
|
||||||
|
*
|
||||||
|
* FT_TRUETYPE_ENGINE_TYPE_PATENTED ::
|
||||||
|
* The library implements a bytecode interpreter that covers the full
|
||||||
|
* instruction set of the TrueType virtual machine (this was governed
|
||||||
|
* by patents until May 2010, hence the name).
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef enum FT_TrueTypeEngineType_
|
||||||
|
{
|
||||||
|
FT_TRUETYPE_ENGINE_TYPE_NONE = 0,
|
||||||
|
FT_TRUETYPE_ENGINE_TYPE_UNPATENTED,
|
||||||
|
FT_TRUETYPE_ENGINE_TYPE_PATENTED
|
||||||
|
|
||||||
|
} FT_TrueTypeEngineType;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_TrueType_Engine_Type
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return an @FT_TrueTypeEngineType value to indicate which level of the
|
||||||
|
* TrueType virtual machine a given library instance supports.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A library instance.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* A value indicating which level is supported.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_TrueTypeEngineType )
|
||||||
|
FT_Get_TrueType_Engine_Type( FT_Library library );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTMODAPI_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,204 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftmoderr.h
|
||||||
|
*
|
||||||
|
* FreeType module error offsets (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2001-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* This file is used to define the FreeType module error codes.
|
||||||
|
*
|
||||||
|
* If the macro `FT_CONFIG_OPTION_USE_MODULE_ERRORS` in `ftoption.h` is
|
||||||
|
* set, the lower byte of an error value identifies the error code as
|
||||||
|
* usual. In addition, the higher byte identifies the module. For
|
||||||
|
* example, the error `FT_Err_Invalid_File_Format` has value 0x0003, the
|
||||||
|
* error `TT_Err_Invalid_File_Format` has value 0x1303, the error
|
||||||
|
* `T1_Err_Invalid_File_Format` has value 0x1403, etc.
|
||||||
|
*
|
||||||
|
* Note that `FT_Err_Ok`, `TT_Err_Ok`, etc. are always equal to zero,
|
||||||
|
* including the high byte.
|
||||||
|
*
|
||||||
|
* If `FT_CONFIG_OPTION_USE_MODULE_ERRORS` isn't set, the higher byte of an
|
||||||
|
* error value is set to zero.
|
||||||
|
*
|
||||||
|
* To hide the various `XXX_Err_` prefixes in the source code, FreeType
|
||||||
|
* provides some macros in `fttypes.h`.
|
||||||
|
*
|
||||||
|
* FT_ERR( err )
|
||||||
|
*
|
||||||
|
* Add current error module prefix (as defined with the `FT_ERR_PREFIX`
|
||||||
|
* macro) to `err`. For example, in the BDF module the line
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* error = FT_ERR( Invalid_Outline );
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* expands to
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* error = BDF_Err_Invalid_Outline;
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* For simplicity, you can always use `FT_Err_Ok` directly instead of
|
||||||
|
* `FT_ERR( Ok )`.
|
||||||
|
*
|
||||||
|
* FT_ERR_EQ( errcode, err )
|
||||||
|
* FT_ERR_NEQ( errcode, err )
|
||||||
|
*
|
||||||
|
* Compare error code `errcode` with the error `err` for equality and
|
||||||
|
* inequality, respectively. Example:
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* if ( FT_ERR_EQ( error, Invalid_Outline ) )
|
||||||
|
* ...
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Using this macro you don't have to think about error prefixes. Of
|
||||||
|
* course, if module errors are not active, the above example is the
|
||||||
|
* same as
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* if ( error == FT_Err_Invalid_Outline )
|
||||||
|
* ...
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* FT_ERROR_BASE( errcode )
|
||||||
|
* FT_ERROR_MODULE( errcode )
|
||||||
|
*
|
||||||
|
* Get base error and module error code, respectively.
|
||||||
|
*
|
||||||
|
* It can also be used to create a module error message table easily with
|
||||||
|
* something like
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* #undef FTMODERR_H_
|
||||||
|
* #define FT_MODERRDEF( e, v, s ) { FT_Mod_Err_ ## e, s },
|
||||||
|
* #define FT_MODERR_START_LIST {
|
||||||
|
* #define FT_MODERR_END_LIST { 0, 0 } };
|
||||||
|
*
|
||||||
|
* const struct
|
||||||
|
* {
|
||||||
|
* int mod_err_offset;
|
||||||
|
* const char* mod_err_msg
|
||||||
|
* } ft_mod_errors[] =
|
||||||
|
*
|
||||||
|
* #include <freetype/ftmoderr.h>
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTMODERR_H_
|
||||||
|
#define FTMODERR_H_
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
/***** *****/
|
||||||
|
/***** SETUP MACROS *****/
|
||||||
|
/***** *****/
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#undef FT_NEED_EXTERN_C
|
||||||
|
|
||||||
|
#ifndef FT_MODERRDEF
|
||||||
|
|
||||||
|
#ifdef FT_CONFIG_OPTION_USE_MODULE_ERRORS
|
||||||
|
#define FT_MODERRDEF( e, v, s ) FT_Mod_Err_ ## e = v,
|
||||||
|
#else
|
||||||
|
#define FT_MODERRDEF( e, v, s ) FT_Mod_Err_ ## e = 0,
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define FT_MODERR_START_LIST enum {
|
||||||
|
#define FT_MODERR_END_LIST FT_Mod_Err_Max };
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define FT_NEED_EXTERN_C
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* !FT_MODERRDEF */
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
/***** *****/
|
||||||
|
/***** LIST MODULE ERROR BASES *****/
|
||||||
|
/***** *****/
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_MODERR_START_LIST
|
||||||
|
FT_MODERR_START_LIST
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_MODERRDEF( Base, 0x000, "base module" )
|
||||||
|
FT_MODERRDEF( Autofit, 0x100, "autofitter module" )
|
||||||
|
FT_MODERRDEF( BDF, 0x200, "BDF module" )
|
||||||
|
FT_MODERRDEF( Bzip2, 0x300, "Bzip2 module" )
|
||||||
|
FT_MODERRDEF( Cache, 0x400, "cache module" )
|
||||||
|
FT_MODERRDEF( CFF, 0x500, "CFF module" )
|
||||||
|
FT_MODERRDEF( CID, 0x600, "CID module" )
|
||||||
|
FT_MODERRDEF( Gzip, 0x700, "Gzip module" )
|
||||||
|
FT_MODERRDEF( LZW, 0x800, "LZW module" )
|
||||||
|
FT_MODERRDEF( OTvalid, 0x900, "OpenType validation module" )
|
||||||
|
FT_MODERRDEF( PCF, 0xA00, "PCF module" )
|
||||||
|
FT_MODERRDEF( PFR, 0xB00, "PFR module" )
|
||||||
|
FT_MODERRDEF( PSaux, 0xC00, "PS auxiliary module" )
|
||||||
|
FT_MODERRDEF( PShinter, 0xD00, "PS hinter module" )
|
||||||
|
FT_MODERRDEF( PSnames, 0xE00, "PS names module" )
|
||||||
|
FT_MODERRDEF( Raster, 0xF00, "raster module" )
|
||||||
|
FT_MODERRDEF( SFNT, 0x1000, "SFNT module" )
|
||||||
|
FT_MODERRDEF( Smooth, 0x1100, "smooth raster module" )
|
||||||
|
FT_MODERRDEF( TrueType, 0x1200, "TrueType module" )
|
||||||
|
FT_MODERRDEF( Type1, 0x1300, "Type 1 module" )
|
||||||
|
FT_MODERRDEF( Type42, 0x1400, "Type 42 module" )
|
||||||
|
FT_MODERRDEF( Winfonts, 0x1500, "Windows FON/FNT module" )
|
||||||
|
FT_MODERRDEF( GXvalid, 0x1600, "GX validation module" )
|
||||||
|
FT_MODERRDEF( Sdf, 0x1700, "Signed distance field raster module" )
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_MODERR_END_LIST
|
||||||
|
FT_MODERR_END_LIST
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
/***** *****/
|
||||||
|
/***** CLEANUP *****/
|
||||||
|
/***** *****/
|
||||||
|
/*******************************************************************/
|
||||||
|
/*******************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_NEED_EXTERN_C
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef FT_MODERR_START_LIST
|
||||||
|
#undef FT_MODERR_END_LIST
|
||||||
|
#undef FT_MODERRDEF
|
||||||
|
#undef FT_NEED_EXTERN_C
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* FTMODERR_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,206 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftotval.h
|
||||||
|
*
|
||||||
|
* FreeType API for validating OpenType tables (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2004-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* Warning: This module might be moved to a different library in the
|
||||||
|
* future to avoid a tight dependency between FreeType and the
|
||||||
|
* OpenType specification.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTOTVAL_H_
|
||||||
|
#define FTOTVAL_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* ot_validation
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* OpenType Validation
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* An API to validate OpenType tables.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the declaration of functions to validate some
|
||||||
|
* OpenType tables (BASE, GDEF, GPOS, GSUB, JSTF, MATH).
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* FT_OpenType_Validate
|
||||||
|
* FT_OpenType_Free
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_OTXXX
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_VALIDATE_OTXXX
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of bit-field constants used with @FT_OpenType_Validate to
|
||||||
|
* indicate which OpenType tables should be validated.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_VALIDATE_BASE ::
|
||||||
|
* Validate BASE table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_GDEF ::
|
||||||
|
* Validate GDEF table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_GPOS ::
|
||||||
|
* Validate GPOS table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_GSUB ::
|
||||||
|
* Validate GSUB table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_JSTF ::
|
||||||
|
* Validate JSTF table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_MATH ::
|
||||||
|
* Validate MATH table.
|
||||||
|
*
|
||||||
|
* FT_VALIDATE_OT ::
|
||||||
|
* Validate all OpenType tables (BASE, GDEF, GPOS, GSUB, JSTF, MATH).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_VALIDATE_BASE 0x0100
|
||||||
|
#define FT_VALIDATE_GDEF 0x0200
|
||||||
|
#define FT_VALIDATE_GPOS 0x0400
|
||||||
|
#define FT_VALIDATE_GSUB 0x0800
|
||||||
|
#define FT_VALIDATE_JSTF 0x1000
|
||||||
|
#define FT_VALIDATE_MATH 0x2000
|
||||||
|
|
||||||
|
#define FT_VALIDATE_OT ( FT_VALIDATE_BASE | \
|
||||||
|
FT_VALIDATE_GDEF | \
|
||||||
|
FT_VALIDATE_GPOS | \
|
||||||
|
FT_VALIDATE_GSUB | \
|
||||||
|
FT_VALIDATE_JSTF | \
|
||||||
|
FT_VALIDATE_MATH )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_OpenType_Validate
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Validate various OpenType tables to assure that all offsets and
|
||||||
|
* indices are valid. The idea is that a higher-level library that
|
||||||
|
* actually does the text layout can access those tables without error
|
||||||
|
* checking (which can be quite time consuming).
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* validation_flags ::
|
||||||
|
* A bit field that specifies the tables to be validated. See
|
||||||
|
* @FT_VALIDATE_OTXXX for possible values.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* BASE_table ::
|
||||||
|
* A pointer to the BASE table.
|
||||||
|
*
|
||||||
|
* GDEF_table ::
|
||||||
|
* A pointer to the GDEF table.
|
||||||
|
*
|
||||||
|
* GPOS_table ::
|
||||||
|
* A pointer to the GPOS table.
|
||||||
|
*
|
||||||
|
* GSUB_table ::
|
||||||
|
* A pointer to the GSUB table.
|
||||||
|
*
|
||||||
|
* JSTF_table ::
|
||||||
|
* A pointer to the JSTF table.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function only works with OpenType fonts, returning an error
|
||||||
|
* otherwise.
|
||||||
|
*
|
||||||
|
* After use, the application should deallocate the five tables with
|
||||||
|
* @FT_OpenType_Free. A `NULL` value indicates that the table either
|
||||||
|
* doesn't exist in the font, or the application hasn't asked for
|
||||||
|
* validation.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_OpenType_Validate( FT_Face face,
|
||||||
|
FT_UInt validation_flags,
|
||||||
|
FT_Bytes *BASE_table,
|
||||||
|
FT_Bytes *GDEF_table,
|
||||||
|
FT_Bytes *GPOS_table,
|
||||||
|
FT_Bytes *GSUB_table,
|
||||||
|
FT_Bytes *JSTF_table );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_OpenType_Free
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Free the buffer allocated by OpenType validator.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* table ::
|
||||||
|
* The pointer to the buffer that is allocated by
|
||||||
|
* @FT_OpenType_Validate.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function must be used to free the buffer allocated by
|
||||||
|
* @FT_OpenType_Validate only.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_OpenType_Free( FT_Face face,
|
||||||
|
FT_Bytes table );
|
||||||
|
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTOTVAL_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,588 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftoutln.h
|
||||||
|
*
|
||||||
|
* Support for the FT_Outline type used to store glyph shapes of
|
||||||
|
* most scalable font formats (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTOUTLN_H_
|
||||||
|
#define FTOUTLN_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* outline_processing
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Outline Processing
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Functions to create, transform, and render vectorial glyph images.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains routines used to create and destroy scalable
|
||||||
|
* glyph images known as 'outlines'. These can also be measured,
|
||||||
|
* transformed, and converted into bitmaps and pixmaps.
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* FT_Outline
|
||||||
|
* FT_Outline_New
|
||||||
|
* FT_Outline_Done
|
||||||
|
* FT_Outline_Copy
|
||||||
|
* FT_Outline_Translate
|
||||||
|
* FT_Outline_Transform
|
||||||
|
* FT_Outline_Embolden
|
||||||
|
* FT_Outline_EmboldenXY
|
||||||
|
* FT_Outline_Reverse
|
||||||
|
* FT_Outline_Check
|
||||||
|
*
|
||||||
|
* FT_Outline_Get_CBox
|
||||||
|
* FT_Outline_Get_BBox
|
||||||
|
*
|
||||||
|
* FT_Outline_Get_Bitmap
|
||||||
|
* FT_Outline_Render
|
||||||
|
* FT_Outline_Decompose
|
||||||
|
* FT_Outline_Funcs
|
||||||
|
* FT_Outline_MoveToFunc
|
||||||
|
* FT_Outline_LineToFunc
|
||||||
|
* FT_Outline_ConicToFunc
|
||||||
|
* FT_Outline_CubicToFunc
|
||||||
|
*
|
||||||
|
* FT_Orientation
|
||||||
|
* FT_Outline_Get_Orientation
|
||||||
|
*
|
||||||
|
* FT_OUTLINE_XXX
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Decompose
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Walk over an outline's structure to decompose it into individual
|
||||||
|
* segments and Bezier arcs. This function also emits 'move to'
|
||||||
|
* operations to indicate the start of new contours in the outline.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the source target.
|
||||||
|
*
|
||||||
|
* func_interface ::
|
||||||
|
* A table of 'emitters', i.e., function pointers called during
|
||||||
|
* decomposition to indicate path operations.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* user ::
|
||||||
|
* A typeless pointer that is passed to each emitter during the
|
||||||
|
* decomposition. It can be used to store the state during the
|
||||||
|
* decomposition.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Degenerate contours, segments, and Bezier arcs may be reported. In
|
||||||
|
* most cases, it is best to filter these out before using the outline
|
||||||
|
* for stroking or other path modification purposes (which may cause
|
||||||
|
* degenerate segments to become non-degenrate and visible, like when
|
||||||
|
* stroke caps are used or the path is otherwise outset). Some glyph
|
||||||
|
* outlines may contain deliberate degenerate single points for mark
|
||||||
|
* attachement.
|
||||||
|
*
|
||||||
|
* Similarly, the function returns success for an empty outline also
|
||||||
|
* (doing nothing, this is, not calling any emitter); if necessary, you
|
||||||
|
* should filter this out, too.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_Decompose( FT_Outline* outline,
|
||||||
|
const FT_Outline_Funcs* func_interface,
|
||||||
|
void* user );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_New
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Create a new outline of a given size.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library object from where the outline is allocated.
|
||||||
|
* Note however that the new outline will **not** necessarily be
|
||||||
|
* **freed**, when destroying the library, by @FT_Done_FreeType.
|
||||||
|
*
|
||||||
|
* numPoints ::
|
||||||
|
* The maximum number of points within the outline. Must be smaller
|
||||||
|
* than or equal to 0xFFFF (65535).
|
||||||
|
*
|
||||||
|
* numContours ::
|
||||||
|
* The maximum number of contours within the outline. This value must
|
||||||
|
* be in the range 0 to `numPoints`.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* anoutline ::
|
||||||
|
* A handle to the new outline.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The reason why this function takes a `library` parameter is simply to
|
||||||
|
* use the library's memory allocator.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_New( FT_Library library,
|
||||||
|
FT_UInt numPoints,
|
||||||
|
FT_Int numContours,
|
||||||
|
FT_Outline *anoutline );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Done
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Destroy an outline created with @FT_Outline_New.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle of the library object used to allocate the outline.
|
||||||
|
*
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the outline object to be discarded.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If the outline's 'owner' field is not set, only the outline descriptor
|
||||||
|
* will be released.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_Done( FT_Library library,
|
||||||
|
FT_Outline* outline );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Check
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Check the contents of an outline descriptor.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* outline ::
|
||||||
|
* A handle to a source outline.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* An empty outline, or an outline with a single point only is also
|
||||||
|
* valid.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_Check( FT_Outline* outline );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Get_CBox
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return an outline's 'control box'. The control box encloses all the
|
||||||
|
* outline's points, including Bezier control points. Though it
|
||||||
|
* coincides with the exact bounding box for most glyphs, it can be
|
||||||
|
* slightly larger in some situations (like when rotating an outline that
|
||||||
|
* contains Bezier outside arcs).
|
||||||
|
*
|
||||||
|
* Computing the control box is very fast, while getting the bounding box
|
||||||
|
* can take much more time as it needs to walk over all segments and arcs
|
||||||
|
* in the outline. To get the latter, you can use the 'ftbbox'
|
||||||
|
* component, which is dedicated to this single task.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the source outline descriptor.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* acbox ::
|
||||||
|
* The outline's control box.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* See @FT_Glyph_Get_CBox for a discussion of tricky fonts.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Outline_Get_CBox( const FT_Outline* outline,
|
||||||
|
FT_BBox *acbox );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Translate
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Apply a simple translation to the points of an outline.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the target outline descriptor.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* xOffset ::
|
||||||
|
* The horizontal offset.
|
||||||
|
*
|
||||||
|
* yOffset ::
|
||||||
|
* The vertical offset.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Outline_Translate( const FT_Outline* outline,
|
||||||
|
FT_Pos xOffset,
|
||||||
|
FT_Pos yOffset );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Copy
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Copy an outline into another one. Both objects must have the same
|
||||||
|
* sizes (number of points & number of contours) when this function is
|
||||||
|
* called.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* source ::
|
||||||
|
* A handle to the source outline.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* target ::
|
||||||
|
* A handle to the target outline.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_Copy( const FT_Outline* source,
|
||||||
|
FT_Outline *target );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Transform
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Apply a simple 2x2 matrix to all of an outline's points. Useful for
|
||||||
|
* applying rotations, slanting, flipping, etc.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the target outline descriptor.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* matrix ::
|
||||||
|
* A pointer to the transformation matrix.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You can use @FT_Outline_Translate if you need to translate the
|
||||||
|
* outline's points.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Outline_Transform( const FT_Outline* outline,
|
||||||
|
const FT_Matrix* matrix );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Embolden
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Embolden an outline. The new outline will be at most 4~times
|
||||||
|
* `strength` pixels wider and higher. You may think of the left and
|
||||||
|
* bottom borders as unchanged.
|
||||||
|
*
|
||||||
|
* Negative `strength` values to reduce the outline thickness are
|
||||||
|
* possible also.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* outline ::
|
||||||
|
* A handle to the target outline.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* strength ::
|
||||||
|
* How strong the glyph is emboldened. Expressed in 26.6 pixel format.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The used algorithm to increase or decrease the thickness of the glyph
|
||||||
|
* doesn't change the number of points; this means that certain
|
||||||
|
* situations like acute angles or intersections are sometimes handled
|
||||||
|
* incorrectly.
|
||||||
|
*
|
||||||
|
* If you need 'better' metrics values you should call
|
||||||
|
* @FT_Outline_Get_CBox or @FT_Outline_Get_BBox.
|
||||||
|
*
|
||||||
|
* To get meaningful results, font scaling values must be set with
|
||||||
|
* functions like @FT_Set_Char_Size before calling FT_Render_Glyph.
|
||||||
|
*
|
||||||
|
* @example:
|
||||||
|
* ```
|
||||||
|
* FT_Load_Glyph( face, index, FT_LOAD_DEFAULT );
|
||||||
|
*
|
||||||
|
* if ( face->glyph->format == FT_GLYPH_FORMAT_OUTLINE )
|
||||||
|
* FT_Outline_Embolden( &face->glyph->outline, strength );
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_Embolden( FT_Outline* outline,
|
||||||
|
FT_Pos strength );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_EmboldenXY
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Embolden an outline. The new outline will be `xstrength` pixels wider
|
||||||
|
* and `ystrength` pixels higher. Otherwise, it is similar to
|
||||||
|
* @FT_Outline_Embolden, which uses the same strength in both directions.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.4.10
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_EmboldenXY( FT_Outline* outline,
|
||||||
|
FT_Pos xstrength,
|
||||||
|
FT_Pos ystrength );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Reverse
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Reverse the drawing direction of an outline. This is used to ensure
|
||||||
|
* consistent fill conventions for mirrored glyphs.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the target outline descriptor.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function toggles the bit flag @FT_OUTLINE_REVERSE_FILL in the
|
||||||
|
* outline's `flags` field.
|
||||||
|
*
|
||||||
|
* It shouldn't be used by a normal client application, unless it knows
|
||||||
|
* what it is doing.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Outline_Reverse( FT_Outline* outline );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Get_Bitmap
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Render an outline within a bitmap. The outline's image is simply
|
||||||
|
* OR-ed to the target bitmap.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to a FreeType library object.
|
||||||
|
*
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the source outline descriptor.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* abitmap ::
|
||||||
|
* A pointer to the target bitmap descriptor.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function does **not create** the bitmap, it only renders an
|
||||||
|
* outline image within the one you pass to it! Consequently, the
|
||||||
|
* various fields in `abitmap` should be set accordingly.
|
||||||
|
*
|
||||||
|
* It will use the raster corresponding to the default glyph format.
|
||||||
|
*
|
||||||
|
* The value of the `num_grays` field in `abitmap` is ignored. If you
|
||||||
|
* select the gray-level rasterizer, and you want less than 256 gray
|
||||||
|
* levels, you have to use @FT_Outline_Render directly.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_Get_Bitmap( FT_Library library,
|
||||||
|
FT_Outline* outline,
|
||||||
|
const FT_Bitmap *abitmap );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Render
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Render an outline within a bitmap using the current scan-convert.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to a FreeType library object.
|
||||||
|
*
|
||||||
|
* outline ::
|
||||||
|
* A pointer to the source outline descriptor.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* params ::
|
||||||
|
* A pointer to an @FT_Raster_Params structure used to describe the
|
||||||
|
* rendering operation.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This advanced function uses @FT_Raster_Params as an argument.
|
||||||
|
* The field `params.source` will be set to `outline` before the scan
|
||||||
|
* converter is called, which means that the value you give to it is
|
||||||
|
* actually ignored. Either `params.target` must point to preallocated
|
||||||
|
* bitmap, or @FT_RASTER_FLAG_DIRECT must be set in `params.flags`
|
||||||
|
* allowing FreeType rasterizer to be used for direct composition,
|
||||||
|
* translucency, etc. See @FT_Raster_Params for more details.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Outline_Render( FT_Library library,
|
||||||
|
FT_Outline* outline,
|
||||||
|
FT_Raster_Params* params );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_Orientation
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of values used to describe an outline's contour orientation.
|
||||||
|
*
|
||||||
|
* The TrueType and PostScript specifications use different conventions
|
||||||
|
* to determine whether outline contours should be filled or unfilled.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_ORIENTATION_TRUETYPE ::
|
||||||
|
* According to the TrueType specification, clockwise contours must be
|
||||||
|
* filled, and counter-clockwise ones must be unfilled.
|
||||||
|
*
|
||||||
|
* FT_ORIENTATION_POSTSCRIPT ::
|
||||||
|
* According to the PostScript specification, counter-clockwise
|
||||||
|
* contours must be filled, and clockwise ones must be unfilled.
|
||||||
|
*
|
||||||
|
* FT_ORIENTATION_FILL_RIGHT ::
|
||||||
|
* This is identical to @FT_ORIENTATION_TRUETYPE, but is used to
|
||||||
|
* remember that in TrueType, everything that is to the right of the
|
||||||
|
* drawing direction of a contour must be filled.
|
||||||
|
*
|
||||||
|
* FT_ORIENTATION_FILL_LEFT ::
|
||||||
|
* This is identical to @FT_ORIENTATION_POSTSCRIPT, but is used to
|
||||||
|
* remember that in PostScript, everything that is to the left of the
|
||||||
|
* drawing direction of a contour must be filled.
|
||||||
|
*
|
||||||
|
* FT_ORIENTATION_NONE ::
|
||||||
|
* The orientation cannot be determined. That is, different parts of
|
||||||
|
* the glyph have different orientation.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef enum FT_Orientation_
|
||||||
|
{
|
||||||
|
FT_ORIENTATION_TRUETYPE = 0,
|
||||||
|
FT_ORIENTATION_POSTSCRIPT = 1,
|
||||||
|
FT_ORIENTATION_FILL_RIGHT = FT_ORIENTATION_TRUETYPE,
|
||||||
|
FT_ORIENTATION_FILL_LEFT = FT_ORIENTATION_POSTSCRIPT,
|
||||||
|
FT_ORIENTATION_NONE
|
||||||
|
|
||||||
|
} FT_Orientation;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_Get_Orientation
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This function analyzes a glyph outline and tries to compute its fill
|
||||||
|
* orientation (see @FT_Orientation). This is done by integrating the
|
||||||
|
* total area covered by the outline. The positive integral corresponds
|
||||||
|
* to the clockwise orientation and @FT_ORIENTATION_POSTSCRIPT is
|
||||||
|
* returned. The negative integral corresponds to the counter-clockwise
|
||||||
|
* orientation and @FT_ORIENTATION_TRUETYPE is returned.
|
||||||
|
*
|
||||||
|
* Note that this will return @FT_ORIENTATION_TRUETYPE for empty
|
||||||
|
* outlines.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* outline ::
|
||||||
|
* A handle to the source outline.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The orientation.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Orientation )
|
||||||
|
FT_Outline_Get_Orientation( FT_Outline* outline );
|
||||||
|
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTOUTLN_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
|
|
||||||
|
|
||||||
|
/* Local Variables: */
|
||||||
|
/* coding: utf-8 */
|
||||||
|
/* End: */
|
||||||
@@ -0,0 +1,218 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftparams.h
|
||||||
|
*
|
||||||
|
* FreeType API for possible FT_Parameter tags (specification only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2017-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTPARAMS_H_
|
||||||
|
#define FTPARAMS_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* parameter_tags
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Parameter Tags
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Macros for driver property and font loading parameter tags.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains macros for the @FT_Parameter structure that are
|
||||||
|
* used with various functions to activate some special functionality or
|
||||||
|
* different behaviour of various components of FreeType.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_PARAM_TAG_IGNORE_TYPOGRAPHIC_FAMILY
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A tag for @FT_Parameter to make @FT_Open_Face ignore typographic
|
||||||
|
* family names in the 'name' table (introduced in OpenType version 1.4).
|
||||||
|
* Use this for backward compatibility with legacy systems that have a
|
||||||
|
* four-faces-per-family restriction.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PARAM_TAG_IGNORE_TYPOGRAPHIC_FAMILY \
|
||||||
|
FT_MAKE_TAG( 'i', 'g', 'p', 'f' )
|
||||||
|
|
||||||
|
|
||||||
|
/* this constant is deprecated */
|
||||||
|
#define FT_PARAM_TAG_IGNORE_PREFERRED_FAMILY \
|
||||||
|
FT_PARAM_TAG_IGNORE_TYPOGRAPHIC_FAMILY
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_PARAM_TAG_IGNORE_TYPOGRAPHIC_SUBFAMILY
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A tag for @FT_Parameter to make @FT_Open_Face ignore typographic
|
||||||
|
* subfamily names in the 'name' table (introduced in OpenType version
|
||||||
|
* 1.4). Use this for backward compatibility with legacy systems that
|
||||||
|
* have a four-faces-per-family restriction.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PARAM_TAG_IGNORE_TYPOGRAPHIC_SUBFAMILY \
|
||||||
|
FT_MAKE_TAG( 'i', 'g', 'p', 's' )
|
||||||
|
|
||||||
|
|
||||||
|
/* this constant is deprecated */
|
||||||
|
#define FT_PARAM_TAG_IGNORE_PREFERRED_SUBFAMILY \
|
||||||
|
FT_PARAM_TAG_IGNORE_TYPOGRAPHIC_SUBFAMILY
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_PARAM_TAG_INCREMENTAL
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An @FT_Parameter tag to be used with @FT_Open_Face to indicate
|
||||||
|
* incremental glyph loading.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PARAM_TAG_INCREMENTAL \
|
||||||
|
FT_MAKE_TAG( 'i', 'n', 'c', 'r' )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_PARAM_TAG_IGNORE_SBIX
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A tag for @FT_Parameter to make @FT_Open_Face ignore an 'sbix' table
|
||||||
|
* while loading a font. Use this if @FT_FACE_FLAG_SBIX is set and you
|
||||||
|
* want to access the outline glyphs in the font.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PARAM_TAG_IGNORE_SBIX \
|
||||||
|
FT_MAKE_TAG( 'i', 's', 'b', 'x' )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_PARAM_TAG_LCD_FILTER_WEIGHTS
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An @FT_Parameter tag to be used with @FT_Face_Properties. The
|
||||||
|
* corresponding argument specifies the five LCD filter weights for a
|
||||||
|
* given face (if using @FT_LOAD_TARGET_LCD, for example), overriding the
|
||||||
|
* global default values or the values set up with
|
||||||
|
* @FT_Library_SetLcdFilterWeights.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PARAM_TAG_LCD_FILTER_WEIGHTS \
|
||||||
|
FT_MAKE_TAG( 'l', 'c', 'd', 'f' )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_PARAM_TAG_RANDOM_SEED
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An @FT_Parameter tag to be used with @FT_Face_Properties. The
|
||||||
|
* corresponding 32bit signed integer argument overrides the font
|
||||||
|
* driver's random seed value with a face-specific one; see @random-seed.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PARAM_TAG_RANDOM_SEED \
|
||||||
|
FT_MAKE_TAG( 's', 'e', 'e', 'd' )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_PARAM_TAG_STEM_DARKENING
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An @FT_Parameter tag to be used with @FT_Face_Properties. The
|
||||||
|
* corresponding Boolean argument specifies whether to apply stem
|
||||||
|
* darkening, overriding the global default values or the values set up
|
||||||
|
* with @FT_Property_Set (see @no-stem-darkening).
|
||||||
|
*
|
||||||
|
* This is a passive setting that only takes effect if the font driver or
|
||||||
|
* autohinter honors it, which the CFF, Type~1, and CID drivers always
|
||||||
|
* do, but the autohinter only in 'light' hinting mode (as of version
|
||||||
|
* 2.9).
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PARAM_TAG_STEM_DARKENING \
|
||||||
|
FT_MAKE_TAG( 'd', 'a', 'r', 'k' )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_PARAM_TAG_UNPATENTED_HINTING
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Deprecated, no effect.
|
||||||
|
*
|
||||||
|
* Previously: A constant used as the tag of an @FT_Parameter structure
|
||||||
|
* to indicate that unpatented methods only should be used by the
|
||||||
|
* TrueType bytecode interpreter for a typeface opened by @FT_Open_Face.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_PARAM_TAG_UNPATENTED_HINTING \
|
||||||
|
FT_MAKE_TAG( 'u', 'n', 'p', 'a' )
|
||||||
|
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* FTPARAMS_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,179 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftpfr.h
|
||||||
|
*
|
||||||
|
* FreeType API for accessing PFR-specific data (specification only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTPFR_H_
|
||||||
|
#define FTPFR_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* pfr_fonts
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* PFR Fonts
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* PFR/TrueDoc-specific API.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the declaration of PFR-specific functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_PFR_Metrics
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the outline and metrics resolutions of a given PFR face.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* Handle to the input face. It can be a non-PFR face.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* aoutline_resolution ::
|
||||||
|
* Outline resolution. This is equivalent to `face->units_per_EM` for
|
||||||
|
* non-PFR fonts. Optional (parameter can be `NULL`).
|
||||||
|
*
|
||||||
|
* ametrics_resolution ::
|
||||||
|
* Metrics resolution. This is equivalent to `outline_resolution` for
|
||||||
|
* non-PFR fonts. Optional (parameter can be `NULL`).
|
||||||
|
*
|
||||||
|
* ametrics_x_scale ::
|
||||||
|
* A 16.16 fixed-point number used to scale distance expressed in
|
||||||
|
* metrics units to device subpixels. This is equivalent to
|
||||||
|
* `face->size->x_scale`, but for metrics only. Optional (parameter
|
||||||
|
* can be `NULL`).
|
||||||
|
*
|
||||||
|
* ametrics_y_scale ::
|
||||||
|
* Same as `ametrics_x_scale` but for the vertical direction.
|
||||||
|
* optional (parameter can be `NULL`).
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If the input face is not a PFR, this function will return an error.
|
||||||
|
* However, in all cases, it will return valid values.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_PFR_Metrics( FT_Face face,
|
||||||
|
FT_UInt *aoutline_resolution,
|
||||||
|
FT_UInt *ametrics_resolution,
|
||||||
|
FT_Fixed *ametrics_x_scale,
|
||||||
|
FT_Fixed *ametrics_y_scale );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_PFR_Kerning
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the kerning pair corresponding to two glyphs in a PFR face.
|
||||||
|
* The distance is expressed in metrics units, unlike the result of
|
||||||
|
* @FT_Get_Kerning.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* left ::
|
||||||
|
* Index of the left glyph.
|
||||||
|
*
|
||||||
|
* right ::
|
||||||
|
* Index of the right glyph.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* avector ::
|
||||||
|
* A kerning vector.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function always return distances in original PFR metrics units.
|
||||||
|
* This is unlike @FT_Get_Kerning with the @FT_KERNING_UNSCALED mode,
|
||||||
|
* which always returns distances converted to outline units.
|
||||||
|
*
|
||||||
|
* You can use the value of the `x_scale` and `y_scale` parameters
|
||||||
|
* returned by @FT_Get_PFR_Metrics to scale these to device subpixels.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_PFR_Kerning( FT_Face face,
|
||||||
|
FT_UInt left,
|
||||||
|
FT_UInt right,
|
||||||
|
FT_Vector *avector );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_PFR_Advance
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return a given glyph advance, expressed in original metrics units,
|
||||||
|
* from a PFR font.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* gindex ::
|
||||||
|
* The glyph index.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* aadvance ::
|
||||||
|
* The glyph advance in metrics units.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You can use the `x_scale` or `y_scale` results of @FT_Get_PFR_Metrics
|
||||||
|
* to convert the advance to device subpixels (i.e., 1/64th of pixels).
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_PFR_Advance( FT_Face face,
|
||||||
|
FT_UInt gindex,
|
||||||
|
FT_Pos *aadvance );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTPFR_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,244 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftrender.h
|
||||||
|
*
|
||||||
|
* FreeType renderer modules public interface (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTRENDER_H_
|
||||||
|
#define FTRENDER_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/ftmodapi.h>
|
||||||
|
#include <freetype/ftglyph.h>
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* module_management
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* create a new glyph object */
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Glyph_InitFunc)( FT_Glyph glyph,
|
||||||
|
FT_GlyphSlot slot );
|
||||||
|
|
||||||
|
/* destroys a given glyph object */
|
||||||
|
typedef void
|
||||||
|
(*FT_Glyph_DoneFunc)( FT_Glyph glyph );
|
||||||
|
|
||||||
|
typedef void
|
||||||
|
(*FT_Glyph_TransformFunc)( FT_Glyph glyph,
|
||||||
|
const FT_Matrix* matrix,
|
||||||
|
const FT_Vector* delta );
|
||||||
|
|
||||||
|
typedef void
|
||||||
|
(*FT_Glyph_GetBBoxFunc)( FT_Glyph glyph,
|
||||||
|
FT_BBox* abbox );
|
||||||
|
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Glyph_CopyFunc)( FT_Glyph source,
|
||||||
|
FT_Glyph target );
|
||||||
|
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Glyph_PrepareFunc)( FT_Glyph glyph,
|
||||||
|
FT_GlyphSlot slot );
|
||||||
|
|
||||||
|
/* deprecated */
|
||||||
|
#define FT_Glyph_Init_Func FT_Glyph_InitFunc
|
||||||
|
#define FT_Glyph_Done_Func FT_Glyph_DoneFunc
|
||||||
|
#define FT_Glyph_Transform_Func FT_Glyph_TransformFunc
|
||||||
|
#define FT_Glyph_BBox_Func FT_Glyph_GetBBoxFunc
|
||||||
|
#define FT_Glyph_Copy_Func FT_Glyph_CopyFunc
|
||||||
|
#define FT_Glyph_Prepare_Func FT_Glyph_PrepareFunc
|
||||||
|
|
||||||
|
|
||||||
|
struct FT_Glyph_Class_
|
||||||
|
{
|
||||||
|
FT_Long glyph_size;
|
||||||
|
FT_Glyph_Format glyph_format;
|
||||||
|
|
||||||
|
FT_Glyph_InitFunc glyph_init;
|
||||||
|
FT_Glyph_DoneFunc glyph_done;
|
||||||
|
FT_Glyph_CopyFunc glyph_copy;
|
||||||
|
FT_Glyph_TransformFunc glyph_transform;
|
||||||
|
FT_Glyph_GetBBoxFunc glyph_bbox;
|
||||||
|
FT_Glyph_PrepareFunc glyph_prepare;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Renderer_RenderFunc)( FT_Renderer renderer,
|
||||||
|
FT_GlyphSlot slot,
|
||||||
|
FT_Render_Mode mode,
|
||||||
|
const FT_Vector* origin );
|
||||||
|
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Renderer_TransformFunc)( FT_Renderer renderer,
|
||||||
|
FT_GlyphSlot slot,
|
||||||
|
const FT_Matrix* matrix,
|
||||||
|
const FT_Vector* delta );
|
||||||
|
|
||||||
|
|
||||||
|
typedef void
|
||||||
|
(*FT_Renderer_GetCBoxFunc)( FT_Renderer renderer,
|
||||||
|
FT_GlyphSlot slot,
|
||||||
|
FT_BBox* cbox );
|
||||||
|
|
||||||
|
|
||||||
|
typedef FT_Error
|
||||||
|
(*FT_Renderer_SetModeFunc)( FT_Renderer renderer,
|
||||||
|
FT_ULong mode_tag,
|
||||||
|
FT_Pointer mode_ptr );
|
||||||
|
|
||||||
|
/* deprecated identifiers */
|
||||||
|
#define FTRenderer_render FT_Renderer_RenderFunc
|
||||||
|
#define FTRenderer_transform FT_Renderer_TransformFunc
|
||||||
|
#define FTRenderer_getCBox FT_Renderer_GetCBoxFunc
|
||||||
|
#define FTRenderer_setMode FT_Renderer_SetModeFunc
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Renderer_Class
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The renderer module class descriptor.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* root ::
|
||||||
|
* The root @FT_Module_Class fields.
|
||||||
|
*
|
||||||
|
* glyph_format ::
|
||||||
|
* The glyph image format this renderer handles.
|
||||||
|
*
|
||||||
|
* render_glyph ::
|
||||||
|
* A method used to render the image that is in a given glyph slot into
|
||||||
|
* a bitmap.
|
||||||
|
*
|
||||||
|
* transform_glyph ::
|
||||||
|
* A method used to transform the image that is in a given glyph slot.
|
||||||
|
*
|
||||||
|
* get_glyph_cbox ::
|
||||||
|
* A method used to access the glyph's cbox.
|
||||||
|
*
|
||||||
|
* set_mode ::
|
||||||
|
* A method used to pass additional parameters.
|
||||||
|
*
|
||||||
|
* raster_class ::
|
||||||
|
* For @FT_GLYPH_FORMAT_OUTLINE renderers only. This is a pointer to
|
||||||
|
* its raster's class.
|
||||||
|
*/
|
||||||
|
typedef struct FT_Renderer_Class_
|
||||||
|
{
|
||||||
|
FT_Module_Class root;
|
||||||
|
|
||||||
|
FT_Glyph_Format glyph_format;
|
||||||
|
|
||||||
|
FT_Renderer_RenderFunc render_glyph;
|
||||||
|
FT_Renderer_TransformFunc transform_glyph;
|
||||||
|
FT_Renderer_GetCBoxFunc get_glyph_cbox;
|
||||||
|
FT_Renderer_SetModeFunc set_mode;
|
||||||
|
|
||||||
|
FT_Raster_Funcs* raster_class;
|
||||||
|
|
||||||
|
} FT_Renderer_Class;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Renderer
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the current renderer for a given glyph format.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library object.
|
||||||
|
*
|
||||||
|
* format ::
|
||||||
|
* The glyph format.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* A renderer handle. 0~if none found.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* An error will be returned if a module already exists by that name, or
|
||||||
|
* if the module requires a version of FreeType that is too great.
|
||||||
|
*
|
||||||
|
* To add a new renderer, simply use @FT_Add_Module. To retrieve a
|
||||||
|
* renderer by its name, use @FT_Get_Module.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Renderer )
|
||||||
|
FT_Get_Renderer( FT_Library library,
|
||||||
|
FT_Glyph_Format format );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Set_Renderer
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Set the current renderer to use, and set additional mode.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* library ::
|
||||||
|
* A handle to the library object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* renderer ::
|
||||||
|
* A handle to the renderer object.
|
||||||
|
*
|
||||||
|
* num_params ::
|
||||||
|
* The number of additional parameters.
|
||||||
|
*
|
||||||
|
* parameters ::
|
||||||
|
* Additional parameters.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* In case of success, the renderer will be used to convert glyph images
|
||||||
|
* in the renderer's known format into bitmaps.
|
||||||
|
*
|
||||||
|
* This doesn't change the current renderer for other formats.
|
||||||
|
*
|
||||||
|
* Currently, no FreeType renderer module uses `parameters`; you should
|
||||||
|
* thus always pass `NULL` as the value.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Set_Renderer( FT_Library library,
|
||||||
|
FT_Renderer renderer,
|
||||||
|
FT_UInt num_params,
|
||||||
|
FT_Parameter* parameters );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTRENDER_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,159 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftsizes.h
|
||||||
|
*
|
||||||
|
* FreeType size objects management (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* Typical application would normally not need to use these functions.
|
||||||
|
* However, they have been placed in a public API for the rare cases where
|
||||||
|
* they are needed.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTSIZES_H_
|
||||||
|
#define FTSIZES_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* sizes_management
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Size Management
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Managing multiple sizes per face.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* When creating a new face object (e.g., with @FT_New_Face), an @FT_Size
|
||||||
|
* object is automatically created and used to store all pixel-size
|
||||||
|
* dependent information, available in the `face->size` field.
|
||||||
|
*
|
||||||
|
* It is however possible to create more sizes for a given face, mostly
|
||||||
|
* in order to manage several character pixel sizes of the same font
|
||||||
|
* family and style. See @FT_New_Size and @FT_Done_Size.
|
||||||
|
*
|
||||||
|
* Note that @FT_Set_Pixel_Sizes and @FT_Set_Char_Size only modify the
|
||||||
|
* contents of the current 'active' size; you thus need to use
|
||||||
|
* @FT_Activate_Size to change it.
|
||||||
|
*
|
||||||
|
* 99% of applications won't need the functions provided here, especially
|
||||||
|
* if they use the caching sub-system, so be cautious when using these.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_New_Size
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Create a new size object from a given face object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to a parent face object.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* asize ::
|
||||||
|
* A handle to a new size object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You need to call @FT_Activate_Size in order to select the new size for
|
||||||
|
* upcoming calls to @FT_Set_Pixel_Sizes, @FT_Set_Char_Size,
|
||||||
|
* @FT_Load_Glyph, @FT_Load_Char, etc.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_New_Size( FT_Face face,
|
||||||
|
FT_Size* size );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Done_Size
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Discard a given size object. Note that @FT_Done_Face automatically
|
||||||
|
* discards all size objects allocated with @FT_New_Size.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* size ::
|
||||||
|
* A handle to a target size object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Done_Size( FT_Size size );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Activate_Size
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Even though it is possible to create several size objects for a given
|
||||||
|
* face (see @FT_New_Size for details), functions like @FT_Load_Glyph or
|
||||||
|
* @FT_Load_Char only use the one that has been activated last to
|
||||||
|
* determine the 'current character pixel size'.
|
||||||
|
*
|
||||||
|
* This function can be used to 'activate' a previously created size
|
||||||
|
* object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* size ::
|
||||||
|
* A handle to a target size object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If `face` is the size's parent face object, this function changes the
|
||||||
|
* value of `face->size` to the input size handle.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Activate_Size( FT_Size size );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTSIZES_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,272 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftsnames.h
|
||||||
|
*
|
||||||
|
* Simple interface to access SFNT 'name' tables (which are used
|
||||||
|
* to hold font names, copyright info, notices, etc.) (specification).
|
||||||
|
*
|
||||||
|
* This is _not_ used to retrieve glyph names!
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTSNAMES_H_
|
||||||
|
#define FTSNAMES_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
#include <freetype/ftparams.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* sfnt_names
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* SFNT Names
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Access the names embedded in TrueType and OpenType files.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The TrueType and OpenType specifications allow the inclusion of a
|
||||||
|
* special names table ('name') in font files. This table contains
|
||||||
|
* textual (and internationalized) information regarding the font, like
|
||||||
|
* family name, copyright, version, etc.
|
||||||
|
*
|
||||||
|
* The definitions below are used to access them if available.
|
||||||
|
*
|
||||||
|
* Note that this has nothing to do with glyph names!
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_SfntName
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to model an SFNT 'name' table entry.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* platform_id ::
|
||||||
|
* The platform ID for `string`. See @TT_PLATFORM_XXX for possible
|
||||||
|
* values.
|
||||||
|
*
|
||||||
|
* encoding_id ::
|
||||||
|
* The encoding ID for `string`. See @TT_APPLE_ID_XXX, @TT_MAC_ID_XXX,
|
||||||
|
* @TT_ISO_ID_XXX, @TT_MS_ID_XXX, and @TT_ADOBE_ID_XXX for possible
|
||||||
|
* values.
|
||||||
|
*
|
||||||
|
* language_id ::
|
||||||
|
* The language ID for `string`. See @TT_MAC_LANGID_XXX and
|
||||||
|
* @TT_MS_LANGID_XXX for possible values.
|
||||||
|
*
|
||||||
|
* Registered OpenType values for `language_id` are always smaller than
|
||||||
|
* 0x8000; values equal or larger than 0x8000 usually indicate a
|
||||||
|
* language tag string (introduced in OpenType version 1.6). Use
|
||||||
|
* function @FT_Get_Sfnt_LangTag with `language_id` as its argument to
|
||||||
|
* retrieve the associated language tag.
|
||||||
|
*
|
||||||
|
* name_id ::
|
||||||
|
* An identifier for `string`. See @TT_NAME_ID_XXX for possible
|
||||||
|
* values.
|
||||||
|
*
|
||||||
|
* string ::
|
||||||
|
* The 'name' string. Note that its format differs depending on the
|
||||||
|
* (platform,encoding) pair, being either a string of bytes (without a
|
||||||
|
* terminating `NULL` byte) or containing UTF-16BE entities.
|
||||||
|
*
|
||||||
|
* string_len ::
|
||||||
|
* The length of `string` in bytes.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Please refer to the TrueType or OpenType specification for more
|
||||||
|
* details.
|
||||||
|
*/
|
||||||
|
typedef struct FT_SfntName_
|
||||||
|
{
|
||||||
|
FT_UShort platform_id;
|
||||||
|
FT_UShort encoding_id;
|
||||||
|
FT_UShort language_id;
|
||||||
|
FT_UShort name_id;
|
||||||
|
|
||||||
|
FT_Byte* string; /* this string is *not* null-terminated! */
|
||||||
|
FT_UInt string_len; /* in bytes */
|
||||||
|
|
||||||
|
} FT_SfntName;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Sfnt_Name_Count
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the number of name strings in the SFNT 'name' table.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The number of strings in the 'name' table.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function always returns an error if the config macro
|
||||||
|
* `TT_CONFIG_OPTION_SFNT_NAMES` is not defined in `ftoption.h`.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_UInt )
|
||||||
|
FT_Get_Sfnt_Name_Count( FT_Face face );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Sfnt_Name
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve a string of the SFNT 'name' table for a given index.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* idx ::
|
||||||
|
* The index of the 'name' string.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* aname ::
|
||||||
|
* The indexed @FT_SfntName structure.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The `string` array returned in the `aname` structure is not
|
||||||
|
* null-terminated. Note that you don't have to deallocate `string` by
|
||||||
|
* yourself; FreeType takes care of it if you call @FT_Done_Face.
|
||||||
|
*
|
||||||
|
* Use @FT_Get_Sfnt_Name_Count to get the total number of available
|
||||||
|
* 'name' table entries, then do a loop until you get the right platform,
|
||||||
|
* encoding, and name ID.
|
||||||
|
*
|
||||||
|
* 'name' table format~1 entries can use language tags also, see
|
||||||
|
* @FT_Get_Sfnt_LangTag.
|
||||||
|
*
|
||||||
|
* This function always returns an error if the config macro
|
||||||
|
* `TT_CONFIG_OPTION_SFNT_NAMES` is not defined in `ftoption.h`.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Sfnt_Name( FT_Face face,
|
||||||
|
FT_UInt idx,
|
||||||
|
FT_SfntName *aname );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_SfntLangTag
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a language tag entry from an SFNT 'name' table.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* string ::
|
||||||
|
* The language tag string, encoded in UTF-16BE (without trailing
|
||||||
|
* `NULL` bytes).
|
||||||
|
*
|
||||||
|
* string_len ::
|
||||||
|
* The length of `string` in **bytes**.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Please refer to the TrueType or OpenType specification for more
|
||||||
|
* details.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*/
|
||||||
|
typedef struct FT_SfntLangTag_
|
||||||
|
{
|
||||||
|
FT_Byte* string; /* this string is *not* null-terminated! */
|
||||||
|
FT_UInt string_len; /* in bytes */
|
||||||
|
|
||||||
|
} FT_SfntLangTag;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Sfnt_LangTag
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the language tag associated with a language ID of an SFNT
|
||||||
|
* 'name' table entry.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* langID ::
|
||||||
|
* The language ID, as returned by @FT_Get_Sfnt_Name. This is always a
|
||||||
|
* value larger than 0x8000.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* alangTag ::
|
||||||
|
* The language tag associated with the 'name' table entry's language
|
||||||
|
* ID.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The `string` array returned in the `alangTag` structure is not
|
||||||
|
* null-terminated. Note that you don't have to deallocate `string` by
|
||||||
|
* yourself; FreeType takes care of it if you call @FT_Done_Face.
|
||||||
|
*
|
||||||
|
* Only 'name' table format~1 supports language tags. For format~0
|
||||||
|
* tables, this function always returns FT_Err_Invalid_Table. For
|
||||||
|
* invalid format~1 language ID values, FT_Err_Invalid_Argument is
|
||||||
|
* returned.
|
||||||
|
*
|
||||||
|
* This function always returns an error if the config macro
|
||||||
|
* `TT_CONFIG_OPTION_SFNT_NAMES` is not defined in `ftoption.h`.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.8
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_Sfnt_LangTag( FT_Face face,
|
||||||
|
FT_UInt langID,
|
||||||
|
FT_SfntLangTag *alangTag );
|
||||||
|
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTSNAMES_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,773 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftstroke.h
|
||||||
|
*
|
||||||
|
* FreeType path stroker (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTSTROKE_H_
|
||||||
|
#define FTSTROKE_H_
|
||||||
|
|
||||||
|
#include <freetype/ftoutln.h>
|
||||||
|
#include <freetype/ftglyph.h>
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* glyph_stroker
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Glyph Stroker
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Generating bordered and stroked glyphs.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This component generates stroked outlines of a given vectorial glyph.
|
||||||
|
* It also allows you to retrieve the 'outside' and/or the 'inside'
|
||||||
|
* borders of the stroke.
|
||||||
|
*
|
||||||
|
* This can be useful to generate 'bordered' glyph, i.e., glyphs
|
||||||
|
* displayed with a colored (and anti-aliased) border around their
|
||||||
|
* shape.
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* FT_Stroker
|
||||||
|
*
|
||||||
|
* FT_Stroker_LineJoin
|
||||||
|
* FT_Stroker_LineCap
|
||||||
|
* FT_StrokerBorder
|
||||||
|
*
|
||||||
|
* FT_Outline_GetInsideBorder
|
||||||
|
* FT_Outline_GetOutsideBorder
|
||||||
|
*
|
||||||
|
* FT_Glyph_Stroke
|
||||||
|
* FT_Glyph_StrokeBorder
|
||||||
|
*
|
||||||
|
* FT_Stroker_New
|
||||||
|
* FT_Stroker_Set
|
||||||
|
* FT_Stroker_Rewind
|
||||||
|
* FT_Stroker_ParseOutline
|
||||||
|
* FT_Stroker_Done
|
||||||
|
*
|
||||||
|
* FT_Stroker_BeginSubPath
|
||||||
|
* FT_Stroker_EndSubPath
|
||||||
|
*
|
||||||
|
* FT_Stroker_LineTo
|
||||||
|
* FT_Stroker_ConicTo
|
||||||
|
* FT_Stroker_CubicTo
|
||||||
|
*
|
||||||
|
* FT_Stroker_GetBorderCounts
|
||||||
|
* FT_Stroker_ExportBorder
|
||||||
|
* FT_Stroker_GetCounts
|
||||||
|
* FT_Stroker_Export
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Stroker
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Opaque handle to a path stroker object.
|
||||||
|
*/
|
||||||
|
typedef struct FT_StrokerRec_* FT_Stroker;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_Stroker_LineJoin
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* These values determine how two joining lines are rendered in a
|
||||||
|
* stroker.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_STROKER_LINEJOIN_ROUND ::
|
||||||
|
* Used to render rounded line joins. Circular arcs are used to join
|
||||||
|
* two lines smoothly.
|
||||||
|
*
|
||||||
|
* FT_STROKER_LINEJOIN_BEVEL ::
|
||||||
|
* Used to render beveled line joins. The outer corner of the joined
|
||||||
|
* lines is filled by enclosing the triangular region of the corner
|
||||||
|
* with a straight line between the outer corners of each stroke.
|
||||||
|
*
|
||||||
|
* FT_STROKER_LINEJOIN_MITER_FIXED ::
|
||||||
|
* Used to render mitered line joins, with fixed bevels if the miter
|
||||||
|
* limit is exceeded. The outer edges of the strokes for the two
|
||||||
|
* segments are extended until they meet at an angle. A bevel join
|
||||||
|
* (see above) is used if the segments meet at too sharp an angle and
|
||||||
|
* the outer edges meet beyond a distance corresponding to the meter
|
||||||
|
* limit. This prevents long spikes being created.
|
||||||
|
* `FT_STROKER_LINEJOIN_MITER_FIXED` generates a miter line join as
|
||||||
|
* used in PostScript and PDF.
|
||||||
|
*
|
||||||
|
* FT_STROKER_LINEJOIN_MITER_VARIABLE ::
|
||||||
|
* FT_STROKER_LINEJOIN_MITER ::
|
||||||
|
* Used to render mitered line joins, with variable bevels if the miter
|
||||||
|
* limit is exceeded. The intersection of the strokes is clipped
|
||||||
|
* perpendicularly to the bisector, at a distance corresponding to
|
||||||
|
* the miter limit. This prevents long spikes being created.
|
||||||
|
* `FT_STROKER_LINEJOIN_MITER_VARIABLE` generates a mitered line join
|
||||||
|
* as used in XPS. `FT_STROKER_LINEJOIN_MITER` is an alias for
|
||||||
|
* `FT_STROKER_LINEJOIN_MITER_VARIABLE`, retained for backward
|
||||||
|
* compatibility.
|
||||||
|
*/
|
||||||
|
typedef enum FT_Stroker_LineJoin_
|
||||||
|
{
|
||||||
|
FT_STROKER_LINEJOIN_ROUND = 0,
|
||||||
|
FT_STROKER_LINEJOIN_BEVEL = 1,
|
||||||
|
FT_STROKER_LINEJOIN_MITER_VARIABLE = 2,
|
||||||
|
FT_STROKER_LINEJOIN_MITER = FT_STROKER_LINEJOIN_MITER_VARIABLE,
|
||||||
|
FT_STROKER_LINEJOIN_MITER_FIXED = 3
|
||||||
|
|
||||||
|
} FT_Stroker_LineJoin;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_Stroker_LineCap
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* These values determine how the end of opened sub-paths are rendered in
|
||||||
|
* a stroke.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_STROKER_LINECAP_BUTT ::
|
||||||
|
* The end of lines is rendered as a full stop on the last point
|
||||||
|
* itself.
|
||||||
|
*
|
||||||
|
* FT_STROKER_LINECAP_ROUND ::
|
||||||
|
* The end of lines is rendered as a half-circle around the last point.
|
||||||
|
*
|
||||||
|
* FT_STROKER_LINECAP_SQUARE ::
|
||||||
|
* The end of lines is rendered as a square around the last point.
|
||||||
|
*/
|
||||||
|
typedef enum FT_Stroker_LineCap_
|
||||||
|
{
|
||||||
|
FT_STROKER_LINECAP_BUTT = 0,
|
||||||
|
FT_STROKER_LINECAP_ROUND,
|
||||||
|
FT_STROKER_LINECAP_SQUARE
|
||||||
|
|
||||||
|
} FT_Stroker_LineCap;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_StrokerBorder
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* These values are used to select a given stroke border in
|
||||||
|
* @FT_Stroker_GetBorderCounts and @FT_Stroker_ExportBorder.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_STROKER_BORDER_LEFT ::
|
||||||
|
* Select the left border, relative to the drawing direction.
|
||||||
|
*
|
||||||
|
* FT_STROKER_BORDER_RIGHT ::
|
||||||
|
* Select the right border, relative to the drawing direction.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Applications are generally interested in the 'inside' and 'outside'
|
||||||
|
* borders. However, there is no direct mapping between these and the
|
||||||
|
* 'left' and 'right' ones, since this really depends on the glyph's
|
||||||
|
* drawing orientation, which varies between font formats.
|
||||||
|
*
|
||||||
|
* You can however use @FT_Outline_GetInsideBorder and
|
||||||
|
* @FT_Outline_GetOutsideBorder to get these.
|
||||||
|
*/
|
||||||
|
typedef enum FT_StrokerBorder_
|
||||||
|
{
|
||||||
|
FT_STROKER_BORDER_LEFT = 0,
|
||||||
|
FT_STROKER_BORDER_RIGHT
|
||||||
|
|
||||||
|
} FT_StrokerBorder;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_GetInsideBorder
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the @FT_StrokerBorder value corresponding to the 'inside'
|
||||||
|
* borders of a given outline.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* outline ::
|
||||||
|
* The source outline handle.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The border index. @FT_STROKER_BORDER_RIGHT for empty or invalid
|
||||||
|
* outlines.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_StrokerBorder )
|
||||||
|
FT_Outline_GetInsideBorder( FT_Outline* outline );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Outline_GetOutsideBorder
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the @FT_StrokerBorder value corresponding to the 'outside'
|
||||||
|
* borders of a given outline.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* outline ::
|
||||||
|
* The source outline handle.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The border index. @FT_STROKER_BORDER_LEFT for empty or invalid
|
||||||
|
* outlines.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_StrokerBorder )
|
||||||
|
FT_Outline_GetOutsideBorder( FT_Outline* outline );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_New
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Create a new stroker object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* library ::
|
||||||
|
* FreeType library handle.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* astroker ::
|
||||||
|
* A new stroker object handle. `NULL` in case of error.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_New( FT_Library library,
|
||||||
|
FT_Stroker *astroker );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_Set
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Reset a stroker object's attributes.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* radius ::
|
||||||
|
* The border radius.
|
||||||
|
*
|
||||||
|
* line_cap ::
|
||||||
|
* The line cap style.
|
||||||
|
*
|
||||||
|
* line_join ::
|
||||||
|
* The line join style.
|
||||||
|
*
|
||||||
|
* miter_limit ::
|
||||||
|
* The maximum reciprocal sine of half-angle at the miter join,
|
||||||
|
* expressed as 16.16 fixed point value.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The `radius` is expressed in the same units as the outline
|
||||||
|
* coordinates.
|
||||||
|
*
|
||||||
|
* The `miter_limit` multiplied by the `radius` gives the maximum size
|
||||||
|
* of a miter spike, at which it is clipped for
|
||||||
|
* @FT_STROKER_LINEJOIN_MITER_VARIABLE or replaced with a bevel join for
|
||||||
|
* @FT_STROKER_LINEJOIN_MITER_FIXED.
|
||||||
|
*
|
||||||
|
* This function calls @FT_Stroker_Rewind automatically.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Stroker_Set( FT_Stroker stroker,
|
||||||
|
FT_Fixed radius,
|
||||||
|
FT_Stroker_LineCap line_cap,
|
||||||
|
FT_Stroker_LineJoin line_join,
|
||||||
|
FT_Fixed miter_limit );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_Rewind
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Reset a stroker object without changing its attributes. You should
|
||||||
|
* call this function before beginning a new series of calls to
|
||||||
|
* @FT_Stroker_BeginSubPath or @FT_Stroker_EndSubPath.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Stroker_Rewind( FT_Stroker stroker );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_ParseOutline
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A convenience function used to parse a whole outline with the stroker.
|
||||||
|
* The resulting outline(s) can be retrieved later by functions like
|
||||||
|
* @FT_Stroker_GetCounts and @FT_Stroker_Export.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* outline ::
|
||||||
|
* The source outline.
|
||||||
|
*
|
||||||
|
* opened ::
|
||||||
|
* A boolean. If~1, the outline is treated as an open path instead of
|
||||||
|
* a closed one.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If `opened` is~0 (the default), the outline is treated as a closed
|
||||||
|
* path, and the stroker generates two distinct 'border' outlines.
|
||||||
|
*
|
||||||
|
* If `opened` is~1, the outline is processed as an open path, and the
|
||||||
|
* stroker generates a single 'stroke' outline.
|
||||||
|
*
|
||||||
|
* This function calls @FT_Stroker_Rewind automatically.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_ParseOutline( FT_Stroker stroker,
|
||||||
|
FT_Outline* outline,
|
||||||
|
FT_Bool opened );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_BeginSubPath
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Start a new sub-path in the stroker.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* to ::
|
||||||
|
* A pointer to the start vector.
|
||||||
|
*
|
||||||
|
* open ::
|
||||||
|
* A boolean. If~1, the sub-path is treated as an open one.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function is useful when you need to stroke a path that is not
|
||||||
|
* stored as an @FT_Outline object.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_BeginSubPath( FT_Stroker stroker,
|
||||||
|
FT_Vector* to,
|
||||||
|
FT_Bool open );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_EndSubPath
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Close the current sub-path in the stroker.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You should call this function after @FT_Stroker_BeginSubPath. If the
|
||||||
|
* subpath was not 'opened', this function 'draws' a single line segment
|
||||||
|
* to the start position when needed.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_EndSubPath( FT_Stroker stroker );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_LineTo
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* 'Draw' a single line segment in the stroker's current sub-path, from
|
||||||
|
* the last position.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* to ::
|
||||||
|
* A pointer to the destination point.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You should call this function between @FT_Stroker_BeginSubPath and
|
||||||
|
* @FT_Stroker_EndSubPath.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_LineTo( FT_Stroker stroker,
|
||||||
|
FT_Vector* to );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_ConicTo
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* 'Draw' a single quadratic Bezier in the stroker's current sub-path,
|
||||||
|
* from the last position.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* control ::
|
||||||
|
* A pointer to a Bezier control point.
|
||||||
|
*
|
||||||
|
* to ::
|
||||||
|
* A pointer to the destination point.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You should call this function between @FT_Stroker_BeginSubPath and
|
||||||
|
* @FT_Stroker_EndSubPath.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_ConicTo( FT_Stroker stroker,
|
||||||
|
FT_Vector* control,
|
||||||
|
FT_Vector* to );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_CubicTo
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* 'Draw' a single cubic Bezier in the stroker's current sub-path, from
|
||||||
|
* the last position.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* control1 ::
|
||||||
|
* A pointer to the first Bezier control point.
|
||||||
|
*
|
||||||
|
* control2 ::
|
||||||
|
* A pointer to second Bezier control point.
|
||||||
|
*
|
||||||
|
* to ::
|
||||||
|
* A pointer to the destination point.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* You should call this function between @FT_Stroker_BeginSubPath and
|
||||||
|
* @FT_Stroker_EndSubPath.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_CubicTo( FT_Stroker stroker,
|
||||||
|
FT_Vector* control1,
|
||||||
|
FT_Vector* control2,
|
||||||
|
FT_Vector* to );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_GetBorderCounts
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Call this function once you have finished parsing your paths with the
|
||||||
|
* stroker. It returns the number of points and contours necessary to
|
||||||
|
* export one of the 'border' or 'stroke' outlines generated by the
|
||||||
|
* stroker.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* border ::
|
||||||
|
* The border index.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* anum_points ::
|
||||||
|
* The number of points.
|
||||||
|
*
|
||||||
|
* anum_contours ::
|
||||||
|
* The number of contours.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* When an outline, or a sub-path, is 'closed', the stroker generates two
|
||||||
|
* independent 'border' outlines, named 'left' and 'right'.
|
||||||
|
*
|
||||||
|
* When the outline, or a sub-path, is 'opened', the stroker merges the
|
||||||
|
* 'border' outlines with caps. The 'left' border receives all points,
|
||||||
|
* while the 'right' border becomes empty.
|
||||||
|
*
|
||||||
|
* Use the function @FT_Stroker_GetCounts instead if you want to retrieve
|
||||||
|
* the counts associated to both borders.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_GetBorderCounts( FT_Stroker stroker,
|
||||||
|
FT_StrokerBorder border,
|
||||||
|
FT_UInt *anum_points,
|
||||||
|
FT_UInt *anum_contours );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_ExportBorder
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Call this function after @FT_Stroker_GetBorderCounts to export the
|
||||||
|
* corresponding border to your own @FT_Outline structure.
|
||||||
|
*
|
||||||
|
* Note that this function appends the border points and contours to your
|
||||||
|
* outline, but does not try to resize its arrays.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* border ::
|
||||||
|
* The border index.
|
||||||
|
*
|
||||||
|
* outline ::
|
||||||
|
* The target outline handle.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* Always call this function after @FT_Stroker_GetBorderCounts to get
|
||||||
|
* sure that there is enough room in your @FT_Outline object to receive
|
||||||
|
* all new data.
|
||||||
|
*
|
||||||
|
* When an outline, or a sub-path, is 'closed', the stroker generates two
|
||||||
|
* independent 'border' outlines, named 'left' and 'right'.
|
||||||
|
*
|
||||||
|
* When the outline, or a sub-path, is 'opened', the stroker merges the
|
||||||
|
* 'border' outlines with caps. The 'left' border receives all points,
|
||||||
|
* while the 'right' border becomes empty.
|
||||||
|
*
|
||||||
|
* Use the function @FT_Stroker_Export instead if you want to retrieve
|
||||||
|
* all borders at once.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Stroker_ExportBorder( FT_Stroker stroker,
|
||||||
|
FT_StrokerBorder border,
|
||||||
|
FT_Outline* outline );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_GetCounts
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Call this function once you have finished parsing your paths with the
|
||||||
|
* stroker. It returns the number of points and contours necessary to
|
||||||
|
* export all points/borders from the stroked outline/path.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* anum_points ::
|
||||||
|
* The number of points.
|
||||||
|
*
|
||||||
|
* anum_contours ::
|
||||||
|
* The number of contours.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Stroker_GetCounts( FT_Stroker stroker,
|
||||||
|
FT_UInt *anum_points,
|
||||||
|
FT_UInt *anum_contours );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_Export
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Call this function after @FT_Stroker_GetBorderCounts to export all
|
||||||
|
* borders to your own @FT_Outline structure.
|
||||||
|
*
|
||||||
|
* Note that this function appends the border points and contours to your
|
||||||
|
* outline, but does not try to resize its arrays.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* The target stroker handle.
|
||||||
|
*
|
||||||
|
* outline ::
|
||||||
|
* The target outline handle.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Stroker_Export( FT_Stroker stroker,
|
||||||
|
FT_Outline* outline );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Stroker_Done
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Destroy a stroker object.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* A stroker handle. Can be `NULL`.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Stroker_Done( FT_Stroker stroker );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Glyph_Stroke
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Stroke a given outline glyph object with a given stroker.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* pglyph ::
|
||||||
|
* Source glyph handle on input, new glyph handle on output.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* A stroker handle.
|
||||||
|
*
|
||||||
|
* destroy ::
|
||||||
|
* A Boolean. If~1, the source glyph object is destroyed on success.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The source glyph is untouched in case of error.
|
||||||
|
*
|
||||||
|
* Adding stroke may yield a significantly wider and taller glyph
|
||||||
|
* depending on how large of a radius was used to stroke the glyph. You
|
||||||
|
* may need to manually adjust horizontal and vertical advance amounts to
|
||||||
|
* account for this added size.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Glyph_Stroke( FT_Glyph *pglyph,
|
||||||
|
FT_Stroker stroker,
|
||||||
|
FT_Bool destroy );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Glyph_StrokeBorder
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Stroke a given outline glyph object with a given stroker, but only
|
||||||
|
* return either its inside or outside border.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* pglyph ::
|
||||||
|
* Source glyph handle on input, new glyph handle on output.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stroker ::
|
||||||
|
* A stroker handle.
|
||||||
|
*
|
||||||
|
* inside ::
|
||||||
|
* A Boolean. If~1, return the inside border, otherwise the outside
|
||||||
|
* border.
|
||||||
|
*
|
||||||
|
* destroy ::
|
||||||
|
* A Boolean. If~1, the source glyph object is destroyed on success.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The source glyph is untouched in case of error.
|
||||||
|
*
|
||||||
|
* Adding stroke may yield a significantly wider and taller glyph
|
||||||
|
* depending on how large of a radius was used to stroke the glyph. You
|
||||||
|
* may need to manually adjust horizontal and vertical advance amounts to
|
||||||
|
* account for this added size.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Glyph_StrokeBorder( FT_Glyph *pglyph,
|
||||||
|
FT_Stroker stroker,
|
||||||
|
FT_Bool inside,
|
||||||
|
FT_Bool destroy );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTSTROKE_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
|
|
||||||
|
|
||||||
|
/* Local Variables: */
|
||||||
|
/* coding: utf-8 */
|
||||||
|
/* End: */
|
||||||
@@ -0,0 +1,83 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftsynth.h
|
||||||
|
*
|
||||||
|
* FreeType synthesizing code for emboldening and slanting
|
||||||
|
* (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2000-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
/********* *********/
|
||||||
|
/********* WARNING, THIS IS ALPHA CODE! THIS API *********/
|
||||||
|
/********* IS DUE TO CHANGE UNTIL STRICTLY NOTIFIED BY THE *********/
|
||||||
|
/********* FREETYPE DEVELOPMENT TEAM *********/
|
||||||
|
/********* *********/
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
/* Main reason for not lifting the functions in this module to a */
|
||||||
|
/* 'standard' API is that the used parameters for emboldening and */
|
||||||
|
/* slanting are not configurable. Consider the functions as a */
|
||||||
|
/* code resource that should be copied into the application and */
|
||||||
|
/* adapted to the particular needs. */
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTSYNTH_H_
|
||||||
|
#define FTSYNTH_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/* Embolden a glyph by a 'reasonable' value (which is highly a matter of */
|
||||||
|
/* taste). This function is actually a convenience function, providing */
|
||||||
|
/* a wrapper for @FT_Outline_Embolden and @FT_Bitmap_Embolden. */
|
||||||
|
/* */
|
||||||
|
/* For emboldened outlines the height, width, and advance metrics are */
|
||||||
|
/* increased by the strength of the emboldening -- this even affects */
|
||||||
|
/* mono-width fonts! */
|
||||||
|
/* */
|
||||||
|
/* You can also call @FT_Outline_Get_CBox to get precise values. */
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_GlyphSlot_Embolden( FT_GlyphSlot slot );
|
||||||
|
|
||||||
|
/* Slant an outline glyph to the right by about 12 degrees. */
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_GlyphSlot_Oblique( FT_GlyphSlot slot );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTSYNTH_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,352 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftsystem.h
|
||||||
|
*
|
||||||
|
* FreeType low-level system interface definition (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTSYSTEM_H_
|
||||||
|
#define FTSYSTEM_H_
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* system_interface
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* System Interface
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* How FreeType manages memory and i/o.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains various definitions related to memory management
|
||||||
|
* and i/o access. You need to understand this information if you want to
|
||||||
|
* use a custom memory manager or you own i/o streams.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* M E M O R Y M A N A G E M E N T
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Memory
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to a given memory manager object, defined with an
|
||||||
|
* @FT_MemoryRec structure.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct FT_MemoryRec_* FT_Memory;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Alloc_Func
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to allocate `size` bytes from `memory`.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* memory ::
|
||||||
|
* A handle to the source memory manager.
|
||||||
|
*
|
||||||
|
* size ::
|
||||||
|
* The size in bytes to allocate.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* Address of new memory block. 0~in case of failure.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef void*
|
||||||
|
(*FT_Alloc_Func)( FT_Memory memory,
|
||||||
|
long size );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Free_Func
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to release a given block of memory.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* memory ::
|
||||||
|
* A handle to the source memory manager.
|
||||||
|
*
|
||||||
|
* block ::
|
||||||
|
* The address of the target memory block.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*FT_Free_Func)( FT_Memory memory,
|
||||||
|
void* block );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Realloc_Func
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to re-allocate a given block of memory.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* memory ::
|
||||||
|
* A handle to the source memory manager.
|
||||||
|
*
|
||||||
|
* cur_size ::
|
||||||
|
* The block's current size in bytes.
|
||||||
|
*
|
||||||
|
* new_size ::
|
||||||
|
* The block's requested new size.
|
||||||
|
*
|
||||||
|
* block ::
|
||||||
|
* The block's current address.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* New block address. 0~in case of memory shortage.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* In case of error, the old block must still be available.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef void*
|
||||||
|
(*FT_Realloc_Func)( FT_Memory memory,
|
||||||
|
long cur_size,
|
||||||
|
long new_size,
|
||||||
|
void* block );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_MemoryRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to describe a given memory manager to FreeType~2.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* user ::
|
||||||
|
* A generic typeless pointer for user data.
|
||||||
|
*
|
||||||
|
* alloc ::
|
||||||
|
* A pointer type to an allocation function.
|
||||||
|
*
|
||||||
|
* free ::
|
||||||
|
* A pointer type to an memory freeing function.
|
||||||
|
*
|
||||||
|
* realloc ::
|
||||||
|
* A pointer type to a reallocation function.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
struct FT_MemoryRec_
|
||||||
|
{
|
||||||
|
void* user;
|
||||||
|
FT_Alloc_Func alloc;
|
||||||
|
FT_Free_Func free;
|
||||||
|
FT_Realloc_Func realloc;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* I / O M A N A G E M E N T
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Stream
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to an input stream.
|
||||||
|
*
|
||||||
|
* @also:
|
||||||
|
* See @FT_StreamRec for the publicly accessible fields of a given stream
|
||||||
|
* object.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct FT_StreamRec_* FT_Stream;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_StreamDesc
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A union type used to store either a long or a pointer. This is used
|
||||||
|
* to store a file descriptor or a `FILE*` in an input stream.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef union FT_StreamDesc_
|
||||||
|
{
|
||||||
|
long value;
|
||||||
|
void* pointer;
|
||||||
|
|
||||||
|
} FT_StreamDesc;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Stream_IoFunc
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to seek and read data from a given input stream.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stream ::
|
||||||
|
* A handle to the source stream.
|
||||||
|
*
|
||||||
|
* offset ::
|
||||||
|
* The offset of read in stream (always from start).
|
||||||
|
*
|
||||||
|
* buffer ::
|
||||||
|
* The address of the read buffer.
|
||||||
|
*
|
||||||
|
* count ::
|
||||||
|
* The number of bytes to read from the stream.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The number of bytes effectively read by the stream.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function might be called to perform a seek or skip operation with
|
||||||
|
* a `count` of~0. A non-zero return value then indicates an error.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef unsigned long
|
||||||
|
(*FT_Stream_IoFunc)( FT_Stream stream,
|
||||||
|
unsigned long offset,
|
||||||
|
unsigned char* buffer,
|
||||||
|
unsigned long count );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Stream_CloseFunc
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A function used to close a given input stream.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* stream ::
|
||||||
|
* A handle to the target stream.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*FT_Stream_CloseFunc)( FT_Stream stream );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_StreamRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to describe an input stream.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* base ::
|
||||||
|
* For memory-based streams, this is the address of the first stream
|
||||||
|
* byte in memory. This field should always be set to `NULL` for
|
||||||
|
* disk-based streams.
|
||||||
|
*
|
||||||
|
* size ::
|
||||||
|
* The stream size in bytes.
|
||||||
|
*
|
||||||
|
* In case of compressed streams where the size is unknown before
|
||||||
|
* actually doing the decompression, the value is set to 0x7FFFFFFF.
|
||||||
|
* (Note that this size value can occur for normal streams also; it is
|
||||||
|
* thus just a hint.)
|
||||||
|
*
|
||||||
|
* pos ::
|
||||||
|
* The current position within the stream.
|
||||||
|
*
|
||||||
|
* descriptor ::
|
||||||
|
* This field is a union that can hold an integer or a pointer. It is
|
||||||
|
* used by stream implementations to store file descriptors or `FILE*`
|
||||||
|
* pointers.
|
||||||
|
*
|
||||||
|
* pathname ::
|
||||||
|
* This field is completely ignored by FreeType. However, it is often
|
||||||
|
* useful during debugging to use it to store the stream's filename
|
||||||
|
* (where available).
|
||||||
|
*
|
||||||
|
* read ::
|
||||||
|
* The stream's input function.
|
||||||
|
*
|
||||||
|
* close ::
|
||||||
|
* The stream's close function.
|
||||||
|
*
|
||||||
|
* memory ::
|
||||||
|
* The memory manager to use to preload frames. This is set internally
|
||||||
|
* by FreeType and shouldn't be touched by stream implementations.
|
||||||
|
*
|
||||||
|
* cursor ::
|
||||||
|
* This field is set and used internally by FreeType when parsing
|
||||||
|
* frames. In particular, the `FT_GET_XXX` macros use this instead of
|
||||||
|
* the `pos` field.
|
||||||
|
*
|
||||||
|
* limit ::
|
||||||
|
* This field is set and used internally by FreeType when parsing
|
||||||
|
* frames.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct FT_StreamRec_
|
||||||
|
{
|
||||||
|
unsigned char* base;
|
||||||
|
unsigned long size;
|
||||||
|
unsigned long pos;
|
||||||
|
|
||||||
|
FT_StreamDesc descriptor;
|
||||||
|
FT_StreamDesc pathname;
|
||||||
|
FT_Stream_IoFunc read;
|
||||||
|
FT_Stream_CloseFunc close;
|
||||||
|
|
||||||
|
FT_Memory memory;
|
||||||
|
unsigned char* cursor;
|
||||||
|
unsigned char* limit;
|
||||||
|
|
||||||
|
} FT_StreamRec;
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTSYSTEM_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,350 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* fttrigon.h
|
||||||
|
*
|
||||||
|
* FreeType trigonometric functions (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2001-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTTRIGON_H_
|
||||||
|
#define FTTRIGON_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* computations
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Angle
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This type is used to model angle values in FreeType. Note that the
|
||||||
|
* angle is a 16.16 fixed-point value expressed in degrees.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef FT_Fixed FT_Angle;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_ANGLE_PI
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The angle pi expressed in @FT_Angle units.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_ANGLE_PI ( 180L << 16 )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_ANGLE_2PI
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The angle 2*pi expressed in @FT_Angle units.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_ANGLE_2PI ( FT_ANGLE_PI * 2 )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_ANGLE_PI2
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The angle pi/2 expressed in @FT_Angle units.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_ANGLE_PI2 ( FT_ANGLE_PI / 2 )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_ANGLE_PI4
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The angle pi/4 expressed in @FT_Angle units.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define FT_ANGLE_PI4 ( FT_ANGLE_PI / 4 )
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Sin
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the sinus of a given angle in fixed-point format.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* angle ::
|
||||||
|
* The input angle.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The sinus value.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If you need both the sinus and cosinus for a given angle, use the
|
||||||
|
* function @FT_Vector_Unit.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Fixed )
|
||||||
|
FT_Sin( FT_Angle angle );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Cos
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the cosinus of a given angle in fixed-point format.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* angle ::
|
||||||
|
* The input angle.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The cosinus value.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If you need both the sinus and cosinus for a given angle, use the
|
||||||
|
* function @FT_Vector_Unit.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Fixed )
|
||||||
|
FT_Cos( FT_Angle angle );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Tan
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the tangent of a given angle in fixed-point format.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* angle ::
|
||||||
|
* The input angle.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The tangent value.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Fixed )
|
||||||
|
FT_Tan( FT_Angle angle );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Atan2
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the arc-tangent corresponding to a given vector (x,y) in the 2d
|
||||||
|
* plane.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* x ::
|
||||||
|
* The horizontal vector coordinate.
|
||||||
|
*
|
||||||
|
* y ::
|
||||||
|
* The vertical vector coordinate.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The arc-tangent value (i.e. angle).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Angle )
|
||||||
|
FT_Atan2( FT_Fixed x,
|
||||||
|
FT_Fixed y );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Angle_Diff
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the difference between two angles. The result is always
|
||||||
|
* constrained to the ]-PI..PI] interval.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* angle1 ::
|
||||||
|
* First angle.
|
||||||
|
*
|
||||||
|
* angle2 ::
|
||||||
|
* Second angle.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* Constrained value of `angle2-angle1`.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Angle )
|
||||||
|
FT_Angle_Diff( FT_Angle angle1,
|
||||||
|
FT_Angle angle2 );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Vector_Unit
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the unit vector corresponding to a given angle. After the
|
||||||
|
* call, the value of `vec.x` will be `cos(angle)`, and the value of
|
||||||
|
* `vec.y` will be `sin(angle)`.
|
||||||
|
*
|
||||||
|
* This function is useful to retrieve both the sinus and cosinus of a
|
||||||
|
* given angle quickly.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* vec ::
|
||||||
|
* The address of target vector.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* angle ::
|
||||||
|
* The input angle.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Vector_Unit( FT_Vector* vec,
|
||||||
|
FT_Angle angle );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Vector_Rotate
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Rotate a vector by a given angle.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* vec ::
|
||||||
|
* The address of target vector.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* angle ::
|
||||||
|
* The input angle.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Vector_Rotate( FT_Vector* vec,
|
||||||
|
FT_Angle angle );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Vector_Length
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the length of a given vector.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* vec ::
|
||||||
|
* The address of target vector.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The vector length, expressed in the same units that the original
|
||||||
|
* vector coordinates.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Fixed )
|
||||||
|
FT_Vector_Length( FT_Vector* vec );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Vector_Polarize
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Compute both the length and angle of a given vector.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* vec ::
|
||||||
|
* The address of source vector.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* length ::
|
||||||
|
* The vector length.
|
||||||
|
*
|
||||||
|
* angle ::
|
||||||
|
* The vector angle.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Vector_Polarize( FT_Vector* vec,
|
||||||
|
FT_Fixed *length,
|
||||||
|
FT_Angle *angle );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Vector_From_Polar
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Compute vector coordinates from a length and angle.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* vec ::
|
||||||
|
* The address of source vector.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* length ::
|
||||||
|
* The vector length.
|
||||||
|
*
|
||||||
|
* angle ::
|
||||||
|
* The vector angle.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void )
|
||||||
|
FT_Vector_From_Polar( FT_Vector* vec,
|
||||||
|
FT_Fixed length,
|
||||||
|
FT_Angle angle );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTTRIGON_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,614 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* fttypes.h
|
||||||
|
*
|
||||||
|
* FreeType simple types definitions (specification only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTTYPES_H_
|
||||||
|
#define FTTYPES_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_CONFIG_CONFIG_H
|
||||||
|
#include <freetype/ftsystem.h>
|
||||||
|
#include <freetype/ftimage.h>
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* basic_types
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Basic Data Types
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* The basic data types defined by the library.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the basic data types defined by FreeType~2,
|
||||||
|
* ranging from simple scalar types to bitmap descriptors. More
|
||||||
|
* font-specific structures are defined in a different section.
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* FT_Byte
|
||||||
|
* FT_Bytes
|
||||||
|
* FT_Char
|
||||||
|
* FT_Int
|
||||||
|
* FT_UInt
|
||||||
|
* FT_Int16
|
||||||
|
* FT_UInt16
|
||||||
|
* FT_Int32
|
||||||
|
* FT_UInt32
|
||||||
|
* FT_Int64
|
||||||
|
* FT_UInt64
|
||||||
|
* FT_Short
|
||||||
|
* FT_UShort
|
||||||
|
* FT_Long
|
||||||
|
* FT_ULong
|
||||||
|
* FT_Bool
|
||||||
|
* FT_Offset
|
||||||
|
* FT_PtrDist
|
||||||
|
* FT_String
|
||||||
|
* FT_Tag
|
||||||
|
* FT_Error
|
||||||
|
* FT_Fixed
|
||||||
|
* FT_Pointer
|
||||||
|
* FT_Pos
|
||||||
|
* FT_Vector
|
||||||
|
* FT_BBox
|
||||||
|
* FT_Matrix
|
||||||
|
* FT_FWord
|
||||||
|
* FT_UFWord
|
||||||
|
* FT_F2Dot14
|
||||||
|
* FT_UnitVector
|
||||||
|
* FT_F26Dot6
|
||||||
|
* FT_Data
|
||||||
|
*
|
||||||
|
* FT_MAKE_TAG
|
||||||
|
*
|
||||||
|
* FT_Generic
|
||||||
|
* FT_Generic_Finalizer
|
||||||
|
*
|
||||||
|
* FT_Bitmap
|
||||||
|
* FT_Pixel_Mode
|
||||||
|
* FT_Palette_Mode
|
||||||
|
* FT_Glyph_Format
|
||||||
|
* FT_IMAGE_TAG
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Bool
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef of unsigned char, used for simple booleans. As usual,
|
||||||
|
* values 1 and~0 represent true and false, respectively.
|
||||||
|
*/
|
||||||
|
typedef unsigned char FT_Bool;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_FWord
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A signed 16-bit integer used to store a distance in original font
|
||||||
|
* units.
|
||||||
|
*/
|
||||||
|
typedef signed short FT_FWord; /* distance in FUnits */
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_UFWord
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An unsigned 16-bit integer used to store a distance in original font
|
||||||
|
* units.
|
||||||
|
*/
|
||||||
|
typedef unsigned short FT_UFWord; /* unsigned distance */
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Char
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A simple typedef for the _signed_ char type.
|
||||||
|
*/
|
||||||
|
typedef signed char FT_Char;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Byte
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A simple typedef for the _unsigned_ char type.
|
||||||
|
*/
|
||||||
|
typedef unsigned char FT_Byte;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Bytes
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for constant memory areas.
|
||||||
|
*/
|
||||||
|
typedef const FT_Byte* FT_Bytes;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Tag
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for 32-bit tags (as used in the SFNT format).
|
||||||
|
*/
|
||||||
|
typedef FT_UInt32 FT_Tag;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_String
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A simple typedef for the char type, usually used for strings.
|
||||||
|
*/
|
||||||
|
typedef char FT_String;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Short
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for signed short.
|
||||||
|
*/
|
||||||
|
typedef signed short FT_Short;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_UShort
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for unsigned short.
|
||||||
|
*/
|
||||||
|
typedef unsigned short FT_UShort;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Int
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for the int type.
|
||||||
|
*/
|
||||||
|
typedef signed int FT_Int;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_UInt
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for the unsigned int type.
|
||||||
|
*/
|
||||||
|
typedef unsigned int FT_UInt;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Long
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for signed long.
|
||||||
|
*/
|
||||||
|
typedef signed long FT_Long;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_ULong
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A typedef for unsigned long.
|
||||||
|
*/
|
||||||
|
typedef unsigned long FT_ULong;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_F2Dot14
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A signed 2.14 fixed-point type used for unit vectors.
|
||||||
|
*/
|
||||||
|
typedef signed short FT_F2Dot14;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_F26Dot6
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A signed 26.6 fixed-point type used for vectorial pixel coordinates.
|
||||||
|
*/
|
||||||
|
typedef signed long FT_F26Dot6;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Fixed
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This type is used to store 16.16 fixed-point values, like scaling
|
||||||
|
* values or matrix coefficients.
|
||||||
|
*/
|
||||||
|
typedef signed long FT_Fixed;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Error
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The FreeType error code type. A value of~0 is always interpreted as a
|
||||||
|
* successful operation.
|
||||||
|
*/
|
||||||
|
typedef int FT_Error;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Pointer
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A simple typedef for a typeless pointer.
|
||||||
|
*/
|
||||||
|
typedef void* FT_Pointer;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_Offset
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This is equivalent to the ANSI~C `size_t` type, i.e., the largest
|
||||||
|
* _unsigned_ integer type used to express a file size or position, or a
|
||||||
|
* memory block size.
|
||||||
|
*/
|
||||||
|
typedef size_t FT_Offset;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_PtrDist
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This is equivalent to the ANSI~C `ptrdiff_t` type, i.e., the largest
|
||||||
|
* _signed_ integer type used to express the distance between two
|
||||||
|
* pointers.
|
||||||
|
*/
|
||||||
|
typedef ft_ptrdiff_t FT_PtrDist;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_UnitVector
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A simple structure used to store a 2D vector unit vector. Uses
|
||||||
|
* FT_F2Dot14 types.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* x ::
|
||||||
|
* Horizontal coordinate.
|
||||||
|
*
|
||||||
|
* y ::
|
||||||
|
* Vertical coordinate.
|
||||||
|
*/
|
||||||
|
typedef struct FT_UnitVector_
|
||||||
|
{
|
||||||
|
FT_F2Dot14 x;
|
||||||
|
FT_F2Dot14 y;
|
||||||
|
|
||||||
|
} FT_UnitVector;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Matrix
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A simple structure used to store a 2x2 matrix. Coefficients are in
|
||||||
|
* 16.16 fixed-point format. The computation performed is:
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* x' = x*xx + y*xy
|
||||||
|
* y' = x*yx + y*yy
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* xx ::
|
||||||
|
* Matrix coefficient.
|
||||||
|
*
|
||||||
|
* xy ::
|
||||||
|
* Matrix coefficient.
|
||||||
|
*
|
||||||
|
* yx ::
|
||||||
|
* Matrix coefficient.
|
||||||
|
*
|
||||||
|
* yy ::
|
||||||
|
* Matrix coefficient.
|
||||||
|
*/
|
||||||
|
typedef struct FT_Matrix_
|
||||||
|
{
|
||||||
|
FT_Fixed xx, xy;
|
||||||
|
FT_Fixed yx, yy;
|
||||||
|
|
||||||
|
} FT_Matrix;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Data
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Read-only binary data represented as a pointer and a length.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* pointer ::
|
||||||
|
* The data.
|
||||||
|
*
|
||||||
|
* length ::
|
||||||
|
* The length of the data in bytes.
|
||||||
|
*/
|
||||||
|
typedef struct FT_Data_
|
||||||
|
{
|
||||||
|
const FT_Byte* pointer;
|
||||||
|
FT_UInt length;
|
||||||
|
|
||||||
|
} FT_Data;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* FT_Generic_Finalizer
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Describe a function used to destroy the 'client' data of any FreeType
|
||||||
|
* object. See the description of the @FT_Generic type for details of
|
||||||
|
* usage.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* The address of the FreeType object that is under finalization. Its
|
||||||
|
* client data is accessed through its `generic` field.
|
||||||
|
*/
|
||||||
|
typedef void (*FT_Generic_Finalizer)( void* object );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_Generic
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Client applications often need to associate their own data to a
|
||||||
|
* variety of FreeType core objects. For example, a text layout API
|
||||||
|
* might want to associate a glyph cache to a given size object.
|
||||||
|
*
|
||||||
|
* Some FreeType object contains a `generic` field, of type `FT_Generic`,
|
||||||
|
* which usage is left to client applications and font servers.
|
||||||
|
*
|
||||||
|
* It can be used to store a pointer to client-specific data, as well as
|
||||||
|
* the address of a 'finalizer' function, which will be called by
|
||||||
|
* FreeType when the object is destroyed (for example, the previous
|
||||||
|
* client example would put the address of the glyph cache destructor in
|
||||||
|
* the `finalizer` field).
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* data ::
|
||||||
|
* A typeless pointer to any client-specified data. This field is
|
||||||
|
* completely ignored by the FreeType library.
|
||||||
|
*
|
||||||
|
* finalizer ::
|
||||||
|
* A pointer to a 'generic finalizer' function, which will be called
|
||||||
|
* when the object is destroyed. If this field is set to `NULL`, no
|
||||||
|
* code will be called.
|
||||||
|
*/
|
||||||
|
typedef struct FT_Generic_
|
||||||
|
{
|
||||||
|
void* data;
|
||||||
|
FT_Generic_Finalizer finalizer;
|
||||||
|
|
||||||
|
} FT_Generic;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @macro:
|
||||||
|
* FT_MAKE_TAG
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This macro converts four-letter tags that are used to label TrueType
|
||||||
|
* tables into an `FT_Tag` type, to be used within FreeType.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The produced values **must** be 32-bit integers. Don't redefine this
|
||||||
|
* macro.
|
||||||
|
*/
|
||||||
|
#define FT_MAKE_TAG( _x1, _x2, _x3, _x4 ) \
|
||||||
|
( ( FT_STATIC_BYTE_CAST( FT_Tag, _x1 ) << 24 ) | \
|
||||||
|
( FT_STATIC_BYTE_CAST( FT_Tag, _x2 ) << 16 ) | \
|
||||||
|
( FT_STATIC_BYTE_CAST( FT_Tag, _x3 ) << 8 ) | \
|
||||||
|
FT_STATIC_BYTE_CAST( FT_Tag, _x4 ) )
|
||||||
|
|
||||||
|
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
/* */
|
||||||
|
/* L I S T M A N A G E M E N T */
|
||||||
|
/* */
|
||||||
|
/*************************************************************************/
|
||||||
|
/*************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* list_processing
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_ListNode
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Many elements and objects in FreeType are listed through an @FT_List
|
||||||
|
* record (see @FT_ListRec). As its name suggests, an FT_ListNode is a
|
||||||
|
* handle to a single list element.
|
||||||
|
*/
|
||||||
|
typedef struct FT_ListNodeRec_* FT_ListNode;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_List
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to a list record (see @FT_ListRec).
|
||||||
|
*/
|
||||||
|
typedef struct FT_ListRec_* FT_List;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_ListNodeRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to hold a single list element.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* prev ::
|
||||||
|
* The previous element in the list. `NULL` if first.
|
||||||
|
*
|
||||||
|
* next ::
|
||||||
|
* The next element in the list. `NULL` if last.
|
||||||
|
*
|
||||||
|
* data ::
|
||||||
|
* A typeless pointer to the listed object.
|
||||||
|
*/
|
||||||
|
typedef struct FT_ListNodeRec_
|
||||||
|
{
|
||||||
|
FT_ListNode prev;
|
||||||
|
FT_ListNode next;
|
||||||
|
void* data;
|
||||||
|
|
||||||
|
} FT_ListNodeRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_ListRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to hold a simple doubly-linked list. These are used
|
||||||
|
* in many parts of FreeType.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* head ::
|
||||||
|
* The head (first element) of doubly-linked list.
|
||||||
|
*
|
||||||
|
* tail ::
|
||||||
|
* The tail (last element) of doubly-linked list.
|
||||||
|
*/
|
||||||
|
typedef struct FT_ListRec_
|
||||||
|
{
|
||||||
|
FT_ListNode head;
|
||||||
|
FT_ListNode tail;
|
||||||
|
|
||||||
|
} FT_ListRec;
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
#define FT_IS_EMPTY( list ) ( (list).head == 0 )
|
||||||
|
#define FT_BOOL( x ) FT_STATIC_CAST( FT_Bool, (x) != 0 )
|
||||||
|
|
||||||
|
/* concatenate C tokens */
|
||||||
|
#define FT_ERR_XCAT( x, y ) x ## y
|
||||||
|
#define FT_ERR_CAT( x, y ) FT_ERR_XCAT( x, y )
|
||||||
|
|
||||||
|
/* see `ftmoderr.h` for descriptions of the following macros */
|
||||||
|
|
||||||
|
#define FT_ERR( e ) FT_ERR_CAT( FT_ERR_PREFIX, e )
|
||||||
|
|
||||||
|
#define FT_ERROR_BASE( x ) ( (x) & 0xFF )
|
||||||
|
#define FT_ERROR_MODULE( x ) ( (x) & 0xFF00U )
|
||||||
|
|
||||||
|
#define FT_ERR_EQ( x, e ) \
|
||||||
|
( FT_ERROR_BASE( x ) == FT_ERROR_BASE( FT_ERR( e ) ) )
|
||||||
|
#define FT_ERR_NEQ( x, e ) \
|
||||||
|
( FT_ERROR_BASE( x ) != FT_ERROR_BASE( FT_ERR( e ) ) )
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTTYPES_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,276 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ftwinfnt.h
|
||||||
|
*
|
||||||
|
* FreeType API for accessing Windows fnt-specific data.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2003-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FTWINFNT_H_
|
||||||
|
#define FTWINFNT_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* winfnt_fonts
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Window FNT Files
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Windows FNT-specific API.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the declaration of Windows FNT-specific
|
||||||
|
* functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_WinFNT_ID_XXX
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A list of valid values for the `charset` byte in @FT_WinFNT_HeaderRec.
|
||||||
|
* Exact mapping tables for the various 'cpXXXX' encodings (except for
|
||||||
|
* 'cp1361') can be found at 'ftp://ftp.unicode.org/Public/' in the
|
||||||
|
* `MAPPINGS/VENDORS/MICSFT/WINDOWS` subdirectory. 'cp1361' is roughly a
|
||||||
|
* superset of `MAPPINGS/OBSOLETE/EASTASIA/KSC/JOHAB.TXT`.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_WinFNT_ID_DEFAULT ::
|
||||||
|
* This is used for font enumeration and font creation as a 'don't
|
||||||
|
* care' value. Valid font files don't contain this value. When
|
||||||
|
* querying for information about the character set of the font that is
|
||||||
|
* currently selected into a specified device context, this return
|
||||||
|
* value (of the related Windows API) simply denotes failure.
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_SYMBOL ::
|
||||||
|
* There is no known mapping table available.
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_MAC ::
|
||||||
|
* Mac Roman encoding.
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_OEM ::
|
||||||
|
* From Michael Poettgen <michael@poettgen.de>:
|
||||||
|
*
|
||||||
|
* The 'Windows Font Mapping' article says that `FT_WinFNT_ID_OEM` is
|
||||||
|
* used for the charset of vector fonts, like `modern.fon`,
|
||||||
|
* `roman.fon`, and `script.fon` on Windows.
|
||||||
|
*
|
||||||
|
* The 'CreateFont' documentation says: The `FT_WinFNT_ID_OEM` value
|
||||||
|
* specifies a character set that is operating-system dependent.
|
||||||
|
*
|
||||||
|
* The 'IFIMETRICS' documentation from the 'Windows Driver Development
|
||||||
|
* Kit' says: This font supports an OEM-specific character set. The
|
||||||
|
* OEM character set is system dependent.
|
||||||
|
*
|
||||||
|
* In general OEM, as opposed to ANSI (i.e., 'cp1252'), denotes the
|
||||||
|
* second default codepage that most international versions of Windows
|
||||||
|
* have. It is one of the OEM codepages from
|
||||||
|
*
|
||||||
|
* https://docs.microsoft.com/en-us/windows/desktop/intl/code-page-identifiers
|
||||||
|
* ,
|
||||||
|
*
|
||||||
|
* and is used for the 'DOS boxes', to support legacy applications. A
|
||||||
|
* German Windows version for example usually uses ANSI codepage 1252
|
||||||
|
* and OEM codepage 850.
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP874 ::
|
||||||
|
* A superset of Thai TIS 620 and ISO 8859-11.
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP932 ::
|
||||||
|
* A superset of Japanese Shift-JIS (with minor deviations).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP936 ::
|
||||||
|
* A superset of simplified Chinese GB 2312-1980 (with different
|
||||||
|
* ordering and minor deviations).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP949 ::
|
||||||
|
* A superset of Korean Hangul KS~C 5601-1987 (with different ordering
|
||||||
|
* and minor deviations).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP950 ::
|
||||||
|
* A superset of traditional Chinese Big~5 ETen (with different
|
||||||
|
* ordering and minor deviations).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1250 ::
|
||||||
|
* A superset of East European ISO 8859-2 (with slightly different
|
||||||
|
* ordering).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1251 ::
|
||||||
|
* A superset of Russian ISO 8859-5 (with different ordering).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1252 ::
|
||||||
|
* ANSI encoding. A superset of ISO 8859-1.
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1253 ::
|
||||||
|
* A superset of Greek ISO 8859-7 (with minor modifications).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1254 ::
|
||||||
|
* A superset of Turkish ISO 8859-9.
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1255 ::
|
||||||
|
* A superset of Hebrew ISO 8859-8 (with some modifications).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1256 ::
|
||||||
|
* A superset of Arabic ISO 8859-6 (with different ordering).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1257 ::
|
||||||
|
* A superset of Baltic ISO 8859-13 (with some deviations).
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1258 ::
|
||||||
|
* For Vietnamese. This encoding doesn't cover all necessary
|
||||||
|
* characters.
|
||||||
|
*
|
||||||
|
* FT_WinFNT_ID_CP1361 ::
|
||||||
|
* Korean (Johab).
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define FT_WinFNT_ID_CP1252 0
|
||||||
|
#define FT_WinFNT_ID_DEFAULT 1
|
||||||
|
#define FT_WinFNT_ID_SYMBOL 2
|
||||||
|
#define FT_WinFNT_ID_MAC 77
|
||||||
|
#define FT_WinFNT_ID_CP932 128
|
||||||
|
#define FT_WinFNT_ID_CP949 129
|
||||||
|
#define FT_WinFNT_ID_CP1361 130
|
||||||
|
#define FT_WinFNT_ID_CP936 134
|
||||||
|
#define FT_WinFNT_ID_CP950 136
|
||||||
|
#define FT_WinFNT_ID_CP1253 161
|
||||||
|
#define FT_WinFNT_ID_CP1254 162
|
||||||
|
#define FT_WinFNT_ID_CP1258 163
|
||||||
|
#define FT_WinFNT_ID_CP1255 177
|
||||||
|
#define FT_WinFNT_ID_CP1256 178
|
||||||
|
#define FT_WinFNT_ID_CP1257 186
|
||||||
|
#define FT_WinFNT_ID_CP1251 204
|
||||||
|
#define FT_WinFNT_ID_CP874 222
|
||||||
|
#define FT_WinFNT_ID_CP1250 238
|
||||||
|
#define FT_WinFNT_ID_OEM 255
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_WinFNT_HeaderRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Windows FNT Header info.
|
||||||
|
*/
|
||||||
|
typedef struct FT_WinFNT_HeaderRec_
|
||||||
|
{
|
||||||
|
FT_UShort version;
|
||||||
|
FT_ULong file_size;
|
||||||
|
FT_Byte copyright[60];
|
||||||
|
FT_UShort file_type;
|
||||||
|
FT_UShort nominal_point_size;
|
||||||
|
FT_UShort vertical_resolution;
|
||||||
|
FT_UShort horizontal_resolution;
|
||||||
|
FT_UShort ascent;
|
||||||
|
FT_UShort internal_leading;
|
||||||
|
FT_UShort external_leading;
|
||||||
|
FT_Byte italic;
|
||||||
|
FT_Byte underline;
|
||||||
|
FT_Byte strike_out;
|
||||||
|
FT_UShort weight;
|
||||||
|
FT_Byte charset;
|
||||||
|
FT_UShort pixel_width;
|
||||||
|
FT_UShort pixel_height;
|
||||||
|
FT_Byte pitch_and_family;
|
||||||
|
FT_UShort avg_width;
|
||||||
|
FT_UShort max_width;
|
||||||
|
FT_Byte first_char;
|
||||||
|
FT_Byte last_char;
|
||||||
|
FT_Byte default_char;
|
||||||
|
FT_Byte break_char;
|
||||||
|
FT_UShort bytes_per_row;
|
||||||
|
FT_ULong device_offset;
|
||||||
|
FT_ULong face_name_offset;
|
||||||
|
FT_ULong bits_pointer;
|
||||||
|
FT_ULong bits_offset;
|
||||||
|
FT_Byte reserved;
|
||||||
|
FT_ULong flags;
|
||||||
|
FT_UShort A_space;
|
||||||
|
FT_UShort B_space;
|
||||||
|
FT_UShort C_space;
|
||||||
|
FT_UShort color_table_offset;
|
||||||
|
FT_ULong reserved1[4];
|
||||||
|
|
||||||
|
} FT_WinFNT_HeaderRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_WinFNT_Header
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to an @FT_WinFNT_HeaderRec structure.
|
||||||
|
*/
|
||||||
|
typedef struct FT_WinFNT_HeaderRec_* FT_WinFNT_Header;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_WinFNT_Header
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve a Windows FNT font info header.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the input face.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* aheader ::
|
||||||
|
* The WinFNT header.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This function only works with Windows FNT faces, returning an error
|
||||||
|
* otherwise.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_WinFNT_Header( FT_Face face,
|
||||||
|
FT_WinFNT_HeaderRec *aheader );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* FTWINFNT_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
|
|
||||||
|
|
||||||
|
/* Local Variables: */
|
||||||
|
/* coding: utf-8 */
|
||||||
|
/* End: */
|
||||||
@@ -0,0 +1,336 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* otsvg.h
|
||||||
|
*
|
||||||
|
* Interface for OT-SVG support related things (specification).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2022 by
|
||||||
|
* David Turner, Robert Wilhelm, Werner Lemberg, and Moazin Khatti.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef OTSVG_H_
|
||||||
|
#define OTSVG_H_
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* svg_fonts
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* OpenType SVG Fonts
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* OT-SVG API between FreeType and an external SVG rendering library.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section describes the four hooks necessary to render SVG
|
||||||
|
* 'documents' that are contained in an OpenType font's 'SVG~' table.
|
||||||
|
*
|
||||||
|
* For more information on the implementation, see our standard hooks
|
||||||
|
* based on 'librsvg' in the [FreeType Demo
|
||||||
|
* Programs](https://gitlab.freedesktop.org/freetype/freetype-demos)
|
||||||
|
* repository.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* SVG_Lib_Init_Func
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A callback that is called when the first OT-SVG glyph is rendered in
|
||||||
|
* the lifetime of an @FT_Library object. In a typical implementation,
|
||||||
|
* one would want to allocate a structure and point the `data_pointer`
|
||||||
|
* to it and perform any library initializations that might be needed.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* data_pointer ::
|
||||||
|
* The SVG rendering module stores a pointer variable that can be used
|
||||||
|
* by clients to store any data that needs to be shared across
|
||||||
|
* different hooks. `data_pointer` is essentially a pointer to that
|
||||||
|
* pointer such that it can be written to as well as read from.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0 means success.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.12
|
||||||
|
*/
|
||||||
|
typedef FT_Error
|
||||||
|
(*SVG_Lib_Init_Func)( FT_Pointer *data_pointer );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* SVG_Lib_Free_Func
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A callback that is called when the `ot-svg` module is being freed.
|
||||||
|
* It is only called if the init hook was called earlier. This means
|
||||||
|
* that neither the init nor the free hook is called if no OT-SVG glyph
|
||||||
|
* is rendered.
|
||||||
|
*
|
||||||
|
* In a typical implementation, one would want to free any state
|
||||||
|
* structure that was allocated in the init hook and perform any
|
||||||
|
* library-related closure that might be needed.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* data_pointer ::
|
||||||
|
* The SVG rendering module stores a pointer variable that can be used
|
||||||
|
* by clients to store any data that needs to be shared across
|
||||||
|
* different hooks. `data_pointer` is essentially a pointer to that
|
||||||
|
* pointer such that it can be written to as well as read from.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.12
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*SVG_Lib_Free_Func)( FT_Pointer *data_pointer );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* SVG_Lib_Render_Func
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A callback that is called to render an OT-SVG glyph. This callback
|
||||||
|
* hook is called right after the preset hook @SVG_Lib_Preset_Slot_Func
|
||||||
|
* has been called with `cache` set to `TRUE`. The data necessary to
|
||||||
|
* render is available through the handle @FT_SVG_Document, which is set
|
||||||
|
* in the `other` field of @FT_GlyphSlotRec.
|
||||||
|
*
|
||||||
|
* The render hook is expected to render the SVG glyph to the bitmap
|
||||||
|
* buffer that is allocated already at `slot->bitmap.buffer`. It also
|
||||||
|
* sets the `num_grays` value as well as `slot->format`.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* slot ::
|
||||||
|
* The slot to render.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* data_pointer ::
|
||||||
|
* The SVG rendering module stores a pointer variable that can be used
|
||||||
|
* by clients to store any data that needs to be shared across
|
||||||
|
* different hooks. `data_pointer` is essentially a pointer to that
|
||||||
|
* pointer such that it can be written to as well as read from.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0 means success.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.12
|
||||||
|
*/
|
||||||
|
typedef FT_Error
|
||||||
|
(*SVG_Lib_Render_Func)( FT_GlyphSlot slot,
|
||||||
|
FT_Pointer *data_pointer );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @functype:
|
||||||
|
* SVG_Lib_Preset_Slot_Func
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A callback that is called to preset the glyph slot. It is called from
|
||||||
|
* two places.
|
||||||
|
*
|
||||||
|
* 1. When `FT_Load_Glyph` needs to preset the glyph slot.
|
||||||
|
*
|
||||||
|
* 2. Right before the `svg` module calls the render callback hook.
|
||||||
|
*
|
||||||
|
* When it is the former, the argument `cache` is set to `FALSE`. When
|
||||||
|
* it is the latter, the argument `cache` is set to `TRUE`. This
|
||||||
|
* distinction has been made because many calculations that are necessary
|
||||||
|
* for presetting a glyph slot are the same needed later for the render
|
||||||
|
* callback hook. Thus, if `cache` is `TRUE`, the hook can _cache_ those
|
||||||
|
* calculations in a memory block referenced by the state pointer.
|
||||||
|
*
|
||||||
|
* This hook is expected to preset the slot by setting parameters such as
|
||||||
|
* `bitmap_left`, `bitmap_top`, `width`, `rows`, `pitch`, and
|
||||||
|
* `pixel_mode`. It is also expected to set all the metrics for the slot
|
||||||
|
* including the vertical advance if it is not already set. Typically,
|
||||||
|
* fonts have horizontal advances but not vertical ones. If those are
|
||||||
|
* available, they had already been set, otherwise they have to be
|
||||||
|
* estimated and set manually. The hook must take into account the
|
||||||
|
* transformations that have been set, and translate the transformation
|
||||||
|
* matrices into the SVG coordinate system, as the original matrix is
|
||||||
|
* intended for the TTF/CFF coordinate system.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* slot ::
|
||||||
|
* The glyph slot that has the SVG document loaded.
|
||||||
|
*
|
||||||
|
* cache ::
|
||||||
|
* See description.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* data_pointer ::
|
||||||
|
* The SVG rendering module stores a pointer variable that can be used
|
||||||
|
* by clients to store any data that needs to be shared across
|
||||||
|
* different hooks. `data_pointer` is essentially a pointer to that
|
||||||
|
* pointer such that it can be written to as well as read from.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0 means success.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.12
|
||||||
|
*/
|
||||||
|
typedef FT_Error
|
||||||
|
(*SVG_Lib_Preset_Slot_Func)( FT_GlyphSlot slot,
|
||||||
|
FT_Bool cache,
|
||||||
|
FT_Pointer *state );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* SVG_RendererHooks
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure that stores the four hooks needed to render OT-SVG glyphs
|
||||||
|
* properly. The structure is publicly used to set the hooks via the
|
||||||
|
* @svg-hooks driver property.
|
||||||
|
*
|
||||||
|
* The behavior of each hook is described in its documentation. One
|
||||||
|
* thing to note is that the preset hook and the render hook often need
|
||||||
|
* to do the same operations; therefore, it's better to cache the
|
||||||
|
* intermediate data in a state structure to avoid calculating it twice.
|
||||||
|
* For example, in the preset hook one can draw the glyph on a recorder
|
||||||
|
* surface and later create a bitmap surface from it in the render hook.
|
||||||
|
*
|
||||||
|
* All four hooks must be non-NULL.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* init_svg ::
|
||||||
|
* The initialization hook.
|
||||||
|
*
|
||||||
|
* free_svg ::
|
||||||
|
* The cleanup hook.
|
||||||
|
*
|
||||||
|
* render_hook ::
|
||||||
|
* The render hook.
|
||||||
|
*
|
||||||
|
* preset_slot ::
|
||||||
|
* The preset hook.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.12
|
||||||
|
*/
|
||||||
|
typedef struct SVG_RendererHooks_
|
||||||
|
{
|
||||||
|
SVG_Lib_Init_Func init_svg;
|
||||||
|
SVG_Lib_Free_Func free_svg;
|
||||||
|
SVG_Lib_Render_Func render_svg;
|
||||||
|
|
||||||
|
SVG_Lib_Preset_Slot_Func preset_slot;
|
||||||
|
|
||||||
|
} SVG_RendererHooks;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* FT_SVG_DocumentRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure that models one SVG document.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* svg_document ::
|
||||||
|
* A pointer to the SVG document.
|
||||||
|
*
|
||||||
|
* svg_document_length ::
|
||||||
|
* The length of `svg_document`.
|
||||||
|
*
|
||||||
|
* metrics ::
|
||||||
|
* A metrics object storing the size information.
|
||||||
|
*
|
||||||
|
* units_per_EM ::
|
||||||
|
* The size of the EM square.
|
||||||
|
*
|
||||||
|
* start_glyph_id ::
|
||||||
|
* The first glyph ID in the glyph range covered by this document.
|
||||||
|
*
|
||||||
|
* end_glyph_id ::
|
||||||
|
* The last glyph ID in the glyph range covered by this document.
|
||||||
|
*
|
||||||
|
* transform ::
|
||||||
|
* A 2x2 transformation matrix to apply to the glyph while rendering
|
||||||
|
* it.
|
||||||
|
*
|
||||||
|
* delta ::
|
||||||
|
* The translation to apply to the glyph while rendering.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* When an @FT_GlyphSlot object `slot` is passed down to a renderer, the
|
||||||
|
* renderer can only access the `metrics` and `units_per_EM` fields via
|
||||||
|
* `slot->face`. However, when @FT_Glyph_To_Bitmap sets up a dummy
|
||||||
|
* object, it has no way to set a `face` object. Thus, metrics
|
||||||
|
* information and `units_per_EM` (which is necessary for OT-SVG) has to
|
||||||
|
* be stored separately.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.12
|
||||||
|
*/
|
||||||
|
typedef struct FT_SVG_DocumentRec_
|
||||||
|
{
|
||||||
|
FT_Byte* svg_document;
|
||||||
|
FT_ULong svg_document_length;
|
||||||
|
|
||||||
|
FT_Size_Metrics metrics;
|
||||||
|
FT_UShort units_per_EM;
|
||||||
|
|
||||||
|
FT_UShort start_glyph_id;
|
||||||
|
FT_UShort end_glyph_id;
|
||||||
|
|
||||||
|
FT_Matrix transform;
|
||||||
|
FT_Vector delta;
|
||||||
|
|
||||||
|
} FT_SVG_DocumentRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @type:
|
||||||
|
* FT_SVG_Document
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to an @FT_SVG_DocumentRec object.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.12
|
||||||
|
*/
|
||||||
|
typedef struct FT_SVG_DocumentRec_* FT_SVG_Document;
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* OTSVG_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,793 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* t1tables.h
|
||||||
|
*
|
||||||
|
* Basic Type 1/Type 2 tables definitions and interface (specification
|
||||||
|
* only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef T1TABLES_H_
|
||||||
|
#define T1TABLES_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* type1_tables
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* Type 1 Tables
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* Type~1-specific font tables.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains the definition of Type~1-specific tables,
|
||||||
|
* including structures related to other PostScript font formats.
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* PS_FontInfoRec
|
||||||
|
* PS_FontInfo
|
||||||
|
* PS_PrivateRec
|
||||||
|
* PS_Private
|
||||||
|
*
|
||||||
|
* CID_FaceDictRec
|
||||||
|
* CID_FaceDict
|
||||||
|
* CID_FaceInfoRec
|
||||||
|
* CID_FaceInfo
|
||||||
|
*
|
||||||
|
* FT_Has_PS_Glyph_Names
|
||||||
|
* FT_Get_PS_Font_Info
|
||||||
|
* FT_Get_PS_Font_Private
|
||||||
|
* FT_Get_PS_Font_Value
|
||||||
|
*
|
||||||
|
* T1_Blend_Flags
|
||||||
|
* T1_EncodingType
|
||||||
|
* PS_Dict_Keys
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* Note that we separate font data in PS_FontInfoRec and PS_PrivateRec */
|
||||||
|
/* structures in order to support Multiple Master fonts. */
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* PS_FontInfoRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to model a Type~1 or Type~2 FontInfo dictionary.
|
||||||
|
* Note that for Multiple Master fonts, each instance has its own
|
||||||
|
* FontInfo dictionary.
|
||||||
|
*/
|
||||||
|
typedef struct PS_FontInfoRec_
|
||||||
|
{
|
||||||
|
FT_String* version;
|
||||||
|
FT_String* notice;
|
||||||
|
FT_String* full_name;
|
||||||
|
FT_String* family_name;
|
||||||
|
FT_String* weight;
|
||||||
|
FT_Long italic_angle;
|
||||||
|
FT_Bool is_fixed_pitch;
|
||||||
|
FT_Short underline_position;
|
||||||
|
FT_UShort underline_thickness;
|
||||||
|
|
||||||
|
} PS_FontInfoRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* PS_FontInfo
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to a @PS_FontInfoRec structure.
|
||||||
|
*/
|
||||||
|
typedef struct PS_FontInfoRec_* PS_FontInfo;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* T1_FontInfo
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This type is equivalent to @PS_FontInfoRec. It is deprecated but kept
|
||||||
|
* to maintain source compatibility between various versions of FreeType.
|
||||||
|
*/
|
||||||
|
typedef PS_FontInfoRec T1_FontInfo;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* PS_PrivateRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to model a Type~1 or Type~2 private dictionary. Note
|
||||||
|
* that for Multiple Master fonts, each instance has its own Private
|
||||||
|
* dictionary.
|
||||||
|
*/
|
||||||
|
typedef struct PS_PrivateRec_
|
||||||
|
{
|
||||||
|
FT_Int unique_id;
|
||||||
|
FT_Int lenIV;
|
||||||
|
|
||||||
|
FT_Byte num_blue_values;
|
||||||
|
FT_Byte num_other_blues;
|
||||||
|
FT_Byte num_family_blues;
|
||||||
|
FT_Byte num_family_other_blues;
|
||||||
|
|
||||||
|
FT_Short blue_values[14];
|
||||||
|
FT_Short other_blues[10];
|
||||||
|
|
||||||
|
FT_Short family_blues [14];
|
||||||
|
FT_Short family_other_blues[10];
|
||||||
|
|
||||||
|
FT_Fixed blue_scale;
|
||||||
|
FT_Int blue_shift;
|
||||||
|
FT_Int blue_fuzz;
|
||||||
|
|
||||||
|
FT_UShort standard_width[1];
|
||||||
|
FT_UShort standard_height[1];
|
||||||
|
|
||||||
|
FT_Byte num_snap_widths;
|
||||||
|
FT_Byte num_snap_heights;
|
||||||
|
FT_Bool force_bold;
|
||||||
|
FT_Bool round_stem_up;
|
||||||
|
|
||||||
|
FT_Short snap_widths [13]; /* including std width */
|
||||||
|
FT_Short snap_heights[13]; /* including std height */
|
||||||
|
|
||||||
|
FT_Fixed expansion_factor;
|
||||||
|
|
||||||
|
FT_Long language_group;
|
||||||
|
FT_Long password;
|
||||||
|
|
||||||
|
FT_Short min_feature[2];
|
||||||
|
|
||||||
|
} PS_PrivateRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* PS_Private
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to a @PS_PrivateRec structure.
|
||||||
|
*/
|
||||||
|
typedef struct PS_PrivateRec_* PS_Private;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* T1_Private
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This type is equivalent to @PS_PrivateRec. It is deprecated but kept
|
||||||
|
* to maintain source compatibility between various versions of FreeType.
|
||||||
|
*/
|
||||||
|
typedef PS_PrivateRec T1_Private;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* T1_Blend_Flags
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A set of flags used to indicate which fields are present in a given
|
||||||
|
* blend dictionary (font info or private). Used to support Multiple
|
||||||
|
* Masters fonts.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* T1_BLEND_UNDERLINE_POSITION ::
|
||||||
|
* T1_BLEND_UNDERLINE_THICKNESS ::
|
||||||
|
* T1_BLEND_ITALIC_ANGLE ::
|
||||||
|
* T1_BLEND_BLUE_VALUES ::
|
||||||
|
* T1_BLEND_OTHER_BLUES ::
|
||||||
|
* T1_BLEND_STANDARD_WIDTH ::
|
||||||
|
* T1_BLEND_STANDARD_HEIGHT ::
|
||||||
|
* T1_BLEND_STEM_SNAP_WIDTHS ::
|
||||||
|
* T1_BLEND_STEM_SNAP_HEIGHTS ::
|
||||||
|
* T1_BLEND_BLUE_SCALE ::
|
||||||
|
* T1_BLEND_BLUE_SHIFT ::
|
||||||
|
* T1_BLEND_FAMILY_BLUES ::
|
||||||
|
* T1_BLEND_FAMILY_OTHER_BLUES ::
|
||||||
|
* T1_BLEND_FORCE_BOLD ::
|
||||||
|
*/
|
||||||
|
typedef enum T1_Blend_Flags_
|
||||||
|
{
|
||||||
|
/* required fields in a FontInfo blend dictionary */
|
||||||
|
T1_BLEND_UNDERLINE_POSITION = 0,
|
||||||
|
T1_BLEND_UNDERLINE_THICKNESS,
|
||||||
|
T1_BLEND_ITALIC_ANGLE,
|
||||||
|
|
||||||
|
/* required fields in a Private blend dictionary */
|
||||||
|
T1_BLEND_BLUE_VALUES,
|
||||||
|
T1_BLEND_OTHER_BLUES,
|
||||||
|
T1_BLEND_STANDARD_WIDTH,
|
||||||
|
T1_BLEND_STANDARD_HEIGHT,
|
||||||
|
T1_BLEND_STEM_SNAP_WIDTHS,
|
||||||
|
T1_BLEND_STEM_SNAP_HEIGHTS,
|
||||||
|
T1_BLEND_BLUE_SCALE,
|
||||||
|
T1_BLEND_BLUE_SHIFT,
|
||||||
|
T1_BLEND_FAMILY_BLUES,
|
||||||
|
T1_BLEND_FAMILY_OTHER_BLUES,
|
||||||
|
T1_BLEND_FORCE_BOLD,
|
||||||
|
|
||||||
|
T1_BLEND_MAX /* do not remove */
|
||||||
|
|
||||||
|
} T1_Blend_Flags;
|
||||||
|
|
||||||
|
|
||||||
|
/* these constants are deprecated; use the corresponding */
|
||||||
|
/* `T1_Blend_Flags` values instead */
|
||||||
|
#define t1_blend_underline_position T1_BLEND_UNDERLINE_POSITION
|
||||||
|
#define t1_blend_underline_thickness T1_BLEND_UNDERLINE_THICKNESS
|
||||||
|
#define t1_blend_italic_angle T1_BLEND_ITALIC_ANGLE
|
||||||
|
#define t1_blend_blue_values T1_BLEND_BLUE_VALUES
|
||||||
|
#define t1_blend_other_blues T1_BLEND_OTHER_BLUES
|
||||||
|
#define t1_blend_standard_widths T1_BLEND_STANDARD_WIDTH
|
||||||
|
#define t1_blend_standard_height T1_BLEND_STANDARD_HEIGHT
|
||||||
|
#define t1_blend_stem_snap_widths T1_BLEND_STEM_SNAP_WIDTHS
|
||||||
|
#define t1_blend_stem_snap_heights T1_BLEND_STEM_SNAP_HEIGHTS
|
||||||
|
#define t1_blend_blue_scale T1_BLEND_BLUE_SCALE
|
||||||
|
#define t1_blend_blue_shift T1_BLEND_BLUE_SHIFT
|
||||||
|
#define t1_blend_family_blues T1_BLEND_FAMILY_BLUES
|
||||||
|
#define t1_blend_family_other_blues T1_BLEND_FAMILY_OTHER_BLUES
|
||||||
|
#define t1_blend_force_bold T1_BLEND_FORCE_BOLD
|
||||||
|
#define t1_blend_max T1_BLEND_MAX
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
/* maximum number of Multiple Masters designs, as defined in the spec */
|
||||||
|
#define T1_MAX_MM_DESIGNS 16
|
||||||
|
|
||||||
|
/* maximum number of Multiple Masters axes, as defined in the spec */
|
||||||
|
#define T1_MAX_MM_AXIS 4
|
||||||
|
|
||||||
|
/* maximum number of elements in a design map */
|
||||||
|
#define T1_MAX_MM_MAP_POINTS 20
|
||||||
|
|
||||||
|
|
||||||
|
/* this structure is used to store the BlendDesignMap entry for an axis */
|
||||||
|
typedef struct PS_DesignMap_
|
||||||
|
{
|
||||||
|
FT_Byte num_points;
|
||||||
|
FT_Long* design_points;
|
||||||
|
FT_Fixed* blend_points;
|
||||||
|
|
||||||
|
} PS_DesignMapRec, *PS_DesignMap;
|
||||||
|
|
||||||
|
/* backward compatible definition */
|
||||||
|
typedef PS_DesignMapRec T1_DesignMap;
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct PS_BlendRec_
|
||||||
|
{
|
||||||
|
FT_UInt num_designs;
|
||||||
|
FT_UInt num_axis;
|
||||||
|
|
||||||
|
FT_String* axis_names[T1_MAX_MM_AXIS];
|
||||||
|
FT_Fixed* design_pos[T1_MAX_MM_DESIGNS];
|
||||||
|
PS_DesignMapRec design_map[T1_MAX_MM_AXIS];
|
||||||
|
|
||||||
|
FT_Fixed* weight_vector;
|
||||||
|
FT_Fixed* default_weight_vector;
|
||||||
|
|
||||||
|
PS_FontInfo font_infos[T1_MAX_MM_DESIGNS + 1];
|
||||||
|
PS_Private privates [T1_MAX_MM_DESIGNS + 1];
|
||||||
|
|
||||||
|
FT_ULong blend_bitflags;
|
||||||
|
|
||||||
|
FT_BBox* bboxes [T1_MAX_MM_DESIGNS + 1];
|
||||||
|
|
||||||
|
/* since 2.3.0 */
|
||||||
|
|
||||||
|
/* undocumented, optional: the default design instance; */
|
||||||
|
/* corresponds to default_weight_vector -- */
|
||||||
|
/* num_default_design_vector == 0 means it is not present */
|
||||||
|
/* in the font and associated metrics files */
|
||||||
|
FT_UInt default_design_vector[T1_MAX_MM_DESIGNS];
|
||||||
|
FT_UInt num_default_design_vector;
|
||||||
|
|
||||||
|
} PS_BlendRec, *PS_Blend;
|
||||||
|
|
||||||
|
|
||||||
|
/* backward compatible definition */
|
||||||
|
typedef PS_BlendRec T1_Blend;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* CID_FaceDictRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to represent data in a CID top-level dictionary. In
|
||||||
|
* most cases, they are part of the font's '/FDArray' array. Within a
|
||||||
|
* CID font file, such (internal) subfont dictionaries are enclosed by
|
||||||
|
* '%ADOBeginFontDict' and '%ADOEndFontDict' comments.
|
||||||
|
*
|
||||||
|
* Note that `CID_FaceDictRec` misses a field for the '/FontName'
|
||||||
|
* keyword, specifying the subfont's name (the top-level font name is
|
||||||
|
* given by the '/CIDFontName' keyword). This is an oversight, but it
|
||||||
|
* doesn't limit the 'cid' font module's functionality because FreeType
|
||||||
|
* neither needs this entry nor gives access to CID subfonts.
|
||||||
|
*/
|
||||||
|
typedef struct CID_FaceDictRec_
|
||||||
|
{
|
||||||
|
PS_PrivateRec private_dict;
|
||||||
|
|
||||||
|
FT_UInt len_buildchar;
|
||||||
|
FT_Fixed forcebold_threshold;
|
||||||
|
FT_Pos stroke_width;
|
||||||
|
FT_Fixed expansion_factor; /* this is a duplicate of */
|
||||||
|
/* `private_dict->expansion_factor' */
|
||||||
|
FT_Byte paint_type;
|
||||||
|
FT_Byte font_type;
|
||||||
|
FT_Matrix font_matrix;
|
||||||
|
FT_Vector font_offset;
|
||||||
|
|
||||||
|
FT_UInt num_subrs;
|
||||||
|
FT_ULong subrmap_offset;
|
||||||
|
FT_UInt sd_bytes;
|
||||||
|
|
||||||
|
} CID_FaceDictRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* CID_FaceDict
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to a @CID_FaceDictRec structure.
|
||||||
|
*/
|
||||||
|
typedef struct CID_FaceDictRec_* CID_FaceDict;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* CID_FontDict
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This type is equivalent to @CID_FaceDictRec. It is deprecated but
|
||||||
|
* kept to maintain source compatibility between various versions of
|
||||||
|
* FreeType.
|
||||||
|
*/
|
||||||
|
typedef CID_FaceDictRec CID_FontDict;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* CID_FaceInfoRec
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to represent CID Face information.
|
||||||
|
*/
|
||||||
|
typedef struct CID_FaceInfoRec_
|
||||||
|
{
|
||||||
|
FT_String* cid_font_name;
|
||||||
|
FT_Fixed cid_version;
|
||||||
|
FT_Int cid_font_type;
|
||||||
|
|
||||||
|
FT_String* registry;
|
||||||
|
FT_String* ordering;
|
||||||
|
FT_Int supplement;
|
||||||
|
|
||||||
|
PS_FontInfoRec font_info;
|
||||||
|
FT_BBox font_bbox;
|
||||||
|
FT_ULong uid_base;
|
||||||
|
|
||||||
|
FT_Int num_xuid;
|
||||||
|
FT_ULong xuid[16];
|
||||||
|
|
||||||
|
FT_ULong cidmap_offset;
|
||||||
|
FT_UInt fd_bytes;
|
||||||
|
FT_UInt gd_bytes;
|
||||||
|
FT_ULong cid_count;
|
||||||
|
|
||||||
|
FT_UInt num_dicts;
|
||||||
|
CID_FaceDict font_dicts;
|
||||||
|
|
||||||
|
FT_ULong data_offset;
|
||||||
|
|
||||||
|
} CID_FaceInfoRec;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* CID_FaceInfo
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A handle to a @CID_FaceInfoRec structure.
|
||||||
|
*/
|
||||||
|
typedef struct CID_FaceInfoRec_* CID_FaceInfo;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* CID_Info
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This type is equivalent to @CID_FaceInfoRec. It is deprecated but kept
|
||||||
|
* to maintain source compatibility between various versions of FreeType.
|
||||||
|
*/
|
||||||
|
typedef CID_FaceInfoRec CID_Info;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Has_PS_Glyph_Names
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return true if a given face provides reliable PostScript glyph names.
|
||||||
|
* This is similar to using the @FT_HAS_GLYPH_NAMES macro, except that
|
||||||
|
* certain fonts (mostly TrueType) contain incorrect glyph name tables.
|
||||||
|
*
|
||||||
|
* When this function returns true, the caller is sure that the glyph
|
||||||
|
* names returned by @FT_Get_Glyph_Name are reliable.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* face handle
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* Boolean. True if glyph names are reliable.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Int )
|
||||||
|
FT_Has_PS_Glyph_Names( FT_Face face );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_PS_Font_Info
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the @PS_FontInfoRec structure corresponding to a given
|
||||||
|
* PostScript font.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* PostScript face handle.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* afont_info ::
|
||||||
|
* A pointer to a @PS_FontInfoRec object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* String pointers within the @PS_FontInfoRec structure are owned by the
|
||||||
|
* face and don't need to be freed by the caller. Missing entries in the
|
||||||
|
* font's FontInfo dictionary are represented by `NULL` pointers.
|
||||||
|
*
|
||||||
|
* The following font formats support this feature: 'Type~1', 'Type~42',
|
||||||
|
* 'CFF', 'CID~Type~1'. For other font formats this function returns the
|
||||||
|
* `FT_Err_Invalid_Argument` error code.
|
||||||
|
*
|
||||||
|
* @example:
|
||||||
|
* ```
|
||||||
|
* PS_FontInfoRec font_info;
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* error = FT_Get_PS_Font_Info( face, &font_info );
|
||||||
|
* ...
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_PS_Font_Info( FT_Face face,
|
||||||
|
PS_FontInfo afont_info );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_PS_Font_Private
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the @PS_PrivateRec structure corresponding to a given
|
||||||
|
* PostScript font.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* PostScript face handle.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* afont_private ::
|
||||||
|
* A pointer to a @PS_PrivateRec object.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The string pointers within the @PS_PrivateRec structure are owned by
|
||||||
|
* the face and don't need to be freed by the caller.
|
||||||
|
*
|
||||||
|
* Only the 'Type~1' font format supports this feature. For other font
|
||||||
|
* formats this function returns the `FT_Err_Invalid_Argument` error
|
||||||
|
* code.
|
||||||
|
*
|
||||||
|
* @example:
|
||||||
|
* ```
|
||||||
|
* PS_PrivateRec font_private;
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* error = FT_Get_PS_Font_Private( face, &font_private );
|
||||||
|
* ...
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Get_PS_Font_Private( FT_Face face,
|
||||||
|
PS_Private afont_private );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* T1_EncodingType
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An enumeration describing the 'Encoding' entry in a Type 1 dictionary.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* T1_ENCODING_TYPE_NONE ::
|
||||||
|
* T1_ENCODING_TYPE_ARRAY ::
|
||||||
|
* T1_ENCODING_TYPE_STANDARD ::
|
||||||
|
* T1_ENCODING_TYPE_ISOLATIN1 ::
|
||||||
|
* T1_ENCODING_TYPE_EXPERT ::
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.4.8
|
||||||
|
*/
|
||||||
|
typedef enum T1_EncodingType_
|
||||||
|
{
|
||||||
|
T1_ENCODING_TYPE_NONE = 0,
|
||||||
|
T1_ENCODING_TYPE_ARRAY,
|
||||||
|
T1_ENCODING_TYPE_STANDARD,
|
||||||
|
T1_ENCODING_TYPE_ISOLATIN1,
|
||||||
|
T1_ENCODING_TYPE_EXPERT
|
||||||
|
|
||||||
|
} T1_EncodingType;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* PS_Dict_Keys
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An enumeration used in calls to @FT_Get_PS_Font_Value to identify the
|
||||||
|
* Type~1 dictionary entry to retrieve.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* PS_DICT_FONT_TYPE ::
|
||||||
|
* PS_DICT_FONT_MATRIX ::
|
||||||
|
* PS_DICT_FONT_BBOX ::
|
||||||
|
* PS_DICT_PAINT_TYPE ::
|
||||||
|
* PS_DICT_FONT_NAME ::
|
||||||
|
* PS_DICT_UNIQUE_ID ::
|
||||||
|
* PS_DICT_NUM_CHAR_STRINGS ::
|
||||||
|
* PS_DICT_CHAR_STRING_KEY ::
|
||||||
|
* PS_DICT_CHAR_STRING ::
|
||||||
|
* PS_DICT_ENCODING_TYPE ::
|
||||||
|
* PS_DICT_ENCODING_ENTRY ::
|
||||||
|
* PS_DICT_NUM_SUBRS ::
|
||||||
|
* PS_DICT_SUBR ::
|
||||||
|
* PS_DICT_STD_HW ::
|
||||||
|
* PS_DICT_STD_VW ::
|
||||||
|
* PS_DICT_NUM_BLUE_VALUES ::
|
||||||
|
* PS_DICT_BLUE_VALUE ::
|
||||||
|
* PS_DICT_BLUE_FUZZ ::
|
||||||
|
* PS_DICT_NUM_OTHER_BLUES ::
|
||||||
|
* PS_DICT_OTHER_BLUE ::
|
||||||
|
* PS_DICT_NUM_FAMILY_BLUES ::
|
||||||
|
* PS_DICT_FAMILY_BLUE ::
|
||||||
|
* PS_DICT_NUM_FAMILY_OTHER_BLUES ::
|
||||||
|
* PS_DICT_FAMILY_OTHER_BLUE ::
|
||||||
|
* PS_DICT_BLUE_SCALE ::
|
||||||
|
* PS_DICT_BLUE_SHIFT ::
|
||||||
|
* PS_DICT_NUM_STEM_SNAP_H ::
|
||||||
|
* PS_DICT_STEM_SNAP_H ::
|
||||||
|
* PS_DICT_NUM_STEM_SNAP_V ::
|
||||||
|
* PS_DICT_STEM_SNAP_V ::
|
||||||
|
* PS_DICT_FORCE_BOLD ::
|
||||||
|
* PS_DICT_RND_STEM_UP ::
|
||||||
|
* PS_DICT_MIN_FEATURE ::
|
||||||
|
* PS_DICT_LEN_IV ::
|
||||||
|
* PS_DICT_PASSWORD ::
|
||||||
|
* PS_DICT_LANGUAGE_GROUP ::
|
||||||
|
* PS_DICT_VERSION ::
|
||||||
|
* PS_DICT_NOTICE ::
|
||||||
|
* PS_DICT_FULL_NAME ::
|
||||||
|
* PS_DICT_FAMILY_NAME ::
|
||||||
|
* PS_DICT_WEIGHT ::
|
||||||
|
* PS_DICT_IS_FIXED_PITCH ::
|
||||||
|
* PS_DICT_UNDERLINE_POSITION ::
|
||||||
|
* PS_DICT_UNDERLINE_THICKNESS ::
|
||||||
|
* PS_DICT_FS_TYPE ::
|
||||||
|
* PS_DICT_ITALIC_ANGLE ::
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.4.8
|
||||||
|
*/
|
||||||
|
typedef enum PS_Dict_Keys_
|
||||||
|
{
|
||||||
|
/* conventionally in the font dictionary */
|
||||||
|
PS_DICT_FONT_TYPE, /* FT_Byte */
|
||||||
|
PS_DICT_FONT_MATRIX, /* FT_Fixed */
|
||||||
|
PS_DICT_FONT_BBOX, /* FT_Fixed */
|
||||||
|
PS_DICT_PAINT_TYPE, /* FT_Byte */
|
||||||
|
PS_DICT_FONT_NAME, /* FT_String* */
|
||||||
|
PS_DICT_UNIQUE_ID, /* FT_Int */
|
||||||
|
PS_DICT_NUM_CHAR_STRINGS, /* FT_Int */
|
||||||
|
PS_DICT_CHAR_STRING_KEY, /* FT_String* */
|
||||||
|
PS_DICT_CHAR_STRING, /* FT_String* */
|
||||||
|
PS_DICT_ENCODING_TYPE, /* T1_EncodingType */
|
||||||
|
PS_DICT_ENCODING_ENTRY, /* FT_String* */
|
||||||
|
|
||||||
|
/* conventionally in the font Private dictionary */
|
||||||
|
PS_DICT_NUM_SUBRS, /* FT_Int */
|
||||||
|
PS_DICT_SUBR, /* FT_String* */
|
||||||
|
PS_DICT_STD_HW, /* FT_UShort */
|
||||||
|
PS_DICT_STD_VW, /* FT_UShort */
|
||||||
|
PS_DICT_NUM_BLUE_VALUES, /* FT_Byte */
|
||||||
|
PS_DICT_BLUE_VALUE, /* FT_Short */
|
||||||
|
PS_DICT_BLUE_FUZZ, /* FT_Int */
|
||||||
|
PS_DICT_NUM_OTHER_BLUES, /* FT_Byte */
|
||||||
|
PS_DICT_OTHER_BLUE, /* FT_Short */
|
||||||
|
PS_DICT_NUM_FAMILY_BLUES, /* FT_Byte */
|
||||||
|
PS_DICT_FAMILY_BLUE, /* FT_Short */
|
||||||
|
PS_DICT_NUM_FAMILY_OTHER_BLUES, /* FT_Byte */
|
||||||
|
PS_DICT_FAMILY_OTHER_BLUE, /* FT_Short */
|
||||||
|
PS_DICT_BLUE_SCALE, /* FT_Fixed */
|
||||||
|
PS_DICT_BLUE_SHIFT, /* FT_Int */
|
||||||
|
PS_DICT_NUM_STEM_SNAP_H, /* FT_Byte */
|
||||||
|
PS_DICT_STEM_SNAP_H, /* FT_Short */
|
||||||
|
PS_DICT_NUM_STEM_SNAP_V, /* FT_Byte */
|
||||||
|
PS_DICT_STEM_SNAP_V, /* FT_Short */
|
||||||
|
PS_DICT_FORCE_BOLD, /* FT_Bool */
|
||||||
|
PS_DICT_RND_STEM_UP, /* FT_Bool */
|
||||||
|
PS_DICT_MIN_FEATURE, /* FT_Short */
|
||||||
|
PS_DICT_LEN_IV, /* FT_Int */
|
||||||
|
PS_DICT_PASSWORD, /* FT_Long */
|
||||||
|
PS_DICT_LANGUAGE_GROUP, /* FT_Long */
|
||||||
|
|
||||||
|
/* conventionally in the font FontInfo dictionary */
|
||||||
|
PS_DICT_VERSION, /* FT_String* */
|
||||||
|
PS_DICT_NOTICE, /* FT_String* */
|
||||||
|
PS_DICT_FULL_NAME, /* FT_String* */
|
||||||
|
PS_DICT_FAMILY_NAME, /* FT_String* */
|
||||||
|
PS_DICT_WEIGHT, /* FT_String* */
|
||||||
|
PS_DICT_IS_FIXED_PITCH, /* FT_Bool */
|
||||||
|
PS_DICT_UNDERLINE_POSITION, /* FT_Short */
|
||||||
|
PS_DICT_UNDERLINE_THICKNESS, /* FT_UShort */
|
||||||
|
PS_DICT_FS_TYPE, /* FT_UShort */
|
||||||
|
PS_DICT_ITALIC_ANGLE, /* FT_Long */
|
||||||
|
|
||||||
|
PS_DICT_MAX = PS_DICT_ITALIC_ANGLE
|
||||||
|
|
||||||
|
} PS_Dict_Keys;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_PS_Font_Value
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Retrieve the value for the supplied key from a PostScript font.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* PostScript face handle.
|
||||||
|
*
|
||||||
|
* key ::
|
||||||
|
* An enumeration value representing the dictionary key to retrieve.
|
||||||
|
*
|
||||||
|
* idx ::
|
||||||
|
* For array values, this specifies the index to be returned.
|
||||||
|
*
|
||||||
|
* value ::
|
||||||
|
* A pointer to memory into which to write the value.
|
||||||
|
*
|
||||||
|
* valen_len ::
|
||||||
|
* The size, in bytes, of the memory supplied for the value.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* value ::
|
||||||
|
* The value matching the above key, if it exists.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The amount of memory (in bytes) required to hold the requested value
|
||||||
|
* (if it exists, -1 otherwise).
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The values returned are not pointers into the internal structures of
|
||||||
|
* the face, but are 'fresh' copies, so that the memory containing them
|
||||||
|
* belongs to the calling application. This also enforces the
|
||||||
|
* 'read-only' nature of these values, i.e., this function cannot be
|
||||||
|
* used to manipulate the face.
|
||||||
|
*
|
||||||
|
* `value` is a void pointer because the values returned can be of
|
||||||
|
* various types.
|
||||||
|
*
|
||||||
|
* If either `value` is `NULL` or `value_len` is too small, just the
|
||||||
|
* required memory size for the requested entry is returned.
|
||||||
|
*
|
||||||
|
* The `idx` parameter is used, not only to retrieve elements of, for
|
||||||
|
* example, the FontMatrix or FontBBox, but also to retrieve name keys
|
||||||
|
* from the CharStrings dictionary, and the charstrings themselves. It
|
||||||
|
* is ignored for atomic values.
|
||||||
|
*
|
||||||
|
* `PS_DICT_BLUE_SCALE` returns a value that is scaled up by 1000. To
|
||||||
|
* get the value as in the font stream, you need to divide by 65536000.0
|
||||||
|
* (to remove the FT_Fixed scale, and the x1000 scale).
|
||||||
|
*
|
||||||
|
* IMPORTANT: Only key/value pairs read by the FreeType interpreter can
|
||||||
|
* be retrieved. So, for example, PostScript procedures such as NP, ND,
|
||||||
|
* and RD are not available. Arbitrary keys are, obviously, not be
|
||||||
|
* available either.
|
||||||
|
*
|
||||||
|
* If the font's format is not PostScript-based, this function returns
|
||||||
|
* the `FT_Err_Invalid_Argument` error code.
|
||||||
|
*
|
||||||
|
* @since:
|
||||||
|
* 2.4.8
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Long )
|
||||||
|
FT_Get_PS_Font_Value( FT_Face face,
|
||||||
|
PS_Dict_Keys key,
|
||||||
|
FT_UInt idx,
|
||||||
|
void *value,
|
||||||
|
FT_Long value_len );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* T1TABLES_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,855 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* tttables.h
|
||||||
|
*
|
||||||
|
* Basic SFNT/TrueType tables definitions and interface
|
||||||
|
* (specification only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef TTTABLES_H_
|
||||||
|
#define TTTABLES_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @section:
|
||||||
|
* truetype_tables
|
||||||
|
*
|
||||||
|
* @title:
|
||||||
|
* TrueType Tables
|
||||||
|
*
|
||||||
|
* @abstract:
|
||||||
|
* TrueType-specific table types and functions.
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* This section contains definitions of some basic tables specific to
|
||||||
|
* TrueType and OpenType as well as some routines used to access and
|
||||||
|
* process them.
|
||||||
|
*
|
||||||
|
* @order:
|
||||||
|
* TT_Header
|
||||||
|
* TT_HoriHeader
|
||||||
|
* TT_VertHeader
|
||||||
|
* TT_OS2
|
||||||
|
* TT_Postscript
|
||||||
|
* TT_PCLT
|
||||||
|
* TT_MaxProfile
|
||||||
|
*
|
||||||
|
* FT_Sfnt_Tag
|
||||||
|
* FT_Get_Sfnt_Table
|
||||||
|
* FT_Load_Sfnt_Table
|
||||||
|
* FT_Sfnt_Table_Info
|
||||||
|
*
|
||||||
|
* FT_Get_CMap_Language_ID
|
||||||
|
* FT_Get_CMap_Format
|
||||||
|
*
|
||||||
|
* FT_PARAM_TAG_UNPATENTED_HINTING
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* TT_Header
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a TrueType font header table. All fields follow
|
||||||
|
* the OpenType specification. The 64-bit timestamps are stored in
|
||||||
|
* two-element arrays `Created` and `Modified`, first the upper then
|
||||||
|
* the lower 32~bits.
|
||||||
|
*/
|
||||||
|
typedef struct TT_Header_
|
||||||
|
{
|
||||||
|
FT_Fixed Table_Version;
|
||||||
|
FT_Fixed Font_Revision;
|
||||||
|
|
||||||
|
FT_Long CheckSum_Adjust;
|
||||||
|
FT_Long Magic_Number;
|
||||||
|
|
||||||
|
FT_UShort Flags;
|
||||||
|
FT_UShort Units_Per_EM;
|
||||||
|
|
||||||
|
FT_ULong Created [2];
|
||||||
|
FT_ULong Modified[2];
|
||||||
|
|
||||||
|
FT_Short xMin;
|
||||||
|
FT_Short yMin;
|
||||||
|
FT_Short xMax;
|
||||||
|
FT_Short yMax;
|
||||||
|
|
||||||
|
FT_UShort Mac_Style;
|
||||||
|
FT_UShort Lowest_Rec_PPEM;
|
||||||
|
|
||||||
|
FT_Short Font_Direction;
|
||||||
|
FT_Short Index_To_Loc_Format;
|
||||||
|
FT_Short Glyph_Data_Format;
|
||||||
|
|
||||||
|
} TT_Header;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* TT_HoriHeader
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a TrueType horizontal header, the 'hhea' table,
|
||||||
|
* as well as the corresponding horizontal metrics table, 'hmtx'.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* Version ::
|
||||||
|
* The table version.
|
||||||
|
*
|
||||||
|
* Ascender ::
|
||||||
|
* The font's ascender, i.e., the distance from the baseline to the
|
||||||
|
* top-most of all glyph points found in the font.
|
||||||
|
*
|
||||||
|
* This value is invalid in many fonts, as it is usually set by the
|
||||||
|
* font designer, and often reflects only a portion of the glyphs found
|
||||||
|
* in the font (maybe ASCII).
|
||||||
|
*
|
||||||
|
* You should use the `sTypoAscender` field of the 'OS/2' table instead
|
||||||
|
* if you want the correct one.
|
||||||
|
*
|
||||||
|
* Descender ::
|
||||||
|
* The font's descender, i.e., the distance from the baseline to the
|
||||||
|
* bottom-most of all glyph points found in the font. It is negative.
|
||||||
|
*
|
||||||
|
* This value is invalid in many fonts, as it is usually set by the
|
||||||
|
* font designer, and often reflects only a portion of the glyphs found
|
||||||
|
* in the font (maybe ASCII).
|
||||||
|
*
|
||||||
|
* You should use the `sTypoDescender` field of the 'OS/2' table
|
||||||
|
* instead if you want the correct one.
|
||||||
|
*
|
||||||
|
* Line_Gap ::
|
||||||
|
* The font's line gap, i.e., the distance to add to the ascender and
|
||||||
|
* descender to get the BTB, i.e., the baseline-to-baseline distance
|
||||||
|
* for the font.
|
||||||
|
*
|
||||||
|
* advance_Width_Max ::
|
||||||
|
* This field is the maximum of all advance widths found in the font.
|
||||||
|
* It can be used to compute the maximum width of an arbitrary string
|
||||||
|
* of text.
|
||||||
|
*
|
||||||
|
* min_Left_Side_Bearing ::
|
||||||
|
* The minimum left side bearing of all glyphs within the font.
|
||||||
|
*
|
||||||
|
* min_Right_Side_Bearing ::
|
||||||
|
* The minimum right side bearing of all glyphs within the font.
|
||||||
|
*
|
||||||
|
* xMax_Extent ::
|
||||||
|
* The maximum horizontal extent (i.e., the 'width' of a glyph's
|
||||||
|
* bounding box) for all glyphs in the font.
|
||||||
|
*
|
||||||
|
* caret_Slope_Rise ::
|
||||||
|
* The rise coefficient of the cursor's slope of the cursor
|
||||||
|
* (slope=rise/run).
|
||||||
|
*
|
||||||
|
* caret_Slope_Run ::
|
||||||
|
* The run coefficient of the cursor's slope.
|
||||||
|
*
|
||||||
|
* caret_Offset ::
|
||||||
|
* The cursor's offset for slanted fonts.
|
||||||
|
*
|
||||||
|
* Reserved ::
|
||||||
|
* 8~reserved bytes.
|
||||||
|
*
|
||||||
|
* metric_Data_Format ::
|
||||||
|
* Always~0.
|
||||||
|
*
|
||||||
|
* number_Of_HMetrics ::
|
||||||
|
* Number of HMetrics entries in the 'hmtx' table -- this value can be
|
||||||
|
* smaller than the total number of glyphs in the font.
|
||||||
|
*
|
||||||
|
* long_metrics ::
|
||||||
|
* A pointer into the 'hmtx' table.
|
||||||
|
*
|
||||||
|
* short_metrics ::
|
||||||
|
* A pointer into the 'hmtx' table.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* For an OpenType variation font, the values of the following fields can
|
||||||
|
* change after a call to @FT_Set_Var_Design_Coordinates (and friends) if
|
||||||
|
* the font contains an 'MVAR' table: `caret_Slope_Rise`,
|
||||||
|
* `caret_Slope_Run`, and `caret_Offset`.
|
||||||
|
*/
|
||||||
|
typedef struct TT_HoriHeader_
|
||||||
|
{
|
||||||
|
FT_Fixed Version;
|
||||||
|
FT_Short Ascender;
|
||||||
|
FT_Short Descender;
|
||||||
|
FT_Short Line_Gap;
|
||||||
|
|
||||||
|
FT_UShort advance_Width_Max; /* advance width maximum */
|
||||||
|
|
||||||
|
FT_Short min_Left_Side_Bearing; /* minimum left-sb */
|
||||||
|
FT_Short min_Right_Side_Bearing; /* minimum right-sb */
|
||||||
|
FT_Short xMax_Extent; /* xmax extents */
|
||||||
|
FT_Short caret_Slope_Rise;
|
||||||
|
FT_Short caret_Slope_Run;
|
||||||
|
FT_Short caret_Offset;
|
||||||
|
|
||||||
|
FT_Short Reserved[4];
|
||||||
|
|
||||||
|
FT_Short metric_Data_Format;
|
||||||
|
FT_UShort number_Of_HMetrics;
|
||||||
|
|
||||||
|
/* The following fields are not defined by the OpenType specification */
|
||||||
|
/* but they are used to connect the metrics header to the relevant */
|
||||||
|
/* 'hmtx' table. */
|
||||||
|
|
||||||
|
void* long_metrics;
|
||||||
|
void* short_metrics;
|
||||||
|
|
||||||
|
} TT_HoriHeader;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* TT_VertHeader
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure used to model a TrueType vertical header, the 'vhea'
|
||||||
|
* table, as well as the corresponding vertical metrics table, 'vmtx'.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* Version ::
|
||||||
|
* The table version.
|
||||||
|
*
|
||||||
|
* Ascender ::
|
||||||
|
* The font's ascender, i.e., the distance from the baseline to the
|
||||||
|
* top-most of all glyph points found in the font.
|
||||||
|
*
|
||||||
|
* This value is invalid in many fonts, as it is usually set by the
|
||||||
|
* font designer, and often reflects only a portion of the glyphs found
|
||||||
|
* in the font (maybe ASCII).
|
||||||
|
*
|
||||||
|
* You should use the `sTypoAscender` field of the 'OS/2' table instead
|
||||||
|
* if you want the correct one.
|
||||||
|
*
|
||||||
|
* Descender ::
|
||||||
|
* The font's descender, i.e., the distance from the baseline to the
|
||||||
|
* bottom-most of all glyph points found in the font. It is negative.
|
||||||
|
*
|
||||||
|
* This value is invalid in many fonts, as it is usually set by the
|
||||||
|
* font designer, and often reflects only a portion of the glyphs found
|
||||||
|
* in the font (maybe ASCII).
|
||||||
|
*
|
||||||
|
* You should use the `sTypoDescender` field of the 'OS/2' table
|
||||||
|
* instead if you want the correct one.
|
||||||
|
*
|
||||||
|
* Line_Gap ::
|
||||||
|
* The font's line gap, i.e., the distance to add to the ascender and
|
||||||
|
* descender to get the BTB, i.e., the baseline-to-baseline distance
|
||||||
|
* for the font.
|
||||||
|
*
|
||||||
|
* advance_Height_Max ::
|
||||||
|
* This field is the maximum of all advance heights found in the font.
|
||||||
|
* It can be used to compute the maximum height of an arbitrary string
|
||||||
|
* of text.
|
||||||
|
*
|
||||||
|
* min_Top_Side_Bearing ::
|
||||||
|
* The minimum top side bearing of all glyphs within the font.
|
||||||
|
*
|
||||||
|
* min_Bottom_Side_Bearing ::
|
||||||
|
* The minimum bottom side bearing of all glyphs within the font.
|
||||||
|
*
|
||||||
|
* yMax_Extent ::
|
||||||
|
* The maximum vertical extent (i.e., the 'height' of a glyph's
|
||||||
|
* bounding box) for all glyphs in the font.
|
||||||
|
*
|
||||||
|
* caret_Slope_Rise ::
|
||||||
|
* The rise coefficient of the cursor's slope of the cursor
|
||||||
|
* (slope=rise/run).
|
||||||
|
*
|
||||||
|
* caret_Slope_Run ::
|
||||||
|
* The run coefficient of the cursor's slope.
|
||||||
|
*
|
||||||
|
* caret_Offset ::
|
||||||
|
* The cursor's offset for slanted fonts.
|
||||||
|
*
|
||||||
|
* Reserved ::
|
||||||
|
* 8~reserved bytes.
|
||||||
|
*
|
||||||
|
* metric_Data_Format ::
|
||||||
|
* Always~0.
|
||||||
|
*
|
||||||
|
* number_Of_VMetrics ::
|
||||||
|
* Number of VMetrics entries in the 'vmtx' table -- this value can be
|
||||||
|
* smaller than the total number of glyphs in the font.
|
||||||
|
*
|
||||||
|
* long_metrics ::
|
||||||
|
* A pointer into the 'vmtx' table.
|
||||||
|
*
|
||||||
|
* short_metrics ::
|
||||||
|
* A pointer into the 'vmtx' table.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* For an OpenType variation font, the values of the following fields can
|
||||||
|
* change after a call to @FT_Set_Var_Design_Coordinates (and friends) if
|
||||||
|
* the font contains an 'MVAR' table: `Ascender`, `Descender`,
|
||||||
|
* `Line_Gap`, `caret_Slope_Rise`, `caret_Slope_Run`, and `caret_Offset`.
|
||||||
|
*/
|
||||||
|
typedef struct TT_VertHeader_
|
||||||
|
{
|
||||||
|
FT_Fixed Version;
|
||||||
|
FT_Short Ascender;
|
||||||
|
FT_Short Descender;
|
||||||
|
FT_Short Line_Gap;
|
||||||
|
|
||||||
|
FT_UShort advance_Height_Max; /* advance height maximum */
|
||||||
|
|
||||||
|
FT_Short min_Top_Side_Bearing; /* minimum top-sb */
|
||||||
|
FT_Short min_Bottom_Side_Bearing; /* minimum bottom-sb */
|
||||||
|
FT_Short yMax_Extent; /* ymax extents */
|
||||||
|
FT_Short caret_Slope_Rise;
|
||||||
|
FT_Short caret_Slope_Run;
|
||||||
|
FT_Short caret_Offset;
|
||||||
|
|
||||||
|
FT_Short Reserved[4];
|
||||||
|
|
||||||
|
FT_Short metric_Data_Format;
|
||||||
|
FT_UShort number_Of_VMetrics;
|
||||||
|
|
||||||
|
/* The following fields are not defined by the OpenType specification */
|
||||||
|
/* but they are used to connect the metrics header to the relevant */
|
||||||
|
/* 'vmtx' table. */
|
||||||
|
|
||||||
|
void* long_metrics;
|
||||||
|
void* short_metrics;
|
||||||
|
|
||||||
|
} TT_VertHeader;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* TT_OS2
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a TrueType 'OS/2' table. All fields comply to
|
||||||
|
* the OpenType specification.
|
||||||
|
*
|
||||||
|
* Note that we now support old Mac fonts that do not include an 'OS/2'
|
||||||
|
* table. In this case, the `version` field is always set to 0xFFFF.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* For an OpenType variation font, the values of the following fields can
|
||||||
|
* change after a call to @FT_Set_Var_Design_Coordinates (and friends) if
|
||||||
|
* the font contains an 'MVAR' table: `sCapHeight`, `sTypoAscender`,
|
||||||
|
* `sTypoDescender`, `sTypoLineGap`, `sxHeight`, `usWinAscent`,
|
||||||
|
* `usWinDescent`, `yStrikeoutPosition`, `yStrikeoutSize`,
|
||||||
|
* `ySubscriptXOffset`, `ySubScriptXSize`, `ySubscriptYOffset`,
|
||||||
|
* `ySubscriptYSize`, `ySuperscriptXOffset`, `ySuperscriptXSize`,
|
||||||
|
* `ySuperscriptYOffset`, and `ySuperscriptYSize`.
|
||||||
|
*
|
||||||
|
* Possible values for bits in the `ulUnicodeRangeX` fields are given by
|
||||||
|
* the @TT_UCR_XXX macros.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct TT_OS2_
|
||||||
|
{
|
||||||
|
FT_UShort version; /* 0x0001 - more or 0xFFFF */
|
||||||
|
FT_Short xAvgCharWidth;
|
||||||
|
FT_UShort usWeightClass;
|
||||||
|
FT_UShort usWidthClass;
|
||||||
|
FT_UShort fsType;
|
||||||
|
FT_Short ySubscriptXSize;
|
||||||
|
FT_Short ySubscriptYSize;
|
||||||
|
FT_Short ySubscriptXOffset;
|
||||||
|
FT_Short ySubscriptYOffset;
|
||||||
|
FT_Short ySuperscriptXSize;
|
||||||
|
FT_Short ySuperscriptYSize;
|
||||||
|
FT_Short ySuperscriptXOffset;
|
||||||
|
FT_Short ySuperscriptYOffset;
|
||||||
|
FT_Short yStrikeoutSize;
|
||||||
|
FT_Short yStrikeoutPosition;
|
||||||
|
FT_Short sFamilyClass;
|
||||||
|
|
||||||
|
FT_Byte panose[10];
|
||||||
|
|
||||||
|
FT_ULong ulUnicodeRange1; /* Bits 0-31 */
|
||||||
|
FT_ULong ulUnicodeRange2; /* Bits 32-63 */
|
||||||
|
FT_ULong ulUnicodeRange3; /* Bits 64-95 */
|
||||||
|
FT_ULong ulUnicodeRange4; /* Bits 96-127 */
|
||||||
|
|
||||||
|
FT_Char achVendID[4];
|
||||||
|
|
||||||
|
FT_UShort fsSelection;
|
||||||
|
FT_UShort usFirstCharIndex;
|
||||||
|
FT_UShort usLastCharIndex;
|
||||||
|
FT_Short sTypoAscender;
|
||||||
|
FT_Short sTypoDescender;
|
||||||
|
FT_Short sTypoLineGap;
|
||||||
|
FT_UShort usWinAscent;
|
||||||
|
FT_UShort usWinDescent;
|
||||||
|
|
||||||
|
/* only version 1 and higher: */
|
||||||
|
|
||||||
|
FT_ULong ulCodePageRange1; /* Bits 0-31 */
|
||||||
|
FT_ULong ulCodePageRange2; /* Bits 32-63 */
|
||||||
|
|
||||||
|
/* only version 2 and higher: */
|
||||||
|
|
||||||
|
FT_Short sxHeight;
|
||||||
|
FT_Short sCapHeight;
|
||||||
|
FT_UShort usDefaultChar;
|
||||||
|
FT_UShort usBreakChar;
|
||||||
|
FT_UShort usMaxContext;
|
||||||
|
|
||||||
|
/* only version 5 and higher: */
|
||||||
|
|
||||||
|
FT_UShort usLowerOpticalPointSize; /* in twips (1/20th points) */
|
||||||
|
FT_UShort usUpperOpticalPointSize; /* in twips (1/20th points) */
|
||||||
|
|
||||||
|
} TT_OS2;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* TT_Postscript
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a TrueType 'post' table. All fields comply to
|
||||||
|
* the OpenType specification. This structure does not reference a
|
||||||
|
* font's PostScript glyph names; use @FT_Get_Glyph_Name to retrieve
|
||||||
|
* them.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* For an OpenType variation font, the values of the following fields can
|
||||||
|
* change after a call to @FT_Set_Var_Design_Coordinates (and friends) if
|
||||||
|
* the font contains an 'MVAR' table: `underlinePosition` and
|
||||||
|
* `underlineThickness`.
|
||||||
|
*/
|
||||||
|
typedef struct TT_Postscript_
|
||||||
|
{
|
||||||
|
FT_Fixed FormatType;
|
||||||
|
FT_Fixed italicAngle;
|
||||||
|
FT_Short underlinePosition;
|
||||||
|
FT_Short underlineThickness;
|
||||||
|
FT_ULong isFixedPitch;
|
||||||
|
FT_ULong minMemType42;
|
||||||
|
FT_ULong maxMemType42;
|
||||||
|
FT_ULong minMemType1;
|
||||||
|
FT_ULong maxMemType1;
|
||||||
|
|
||||||
|
/* Glyph names follow in the 'post' table, but we don't */
|
||||||
|
/* load them by default. */
|
||||||
|
|
||||||
|
} TT_Postscript;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* TT_PCLT
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* A structure to model a TrueType 'PCLT' table. All fields comply to
|
||||||
|
* the OpenType specification.
|
||||||
|
*/
|
||||||
|
typedef struct TT_PCLT_
|
||||||
|
{
|
||||||
|
FT_Fixed Version;
|
||||||
|
FT_ULong FontNumber;
|
||||||
|
FT_UShort Pitch;
|
||||||
|
FT_UShort xHeight;
|
||||||
|
FT_UShort Style;
|
||||||
|
FT_UShort TypeFamily;
|
||||||
|
FT_UShort CapHeight;
|
||||||
|
FT_UShort SymbolSet;
|
||||||
|
FT_Char TypeFace[16];
|
||||||
|
FT_Char CharacterComplement[8];
|
||||||
|
FT_Char FileName[6];
|
||||||
|
FT_Char StrokeWeight;
|
||||||
|
FT_Char WidthType;
|
||||||
|
FT_Byte SerifStyle;
|
||||||
|
FT_Byte Reserved;
|
||||||
|
|
||||||
|
} TT_PCLT;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @struct:
|
||||||
|
* TT_MaxProfile
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* The maximum profile ('maxp') table contains many max values, which can
|
||||||
|
* be used to pre-allocate arrays for speeding up glyph loading and
|
||||||
|
* hinting.
|
||||||
|
*
|
||||||
|
* @fields:
|
||||||
|
* version ::
|
||||||
|
* The version number.
|
||||||
|
*
|
||||||
|
* numGlyphs ::
|
||||||
|
* The number of glyphs in this TrueType font.
|
||||||
|
*
|
||||||
|
* maxPoints ::
|
||||||
|
* The maximum number of points in a non-composite TrueType glyph. See
|
||||||
|
* also `maxCompositePoints`.
|
||||||
|
*
|
||||||
|
* maxContours ::
|
||||||
|
* The maximum number of contours in a non-composite TrueType glyph.
|
||||||
|
* See also `maxCompositeContours`.
|
||||||
|
*
|
||||||
|
* maxCompositePoints ::
|
||||||
|
* The maximum number of points in a composite TrueType glyph. See
|
||||||
|
* also `maxPoints`.
|
||||||
|
*
|
||||||
|
* maxCompositeContours ::
|
||||||
|
* The maximum number of contours in a composite TrueType glyph. See
|
||||||
|
* also `maxContours`.
|
||||||
|
*
|
||||||
|
* maxZones ::
|
||||||
|
* The maximum number of zones used for glyph hinting.
|
||||||
|
*
|
||||||
|
* maxTwilightPoints ::
|
||||||
|
* The maximum number of points in the twilight zone used for glyph
|
||||||
|
* hinting.
|
||||||
|
*
|
||||||
|
* maxStorage ::
|
||||||
|
* The maximum number of elements in the storage area used for glyph
|
||||||
|
* hinting.
|
||||||
|
*
|
||||||
|
* maxFunctionDefs ::
|
||||||
|
* The maximum number of function definitions in the TrueType bytecode
|
||||||
|
* for this font.
|
||||||
|
*
|
||||||
|
* maxInstructionDefs ::
|
||||||
|
* The maximum number of instruction definitions in the TrueType
|
||||||
|
* bytecode for this font.
|
||||||
|
*
|
||||||
|
* maxStackElements ::
|
||||||
|
* The maximum number of stack elements used during bytecode
|
||||||
|
* interpretation.
|
||||||
|
*
|
||||||
|
* maxSizeOfInstructions ::
|
||||||
|
* The maximum number of TrueType opcodes used for glyph hinting.
|
||||||
|
*
|
||||||
|
* maxComponentElements ::
|
||||||
|
* The maximum number of simple (i.e., non-composite) glyphs in a
|
||||||
|
* composite glyph.
|
||||||
|
*
|
||||||
|
* maxComponentDepth ::
|
||||||
|
* The maximum nesting depth of composite glyphs.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* This structure is only used during font loading.
|
||||||
|
*/
|
||||||
|
typedef struct TT_MaxProfile_
|
||||||
|
{
|
||||||
|
FT_Fixed version;
|
||||||
|
FT_UShort numGlyphs;
|
||||||
|
FT_UShort maxPoints;
|
||||||
|
FT_UShort maxContours;
|
||||||
|
FT_UShort maxCompositePoints;
|
||||||
|
FT_UShort maxCompositeContours;
|
||||||
|
FT_UShort maxZones;
|
||||||
|
FT_UShort maxTwilightPoints;
|
||||||
|
FT_UShort maxStorage;
|
||||||
|
FT_UShort maxFunctionDefs;
|
||||||
|
FT_UShort maxInstructionDefs;
|
||||||
|
FT_UShort maxStackElements;
|
||||||
|
FT_UShort maxSizeOfInstructions;
|
||||||
|
FT_UShort maxComponentElements;
|
||||||
|
FT_UShort maxComponentDepth;
|
||||||
|
|
||||||
|
} TT_MaxProfile;
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @enum:
|
||||||
|
* FT_Sfnt_Tag
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* An enumeration to specify indices of SFNT tables loaded and parsed by
|
||||||
|
* FreeType during initialization of an SFNT font. Used in the
|
||||||
|
* @FT_Get_Sfnt_Table API function.
|
||||||
|
*
|
||||||
|
* @values:
|
||||||
|
* FT_SFNT_HEAD ::
|
||||||
|
* To access the font's @TT_Header structure.
|
||||||
|
*
|
||||||
|
* FT_SFNT_MAXP ::
|
||||||
|
* To access the font's @TT_MaxProfile structure.
|
||||||
|
*
|
||||||
|
* FT_SFNT_OS2 ::
|
||||||
|
* To access the font's @TT_OS2 structure.
|
||||||
|
*
|
||||||
|
* FT_SFNT_HHEA ::
|
||||||
|
* To access the font's @TT_HoriHeader structure.
|
||||||
|
*
|
||||||
|
* FT_SFNT_VHEA ::
|
||||||
|
* To access the font's @TT_VertHeader structure.
|
||||||
|
*
|
||||||
|
* FT_SFNT_POST ::
|
||||||
|
* To access the font's @TT_Postscript structure.
|
||||||
|
*
|
||||||
|
* FT_SFNT_PCLT ::
|
||||||
|
* To access the font's @TT_PCLT structure.
|
||||||
|
*/
|
||||||
|
typedef enum FT_Sfnt_Tag_
|
||||||
|
{
|
||||||
|
FT_SFNT_HEAD,
|
||||||
|
FT_SFNT_MAXP,
|
||||||
|
FT_SFNT_OS2,
|
||||||
|
FT_SFNT_HHEA,
|
||||||
|
FT_SFNT_VHEA,
|
||||||
|
FT_SFNT_POST,
|
||||||
|
FT_SFNT_PCLT,
|
||||||
|
|
||||||
|
FT_SFNT_MAX
|
||||||
|
|
||||||
|
} FT_Sfnt_Tag;
|
||||||
|
|
||||||
|
/* these constants are deprecated; use the corresponding `FT_Sfnt_Tag` */
|
||||||
|
/* values instead */
|
||||||
|
#define ft_sfnt_head FT_SFNT_HEAD
|
||||||
|
#define ft_sfnt_maxp FT_SFNT_MAXP
|
||||||
|
#define ft_sfnt_os2 FT_SFNT_OS2
|
||||||
|
#define ft_sfnt_hhea FT_SFNT_HHEA
|
||||||
|
#define ft_sfnt_vhea FT_SFNT_VHEA
|
||||||
|
#define ft_sfnt_post FT_SFNT_POST
|
||||||
|
#define ft_sfnt_pclt FT_SFNT_PCLT
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_Sfnt_Table
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return a pointer to a given SFNT table stored within a face.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source.
|
||||||
|
*
|
||||||
|
* tag ::
|
||||||
|
* The index of the SFNT table.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* A type-less pointer to the table. This will be `NULL` in case of
|
||||||
|
* error, or if the corresponding table was not found **OR** loaded from
|
||||||
|
* the file.
|
||||||
|
*
|
||||||
|
* Use a typecast according to `tag` to access the structure elements.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* The table is owned by the face object and disappears with it.
|
||||||
|
*
|
||||||
|
* This function is only useful to access SFNT tables that are loaded by
|
||||||
|
* the sfnt, truetype, and opentype drivers. See @FT_Sfnt_Tag for a
|
||||||
|
* list.
|
||||||
|
*
|
||||||
|
* @example:
|
||||||
|
* Here is an example demonstrating access to the 'vhea' table.
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* TT_VertHeader* vert_header;
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* vert_header =
|
||||||
|
* (TT_VertHeader*)FT_Get_Sfnt_Table( face, FT_SFNT_VHEA );
|
||||||
|
* ```
|
||||||
|
*/
|
||||||
|
FT_EXPORT( void* )
|
||||||
|
FT_Get_Sfnt_Table( FT_Face face,
|
||||||
|
FT_Sfnt_Tag tag );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Load_Sfnt_Table
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Load any SFNT font table into client memory.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* tag ::
|
||||||
|
* The four-byte tag of the table to load. Use value~0 if you want to
|
||||||
|
* access the whole font file. Otherwise, you can use one of the
|
||||||
|
* definitions found in the @FT_TRUETYPE_TAGS_H file, or forge a new
|
||||||
|
* one with @FT_MAKE_TAG.
|
||||||
|
*
|
||||||
|
* offset ::
|
||||||
|
* The starting offset in the table (or file if tag~==~0).
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* buffer ::
|
||||||
|
* The target buffer address. The client must ensure that the memory
|
||||||
|
* array is big enough to hold the data.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* length ::
|
||||||
|
* If the `length` parameter is `NULL`, try to load the whole table.
|
||||||
|
* Return an error code if it fails.
|
||||||
|
*
|
||||||
|
* Else, if `*length` is~0, exit immediately while returning the
|
||||||
|
* table's (or file) full size in it.
|
||||||
|
*
|
||||||
|
* Else the number of bytes to read from the table or file, from the
|
||||||
|
* starting offset.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* If you need to determine the table's length you should first call this
|
||||||
|
* function with `*length` set to~0, as in the following example:
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* FT_ULong length = 0;
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* error = FT_Load_Sfnt_Table( face, tag, 0, NULL, &length );
|
||||||
|
* if ( error ) { ... table does not exist ... }
|
||||||
|
*
|
||||||
|
* buffer = malloc( length );
|
||||||
|
* if ( buffer == NULL ) { ... not enough memory ... }
|
||||||
|
*
|
||||||
|
* error = FT_Load_Sfnt_Table( face, tag, 0, buffer, &length );
|
||||||
|
* if ( error ) { ... could not load table ... }
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Note that structures like @TT_Header or @TT_OS2 can't be used with
|
||||||
|
* this function; they are limited to @FT_Get_Sfnt_Table. Reason is that
|
||||||
|
* those structures depend on the processor architecture, with varying
|
||||||
|
* size (e.g. 32bit vs. 64bit) or order (big endian vs. little endian).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Load_Sfnt_Table( FT_Face face,
|
||||||
|
FT_ULong tag,
|
||||||
|
FT_Long offset,
|
||||||
|
FT_Byte* buffer,
|
||||||
|
FT_ULong* length );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Sfnt_Table_Info
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return information on an SFNT table.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* face ::
|
||||||
|
* A handle to the source face.
|
||||||
|
*
|
||||||
|
* table_index ::
|
||||||
|
* The index of an SFNT table. The function returns
|
||||||
|
* FT_Err_Table_Missing for an invalid value.
|
||||||
|
*
|
||||||
|
* @inout:
|
||||||
|
* tag ::
|
||||||
|
* The name tag of the SFNT table. If the value is `NULL`,
|
||||||
|
* `table_index` is ignored, and `length` returns the number of SFNT
|
||||||
|
* tables in the font.
|
||||||
|
*
|
||||||
|
* @output:
|
||||||
|
* length ::
|
||||||
|
* The length of the SFNT table (or the number of SFNT tables,
|
||||||
|
* depending on `tag`).
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* FreeType error code. 0~means success.
|
||||||
|
*
|
||||||
|
* @note:
|
||||||
|
* While parsing fonts, FreeType handles SFNT tables with length zero as
|
||||||
|
* missing.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Error )
|
||||||
|
FT_Sfnt_Table_Info( FT_Face face,
|
||||||
|
FT_UInt table_index,
|
||||||
|
FT_ULong *tag,
|
||||||
|
FT_ULong *length );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_CMap_Language_ID
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return cmap language ID as specified in the OpenType standard.
|
||||||
|
* Definitions of language ID values are in file @FT_TRUETYPE_IDS_H.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* charmap ::
|
||||||
|
* The target charmap.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The language ID of `charmap`. If `charmap` doesn't belong to an SFNT
|
||||||
|
* face, just return~0 as the default value.
|
||||||
|
*
|
||||||
|
* For a format~14 cmap (to access Unicode IVS), the return value is
|
||||||
|
* 0xFFFFFFFF.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_ULong )
|
||||||
|
FT_Get_CMap_Language_ID( FT_CharMap charmap );
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* @function:
|
||||||
|
* FT_Get_CMap_Format
|
||||||
|
*
|
||||||
|
* @description:
|
||||||
|
* Return the format of an SFNT 'cmap' table.
|
||||||
|
*
|
||||||
|
* @input:
|
||||||
|
* charmap ::
|
||||||
|
* The target charmap.
|
||||||
|
*
|
||||||
|
* @return:
|
||||||
|
* The format of `charmap`. If `charmap` doesn't belong to an SFNT face,
|
||||||
|
* return -1.
|
||||||
|
*/
|
||||||
|
FT_EXPORT( FT_Long )
|
||||||
|
FT_Get_CMap_Format( FT_CharMap charmap );
|
||||||
|
|
||||||
|
/* */
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* TTTABLES_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,124 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* tttags.h
|
||||||
|
*
|
||||||
|
* Tags for TrueType and OpenType tables (specification only).
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef TTAGS_H_
|
||||||
|
#define TTAGS_H_
|
||||||
|
|
||||||
|
|
||||||
|
#include <freetype/freetype.h>
|
||||||
|
|
||||||
|
#ifdef FREETYPE_H
|
||||||
|
#error "freetype.h of FreeType 1 has been loaded!"
|
||||||
|
#error "Please fix the directory search order for header files"
|
||||||
|
#error "so that freetype.h of FreeType 2 is found first."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
FT_BEGIN_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
#define TTAG_avar FT_MAKE_TAG( 'a', 'v', 'a', 'r' )
|
||||||
|
#define TTAG_BASE FT_MAKE_TAG( 'B', 'A', 'S', 'E' )
|
||||||
|
#define TTAG_bdat FT_MAKE_TAG( 'b', 'd', 'a', 't' )
|
||||||
|
#define TTAG_BDF FT_MAKE_TAG( 'B', 'D', 'F', ' ' )
|
||||||
|
#define TTAG_bhed FT_MAKE_TAG( 'b', 'h', 'e', 'd' )
|
||||||
|
#define TTAG_bloc FT_MAKE_TAG( 'b', 'l', 'o', 'c' )
|
||||||
|
#define TTAG_bsln FT_MAKE_TAG( 'b', 's', 'l', 'n' )
|
||||||
|
#define TTAG_CBDT FT_MAKE_TAG( 'C', 'B', 'D', 'T' )
|
||||||
|
#define TTAG_CBLC FT_MAKE_TAG( 'C', 'B', 'L', 'C' )
|
||||||
|
#define TTAG_CFF FT_MAKE_TAG( 'C', 'F', 'F', ' ' )
|
||||||
|
#define TTAG_CFF2 FT_MAKE_TAG( 'C', 'F', 'F', '2' )
|
||||||
|
#define TTAG_CID FT_MAKE_TAG( 'C', 'I', 'D', ' ' )
|
||||||
|
#define TTAG_cmap FT_MAKE_TAG( 'c', 'm', 'a', 'p' )
|
||||||
|
#define TTAG_COLR FT_MAKE_TAG( 'C', 'O', 'L', 'R' )
|
||||||
|
#define TTAG_CPAL FT_MAKE_TAG( 'C', 'P', 'A', 'L' )
|
||||||
|
#define TTAG_cvar FT_MAKE_TAG( 'c', 'v', 'a', 'r' )
|
||||||
|
#define TTAG_cvt FT_MAKE_TAG( 'c', 'v', 't', ' ' )
|
||||||
|
#define TTAG_DSIG FT_MAKE_TAG( 'D', 'S', 'I', 'G' )
|
||||||
|
#define TTAG_EBDT FT_MAKE_TAG( 'E', 'B', 'D', 'T' )
|
||||||
|
#define TTAG_EBLC FT_MAKE_TAG( 'E', 'B', 'L', 'C' )
|
||||||
|
#define TTAG_EBSC FT_MAKE_TAG( 'E', 'B', 'S', 'C' )
|
||||||
|
#define TTAG_feat FT_MAKE_TAG( 'f', 'e', 'a', 't' )
|
||||||
|
#define TTAG_FOND FT_MAKE_TAG( 'F', 'O', 'N', 'D' )
|
||||||
|
#define TTAG_fpgm FT_MAKE_TAG( 'f', 'p', 'g', 'm' )
|
||||||
|
#define TTAG_fvar FT_MAKE_TAG( 'f', 'v', 'a', 'r' )
|
||||||
|
#define TTAG_gasp FT_MAKE_TAG( 'g', 'a', 's', 'p' )
|
||||||
|
#define TTAG_GDEF FT_MAKE_TAG( 'G', 'D', 'E', 'F' )
|
||||||
|
#define TTAG_glyf FT_MAKE_TAG( 'g', 'l', 'y', 'f' )
|
||||||
|
#define TTAG_GPOS FT_MAKE_TAG( 'G', 'P', 'O', 'S' )
|
||||||
|
#define TTAG_GSUB FT_MAKE_TAG( 'G', 'S', 'U', 'B' )
|
||||||
|
#define TTAG_gvar FT_MAKE_TAG( 'g', 'v', 'a', 'r' )
|
||||||
|
#define TTAG_HVAR FT_MAKE_TAG( 'H', 'V', 'A', 'R' )
|
||||||
|
#define TTAG_hdmx FT_MAKE_TAG( 'h', 'd', 'm', 'x' )
|
||||||
|
#define TTAG_head FT_MAKE_TAG( 'h', 'e', 'a', 'd' )
|
||||||
|
#define TTAG_hhea FT_MAKE_TAG( 'h', 'h', 'e', 'a' )
|
||||||
|
#define TTAG_hmtx FT_MAKE_TAG( 'h', 'm', 't', 'x' )
|
||||||
|
#define TTAG_JSTF FT_MAKE_TAG( 'J', 'S', 'T', 'F' )
|
||||||
|
#define TTAG_just FT_MAKE_TAG( 'j', 'u', 's', 't' )
|
||||||
|
#define TTAG_kern FT_MAKE_TAG( 'k', 'e', 'r', 'n' )
|
||||||
|
#define TTAG_lcar FT_MAKE_TAG( 'l', 'c', 'a', 'r' )
|
||||||
|
#define TTAG_loca FT_MAKE_TAG( 'l', 'o', 'c', 'a' )
|
||||||
|
#define TTAG_LTSH FT_MAKE_TAG( 'L', 'T', 'S', 'H' )
|
||||||
|
#define TTAG_LWFN FT_MAKE_TAG( 'L', 'W', 'F', 'N' )
|
||||||
|
#define TTAG_MATH FT_MAKE_TAG( 'M', 'A', 'T', 'H' )
|
||||||
|
#define TTAG_maxp FT_MAKE_TAG( 'm', 'a', 'x', 'p' )
|
||||||
|
#define TTAG_META FT_MAKE_TAG( 'M', 'E', 'T', 'A' )
|
||||||
|
#define TTAG_MMFX FT_MAKE_TAG( 'M', 'M', 'F', 'X' )
|
||||||
|
#define TTAG_MMSD FT_MAKE_TAG( 'M', 'M', 'S', 'D' )
|
||||||
|
#define TTAG_mort FT_MAKE_TAG( 'm', 'o', 'r', 't' )
|
||||||
|
#define TTAG_morx FT_MAKE_TAG( 'm', 'o', 'r', 'x' )
|
||||||
|
#define TTAG_MVAR FT_MAKE_TAG( 'M', 'V', 'A', 'R' )
|
||||||
|
#define TTAG_name FT_MAKE_TAG( 'n', 'a', 'm', 'e' )
|
||||||
|
#define TTAG_opbd FT_MAKE_TAG( 'o', 'p', 'b', 'd' )
|
||||||
|
#define TTAG_OS2 FT_MAKE_TAG( 'O', 'S', '/', '2' )
|
||||||
|
#define TTAG_OTTO FT_MAKE_TAG( 'O', 'T', 'T', 'O' )
|
||||||
|
#define TTAG_PCLT FT_MAKE_TAG( 'P', 'C', 'L', 'T' )
|
||||||
|
#define TTAG_POST FT_MAKE_TAG( 'P', 'O', 'S', 'T' )
|
||||||
|
#define TTAG_post FT_MAKE_TAG( 'p', 'o', 's', 't' )
|
||||||
|
#define TTAG_prep FT_MAKE_TAG( 'p', 'r', 'e', 'p' )
|
||||||
|
#define TTAG_prop FT_MAKE_TAG( 'p', 'r', 'o', 'p' )
|
||||||
|
#define TTAG_sbix FT_MAKE_TAG( 's', 'b', 'i', 'x' )
|
||||||
|
#define TTAG_sfnt FT_MAKE_TAG( 's', 'f', 'n', 't' )
|
||||||
|
#define TTAG_SING FT_MAKE_TAG( 'S', 'I', 'N', 'G' )
|
||||||
|
#define TTAG_SVG FT_MAKE_TAG( 'S', 'V', 'G', ' ' )
|
||||||
|
#define TTAG_trak FT_MAKE_TAG( 't', 'r', 'a', 'k' )
|
||||||
|
#define TTAG_true FT_MAKE_TAG( 't', 'r', 'u', 'e' )
|
||||||
|
#define TTAG_ttc FT_MAKE_TAG( 't', 't', 'c', ' ' )
|
||||||
|
#define TTAG_ttcf FT_MAKE_TAG( 't', 't', 'c', 'f' )
|
||||||
|
#define TTAG_TYP1 FT_MAKE_TAG( 'T', 'Y', 'P', '1' )
|
||||||
|
#define TTAG_typ1 FT_MAKE_TAG( 't', 'y', 'p', '1' )
|
||||||
|
#define TTAG_VDMX FT_MAKE_TAG( 'V', 'D', 'M', 'X' )
|
||||||
|
#define TTAG_vhea FT_MAKE_TAG( 'v', 'h', 'e', 'a' )
|
||||||
|
#define TTAG_vmtx FT_MAKE_TAG( 'v', 'm', 't', 'x' )
|
||||||
|
#define TTAG_VVAR FT_MAKE_TAG( 'V', 'V', 'A', 'R' )
|
||||||
|
#define TTAG_wOFF FT_MAKE_TAG( 'w', 'O', 'F', 'F' )
|
||||||
|
#define TTAG_wOF2 FT_MAKE_TAG( 'w', 'O', 'F', '2' )
|
||||||
|
|
||||||
|
/* used by "Keyboard.dfont" on legacy Mac OS X */
|
||||||
|
#define TTAG_0xA5kbd FT_MAKE_TAG( 0xA5, 'k', 'b', 'd' )
|
||||||
|
|
||||||
|
/* used by "LastResort.dfont" on legacy Mac OS X */
|
||||||
|
#define TTAG_0xA5lst FT_MAKE_TAG( 0xA5, 'l', 's', 't' )
|
||||||
|
|
||||||
|
|
||||||
|
FT_END_HEADER
|
||||||
|
|
||||||
|
#endif /* TTAGS_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
@@ -0,0 +1,42 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
*
|
||||||
|
* ft2build.h
|
||||||
|
*
|
||||||
|
* FreeType 2 build and setup macros.
|
||||||
|
*
|
||||||
|
* Copyright (C) 1996-2022 by
|
||||||
|
* David Turner, Robert Wilhelm, and Werner Lemberg.
|
||||||
|
*
|
||||||
|
* This file is part of the FreeType project, and may only be used,
|
||||||
|
* modified, and distributed under the terms of the FreeType project
|
||||||
|
* license, LICENSE.TXT. By continuing to use, modify, or distribute
|
||||||
|
* this file you indicate that you have read the license and
|
||||||
|
* understand and accept it fully.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* This is the 'entry point' for FreeType header file inclusions, to be
|
||||||
|
* loaded before all other header files.
|
||||||
|
*
|
||||||
|
* A typical example is
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* #include <ft2build.h>
|
||||||
|
* #include <freetype/freetype.h>
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FT2BUILD_H_
|
||||||
|
#define FT2BUILD_H_
|
||||||
|
|
||||||
|
#include <freetype/config/ftheader.h>
|
||||||
|
|
||||||
|
#endif /* FT2BUILD_H_ */
|
||||||
|
|
||||||
|
|
||||||
|
/* END */
|
||||||
Binary file not shown.
+21
@@ -0,0 +1,21 @@
|
|||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2014-2024 Omar Cornut
|
||||||
|
|
||||||
|
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:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
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.
|
||||||
@@ -0,0 +1,606 @@
|
|||||||
|
// dear imgui: Renderer Backend for DirectX11
|
||||||
|
// This needs to be used along with a Platform Backend (e.g. Win32)
|
||||||
|
|
||||||
|
// Implemented features:
|
||||||
|
// [X] Renderer: User texture binding. Use 'ID3D11ShaderResourceView*' as ImTextureID. Read the FAQ about ImTextureID!
|
||||||
|
// [X] Renderer: Large meshes support (64k+ vertices) with 16-bit indices.
|
||||||
|
|
||||||
|
// You can use unmodified imgui_impl_* files in your project. See examples/ folder for examples of using this.
|
||||||
|
// Prefer including the entire imgui/ repository into your project (either as a copy or as a submodule), and only build the backends you need.
|
||||||
|
// Learn about Dear ImGui:
|
||||||
|
// - FAQ https://dearimgui.com/faq
|
||||||
|
// - Getting Started https://dearimgui.com/getting-started
|
||||||
|
// - Documentation https://dearimgui.com/docs (same as your local docs/ folder).
|
||||||
|
// - Introduction, links and more at the top of imgui.cpp
|
||||||
|
|
||||||
|
// CHANGELOG
|
||||||
|
// (minor and older changes stripped away, please see git history for details)
|
||||||
|
// 2022-10-11: Using 'nullptr' instead of 'NULL' as per our switch to C++11.
|
||||||
|
// 2021-06-29: Reorganized backend to pull data from a single structure to facilitate usage with multiple-contexts (all g_XXXX access changed to bd->XXXX).
|
||||||
|
// 2021-05-19: DirectX11: Replaced direct access to ImDrawCmd::TextureId with a call to ImDrawCmd::GetTexID(). (will become a requirement)
|
||||||
|
// 2021-02-18: DirectX11: Change blending equation to preserve alpha in output buffer.
|
||||||
|
// 2019-08-01: DirectX11: Fixed code querying the Geometry Shader state (would generally error with Debug layer enabled).
|
||||||
|
// 2019-07-21: DirectX11: Backup, clear and restore Geometry Shader is any is bound when calling ImGui_ImplDX10_RenderDrawData. Clearing Hull/Domain/Compute shaders without backup/restore.
|
||||||
|
// 2019-05-29: DirectX11: Added support for large mesh (64K+ vertices), enable ImGuiBackendFlags_RendererHasVtxOffset flag.
|
||||||
|
// 2019-04-30: DirectX11: Added support for special ImDrawCallback_ResetRenderState callback to reset render state.
|
||||||
|
// 2018-12-03: Misc: Added #pragma comment statement to automatically link with d3dcompiler.lib when using D3DCompile().
|
||||||
|
// 2018-11-30: Misc: Setting up io.BackendRendererName so it can be displayed in the About Window.
|
||||||
|
// 2018-08-01: DirectX11: Querying for IDXGIFactory instead of IDXGIFactory1 to increase compatibility.
|
||||||
|
// 2018-07-13: DirectX11: Fixed unreleased resources in Init and Shutdown functions.
|
||||||
|
// 2018-06-08: Misc: Extracted imgui_impl_dx11.cpp/.h away from the old combined DX11+Win32 example.
|
||||||
|
// 2018-06-08: DirectX11: Use draw_data->DisplayPos and draw_data->DisplaySize to setup projection matrix and clipping rectangle.
|
||||||
|
// 2018-02-16: Misc: Obsoleted the io.RenderDrawListsFn callback and exposed ImGui_ImplDX11_RenderDrawData() in the .h file so you can call it yourself.
|
||||||
|
// 2018-02-06: Misc: Removed call to ImGui::Shutdown() which is not available from 1.60 WIP, user needs to call CreateContext/DestroyContext themselves.
|
||||||
|
// 2016-05-07: DirectX11: Disabling depth-write.
|
||||||
|
|
||||||
|
#include "imgui.h"
|
||||||
|
#ifndef IMGUI_DISABLE
|
||||||
|
#include "imgui_impl_dx11.h"
|
||||||
|
|
||||||
|
// DirectX
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <d3d11.h>
|
||||||
|
#include <d3dcompiler.h>
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#pragma comment(lib, "d3dcompiler") // Automatically link with d3dcompiler.lib as we are using D3DCompile() below.
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// DirectX11 data
|
||||||
|
struct ImGui_ImplDX11_Data
|
||||||
|
{
|
||||||
|
ID3D11Device* pd3dDevice;
|
||||||
|
ID3D11DeviceContext* pd3dDeviceContext;
|
||||||
|
IDXGIFactory* pFactory;
|
||||||
|
ID3D11Buffer* pVB;
|
||||||
|
ID3D11Buffer* pIB;
|
||||||
|
ID3D11VertexShader* pVertexShader;
|
||||||
|
ID3D11InputLayout* pInputLayout;
|
||||||
|
ID3D11Buffer* pVertexConstantBuffer;
|
||||||
|
ID3D11PixelShader* pPixelShader;
|
||||||
|
ID3D11SamplerState* pFontSampler;
|
||||||
|
ID3D11ShaderResourceView* pFontTextureView;
|
||||||
|
ID3D11RasterizerState* pRasterizerState;
|
||||||
|
ID3D11BlendState* pBlendState;
|
||||||
|
ID3D11DepthStencilState* pDepthStencilState;
|
||||||
|
int VertexBufferSize;
|
||||||
|
int IndexBufferSize;
|
||||||
|
|
||||||
|
ImGui_ImplDX11_Data() { memset((void*)this, 0, sizeof(*this)); VertexBufferSize = 5000; IndexBufferSize = 10000; }
|
||||||
|
};
|
||||||
|
|
||||||
|
struct VERTEX_CONSTANT_BUFFER_DX11
|
||||||
|
{
|
||||||
|
float mvp[4][4];
|
||||||
|
};
|
||||||
|
|
||||||
|
// Backend data stored in io.BackendRendererUserData to allow support for multiple Dear ImGui contexts
|
||||||
|
// It is STRONGLY preferred that you use docking branch with multi-viewports (== single Dear ImGui context + multiple windows) instead of multiple Dear ImGui contexts.
|
||||||
|
static ImGui_ImplDX11_Data* ImGui_ImplDX11_GetBackendData()
|
||||||
|
{
|
||||||
|
return ImGui::GetCurrentContext() ? (ImGui_ImplDX11_Data*)ImGui::GetIO().BackendRendererUserData : nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Functions
|
||||||
|
static void ImGui_ImplDX11_SetupRenderState(ImDrawData* draw_data, ID3D11DeviceContext* ctx)
|
||||||
|
{
|
||||||
|
ImGui_ImplDX11_Data* bd = ImGui_ImplDX11_GetBackendData();
|
||||||
|
|
||||||
|
// Setup viewport
|
||||||
|
D3D11_VIEWPORT vp;
|
||||||
|
memset(&vp, 0, sizeof(D3D11_VIEWPORT));
|
||||||
|
vp.Width = draw_data->DisplaySize.x;
|
||||||
|
vp.Height = draw_data->DisplaySize.y;
|
||||||
|
vp.MinDepth = 0.0f;
|
||||||
|
vp.MaxDepth = 1.0f;
|
||||||
|
vp.TopLeftX = vp.TopLeftY = 0;
|
||||||
|
ctx->RSSetViewports(1, &vp);
|
||||||
|
|
||||||
|
// Setup shader and vertex buffers
|
||||||
|
unsigned int stride = sizeof(ImDrawVert);
|
||||||
|
unsigned int offset = 0;
|
||||||
|
ctx->IASetInputLayout(bd->pInputLayout);
|
||||||
|
ctx->IASetVertexBuffers(0, 1, &bd->pVB, &stride, &offset);
|
||||||
|
ctx->IASetIndexBuffer(bd->pIB, sizeof(ImDrawIdx) == 2 ? DXGI_FORMAT_R16_UINT : DXGI_FORMAT_R32_UINT, 0);
|
||||||
|
ctx->IASetPrimitiveTopology(D3D11_PRIMITIVE_TOPOLOGY_TRIANGLELIST);
|
||||||
|
ctx->VSSetShader(bd->pVertexShader, nullptr, 0);
|
||||||
|
ctx->VSSetConstantBuffers(0, 1, &bd->pVertexConstantBuffer);
|
||||||
|
ctx->PSSetShader(bd->pPixelShader, nullptr, 0);
|
||||||
|
ctx->PSSetSamplers(0, 1, &bd->pFontSampler);
|
||||||
|
ctx->GSSetShader(nullptr, nullptr, 0);
|
||||||
|
ctx->HSSetShader(nullptr, nullptr, 0); // In theory we should backup and restore this as well.. very infrequently used..
|
||||||
|
ctx->DSSetShader(nullptr, nullptr, 0); // In theory we should backup and restore this as well.. very infrequently used..
|
||||||
|
ctx->CSSetShader(nullptr, nullptr, 0); // In theory we should backup and restore this as well.. very infrequently used..
|
||||||
|
|
||||||
|
// Setup blend state
|
||||||
|
const float blend_factor[4] = { 0.f, 0.f, 0.f, 0.f };
|
||||||
|
ctx->OMSetBlendState(bd->pBlendState, blend_factor, 0xffffffff);
|
||||||
|
ctx->OMSetDepthStencilState(bd->pDepthStencilState, 0);
|
||||||
|
ctx->RSSetState(bd->pRasterizerState);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Render function
|
||||||
|
void ImGui_ImplDX11_RenderDrawData(ImDrawData* draw_data)
|
||||||
|
{
|
||||||
|
// Avoid rendering when minimized
|
||||||
|
if (draw_data->DisplaySize.x <= 0.0f || draw_data->DisplaySize.y <= 0.0f)
|
||||||
|
return;
|
||||||
|
|
||||||
|
ImGui_ImplDX11_Data* bd = ImGui_ImplDX11_GetBackendData();
|
||||||
|
ID3D11DeviceContext* ctx = bd->pd3dDeviceContext;
|
||||||
|
|
||||||
|
// Create and grow vertex/index buffers if needed
|
||||||
|
if (!bd->pVB || bd->VertexBufferSize < draw_data->TotalVtxCount)
|
||||||
|
{
|
||||||
|
if (bd->pVB) { bd->pVB->Release(); bd->pVB = nullptr; }
|
||||||
|
bd->VertexBufferSize = draw_data->TotalVtxCount + 5000;
|
||||||
|
D3D11_BUFFER_DESC desc;
|
||||||
|
memset(&desc, 0, sizeof(D3D11_BUFFER_DESC));
|
||||||
|
desc.Usage = D3D11_USAGE_DYNAMIC;
|
||||||
|
desc.ByteWidth = bd->VertexBufferSize * sizeof(ImDrawVert);
|
||||||
|
desc.BindFlags = D3D11_BIND_VERTEX_BUFFER;
|
||||||
|
desc.CPUAccessFlags = D3D11_CPU_ACCESS_WRITE;
|
||||||
|
desc.MiscFlags = 0;
|
||||||
|
if (bd->pd3dDevice->CreateBuffer(&desc, nullptr, &bd->pVB) < 0)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!bd->pIB || bd->IndexBufferSize < draw_data->TotalIdxCount)
|
||||||
|
{
|
||||||
|
if (bd->pIB) { bd->pIB->Release(); bd->pIB = nullptr; }
|
||||||
|
bd->IndexBufferSize = draw_data->TotalIdxCount + 10000;
|
||||||
|
D3D11_BUFFER_DESC desc;
|
||||||
|
memset(&desc, 0, sizeof(D3D11_BUFFER_DESC));
|
||||||
|
desc.Usage = D3D11_USAGE_DYNAMIC;
|
||||||
|
desc.ByteWidth = bd->IndexBufferSize * sizeof(ImDrawIdx);
|
||||||
|
desc.BindFlags = D3D11_BIND_INDEX_BUFFER;
|
||||||
|
desc.CPUAccessFlags = D3D11_CPU_ACCESS_WRITE;
|
||||||
|
if (bd->pd3dDevice->CreateBuffer(&desc, nullptr, &bd->pIB) < 0)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Upload vertex/index data into a single contiguous GPU buffer
|
||||||
|
D3D11_MAPPED_SUBRESOURCE vtx_resource, idx_resource;
|
||||||
|
if (ctx->Map(bd->pVB, 0, D3D11_MAP_WRITE_DISCARD, 0, &vtx_resource) != S_OK)
|
||||||
|
return;
|
||||||
|
if (ctx->Map(bd->pIB, 0, D3D11_MAP_WRITE_DISCARD, 0, &idx_resource) != S_OK)
|
||||||
|
return;
|
||||||
|
ImDrawVert* vtx_dst = (ImDrawVert*)vtx_resource.pData;
|
||||||
|
ImDrawIdx* idx_dst = (ImDrawIdx*)idx_resource.pData;
|
||||||
|
for (int n = 0; n < draw_data->CmdListsCount; n++)
|
||||||
|
{
|
||||||
|
const ImDrawList* cmd_list = draw_data->CmdLists[n];
|
||||||
|
memcpy(vtx_dst, cmd_list->VtxBuffer.Data, cmd_list->VtxBuffer.Size * sizeof(ImDrawVert));
|
||||||
|
memcpy(idx_dst, cmd_list->IdxBuffer.Data, cmd_list->IdxBuffer.Size * sizeof(ImDrawIdx));
|
||||||
|
vtx_dst += cmd_list->VtxBuffer.Size;
|
||||||
|
idx_dst += cmd_list->IdxBuffer.Size;
|
||||||
|
}
|
||||||
|
ctx->Unmap(bd->pVB, 0);
|
||||||
|
ctx->Unmap(bd->pIB, 0);
|
||||||
|
|
||||||
|
// Setup orthographic projection matrix into our constant buffer
|
||||||
|
// Our visible imgui space lies from draw_data->DisplayPos (top left) to draw_data->DisplayPos+data_data->DisplaySize (bottom right). DisplayPos is (0,0) for single viewport apps.
|
||||||
|
{
|
||||||
|
D3D11_MAPPED_SUBRESOURCE mapped_resource;
|
||||||
|
if (ctx->Map(bd->pVertexConstantBuffer, 0, D3D11_MAP_WRITE_DISCARD, 0, &mapped_resource) != S_OK)
|
||||||
|
return;
|
||||||
|
VERTEX_CONSTANT_BUFFER_DX11* constant_buffer = (VERTEX_CONSTANT_BUFFER_DX11*)mapped_resource.pData;
|
||||||
|
float L = draw_data->DisplayPos.x;
|
||||||
|
float R = draw_data->DisplayPos.x + draw_data->DisplaySize.x;
|
||||||
|
float T = draw_data->DisplayPos.y;
|
||||||
|
float B = draw_data->DisplayPos.y + draw_data->DisplaySize.y;
|
||||||
|
float mvp[4][4] =
|
||||||
|
{
|
||||||
|
{ 2.0f/(R-L), 0.0f, 0.0f, 0.0f },
|
||||||
|
{ 0.0f, 2.0f/(T-B), 0.0f, 0.0f },
|
||||||
|
{ 0.0f, 0.0f, 0.5f, 0.0f },
|
||||||
|
{ (R+L)/(L-R), (T+B)/(B-T), 0.5f, 1.0f },
|
||||||
|
};
|
||||||
|
memcpy(&constant_buffer->mvp, mvp, sizeof(mvp));
|
||||||
|
ctx->Unmap(bd->pVertexConstantBuffer, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Backup DX state that will be modified to restore it afterwards (unfortunately this is very ugly looking and verbose. Close your eyes!)
|
||||||
|
struct BACKUP_DX11_STATE
|
||||||
|
{
|
||||||
|
UINT ScissorRectsCount, ViewportsCount;
|
||||||
|
D3D11_RECT ScissorRects[D3D11_VIEWPORT_AND_SCISSORRECT_OBJECT_COUNT_PER_PIPELINE];
|
||||||
|
D3D11_VIEWPORT Viewports[D3D11_VIEWPORT_AND_SCISSORRECT_OBJECT_COUNT_PER_PIPELINE];
|
||||||
|
ID3D11RasterizerState* RS;
|
||||||
|
ID3D11BlendState* BlendState;
|
||||||
|
FLOAT BlendFactor[4];
|
||||||
|
UINT SampleMask;
|
||||||
|
UINT StencilRef;
|
||||||
|
ID3D11DepthStencilState* DepthStencilState;
|
||||||
|
ID3D11ShaderResourceView* PSShaderResource;
|
||||||
|
ID3D11SamplerState* PSSampler;
|
||||||
|
ID3D11PixelShader* PS;
|
||||||
|
ID3D11VertexShader* VS;
|
||||||
|
ID3D11GeometryShader* GS;
|
||||||
|
UINT PSInstancesCount, VSInstancesCount, GSInstancesCount;
|
||||||
|
ID3D11ClassInstance *PSInstances[256], *VSInstances[256], *GSInstances[256]; // 256 is max according to PSSetShader documentation
|
||||||
|
D3D11_PRIMITIVE_TOPOLOGY PrimitiveTopology;
|
||||||
|
ID3D11Buffer* IndexBuffer, *VertexBuffer, *VSConstantBuffer;
|
||||||
|
UINT IndexBufferOffset, VertexBufferStride, VertexBufferOffset;
|
||||||
|
DXGI_FORMAT IndexBufferFormat;
|
||||||
|
ID3D11InputLayout* InputLayout;
|
||||||
|
};
|
||||||
|
BACKUP_DX11_STATE old = {};
|
||||||
|
old.ScissorRectsCount = old.ViewportsCount = D3D11_VIEWPORT_AND_SCISSORRECT_OBJECT_COUNT_PER_PIPELINE;
|
||||||
|
ctx->RSGetScissorRects(&old.ScissorRectsCount, old.ScissorRects);
|
||||||
|
ctx->RSGetViewports(&old.ViewportsCount, old.Viewports);
|
||||||
|
ctx->RSGetState(&old.RS);
|
||||||
|
ctx->OMGetBlendState(&old.BlendState, old.BlendFactor, &old.SampleMask);
|
||||||
|
ctx->OMGetDepthStencilState(&old.DepthStencilState, &old.StencilRef);
|
||||||
|
ctx->PSGetShaderResources(0, 1, &old.PSShaderResource);
|
||||||
|
ctx->PSGetSamplers(0, 1, &old.PSSampler);
|
||||||
|
old.PSInstancesCount = old.VSInstancesCount = old.GSInstancesCount = 256;
|
||||||
|
ctx->PSGetShader(&old.PS, old.PSInstances, &old.PSInstancesCount);
|
||||||
|
ctx->VSGetShader(&old.VS, old.VSInstances, &old.VSInstancesCount);
|
||||||
|
ctx->VSGetConstantBuffers(0, 1, &old.VSConstantBuffer);
|
||||||
|
ctx->GSGetShader(&old.GS, old.GSInstances, &old.GSInstancesCount);
|
||||||
|
|
||||||
|
ctx->IAGetPrimitiveTopology(&old.PrimitiveTopology);
|
||||||
|
ctx->IAGetIndexBuffer(&old.IndexBuffer, &old.IndexBufferFormat, &old.IndexBufferOffset);
|
||||||
|
ctx->IAGetVertexBuffers(0, 1, &old.VertexBuffer, &old.VertexBufferStride, &old.VertexBufferOffset);
|
||||||
|
ctx->IAGetInputLayout(&old.InputLayout);
|
||||||
|
|
||||||
|
// Setup desired DX state
|
||||||
|
ImGui_ImplDX11_SetupRenderState(draw_data, ctx);
|
||||||
|
|
||||||
|
// Render command lists
|
||||||
|
// (Because we merged all buffers into a single one, we maintain our own offset into them)
|
||||||
|
int global_idx_offset = 0;
|
||||||
|
int global_vtx_offset = 0;
|
||||||
|
ImVec2 clip_off = draw_data->DisplayPos;
|
||||||
|
for (int n = 0; n < draw_data->CmdListsCount; n++)
|
||||||
|
{
|
||||||
|
const ImDrawList* cmd_list = draw_data->CmdLists[n];
|
||||||
|
for (int cmd_i = 0; cmd_i < cmd_list->CmdBuffer.Size; cmd_i++)
|
||||||
|
{
|
||||||
|
const ImDrawCmd* pcmd = &cmd_list->CmdBuffer[cmd_i];
|
||||||
|
if (pcmd->UserCallback != nullptr)
|
||||||
|
{
|
||||||
|
// User callback, registered via ImDrawList::AddCallback()
|
||||||
|
// (ImDrawCallback_ResetRenderState is a special callback value used by the user to request the renderer to reset render state.)
|
||||||
|
if (pcmd->UserCallback == ImDrawCallback_ResetRenderState)
|
||||||
|
ImGui_ImplDX11_SetupRenderState(draw_data, ctx);
|
||||||
|
else
|
||||||
|
pcmd->UserCallback(cmd_list, pcmd);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Project scissor/clipping rectangles into framebuffer space
|
||||||
|
ImVec2 clip_min(pcmd->ClipRect.x - clip_off.x, pcmd->ClipRect.y - clip_off.y);
|
||||||
|
ImVec2 clip_max(pcmd->ClipRect.z - clip_off.x, pcmd->ClipRect.w - clip_off.y);
|
||||||
|
if (clip_max.x <= clip_min.x || clip_max.y <= clip_min.y)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Apply scissor/clipping rectangle
|
||||||
|
const D3D11_RECT r = { (LONG)clip_min.x, (LONG)clip_min.y, (LONG)clip_max.x, (LONG)clip_max.y };
|
||||||
|
ctx->RSSetScissorRects(1, &r);
|
||||||
|
|
||||||
|
// Bind texture, Draw
|
||||||
|
ID3D11ShaderResourceView* texture_srv = (ID3D11ShaderResourceView*)pcmd->GetTexID();
|
||||||
|
ctx->PSSetShaderResources(0, 1, &texture_srv);
|
||||||
|
ctx->DrawIndexed(pcmd->ElemCount, pcmd->IdxOffset + global_idx_offset, pcmd->VtxOffset + global_vtx_offset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
global_idx_offset += cmd_list->IdxBuffer.Size;
|
||||||
|
global_vtx_offset += cmd_list->VtxBuffer.Size;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Restore modified DX state
|
||||||
|
ctx->RSSetScissorRects(old.ScissorRectsCount, old.ScissorRects);
|
||||||
|
ctx->RSSetViewports(old.ViewportsCount, old.Viewports);
|
||||||
|
ctx->RSSetState(old.RS); if (old.RS) old.RS->Release();
|
||||||
|
ctx->OMSetBlendState(old.BlendState, old.BlendFactor, old.SampleMask); if (old.BlendState) old.BlendState->Release();
|
||||||
|
ctx->OMSetDepthStencilState(old.DepthStencilState, old.StencilRef); if (old.DepthStencilState) old.DepthStencilState->Release();
|
||||||
|
ctx->PSSetShaderResources(0, 1, &old.PSShaderResource); if (old.PSShaderResource) old.PSShaderResource->Release();
|
||||||
|
ctx->PSSetSamplers(0, 1, &old.PSSampler); if (old.PSSampler) old.PSSampler->Release();
|
||||||
|
ctx->PSSetShader(old.PS, old.PSInstances, old.PSInstancesCount); if (old.PS) old.PS->Release();
|
||||||
|
for (UINT i = 0; i < old.PSInstancesCount; i++) if (old.PSInstances[i]) old.PSInstances[i]->Release();
|
||||||
|
ctx->VSSetShader(old.VS, old.VSInstances, old.VSInstancesCount); if (old.VS) old.VS->Release();
|
||||||
|
ctx->VSSetConstantBuffers(0, 1, &old.VSConstantBuffer); if (old.VSConstantBuffer) old.VSConstantBuffer->Release();
|
||||||
|
ctx->GSSetShader(old.GS, old.GSInstances, old.GSInstancesCount); if (old.GS) old.GS->Release();
|
||||||
|
for (UINT i = 0; i < old.VSInstancesCount; i++) if (old.VSInstances[i]) old.VSInstances[i]->Release();
|
||||||
|
ctx->IASetPrimitiveTopology(old.PrimitiveTopology);
|
||||||
|
ctx->IASetIndexBuffer(old.IndexBuffer, old.IndexBufferFormat, old.IndexBufferOffset); if (old.IndexBuffer) old.IndexBuffer->Release();
|
||||||
|
ctx->IASetVertexBuffers(0, 1, &old.VertexBuffer, &old.VertexBufferStride, &old.VertexBufferOffset); if (old.VertexBuffer) old.VertexBuffer->Release();
|
||||||
|
ctx->IASetInputLayout(old.InputLayout); if (old.InputLayout) old.InputLayout->Release();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ImGui_ImplDX11_CreateFontsTexture()
|
||||||
|
{
|
||||||
|
// Build texture atlas
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
ImGui_ImplDX11_Data* bd = ImGui_ImplDX11_GetBackendData();
|
||||||
|
unsigned char* pixels;
|
||||||
|
int width, height;
|
||||||
|
io.Fonts->GetTexDataAsRGBA32(&pixels, &width, &height);
|
||||||
|
|
||||||
|
// Upload texture to graphics system
|
||||||
|
{
|
||||||
|
D3D11_TEXTURE2D_DESC desc;
|
||||||
|
ZeroMemory(&desc, sizeof(desc));
|
||||||
|
desc.Width = width;
|
||||||
|
desc.Height = height;
|
||||||
|
desc.MipLevels = 1;
|
||||||
|
desc.ArraySize = 1;
|
||||||
|
desc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
|
||||||
|
desc.SampleDesc.Count = 1;
|
||||||
|
desc.Usage = D3D11_USAGE_DEFAULT;
|
||||||
|
desc.BindFlags = D3D11_BIND_SHADER_RESOURCE;
|
||||||
|
desc.CPUAccessFlags = 0;
|
||||||
|
|
||||||
|
ID3D11Texture2D* pTexture = nullptr;
|
||||||
|
D3D11_SUBRESOURCE_DATA subResource;
|
||||||
|
subResource.pSysMem = pixels;
|
||||||
|
subResource.SysMemPitch = desc.Width * 4;
|
||||||
|
subResource.SysMemSlicePitch = 0;
|
||||||
|
bd->pd3dDevice->CreateTexture2D(&desc, &subResource, &pTexture);
|
||||||
|
IM_ASSERT(pTexture != nullptr);
|
||||||
|
|
||||||
|
// Create texture view
|
||||||
|
D3D11_SHADER_RESOURCE_VIEW_DESC srvDesc;
|
||||||
|
ZeroMemory(&srvDesc, sizeof(srvDesc));
|
||||||
|
srvDesc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
|
||||||
|
srvDesc.ViewDimension = D3D11_SRV_DIMENSION_TEXTURE2D;
|
||||||
|
srvDesc.Texture2D.MipLevels = desc.MipLevels;
|
||||||
|
srvDesc.Texture2D.MostDetailedMip = 0;
|
||||||
|
bd->pd3dDevice->CreateShaderResourceView(pTexture, &srvDesc, &bd->pFontTextureView);
|
||||||
|
pTexture->Release();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Store our identifier
|
||||||
|
io.Fonts->SetTexID((ImTextureID)bd->pFontTextureView);
|
||||||
|
|
||||||
|
// Create texture sampler
|
||||||
|
// (Bilinear sampling is required by default. Set 'io.Fonts->Flags |= ImFontAtlasFlags_NoBakedLines' or 'style.AntiAliasedLinesUseTex = false' to allow point/nearest sampling)
|
||||||
|
{
|
||||||
|
D3D11_SAMPLER_DESC desc;
|
||||||
|
ZeroMemory(&desc, sizeof(desc));
|
||||||
|
desc.Filter = D3D11_FILTER_MIN_MAG_MIP_LINEAR;
|
||||||
|
desc.AddressU = D3D11_TEXTURE_ADDRESS_WRAP;
|
||||||
|
desc.AddressV = D3D11_TEXTURE_ADDRESS_WRAP;
|
||||||
|
desc.AddressW = D3D11_TEXTURE_ADDRESS_WRAP;
|
||||||
|
desc.MipLODBias = 0.f;
|
||||||
|
desc.ComparisonFunc = D3D11_COMPARISON_ALWAYS;
|
||||||
|
desc.MinLOD = 0.f;
|
||||||
|
desc.MaxLOD = 0.f;
|
||||||
|
bd->pd3dDevice->CreateSamplerState(&desc, &bd->pFontSampler);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ImGui_ImplDX11_CreateDeviceObjects()
|
||||||
|
{
|
||||||
|
ImGui_ImplDX11_Data* bd = ImGui_ImplDX11_GetBackendData();
|
||||||
|
if (!bd->pd3dDevice)
|
||||||
|
return false;
|
||||||
|
if (bd->pFontSampler)
|
||||||
|
ImGui_ImplDX11_InvalidateDeviceObjects();
|
||||||
|
|
||||||
|
// By using D3DCompile() from <d3dcompiler.h> / d3dcompiler.lib, we introduce a dependency to a given version of d3dcompiler_XX.dll (see D3DCOMPILER_DLL_A)
|
||||||
|
// If you would like to use this DX11 sample code but remove this dependency you can:
|
||||||
|
// 1) compile once, save the compiled shader blobs into a file or source code and pass them to CreateVertexShader()/CreatePixelShader() [preferred solution]
|
||||||
|
// 2) use code to detect any version of the DLL and grab a pointer to D3DCompile from the DLL.
|
||||||
|
// See https://github.com/ocornut/imgui/pull/638 for sources and details.
|
||||||
|
|
||||||
|
// Create the vertex shader
|
||||||
|
{
|
||||||
|
static const char* vertexShader =
|
||||||
|
"cbuffer vertexBuffer : register(b0) \
|
||||||
|
{\
|
||||||
|
float4x4 ProjectionMatrix; \
|
||||||
|
};\
|
||||||
|
struct VS_INPUT\
|
||||||
|
{\
|
||||||
|
float2 pos : POSITION;\
|
||||||
|
float4 col : COLOR0;\
|
||||||
|
float2 uv : TEXCOORD0;\
|
||||||
|
};\
|
||||||
|
\
|
||||||
|
struct PS_INPUT\
|
||||||
|
{\
|
||||||
|
float4 pos : SV_POSITION;\
|
||||||
|
float4 col : COLOR0;\
|
||||||
|
float2 uv : TEXCOORD0;\
|
||||||
|
};\
|
||||||
|
\
|
||||||
|
PS_INPUT main(VS_INPUT input)\
|
||||||
|
{\
|
||||||
|
PS_INPUT output;\
|
||||||
|
output.pos = mul( ProjectionMatrix, float4(input.pos.xy, 0.f, 1.f));\
|
||||||
|
output.col = input.col;\
|
||||||
|
output.uv = input.uv;\
|
||||||
|
return output;\
|
||||||
|
}";
|
||||||
|
|
||||||
|
ID3DBlob* vertexShaderBlob;
|
||||||
|
if (FAILED(D3DCompile(vertexShader, strlen(vertexShader), nullptr, nullptr, nullptr, "main", "vs_4_0", 0, 0, &vertexShaderBlob, nullptr)))
|
||||||
|
return false; // NB: Pass ID3DBlob* pErrorBlob to D3DCompile() to get error showing in (const char*)pErrorBlob->GetBufferPointer(). Make sure to Release() the blob!
|
||||||
|
if (bd->pd3dDevice->CreateVertexShader(vertexShaderBlob->GetBufferPointer(), vertexShaderBlob->GetBufferSize(), nullptr, &bd->pVertexShader) != S_OK)
|
||||||
|
{
|
||||||
|
vertexShaderBlob->Release();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the input layout
|
||||||
|
D3D11_INPUT_ELEMENT_DESC local_layout[] =
|
||||||
|
{
|
||||||
|
{ "POSITION", 0, DXGI_FORMAT_R32G32_FLOAT, 0, (UINT)offsetof(ImDrawVert, pos), D3D11_INPUT_PER_VERTEX_DATA, 0 },
|
||||||
|
{ "TEXCOORD", 0, DXGI_FORMAT_R32G32_FLOAT, 0, (UINT)offsetof(ImDrawVert, uv), D3D11_INPUT_PER_VERTEX_DATA, 0 },
|
||||||
|
{ "COLOR", 0, DXGI_FORMAT_R8G8B8A8_UNORM, 0, (UINT)offsetof(ImDrawVert, col), D3D11_INPUT_PER_VERTEX_DATA, 0 },
|
||||||
|
};
|
||||||
|
if (bd->pd3dDevice->CreateInputLayout(local_layout, 3, vertexShaderBlob->GetBufferPointer(), vertexShaderBlob->GetBufferSize(), &bd->pInputLayout) != S_OK)
|
||||||
|
{
|
||||||
|
vertexShaderBlob->Release();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
vertexShaderBlob->Release();
|
||||||
|
|
||||||
|
// Create the constant buffer
|
||||||
|
{
|
||||||
|
D3D11_BUFFER_DESC desc;
|
||||||
|
desc.ByteWidth = sizeof(VERTEX_CONSTANT_BUFFER_DX11);
|
||||||
|
desc.Usage = D3D11_USAGE_DYNAMIC;
|
||||||
|
desc.BindFlags = D3D11_BIND_CONSTANT_BUFFER;
|
||||||
|
desc.CPUAccessFlags = D3D11_CPU_ACCESS_WRITE;
|
||||||
|
desc.MiscFlags = 0;
|
||||||
|
bd->pd3dDevice->CreateBuffer(&desc, nullptr, &bd->pVertexConstantBuffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the pixel shader
|
||||||
|
{
|
||||||
|
static const char* pixelShader =
|
||||||
|
"struct PS_INPUT\
|
||||||
|
{\
|
||||||
|
float4 pos : SV_POSITION;\
|
||||||
|
float4 col : COLOR0;\
|
||||||
|
float2 uv : TEXCOORD0;\
|
||||||
|
};\
|
||||||
|
sampler sampler0;\
|
||||||
|
Texture2D texture0;\
|
||||||
|
\
|
||||||
|
float4 main(PS_INPUT input) : SV_Target\
|
||||||
|
{\
|
||||||
|
float4 out_col = input.col * texture0.Sample(sampler0, input.uv); \
|
||||||
|
return out_col; \
|
||||||
|
}";
|
||||||
|
|
||||||
|
ID3DBlob* pixelShaderBlob;
|
||||||
|
if (FAILED(D3DCompile(pixelShader, strlen(pixelShader), nullptr, nullptr, nullptr, "main", "ps_4_0", 0, 0, &pixelShaderBlob, nullptr)))
|
||||||
|
return false; // NB: Pass ID3DBlob* pErrorBlob to D3DCompile() to get error showing in (const char*)pErrorBlob->GetBufferPointer(). Make sure to Release() the blob!
|
||||||
|
if (bd->pd3dDevice->CreatePixelShader(pixelShaderBlob->GetBufferPointer(), pixelShaderBlob->GetBufferSize(), nullptr, &bd->pPixelShader) != S_OK)
|
||||||
|
{
|
||||||
|
pixelShaderBlob->Release();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
pixelShaderBlob->Release();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the blending setup
|
||||||
|
{
|
||||||
|
D3D11_BLEND_DESC desc;
|
||||||
|
ZeroMemory(&desc, sizeof(desc));
|
||||||
|
desc.AlphaToCoverageEnable = false;
|
||||||
|
desc.RenderTarget[0].BlendEnable = true;
|
||||||
|
desc.RenderTarget[0].SrcBlend = D3D11_BLEND_SRC_ALPHA;
|
||||||
|
desc.RenderTarget[0].DestBlend = D3D11_BLEND_INV_SRC_ALPHA;
|
||||||
|
desc.RenderTarget[0].BlendOp = D3D11_BLEND_OP_ADD;
|
||||||
|
desc.RenderTarget[0].SrcBlendAlpha = D3D11_BLEND_ONE;
|
||||||
|
desc.RenderTarget[0].DestBlendAlpha = D3D11_BLEND_INV_SRC_ALPHA;
|
||||||
|
desc.RenderTarget[0].BlendOpAlpha = D3D11_BLEND_OP_ADD;
|
||||||
|
desc.RenderTarget[0].RenderTargetWriteMask = D3D11_COLOR_WRITE_ENABLE_ALL;
|
||||||
|
bd->pd3dDevice->CreateBlendState(&desc, &bd->pBlendState);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the rasterizer state
|
||||||
|
{
|
||||||
|
D3D11_RASTERIZER_DESC desc;
|
||||||
|
ZeroMemory(&desc, sizeof(desc));
|
||||||
|
desc.FillMode = D3D11_FILL_SOLID;
|
||||||
|
desc.CullMode = D3D11_CULL_NONE;
|
||||||
|
desc.ScissorEnable = true;
|
||||||
|
desc.DepthClipEnable = true;
|
||||||
|
bd->pd3dDevice->CreateRasterizerState(&desc, &bd->pRasterizerState);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create depth-stencil State
|
||||||
|
{
|
||||||
|
D3D11_DEPTH_STENCIL_DESC desc;
|
||||||
|
ZeroMemory(&desc, sizeof(desc));
|
||||||
|
desc.DepthEnable = false;
|
||||||
|
desc.DepthWriteMask = D3D11_DEPTH_WRITE_MASK_ALL;
|
||||||
|
desc.DepthFunc = D3D11_COMPARISON_ALWAYS;
|
||||||
|
desc.StencilEnable = false;
|
||||||
|
desc.FrontFace.StencilFailOp = desc.FrontFace.StencilDepthFailOp = desc.FrontFace.StencilPassOp = D3D11_STENCIL_OP_KEEP;
|
||||||
|
desc.FrontFace.StencilFunc = D3D11_COMPARISON_ALWAYS;
|
||||||
|
desc.BackFace = desc.FrontFace;
|
||||||
|
bd->pd3dDevice->CreateDepthStencilState(&desc, &bd->pDepthStencilState);
|
||||||
|
}
|
||||||
|
|
||||||
|
ImGui_ImplDX11_CreateFontsTexture();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImGui_ImplDX11_InvalidateDeviceObjects()
|
||||||
|
{
|
||||||
|
ImGui_ImplDX11_Data* bd = ImGui_ImplDX11_GetBackendData();
|
||||||
|
if (!bd->pd3dDevice)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (bd->pFontSampler) { bd->pFontSampler->Release(); bd->pFontSampler = nullptr; }
|
||||||
|
if (bd->pFontTextureView) { bd->pFontTextureView->Release(); bd->pFontTextureView = nullptr; ImGui::GetIO().Fonts->SetTexID(0); } // We copied data->pFontTextureView to io.Fonts->TexID so let's clear that as well.
|
||||||
|
if (bd->pIB) { bd->pIB->Release(); bd->pIB = nullptr; }
|
||||||
|
if (bd->pVB) { bd->pVB->Release(); bd->pVB = nullptr; }
|
||||||
|
if (bd->pBlendState) { bd->pBlendState->Release(); bd->pBlendState = nullptr; }
|
||||||
|
if (bd->pDepthStencilState) { bd->pDepthStencilState->Release(); bd->pDepthStencilState = nullptr; }
|
||||||
|
if (bd->pRasterizerState) { bd->pRasterizerState->Release(); bd->pRasterizerState = nullptr; }
|
||||||
|
if (bd->pPixelShader) { bd->pPixelShader->Release(); bd->pPixelShader = nullptr; }
|
||||||
|
if (bd->pVertexConstantBuffer) { bd->pVertexConstantBuffer->Release(); bd->pVertexConstantBuffer = nullptr; }
|
||||||
|
if (bd->pInputLayout) { bd->pInputLayout->Release(); bd->pInputLayout = nullptr; }
|
||||||
|
if (bd->pVertexShader) { bd->pVertexShader->Release(); bd->pVertexShader = nullptr; }
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ImGui_ImplDX11_Init(ID3D11Device* device, ID3D11DeviceContext* device_context)
|
||||||
|
{
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
IMGUI_CHECKVERSION();
|
||||||
|
IM_ASSERT(io.BackendRendererUserData == nullptr && "Already initialized a renderer backend!");
|
||||||
|
|
||||||
|
// Setup backend capabilities flags
|
||||||
|
ImGui_ImplDX11_Data* bd = IM_NEW(ImGui_ImplDX11_Data)();
|
||||||
|
io.BackendRendererUserData = (void*)bd;
|
||||||
|
io.BackendRendererName = "imgui_impl_dx11";
|
||||||
|
io.BackendFlags |= ImGuiBackendFlags_RendererHasVtxOffset; // We can honor the ImDrawCmd::VtxOffset field, allowing for large meshes.
|
||||||
|
|
||||||
|
// Get factory from device
|
||||||
|
IDXGIDevice* pDXGIDevice = nullptr;
|
||||||
|
IDXGIAdapter* pDXGIAdapter = nullptr;
|
||||||
|
IDXGIFactory* pFactory = nullptr;
|
||||||
|
|
||||||
|
if (device->QueryInterface(IID_PPV_ARGS(&pDXGIDevice)) == S_OK)
|
||||||
|
if (pDXGIDevice->GetParent(IID_PPV_ARGS(&pDXGIAdapter)) == S_OK)
|
||||||
|
if (pDXGIAdapter->GetParent(IID_PPV_ARGS(&pFactory)) == S_OK)
|
||||||
|
{
|
||||||
|
bd->pd3dDevice = device;
|
||||||
|
bd->pd3dDeviceContext = device_context;
|
||||||
|
bd->pFactory = pFactory;
|
||||||
|
}
|
||||||
|
if (pDXGIDevice) pDXGIDevice->Release();
|
||||||
|
if (pDXGIAdapter) pDXGIAdapter->Release();
|
||||||
|
bd->pd3dDevice->AddRef();
|
||||||
|
bd->pd3dDeviceContext->AddRef();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImGui_ImplDX11_Shutdown()
|
||||||
|
{
|
||||||
|
ImGui_ImplDX11_Data* bd = ImGui_ImplDX11_GetBackendData();
|
||||||
|
IM_ASSERT(bd != nullptr && "No renderer backend to shutdown, or already shutdown?");
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
|
||||||
|
ImGui_ImplDX11_InvalidateDeviceObjects();
|
||||||
|
if (bd->pFactory) { bd->pFactory->Release(); }
|
||||||
|
if (bd->pd3dDevice) { bd->pd3dDevice->Release(); }
|
||||||
|
if (bd->pd3dDeviceContext) { bd->pd3dDeviceContext->Release(); }
|
||||||
|
io.BackendRendererName = nullptr;
|
||||||
|
io.BackendRendererUserData = nullptr;
|
||||||
|
io.BackendFlags &= ~ImGuiBackendFlags_RendererHasVtxOffset;
|
||||||
|
IM_DELETE(bd);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImGui_ImplDX11_NewFrame()
|
||||||
|
{
|
||||||
|
ImGui_ImplDX11_Data* bd = ImGui_ImplDX11_GetBackendData();
|
||||||
|
IM_ASSERT(bd != nullptr && "Context or backend not initialized! Did you call ImGui_ImplDX11_Init()?");
|
||||||
|
|
||||||
|
if (!bd->pFontSampler)
|
||||||
|
ImGui_ImplDX11_CreateDeviceObjects();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#endif // #ifndef IMGUI_DISABLE
|
||||||
@@ -0,0 +1,32 @@
|
|||||||
|
// dear imgui: Renderer Backend for DirectX11
|
||||||
|
// This needs to be used along with a Platform Backend (e.g. Win32)
|
||||||
|
|
||||||
|
// Implemented features:
|
||||||
|
// [X] Renderer: User texture binding. Use 'ID3D11ShaderResourceView*' as ImTextureID. Read the FAQ about ImTextureID!
|
||||||
|
// [X] Renderer: Large meshes support (64k+ vertices) with 16-bit indices.
|
||||||
|
|
||||||
|
// You can use unmodified imgui_impl_* files in your project. See examples/ folder for examples of using this.
|
||||||
|
// Prefer including the entire imgui/ repository into your project (either as a copy or as a submodule), and only build the backends you need.
|
||||||
|
// Learn about Dear ImGui:
|
||||||
|
// - FAQ https://dearimgui.com/faq
|
||||||
|
// - Getting Started https://dearimgui.com/getting-started
|
||||||
|
// - Documentation https://dearimgui.com/docs (same as your local docs/ folder).
|
||||||
|
// - Introduction, links and more at the top of imgui.cpp
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include "imgui.h" // IMGUI_IMPL_API
|
||||||
|
#ifndef IMGUI_DISABLE
|
||||||
|
|
||||||
|
struct ID3D11Device;
|
||||||
|
struct ID3D11DeviceContext;
|
||||||
|
|
||||||
|
IMGUI_IMPL_API bool ImGui_ImplDX11_Init(ID3D11Device* device, ID3D11DeviceContext* device_context);
|
||||||
|
IMGUI_IMPL_API void ImGui_ImplDX11_Shutdown();
|
||||||
|
IMGUI_IMPL_API void ImGui_ImplDX11_NewFrame();
|
||||||
|
IMGUI_IMPL_API void ImGui_ImplDX11_RenderDrawData(ImDrawData* draw_data);
|
||||||
|
|
||||||
|
// Use if you want to reset your rendering device without losing Dear ImGui state.
|
||||||
|
IMGUI_IMPL_API void ImGui_ImplDX11_InvalidateDeviceObjects();
|
||||||
|
IMGUI_IMPL_API bool ImGui_ImplDX11_CreateDeviceObjects();
|
||||||
|
|
||||||
|
#endif // #ifndef IMGUI_DISABLE
|
||||||
@@ -0,0 +1,933 @@
|
|||||||
|
// dear imgui: Platform Backend for Windows (standard windows API for 32-bits AND 64-bits applications)
|
||||||
|
// This needs to be used along with a Renderer (e.g. DirectX11, OpenGL3, Vulkan..)
|
||||||
|
|
||||||
|
// Implemented features:
|
||||||
|
// [X] Platform: Clipboard support (for Win32 this is actually part of core dear imgui)
|
||||||
|
// [X] Platform: Mouse support. Can discriminate Mouse/TouchScreen/Pen.
|
||||||
|
// [X] Platform: Keyboard support. Since 1.87 we are using the io.AddKeyEvent() function. Pass ImGuiKey values to all key functions e.g. ImGui::IsKeyPressed(ImGuiKey_Space). [Legacy VK_* values will also be supported unless IMGUI_DISABLE_OBSOLETE_KEYIO is set]
|
||||||
|
// [X] Platform: Gamepad support. Enabled with 'io.ConfigFlags |= ImGuiConfigFlags_NavEnableGamepad'.
|
||||||
|
// [X] Platform: Mouse cursor shape and visibility. Disable with 'io.ConfigFlags |= ImGuiConfigFlags_NoMouseCursorChange'.
|
||||||
|
|
||||||
|
// You can use unmodified imgui_impl_* files in your project. See examples/ folder for examples of using this.
|
||||||
|
// Prefer including the entire imgui/ repository into your project (either as a copy or as a submodule), and only build the backends you need.
|
||||||
|
// Learn about Dear ImGui:
|
||||||
|
// - FAQ https://dearimgui.com/faq
|
||||||
|
// - Getting Started https://dearimgui.com/getting-started
|
||||||
|
// - Documentation https://dearimgui.com/docs (same as your local docs/ folder).
|
||||||
|
// - Introduction, links and more at the top of imgui.cpp
|
||||||
|
|
||||||
|
// Configuration flags to add in your imconfig file:
|
||||||
|
//#define IMGUI_IMPL_WIN32_DISABLE_GAMEPAD // Disable gamepad support. This was meaningful before <1.81 but we now load XInput dynamically so the option is now less relevant.
|
||||||
|
|
||||||
|
// CHANGELOG
|
||||||
|
// (minor and older changes stripped away, please see git history for details)
|
||||||
|
// 2024-07-08: Inputs: Fixed ImGuiMod_Super being mapped to VK_APPS instead of VK_LWIN||VK_RWIN. (#7768)
|
||||||
|
// 2023-10-05: Inputs: Added support for extra ImGuiKey values: F13 to F24 function keys, app back/forward keys.
|
||||||
|
// 2023-09-25: Inputs: Synthesize key-down event on key-up for VK_SNAPSHOT / ImGuiKey_PrintScreen as Windows doesn't emit it (same behavior as GLFW/SDL).
|
||||||
|
// 2023-09-07: Inputs: Added support for keyboard codepage conversion for when application is compiled in MBCS mode and using a non-Unicode window.
|
||||||
|
// 2023-04-19: Added ImGui_ImplWin32_InitForOpenGL() to facilitate combining raw Win32/Winapi with OpenGL. (#3218)
|
||||||
|
// 2023-04-04: Inputs: Added support for io.AddMouseSourceEvent() to discriminate ImGuiMouseSource_Mouse/ImGuiMouseSource_TouchScreen/ImGuiMouseSource_Pen. (#2702)
|
||||||
|
// 2023-02-15: Inputs: Use WM_NCMOUSEMOVE / WM_NCMOUSELEAVE to track mouse position over non-client area (e.g. OS decorations) when app is not focused. (#6045, #6162)
|
||||||
|
// 2023-02-02: Inputs: Flipping WM_MOUSEHWHEEL (horizontal mouse-wheel) value to match other backends and offer consistent horizontal scrolling direction. (#4019, #6096, #1463)
|
||||||
|
// 2022-10-11: Using 'nullptr' instead of 'NULL' as per our switch to C++11.
|
||||||
|
// 2022-09-28: Inputs: Convert WM_CHAR values with MultiByteToWideChar() when window class was registered as MBCS (not Unicode).
|
||||||
|
// 2022-09-26: Inputs: Renamed ImGuiKey_ModXXX introduced in 1.87 to ImGuiMod_XXX (old names still supported).
|
||||||
|
// 2022-01-26: Inputs: replaced short-lived io.AddKeyModsEvent() (added two weeks ago) with io.AddKeyEvent() using ImGuiKey_ModXXX flags. Sorry for the confusion.
|
||||||
|
// 2021-01-20: Inputs: calling new io.AddKeyAnalogEvent() for gamepad support, instead of writing directly to io.NavInputs[].
|
||||||
|
// 2022-01-17: Inputs: calling new io.AddMousePosEvent(), io.AddMouseButtonEvent(), io.AddMouseWheelEvent() API (1.87+).
|
||||||
|
// 2022-01-17: Inputs: always update key mods next and before a key event (not in NewFrame) to fix input queue with very low framerates.
|
||||||
|
// 2022-01-12: Inputs: Update mouse inputs using WM_MOUSEMOVE/WM_MOUSELEAVE + fallback to provide it when focused but not hovered/captured. More standard and will allow us to pass it to future input queue API.
|
||||||
|
// 2022-01-12: Inputs: Maintain our own copy of MouseButtonsDown mask instead of using ImGui::IsAnyMouseDown() which will be obsoleted.
|
||||||
|
// 2022-01-10: Inputs: calling new io.AddKeyEvent(), io.AddKeyModsEvent() + io.SetKeyEventNativeData() API (1.87+). Support for full ImGuiKey range.
|
||||||
|
// 2021-12-16: Inputs: Fill VK_LCONTROL/VK_RCONTROL/VK_LSHIFT/VK_RSHIFT/VK_LMENU/VK_RMENU for completeness.
|
||||||
|
// 2021-08-17: Calling io.AddFocusEvent() on WM_SETFOCUS/WM_KILLFOCUS messages.
|
||||||
|
// 2021-08-02: Inputs: Fixed keyboard modifiers being reported when host window doesn't have focus.
|
||||||
|
// 2021-07-29: Inputs: MousePos is correctly reported when the host platform window is hovered but not focused (using TrackMouseEvent() to receive WM_MOUSELEAVE events).
|
||||||
|
// 2021-06-29: Reorganized backend to pull data from a single structure to facilitate usage with multiple-contexts (all g_XXXX access changed to bd->XXXX).
|
||||||
|
// 2021-06-08: Fixed ImGui_ImplWin32_EnableDpiAwareness() and ImGui_ImplWin32_GetDpiScaleForMonitor() to handle Windows 8.1/10 features without a manifest (per-monitor DPI, and properly calls SetProcessDpiAwareness() on 8.1).
|
||||||
|
// 2021-03-23: Inputs: Clearing keyboard down array when losing focus (WM_KILLFOCUS).
|
||||||
|
// 2021-02-18: Added ImGui_ImplWin32_EnableAlphaCompositing(). Non Visual Studio users will need to link with dwmapi.lib (MinGW/gcc: use -ldwmapi).
|
||||||
|
// 2021-02-17: Fixed ImGui_ImplWin32_EnableDpiAwareness() attempting to get SetProcessDpiAwareness from shcore.dll on Windows 8 whereas it is only supported on Windows 8.1.
|
||||||
|
// 2021-01-25: Inputs: Dynamically loading XInput DLL.
|
||||||
|
// 2020-12-04: Misc: Fixed setting of io.DisplaySize to invalid/uninitialized data when after hwnd has been closed.
|
||||||
|
// 2020-03-03: Inputs: Calling AddInputCharacterUTF16() to support surrogate pairs leading to codepoint >= 0x10000 (for more complete CJK inputs)
|
||||||
|
// 2020-02-17: Added ImGui_ImplWin32_EnableDpiAwareness(), ImGui_ImplWin32_GetDpiScaleForHwnd(), ImGui_ImplWin32_GetDpiScaleForMonitor() helper functions.
|
||||||
|
// 2020-01-14: Inputs: Added support for #define IMGUI_IMPL_WIN32_DISABLE_GAMEPAD/IMGUI_IMPL_WIN32_DISABLE_LINKING_XINPUT.
|
||||||
|
// 2019-12-05: Inputs: Added support for ImGuiMouseCursor_NotAllowed mouse cursor.
|
||||||
|
// 2019-05-11: Inputs: Don't filter value from WM_CHAR before calling AddInputCharacter().
|
||||||
|
// 2019-01-17: Misc: Using GetForegroundWindow()+IsChild() instead of GetActiveWindow() to be compatible with windows created in a different thread or parent.
|
||||||
|
// 2019-01-17: Inputs: Added support for mouse buttons 4 and 5 via WM_XBUTTON* messages.
|
||||||
|
// 2019-01-15: Inputs: Added support for XInput gamepads (if ImGuiConfigFlags_NavEnableGamepad is set by user application).
|
||||||
|
// 2018-11-30: Misc: Setting up io.BackendPlatformName so it can be displayed in the About Window.
|
||||||
|
// 2018-06-29: Inputs: Added support for the ImGuiMouseCursor_Hand cursor.
|
||||||
|
// 2018-06-10: Inputs: Fixed handling of mouse wheel messages to support fine position messages (typically sent by track-pads).
|
||||||
|
// 2018-06-08: Misc: Extracted imgui_impl_win32.cpp/.h away from the old combined DX9/DX10/DX11/DX12 examples.
|
||||||
|
// 2018-03-20: Misc: Setup io.BackendFlags ImGuiBackendFlags_HasMouseCursors and ImGuiBackendFlags_HasSetMousePos flags + honor ImGuiConfigFlags_NoMouseCursorChange flag.
|
||||||
|
// 2018-02-20: Inputs: Added support for mouse cursors (ImGui::GetMouseCursor() value and WM_SETCURSOR message handling).
|
||||||
|
// 2018-02-06: Inputs: Added mapping for ImGuiKey_Space.
|
||||||
|
// 2018-02-06: Inputs: Honoring the io.WantSetMousePos by repositioning the mouse (when using navigation and ImGuiConfigFlags_NavMoveMouse is set).
|
||||||
|
// 2018-02-06: Misc: Removed call to ImGui::Shutdown() which is not available from 1.60 WIP, user needs to call CreateContext/DestroyContext themselves.
|
||||||
|
// 2018-01-20: Inputs: Added Horizontal Mouse Wheel support.
|
||||||
|
// 2018-01-08: Inputs: Added mapping for ImGuiKey_Insert.
|
||||||
|
// 2018-01-05: Inputs: Added WM_LBUTTONDBLCLK double-click handlers for window classes with the CS_DBLCLKS flag.
|
||||||
|
// 2017-10-23: Inputs: Added WM_SYSKEYDOWN / WM_SYSKEYUP handlers so e.g. the VK_MENU key can be read.
|
||||||
|
// 2017-10-23: Inputs: Using Win32 ::SetCapture/::GetCapture() to retrieve mouse positions outside the client area when dragging.
|
||||||
|
// 2016-11-12: Inputs: Only call Win32 ::SetCursor(nullptr) when io.MouseDrawCursor is set.
|
||||||
|
|
||||||
|
#include "imgui.h"
|
||||||
|
#ifndef IMGUI_DISABLE
|
||||||
|
#include "imgui_impl_win32.h"
|
||||||
|
#ifndef WIN32_LEAN_AND_MEAN
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#endif
|
||||||
|
#include <windows.h>
|
||||||
|
#include <windowsx.h> // GET_X_LPARAM(), GET_Y_LPARAM()
|
||||||
|
#include <tchar.h>
|
||||||
|
#include <dwmapi.h>
|
||||||
|
|
||||||
|
// Using XInput for gamepad (will load DLL dynamically)
|
||||||
|
#ifndef IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
#include <xinput.h>
|
||||||
|
typedef DWORD(WINAPI* PFN_XInputGetCapabilities)(DWORD, DWORD, XINPUT_CAPABILITIES*);
|
||||||
|
typedef DWORD(WINAPI* PFN_XInputGetState)(DWORD, XINPUT_STATE*);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Clang/GCC warnings with -Weverything
|
||||||
|
#if defined(__clang__)
|
||||||
|
#pragma clang diagnostic push
|
||||||
|
#pragma clang diagnostic ignored "-Wcast-function-type" // warning: cast between incompatible function types (for loader)
|
||||||
|
#endif
|
||||||
|
#if defined(__GNUC__)
|
||||||
|
#pragma GCC diagnostic push
|
||||||
|
#pragma GCC diagnostic ignored "-Wpragmas" // warning: unknown option after '#pragma GCC diagnostic' kind
|
||||||
|
#pragma GCC diagnostic ignored "-Wcast-function-type" // warning: cast between incompatible function types (for loader)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
struct ImGui_ImplWin32_Data
|
||||||
|
{
|
||||||
|
HWND hWnd;
|
||||||
|
HWND MouseHwnd;
|
||||||
|
int MouseTrackedArea; // 0: not tracked, 1: client area, 2: non-client area
|
||||||
|
int MouseButtonsDown;
|
||||||
|
INT64 Time;
|
||||||
|
INT64 TicksPerSecond;
|
||||||
|
ImGuiMouseCursor LastMouseCursor;
|
||||||
|
UINT32 KeyboardCodePage;
|
||||||
|
|
||||||
|
#ifndef IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
bool HasGamepad;
|
||||||
|
bool WantUpdateHasGamepad;
|
||||||
|
HMODULE XInputDLL;
|
||||||
|
PFN_XInputGetCapabilities XInputGetCapabilities;
|
||||||
|
PFN_XInputGetState XInputGetState;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ImGui_ImplWin32_Data() { memset((void*)this, 0, sizeof(*this)); }
|
||||||
|
};
|
||||||
|
|
||||||
|
// Backend data stored in io.BackendPlatformUserData to allow support for multiple Dear ImGui contexts
|
||||||
|
// It is STRONGLY preferred that you use docking branch with multi-viewports (== single Dear ImGui context + multiple windows) instead of multiple Dear ImGui contexts.
|
||||||
|
// FIXME: multi-context support is not well tested and probably dysfunctional in this backend.
|
||||||
|
// FIXME: some shared resources (mouse cursor shape, gamepad) are mishandled when using multi-context.
|
||||||
|
static ImGui_ImplWin32_Data* ImGui_ImplWin32_GetBackendData()
|
||||||
|
{
|
||||||
|
return ImGui::GetCurrentContext() ? (ImGui_ImplWin32_Data*)ImGui::GetIO().BackendPlatformUserData : nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Functions
|
||||||
|
static void ImGui_ImplWin32_UpdateKeyboardCodePage()
|
||||||
|
{
|
||||||
|
// Retrieve keyboard code page, required for handling of non-Unicode Windows.
|
||||||
|
ImGui_ImplWin32_Data* bd = ImGui_ImplWin32_GetBackendData();
|
||||||
|
HKL keyboard_layout = ::GetKeyboardLayout(0);
|
||||||
|
LCID keyboard_lcid = MAKELCID(HIWORD(keyboard_layout), SORT_DEFAULT);
|
||||||
|
if (::GetLocaleInfoA(keyboard_lcid, (LOCALE_RETURN_NUMBER | LOCALE_IDEFAULTANSICODEPAGE), (LPSTR)&bd->KeyboardCodePage, sizeof(bd->KeyboardCodePage)) == 0)
|
||||||
|
bd->KeyboardCodePage = CP_ACP; // Fallback to default ANSI code page when fails.
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool ImGui_ImplWin32_InitEx(void* hwnd, bool platform_has_own_dc)
|
||||||
|
{
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
IMGUI_CHECKVERSION();
|
||||||
|
IM_ASSERT(io.BackendPlatformUserData == nullptr && "Already initialized a platform backend!");
|
||||||
|
|
||||||
|
INT64 perf_frequency, perf_counter;
|
||||||
|
if (!::QueryPerformanceFrequency((LARGE_INTEGER*)&perf_frequency))
|
||||||
|
return false;
|
||||||
|
if (!::QueryPerformanceCounter((LARGE_INTEGER*)&perf_counter))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Setup backend capabilities flags
|
||||||
|
ImGui_ImplWin32_Data* bd = IM_NEW(ImGui_ImplWin32_Data)();
|
||||||
|
io.BackendPlatformUserData = (void*)bd;
|
||||||
|
io.BackendPlatformName = "imgui_impl_win32";
|
||||||
|
io.BackendFlags |= ImGuiBackendFlags_HasMouseCursors; // We can honor GetMouseCursor() values (optional)
|
||||||
|
io.BackendFlags |= ImGuiBackendFlags_HasSetMousePos; // We can honor io.WantSetMousePos requests (optional, rarely used)
|
||||||
|
|
||||||
|
bd->hWnd = (HWND)hwnd;
|
||||||
|
bd->TicksPerSecond = perf_frequency;
|
||||||
|
bd->Time = perf_counter;
|
||||||
|
bd->LastMouseCursor = ImGuiMouseCursor_COUNT;
|
||||||
|
ImGui_ImplWin32_UpdateKeyboardCodePage();
|
||||||
|
|
||||||
|
// Set platform dependent data in viewport
|
||||||
|
ImGuiViewport* main_viewport = ImGui::GetMainViewport();
|
||||||
|
main_viewport->PlatformHandle = main_viewport->PlatformHandleRaw = (void*)bd->hWnd;
|
||||||
|
IM_UNUSED(platform_has_own_dc); // Used in 'docking' branch
|
||||||
|
|
||||||
|
// Dynamically load XInput library
|
||||||
|
#ifndef IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
bd->WantUpdateHasGamepad = true;
|
||||||
|
const char* xinput_dll_names[] =
|
||||||
|
{
|
||||||
|
"xinput1_4.dll", // Windows 8+
|
||||||
|
"xinput1_3.dll", // DirectX SDK
|
||||||
|
"xinput9_1_0.dll", // Windows Vista, Windows 7
|
||||||
|
"xinput1_2.dll", // DirectX SDK
|
||||||
|
"xinput1_1.dll" // DirectX SDK
|
||||||
|
};
|
||||||
|
for (int n = 0; n < IM_ARRAYSIZE(xinput_dll_names); n++)
|
||||||
|
if (HMODULE dll = ::LoadLibraryA(xinput_dll_names[n]))
|
||||||
|
{
|
||||||
|
bd->XInputDLL = dll;
|
||||||
|
bd->XInputGetCapabilities = (PFN_XInputGetCapabilities)::GetProcAddress(dll, "XInputGetCapabilities");
|
||||||
|
bd->XInputGetState = (PFN_XInputGetState)::GetProcAddress(dll, "XInputGetState");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif // IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
IMGUI_IMPL_API bool ImGui_ImplWin32_Init(void* hwnd)
|
||||||
|
{
|
||||||
|
return ImGui_ImplWin32_InitEx(hwnd, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
IMGUI_IMPL_API bool ImGui_ImplWin32_InitForOpenGL(void* hwnd)
|
||||||
|
{
|
||||||
|
// OpenGL needs CS_OWNDC
|
||||||
|
return ImGui_ImplWin32_InitEx(hwnd, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImGui_ImplWin32_Shutdown()
|
||||||
|
{
|
||||||
|
ImGui_ImplWin32_Data* bd = ImGui_ImplWin32_GetBackendData();
|
||||||
|
IM_ASSERT(bd != nullptr && "No platform backend to shutdown, or already shutdown?");
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
|
||||||
|
// Unload XInput library
|
||||||
|
#ifndef IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
if (bd->XInputDLL)
|
||||||
|
::FreeLibrary(bd->XInputDLL);
|
||||||
|
#endif // IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
|
||||||
|
io.BackendPlatformName = nullptr;
|
||||||
|
io.BackendPlatformUserData = nullptr;
|
||||||
|
io.BackendFlags &= ~(ImGuiBackendFlags_HasMouseCursors | ImGuiBackendFlags_HasSetMousePos | ImGuiBackendFlags_HasGamepad);
|
||||||
|
IM_DELETE(bd);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool ImGui_ImplWin32_UpdateMouseCursor()
|
||||||
|
{
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
if (io.ConfigFlags & ImGuiConfigFlags_NoMouseCursorChange)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
ImGuiMouseCursor imgui_cursor = ImGui::GetMouseCursor();
|
||||||
|
if (imgui_cursor == ImGuiMouseCursor_None || io.MouseDrawCursor)
|
||||||
|
{
|
||||||
|
// Hide OS mouse cursor if imgui is drawing it or if it wants no cursor
|
||||||
|
::SetCursor(nullptr);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Show OS mouse cursor
|
||||||
|
LPTSTR win32_cursor = IDC_ARROW;
|
||||||
|
switch (imgui_cursor)
|
||||||
|
{
|
||||||
|
case ImGuiMouseCursor_Arrow: win32_cursor = IDC_ARROW; break;
|
||||||
|
case ImGuiMouseCursor_TextInput: win32_cursor = IDC_IBEAM; break;
|
||||||
|
case ImGuiMouseCursor_ResizeAll: win32_cursor = IDC_SIZEALL; break;
|
||||||
|
case ImGuiMouseCursor_ResizeEW: win32_cursor = IDC_SIZEWE; break;
|
||||||
|
case ImGuiMouseCursor_ResizeNS: win32_cursor = IDC_SIZENS; break;
|
||||||
|
case ImGuiMouseCursor_ResizeNESW: win32_cursor = IDC_SIZENESW; break;
|
||||||
|
case ImGuiMouseCursor_ResizeNWSE: win32_cursor = IDC_SIZENWSE; break;
|
||||||
|
case ImGuiMouseCursor_Hand: win32_cursor = IDC_HAND; break;
|
||||||
|
case ImGuiMouseCursor_NotAllowed: win32_cursor = IDC_NO; break;
|
||||||
|
}
|
||||||
|
::SetCursor(::LoadCursor(nullptr, win32_cursor));
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IsVkDown(int vk)
|
||||||
|
{
|
||||||
|
return (::GetKeyState(vk) & 0x8000) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ImGui_ImplWin32_AddKeyEvent(ImGuiKey key, bool down, int native_keycode, int native_scancode = -1)
|
||||||
|
{
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
io.AddKeyEvent(key, down);
|
||||||
|
io.SetKeyEventNativeData(key, native_keycode, native_scancode); // To support legacy indexing (<1.87 user code)
|
||||||
|
IM_UNUSED(native_scancode);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ImGui_ImplWin32_ProcessKeyEventsWorkarounds()
|
||||||
|
{
|
||||||
|
// Left & right Shift keys: when both are pressed together, Windows tend to not generate the WM_KEYUP event for the first released one.
|
||||||
|
if (ImGui::IsKeyDown(ImGuiKey_LeftShift) && !IsVkDown(VK_LSHIFT))
|
||||||
|
ImGui_ImplWin32_AddKeyEvent(ImGuiKey_LeftShift, false, VK_LSHIFT);
|
||||||
|
if (ImGui::IsKeyDown(ImGuiKey_RightShift) && !IsVkDown(VK_RSHIFT))
|
||||||
|
ImGui_ImplWin32_AddKeyEvent(ImGuiKey_RightShift, false, VK_RSHIFT);
|
||||||
|
|
||||||
|
// Sometimes WM_KEYUP for Win key is not passed down to the app (e.g. for Win+V on some setups, according to GLFW).
|
||||||
|
if (ImGui::IsKeyDown(ImGuiKey_LeftSuper) && !IsVkDown(VK_LWIN))
|
||||||
|
ImGui_ImplWin32_AddKeyEvent(ImGuiKey_LeftSuper, false, VK_LWIN);
|
||||||
|
if (ImGui::IsKeyDown(ImGuiKey_RightSuper) && !IsVkDown(VK_RWIN))
|
||||||
|
ImGui_ImplWin32_AddKeyEvent(ImGuiKey_RightSuper, false, VK_RWIN);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ImGui_ImplWin32_UpdateKeyModifiers()
|
||||||
|
{
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
io.AddKeyEvent(ImGuiMod_Ctrl, IsVkDown(VK_CONTROL));
|
||||||
|
io.AddKeyEvent(ImGuiMod_Shift, IsVkDown(VK_SHIFT));
|
||||||
|
io.AddKeyEvent(ImGuiMod_Alt, IsVkDown(VK_MENU));
|
||||||
|
io.AddKeyEvent(ImGuiMod_Super, IsVkDown(VK_LWIN) || IsVkDown(VK_RWIN));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ImGui_ImplWin32_UpdateMouseData()
|
||||||
|
{
|
||||||
|
ImGui_ImplWin32_Data* bd = ImGui_ImplWin32_GetBackendData();
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
IM_ASSERT(bd->hWnd != 0);
|
||||||
|
|
||||||
|
HWND focused_window = ::GetForegroundWindow();
|
||||||
|
const bool is_app_focused = (focused_window == bd->hWnd);
|
||||||
|
if (is_app_focused)
|
||||||
|
{
|
||||||
|
// (Optional) Set OS mouse position from Dear ImGui if requested (rarely used, only when io.ConfigNavMoveSetMousePos is enabled by user)
|
||||||
|
if (io.WantSetMousePos)
|
||||||
|
{
|
||||||
|
POINT pos = { (int)io.MousePos.x, (int)io.MousePos.y };
|
||||||
|
if (::ClientToScreen(bd->hWnd, &pos))
|
||||||
|
::SetCursorPos(pos.x, pos.y);
|
||||||
|
}
|
||||||
|
|
||||||
|
// (Optional) Fallback to provide mouse position when focused (WM_MOUSEMOVE already provides this when hovered or captured)
|
||||||
|
// This also fills a short gap when clicking non-client area: WM_NCMOUSELEAVE -> modal OS move -> gap -> WM_NCMOUSEMOVE
|
||||||
|
if (!io.WantSetMousePos && bd->MouseTrackedArea == 0)
|
||||||
|
{
|
||||||
|
POINT pos;
|
||||||
|
if (::GetCursorPos(&pos) && ::ScreenToClient(bd->hWnd, &pos))
|
||||||
|
io.AddMousePosEvent((float)pos.x, (float)pos.y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gamepad navigation mapping
|
||||||
|
static void ImGui_ImplWin32_UpdateGamepads()
|
||||||
|
{
|
||||||
|
#ifndef IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
ImGui_ImplWin32_Data* bd = ImGui_ImplWin32_GetBackendData();
|
||||||
|
//if ((io.ConfigFlags & ImGuiConfigFlags_NavEnableGamepad) == 0) // FIXME: Technically feeding gamepad shouldn't depend on this now that they are regular inputs.
|
||||||
|
// return;
|
||||||
|
|
||||||
|
// Calling XInputGetState() every frame on disconnected gamepads is unfortunately too slow.
|
||||||
|
// Instead we refresh gamepad availability by calling XInputGetCapabilities() _only_ after receiving WM_DEVICECHANGE.
|
||||||
|
if (bd->WantUpdateHasGamepad)
|
||||||
|
{
|
||||||
|
XINPUT_CAPABILITIES caps = {};
|
||||||
|
bd->HasGamepad = bd->XInputGetCapabilities ? (bd->XInputGetCapabilities(0, XINPUT_FLAG_GAMEPAD, &caps) == ERROR_SUCCESS) : false;
|
||||||
|
bd->WantUpdateHasGamepad = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
io.BackendFlags &= ~ImGuiBackendFlags_HasGamepad;
|
||||||
|
XINPUT_STATE xinput_state;
|
||||||
|
XINPUT_GAMEPAD& gamepad = xinput_state.Gamepad;
|
||||||
|
if (!bd->HasGamepad || bd->XInputGetState == nullptr || bd->XInputGetState(0, &xinput_state) != ERROR_SUCCESS)
|
||||||
|
return;
|
||||||
|
io.BackendFlags |= ImGuiBackendFlags_HasGamepad;
|
||||||
|
|
||||||
|
#define IM_SATURATE(V) (V < 0.0f ? 0.0f : V > 1.0f ? 1.0f : V)
|
||||||
|
#define MAP_BUTTON(KEY_NO, BUTTON_ENUM) { io.AddKeyEvent(KEY_NO, (gamepad.wButtons & BUTTON_ENUM) != 0); }
|
||||||
|
#define MAP_ANALOG(KEY_NO, VALUE, V0, V1) { float vn = (float)(VALUE - V0) / (float)(V1 - V0); io.AddKeyAnalogEvent(KEY_NO, vn > 0.10f, IM_SATURATE(vn)); }
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadStart, XINPUT_GAMEPAD_START);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadBack, XINPUT_GAMEPAD_BACK);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadFaceLeft, XINPUT_GAMEPAD_X);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadFaceRight, XINPUT_GAMEPAD_B);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadFaceUp, XINPUT_GAMEPAD_Y);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadFaceDown, XINPUT_GAMEPAD_A);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadDpadLeft, XINPUT_GAMEPAD_DPAD_LEFT);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadDpadRight, XINPUT_GAMEPAD_DPAD_RIGHT);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadDpadUp, XINPUT_GAMEPAD_DPAD_UP);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadDpadDown, XINPUT_GAMEPAD_DPAD_DOWN);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadL1, XINPUT_GAMEPAD_LEFT_SHOULDER);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadR1, XINPUT_GAMEPAD_RIGHT_SHOULDER);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadL2, gamepad.bLeftTrigger, XINPUT_GAMEPAD_TRIGGER_THRESHOLD, 255);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadR2, gamepad.bRightTrigger, XINPUT_GAMEPAD_TRIGGER_THRESHOLD, 255);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadL3, XINPUT_GAMEPAD_LEFT_THUMB);
|
||||||
|
MAP_BUTTON(ImGuiKey_GamepadR3, XINPUT_GAMEPAD_RIGHT_THUMB);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadLStickLeft, gamepad.sThumbLX, -XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE, -32768);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadLStickRight, gamepad.sThumbLX, +XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE, +32767);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadLStickUp, gamepad.sThumbLY, +XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE, +32767);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadLStickDown, gamepad.sThumbLY, -XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE, -32768);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadRStickLeft, gamepad.sThumbRX, -XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE, -32768);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadRStickRight, gamepad.sThumbRX, +XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE, +32767);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadRStickUp, gamepad.sThumbRY, +XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE, +32767);
|
||||||
|
MAP_ANALOG(ImGuiKey_GamepadRStickDown, gamepad.sThumbRY, -XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE, -32768);
|
||||||
|
#undef MAP_BUTTON
|
||||||
|
#undef MAP_ANALOG
|
||||||
|
#endif // #ifndef IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImGui_ImplWin32_NewFrame()
|
||||||
|
{
|
||||||
|
ImGui_ImplWin32_Data* bd = ImGui_ImplWin32_GetBackendData();
|
||||||
|
IM_ASSERT(bd != nullptr && "Context or backend not initialized? Did you call ImGui_ImplWin32_Init()?");
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
|
||||||
|
// Setup display size (every frame to accommodate for window resizing)
|
||||||
|
RECT rect = { 0, 0, 0, 0 };
|
||||||
|
::GetClientRect(bd->hWnd, &rect);
|
||||||
|
io.DisplaySize = ImVec2((float)(rect.right - rect.left), (float)(rect.bottom - rect.top));
|
||||||
|
|
||||||
|
// Setup time step
|
||||||
|
INT64 current_time = 0;
|
||||||
|
::QueryPerformanceCounter((LARGE_INTEGER*)¤t_time);
|
||||||
|
io.DeltaTime = (float)(current_time - bd->Time) / bd->TicksPerSecond;
|
||||||
|
bd->Time = current_time;
|
||||||
|
|
||||||
|
// Update OS mouse position
|
||||||
|
ImGui_ImplWin32_UpdateMouseData();
|
||||||
|
|
||||||
|
// Process workarounds for known Windows key handling issues
|
||||||
|
ImGui_ImplWin32_ProcessKeyEventsWorkarounds();
|
||||||
|
|
||||||
|
// Update OS mouse cursor with the cursor requested by imgui
|
||||||
|
ImGuiMouseCursor mouse_cursor = io.MouseDrawCursor ? ImGuiMouseCursor_None : ImGui::GetMouseCursor();
|
||||||
|
if (bd->LastMouseCursor != mouse_cursor)
|
||||||
|
{
|
||||||
|
bd->LastMouseCursor = mouse_cursor;
|
||||||
|
ImGui_ImplWin32_UpdateMouseCursor();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update game controllers (if enabled and available)
|
||||||
|
ImGui_ImplWin32_UpdateGamepads();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Map VK_xxx to ImGuiKey_xxx.
|
||||||
|
// Not static to allow third-party code to use that if they want to (but undocumented)
|
||||||
|
ImGuiKey ImGui_ImplWin32_KeyEventToImGuiKey(WPARAM wParam, LPARAM lParam)
|
||||||
|
{
|
||||||
|
// There is no distinct VK_xxx for keypad enter, instead it is VK_RETURN + KF_EXTENDED.
|
||||||
|
if ((wParam == VK_RETURN) && (HIWORD(lParam) & KF_EXTENDED))
|
||||||
|
return ImGuiKey_KeypadEnter;
|
||||||
|
|
||||||
|
switch (wParam)
|
||||||
|
{
|
||||||
|
case VK_TAB: return ImGuiKey_Tab;
|
||||||
|
case VK_LEFT: return ImGuiKey_LeftArrow;
|
||||||
|
case VK_RIGHT: return ImGuiKey_RightArrow;
|
||||||
|
case VK_UP: return ImGuiKey_UpArrow;
|
||||||
|
case VK_DOWN: return ImGuiKey_DownArrow;
|
||||||
|
case VK_PRIOR: return ImGuiKey_PageUp;
|
||||||
|
case VK_NEXT: return ImGuiKey_PageDown;
|
||||||
|
case VK_HOME: return ImGuiKey_Home;
|
||||||
|
case VK_END: return ImGuiKey_End;
|
||||||
|
case VK_INSERT: return ImGuiKey_Insert;
|
||||||
|
case VK_DELETE: return ImGuiKey_Delete;
|
||||||
|
case VK_BACK: return ImGuiKey_Backspace;
|
||||||
|
case VK_SPACE: return ImGuiKey_Space;
|
||||||
|
case VK_RETURN: return ImGuiKey_Enter;
|
||||||
|
case VK_ESCAPE: return ImGuiKey_Escape;
|
||||||
|
case VK_OEM_7: return ImGuiKey_Apostrophe;
|
||||||
|
case VK_OEM_COMMA: return ImGuiKey_Comma;
|
||||||
|
case VK_OEM_MINUS: return ImGuiKey_Minus;
|
||||||
|
case VK_OEM_PERIOD: return ImGuiKey_Period;
|
||||||
|
case VK_OEM_2: return ImGuiKey_Slash;
|
||||||
|
case VK_OEM_1: return ImGuiKey_Semicolon;
|
||||||
|
case VK_OEM_PLUS: return ImGuiKey_Equal;
|
||||||
|
case VK_OEM_4: return ImGuiKey_LeftBracket;
|
||||||
|
case VK_OEM_5: return ImGuiKey_Backslash;
|
||||||
|
case VK_OEM_6: return ImGuiKey_RightBracket;
|
||||||
|
case VK_OEM_3: return ImGuiKey_GraveAccent;
|
||||||
|
case VK_CAPITAL: return ImGuiKey_CapsLock;
|
||||||
|
case VK_SCROLL: return ImGuiKey_ScrollLock;
|
||||||
|
case VK_NUMLOCK: return ImGuiKey_NumLock;
|
||||||
|
case VK_SNAPSHOT: return ImGuiKey_PrintScreen;
|
||||||
|
case VK_PAUSE: return ImGuiKey_Pause;
|
||||||
|
case VK_NUMPAD0: return ImGuiKey_Keypad0;
|
||||||
|
case VK_NUMPAD1: return ImGuiKey_Keypad1;
|
||||||
|
case VK_NUMPAD2: return ImGuiKey_Keypad2;
|
||||||
|
case VK_NUMPAD3: return ImGuiKey_Keypad3;
|
||||||
|
case VK_NUMPAD4: return ImGuiKey_Keypad4;
|
||||||
|
case VK_NUMPAD5: return ImGuiKey_Keypad5;
|
||||||
|
case VK_NUMPAD6: return ImGuiKey_Keypad6;
|
||||||
|
case VK_NUMPAD7: return ImGuiKey_Keypad7;
|
||||||
|
case VK_NUMPAD8: return ImGuiKey_Keypad8;
|
||||||
|
case VK_NUMPAD9: return ImGuiKey_Keypad9;
|
||||||
|
case VK_DECIMAL: return ImGuiKey_KeypadDecimal;
|
||||||
|
case VK_DIVIDE: return ImGuiKey_KeypadDivide;
|
||||||
|
case VK_MULTIPLY: return ImGuiKey_KeypadMultiply;
|
||||||
|
case VK_SUBTRACT: return ImGuiKey_KeypadSubtract;
|
||||||
|
case VK_ADD: return ImGuiKey_KeypadAdd;
|
||||||
|
case VK_LSHIFT: return ImGuiKey_LeftShift;
|
||||||
|
case VK_LCONTROL: return ImGuiKey_LeftCtrl;
|
||||||
|
case VK_LMENU: return ImGuiKey_LeftAlt;
|
||||||
|
case VK_LWIN: return ImGuiKey_LeftSuper;
|
||||||
|
case VK_RSHIFT: return ImGuiKey_RightShift;
|
||||||
|
case VK_RCONTROL: return ImGuiKey_RightCtrl;
|
||||||
|
case VK_RMENU: return ImGuiKey_RightAlt;
|
||||||
|
case VK_RWIN: return ImGuiKey_RightSuper;
|
||||||
|
case VK_APPS: return ImGuiKey_Menu;
|
||||||
|
case '0': return ImGuiKey_0;
|
||||||
|
case '1': return ImGuiKey_1;
|
||||||
|
case '2': return ImGuiKey_2;
|
||||||
|
case '3': return ImGuiKey_3;
|
||||||
|
case '4': return ImGuiKey_4;
|
||||||
|
case '5': return ImGuiKey_5;
|
||||||
|
case '6': return ImGuiKey_6;
|
||||||
|
case '7': return ImGuiKey_7;
|
||||||
|
case '8': return ImGuiKey_8;
|
||||||
|
case '9': return ImGuiKey_9;
|
||||||
|
case 'A': return ImGuiKey_A;
|
||||||
|
case 'B': return ImGuiKey_B;
|
||||||
|
case 'C': return ImGuiKey_C;
|
||||||
|
case 'D': return ImGuiKey_D;
|
||||||
|
case 'E': return ImGuiKey_E;
|
||||||
|
case 'F': return ImGuiKey_F;
|
||||||
|
case 'G': return ImGuiKey_G;
|
||||||
|
case 'H': return ImGuiKey_H;
|
||||||
|
case 'I': return ImGuiKey_I;
|
||||||
|
case 'J': return ImGuiKey_J;
|
||||||
|
case 'K': return ImGuiKey_K;
|
||||||
|
case 'L': return ImGuiKey_L;
|
||||||
|
case 'M': return ImGuiKey_M;
|
||||||
|
case 'N': return ImGuiKey_N;
|
||||||
|
case 'O': return ImGuiKey_O;
|
||||||
|
case 'P': return ImGuiKey_P;
|
||||||
|
case 'Q': return ImGuiKey_Q;
|
||||||
|
case 'R': return ImGuiKey_R;
|
||||||
|
case 'S': return ImGuiKey_S;
|
||||||
|
case 'T': return ImGuiKey_T;
|
||||||
|
case 'U': return ImGuiKey_U;
|
||||||
|
case 'V': return ImGuiKey_V;
|
||||||
|
case 'W': return ImGuiKey_W;
|
||||||
|
case 'X': return ImGuiKey_X;
|
||||||
|
case 'Y': return ImGuiKey_Y;
|
||||||
|
case 'Z': return ImGuiKey_Z;
|
||||||
|
case VK_F1: return ImGuiKey_F1;
|
||||||
|
case VK_F2: return ImGuiKey_F2;
|
||||||
|
case VK_F3: return ImGuiKey_F3;
|
||||||
|
case VK_F4: return ImGuiKey_F4;
|
||||||
|
case VK_F5: return ImGuiKey_F5;
|
||||||
|
case VK_F6: return ImGuiKey_F6;
|
||||||
|
case VK_F7: return ImGuiKey_F7;
|
||||||
|
case VK_F8: return ImGuiKey_F8;
|
||||||
|
case VK_F9: return ImGuiKey_F9;
|
||||||
|
case VK_F10: return ImGuiKey_F10;
|
||||||
|
case VK_F11: return ImGuiKey_F11;
|
||||||
|
case VK_F12: return ImGuiKey_F12;
|
||||||
|
case VK_F13: return ImGuiKey_F13;
|
||||||
|
case VK_F14: return ImGuiKey_F14;
|
||||||
|
case VK_F15: return ImGuiKey_F15;
|
||||||
|
case VK_F16: return ImGuiKey_F16;
|
||||||
|
case VK_F17: return ImGuiKey_F17;
|
||||||
|
case VK_F18: return ImGuiKey_F18;
|
||||||
|
case VK_F19: return ImGuiKey_F19;
|
||||||
|
case VK_F20: return ImGuiKey_F20;
|
||||||
|
case VK_F21: return ImGuiKey_F21;
|
||||||
|
case VK_F22: return ImGuiKey_F22;
|
||||||
|
case VK_F23: return ImGuiKey_F23;
|
||||||
|
case VK_F24: return ImGuiKey_F24;
|
||||||
|
case VK_BROWSER_BACK: return ImGuiKey_AppBack;
|
||||||
|
case VK_BROWSER_FORWARD: return ImGuiKey_AppForward;
|
||||||
|
default: return ImGuiKey_None;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Allow compilation with old Windows SDK. MinGW doesn't have default _WIN32_WINNT/WINVER versions.
|
||||||
|
#ifndef WM_MOUSEHWHEEL
|
||||||
|
#define WM_MOUSEHWHEEL 0x020E
|
||||||
|
#endif
|
||||||
|
#ifndef DBT_DEVNODES_CHANGED
|
||||||
|
#define DBT_DEVNODES_CHANGED 0x0007
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Win32 message handler (process Win32 mouse/keyboard inputs, etc.)
|
||||||
|
// Call from your application's message handler. Keep calling your message handler unless this function returns TRUE.
|
||||||
|
// When implementing your own backend, you can read the io.WantCaptureMouse, io.WantCaptureKeyboard flags to tell if Dear ImGui wants to use your inputs.
|
||||||
|
// - When io.WantCaptureMouse is true, do not dispatch mouse input data to your main application, or clear/overwrite your copy of the mouse data.
|
||||||
|
// - When io.WantCaptureKeyboard is true, do not dispatch keyboard input data to your main application, or clear/overwrite your copy of the keyboard data.
|
||||||
|
// Generally you may always pass all inputs to Dear ImGui, and hide them from your application based on those two flags.
|
||||||
|
// PS: In this Win32 handler, we use the capture API (GetCapture/SetCapture/ReleaseCapture) to be able to read mouse coordinates when dragging mouse outside of our window bounds.
|
||||||
|
// PS: We treat DBLCLK messages as regular mouse down messages, so this code will work on windows classes that have the CS_DBLCLKS flag set. Our own example app code doesn't set this flag.
|
||||||
|
#if 0
|
||||||
|
// Copy this line into your .cpp file to forward declare the function.
|
||||||
|
extern IMGUI_IMPL_API LRESULT ImGui_ImplWin32_WndProcHandler(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// See https://learn.microsoft.com/en-us/windows/win32/tablet/system-events-and-mouse-messages
|
||||||
|
// Prefer to call this at the top of the message handler to avoid the possibility of other Win32 calls interfering with this.
|
||||||
|
static ImGuiMouseSource GetMouseSourceFromMessageExtraInfo()
|
||||||
|
{
|
||||||
|
LPARAM extra_info = ::GetMessageExtraInfo();
|
||||||
|
if ((extra_info & 0xFFFFFF80) == 0xFF515700)
|
||||||
|
return ImGuiMouseSource_Pen;
|
||||||
|
if ((extra_info & 0xFFFFFF80) == 0xFF515780)
|
||||||
|
return ImGuiMouseSource_TouchScreen;
|
||||||
|
return ImGuiMouseSource_Mouse;
|
||||||
|
}
|
||||||
|
|
||||||
|
IMGUI_IMPL_API LRESULT ImGui_ImplWin32_WndProcHandler(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
|
{
|
||||||
|
// Most backends don't have silent checks like this one, but we need it because WndProc are called early in CreateWindow().
|
||||||
|
// We silently allow both context or just only backend data to be nullptr.
|
||||||
|
ImGui_ImplWin32_Data* bd = ImGui_ImplWin32_GetBackendData();
|
||||||
|
if (bd == nullptr)
|
||||||
|
return 0;
|
||||||
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
|
||||||
|
switch (msg)
|
||||||
|
{
|
||||||
|
case WM_MOUSEMOVE:
|
||||||
|
case WM_NCMOUSEMOVE:
|
||||||
|
{
|
||||||
|
// We need to call TrackMouseEvent in order to receive WM_MOUSELEAVE events
|
||||||
|
ImGuiMouseSource mouse_source = GetMouseSourceFromMessageExtraInfo();
|
||||||
|
const int area = (msg == WM_MOUSEMOVE) ? 1 : 2;
|
||||||
|
bd->MouseHwnd = hwnd;
|
||||||
|
if (bd->MouseTrackedArea != area)
|
||||||
|
{
|
||||||
|
TRACKMOUSEEVENT tme_cancel = { sizeof(tme_cancel), TME_CANCEL, hwnd, 0 };
|
||||||
|
TRACKMOUSEEVENT tme_track = { sizeof(tme_track), (DWORD)((area == 2) ? (TME_LEAVE | TME_NONCLIENT) : TME_LEAVE), hwnd, 0 };
|
||||||
|
if (bd->MouseTrackedArea != 0)
|
||||||
|
::TrackMouseEvent(&tme_cancel);
|
||||||
|
::TrackMouseEvent(&tme_track);
|
||||||
|
bd->MouseTrackedArea = area;
|
||||||
|
}
|
||||||
|
POINT mouse_pos = { (LONG)GET_X_LPARAM(lParam), (LONG)GET_Y_LPARAM(lParam) };
|
||||||
|
if (msg == WM_NCMOUSEMOVE && ::ScreenToClient(hwnd, &mouse_pos) == FALSE) // WM_NCMOUSEMOVE are provided in absolute coordinates.
|
||||||
|
return 0;
|
||||||
|
io.AddMouseSourceEvent(mouse_source);
|
||||||
|
io.AddMousePosEvent((float)mouse_pos.x, (float)mouse_pos.y);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
case WM_MOUSELEAVE:
|
||||||
|
case WM_NCMOUSELEAVE:
|
||||||
|
{
|
||||||
|
const int area = (msg == WM_MOUSELEAVE) ? 1 : 2;
|
||||||
|
if (bd->MouseTrackedArea == area)
|
||||||
|
{
|
||||||
|
if (bd->MouseHwnd == hwnd)
|
||||||
|
bd->MouseHwnd = nullptr;
|
||||||
|
bd->MouseTrackedArea = 0;
|
||||||
|
io.AddMousePosEvent(-FLT_MAX, -FLT_MAX);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
case WM_DESTROY:
|
||||||
|
if (bd->MouseHwnd == hwnd && bd->MouseTrackedArea != 0)
|
||||||
|
{
|
||||||
|
TRACKMOUSEEVENT tme_cancel = { sizeof(tme_cancel), TME_CANCEL, hwnd, 0 };
|
||||||
|
::TrackMouseEvent(&tme_cancel);
|
||||||
|
bd->MouseHwnd = nullptr;
|
||||||
|
bd->MouseTrackedArea = 0;
|
||||||
|
io.AddMousePosEvent(-FLT_MAX, -FLT_MAX);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
case WM_LBUTTONDOWN: case WM_LBUTTONDBLCLK:
|
||||||
|
case WM_RBUTTONDOWN: case WM_RBUTTONDBLCLK:
|
||||||
|
case WM_MBUTTONDOWN: case WM_MBUTTONDBLCLK:
|
||||||
|
case WM_XBUTTONDOWN: case WM_XBUTTONDBLCLK:
|
||||||
|
{
|
||||||
|
ImGuiMouseSource mouse_source = GetMouseSourceFromMessageExtraInfo();
|
||||||
|
int button = 0;
|
||||||
|
if (msg == WM_LBUTTONDOWN || msg == WM_LBUTTONDBLCLK) { button = 0; }
|
||||||
|
if (msg == WM_RBUTTONDOWN || msg == WM_RBUTTONDBLCLK) { button = 1; }
|
||||||
|
if (msg == WM_MBUTTONDOWN || msg == WM_MBUTTONDBLCLK) { button = 2; }
|
||||||
|
if (msg == WM_XBUTTONDOWN || msg == WM_XBUTTONDBLCLK) { button = (GET_XBUTTON_WPARAM(wParam) == XBUTTON1) ? 3 : 4; }
|
||||||
|
if (bd->MouseButtonsDown == 0 && ::GetCapture() == nullptr)
|
||||||
|
::SetCapture(hwnd);
|
||||||
|
bd->MouseButtonsDown |= 1 << button;
|
||||||
|
io.AddMouseSourceEvent(mouse_source);
|
||||||
|
io.AddMouseButtonEvent(button, true);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
case WM_LBUTTONUP:
|
||||||
|
case WM_RBUTTONUP:
|
||||||
|
case WM_MBUTTONUP:
|
||||||
|
case WM_XBUTTONUP:
|
||||||
|
{
|
||||||
|
ImGuiMouseSource mouse_source = GetMouseSourceFromMessageExtraInfo();
|
||||||
|
int button = 0;
|
||||||
|
if (msg == WM_LBUTTONUP) { button = 0; }
|
||||||
|
if (msg == WM_RBUTTONUP) { button = 1; }
|
||||||
|
if (msg == WM_MBUTTONUP) { button = 2; }
|
||||||
|
if (msg == WM_XBUTTONUP) { button = (GET_XBUTTON_WPARAM(wParam) == XBUTTON1) ? 3 : 4; }
|
||||||
|
bd->MouseButtonsDown &= ~(1 << button);
|
||||||
|
if (bd->MouseButtonsDown == 0 && ::GetCapture() == hwnd)
|
||||||
|
::ReleaseCapture();
|
||||||
|
io.AddMouseSourceEvent(mouse_source);
|
||||||
|
io.AddMouseButtonEvent(button, false);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
case WM_MOUSEWHEEL:
|
||||||
|
io.AddMouseWheelEvent(0.0f, (float)GET_WHEEL_DELTA_WPARAM(wParam) / (float)WHEEL_DELTA);
|
||||||
|
return 0;
|
||||||
|
case WM_MOUSEHWHEEL:
|
||||||
|
io.AddMouseWheelEvent(-(float)GET_WHEEL_DELTA_WPARAM(wParam) / (float)WHEEL_DELTA, 0.0f);
|
||||||
|
return 0;
|
||||||
|
case WM_KEYDOWN:
|
||||||
|
case WM_KEYUP:
|
||||||
|
case WM_SYSKEYDOWN:
|
||||||
|
case WM_SYSKEYUP:
|
||||||
|
{
|
||||||
|
const bool is_key_down = (msg == WM_KEYDOWN || msg == WM_SYSKEYDOWN);
|
||||||
|
if (wParam < 256)
|
||||||
|
{
|
||||||
|
// Submit modifiers
|
||||||
|
ImGui_ImplWin32_UpdateKeyModifiers();
|
||||||
|
|
||||||
|
// Obtain virtual key code and convert to ImGuiKey
|
||||||
|
const ImGuiKey key = ImGui_ImplWin32_KeyEventToImGuiKey(wParam, lParam);
|
||||||
|
const int vk = (int)wParam;
|
||||||
|
const int scancode = (int)LOBYTE(HIWORD(lParam));
|
||||||
|
|
||||||
|
// Special behavior for VK_SNAPSHOT / ImGuiKey_PrintScreen as Windows doesn't emit the key down event.
|
||||||
|
if (key == ImGuiKey_PrintScreen && !is_key_down)
|
||||||
|
ImGui_ImplWin32_AddKeyEvent(key, true, vk, scancode);
|
||||||
|
|
||||||
|
// Submit key event
|
||||||
|
if (key != ImGuiKey_None)
|
||||||
|
ImGui_ImplWin32_AddKeyEvent(key, is_key_down, vk, scancode);
|
||||||
|
|
||||||
|
// Submit individual left/right modifier events
|
||||||
|
if (vk == VK_SHIFT)
|
||||||
|
{
|
||||||
|
// Important: Shift keys tend to get stuck when pressed together, missing key-up events are corrected in ImGui_ImplWin32_ProcessKeyEventsWorkarounds()
|
||||||
|
if (IsVkDown(VK_LSHIFT) == is_key_down) { ImGui_ImplWin32_AddKeyEvent(ImGuiKey_LeftShift, is_key_down, VK_LSHIFT, scancode); }
|
||||||
|
if (IsVkDown(VK_RSHIFT) == is_key_down) { ImGui_ImplWin32_AddKeyEvent(ImGuiKey_RightShift, is_key_down, VK_RSHIFT, scancode); }
|
||||||
|
}
|
||||||
|
else if (vk == VK_CONTROL)
|
||||||
|
{
|
||||||
|
if (IsVkDown(VK_LCONTROL) == is_key_down) { ImGui_ImplWin32_AddKeyEvent(ImGuiKey_LeftCtrl, is_key_down, VK_LCONTROL, scancode); }
|
||||||
|
if (IsVkDown(VK_RCONTROL) == is_key_down) { ImGui_ImplWin32_AddKeyEvent(ImGuiKey_RightCtrl, is_key_down, VK_RCONTROL, scancode); }
|
||||||
|
}
|
||||||
|
else if (vk == VK_MENU)
|
||||||
|
{
|
||||||
|
if (IsVkDown(VK_LMENU) == is_key_down) { ImGui_ImplWin32_AddKeyEvent(ImGuiKey_LeftAlt, is_key_down, VK_LMENU, scancode); }
|
||||||
|
if (IsVkDown(VK_RMENU) == is_key_down) { ImGui_ImplWin32_AddKeyEvent(ImGuiKey_RightAlt, is_key_down, VK_RMENU, scancode); }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
case WM_SETFOCUS:
|
||||||
|
case WM_KILLFOCUS:
|
||||||
|
io.AddFocusEvent(msg == WM_SETFOCUS);
|
||||||
|
return 0;
|
||||||
|
case WM_INPUTLANGCHANGE:
|
||||||
|
ImGui_ImplWin32_UpdateKeyboardCodePage();
|
||||||
|
return 0;
|
||||||
|
case WM_CHAR:
|
||||||
|
if (::IsWindowUnicode(hwnd))
|
||||||
|
{
|
||||||
|
// You can also use ToAscii()+GetKeyboardState() to retrieve characters.
|
||||||
|
if (wParam > 0 && wParam < 0x10000)
|
||||||
|
io.AddInputCharacterUTF16((unsigned short)wParam);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wchar_t wch = 0;
|
||||||
|
::MultiByteToWideChar(bd->KeyboardCodePage, MB_PRECOMPOSED, (char*)&wParam, 1, &wch, 1);
|
||||||
|
io.AddInputCharacter(wch);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
case WM_SETCURSOR:
|
||||||
|
// This is required to restore cursor when transitioning from e.g resize borders to client area.
|
||||||
|
if (LOWORD(lParam) == HTCLIENT && ImGui_ImplWin32_UpdateMouseCursor())
|
||||||
|
return 1;
|
||||||
|
return 0;
|
||||||
|
case WM_DEVICECHANGE:
|
||||||
|
#ifndef IMGUI_IMPL_WIN32_DISABLE_GAMEPAD
|
||||||
|
if ((UINT)wParam == DBT_DEVNODES_CHANGED)
|
||||||
|
bd->WantUpdateHasGamepad = true;
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------------
|
||||||
|
// DPI-related helpers (optional)
|
||||||
|
//--------------------------------------------------------------------------------------------------------
|
||||||
|
// - Use to enable DPI awareness without having to create an application manifest.
|
||||||
|
// - Your own app may already do this via a manifest or explicit calls. This is mostly useful for our examples/ apps.
|
||||||
|
// - In theory we could call simple functions from Windows SDK such as SetProcessDPIAware(), SetProcessDpiAwareness(), etc.
|
||||||
|
// but most of the functions provided by Microsoft require Windows 8.1/10+ SDK at compile time and Windows 8/10+ at runtime,
|
||||||
|
// neither we want to require the user to have. So we dynamically select and load those functions to avoid dependencies.
|
||||||
|
//---------------------------------------------------------------------------------------------------------
|
||||||
|
// This is the scheme successfully used by GLFW (from which we borrowed some of the code) and other apps aiming to be highly portable.
|
||||||
|
// ImGui_ImplWin32_EnableDpiAwareness() is just a helper called by main.cpp, we don't call it automatically.
|
||||||
|
// If you are trying to implement your own backend for your own engine, you may ignore that noise.
|
||||||
|
//---------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// Perform our own check with RtlVerifyVersionInfo() instead of using functions from <VersionHelpers.h> as they
|
||||||
|
// require a manifest to be functional for checks above 8.1. See https://github.com/ocornut/imgui/issues/4200
|
||||||
|
static BOOL _IsWindowsVersionOrGreater(WORD major, WORD minor, WORD)
|
||||||
|
{
|
||||||
|
typedef LONG(WINAPI* PFN_RtlVerifyVersionInfo)(OSVERSIONINFOEXW*, ULONG, ULONGLONG);
|
||||||
|
static PFN_RtlVerifyVersionInfo RtlVerifyVersionInfoFn = nullptr;
|
||||||
|
if (RtlVerifyVersionInfoFn == nullptr)
|
||||||
|
if (HMODULE ntdllModule = ::GetModuleHandleA("ntdll.dll"))
|
||||||
|
RtlVerifyVersionInfoFn = (PFN_RtlVerifyVersionInfo)GetProcAddress(ntdllModule, "RtlVerifyVersionInfo");
|
||||||
|
if (RtlVerifyVersionInfoFn == nullptr)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
RTL_OSVERSIONINFOEXW versionInfo = { };
|
||||||
|
ULONGLONG conditionMask = 0;
|
||||||
|
versionInfo.dwOSVersionInfoSize = sizeof(RTL_OSVERSIONINFOEXW);
|
||||||
|
versionInfo.dwMajorVersion = major;
|
||||||
|
versionInfo.dwMinorVersion = minor;
|
||||||
|
VER_SET_CONDITION(conditionMask, VER_MAJORVERSION, VER_GREATER_EQUAL);
|
||||||
|
VER_SET_CONDITION(conditionMask, VER_MINORVERSION, VER_GREATER_EQUAL);
|
||||||
|
return (RtlVerifyVersionInfoFn(&versionInfo, VER_MAJORVERSION | VER_MINORVERSION, conditionMask) == 0) ? TRUE : FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define _IsWindowsVistaOrGreater() _IsWindowsVersionOrGreater(HIBYTE(0x0600), LOBYTE(0x0600), 0) // _WIN32_WINNT_VISTA
|
||||||
|
#define _IsWindows8OrGreater() _IsWindowsVersionOrGreater(HIBYTE(0x0602), LOBYTE(0x0602), 0) // _WIN32_WINNT_WIN8
|
||||||
|
#define _IsWindows8Point1OrGreater() _IsWindowsVersionOrGreater(HIBYTE(0x0603), LOBYTE(0x0603), 0) // _WIN32_WINNT_WINBLUE
|
||||||
|
#define _IsWindows10OrGreater() _IsWindowsVersionOrGreater(HIBYTE(0x0A00), LOBYTE(0x0A00), 0) // _WIN32_WINNT_WINTHRESHOLD / _WIN32_WINNT_WIN10
|
||||||
|
|
||||||
|
#ifndef DPI_ENUMS_DECLARED
|
||||||
|
typedef enum { PROCESS_DPI_UNAWARE = 0, PROCESS_SYSTEM_DPI_AWARE = 1, PROCESS_PER_MONITOR_DPI_AWARE = 2 } PROCESS_DPI_AWARENESS;
|
||||||
|
typedef enum { MDT_EFFECTIVE_DPI = 0, MDT_ANGULAR_DPI = 1, MDT_RAW_DPI = 2, MDT_DEFAULT = MDT_EFFECTIVE_DPI } MONITOR_DPI_TYPE;
|
||||||
|
#endif
|
||||||
|
#ifndef _DPI_AWARENESS_CONTEXTS_
|
||||||
|
DECLARE_HANDLE(DPI_AWARENESS_CONTEXT);
|
||||||
|
#define DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE (DPI_AWARENESS_CONTEXT)-3
|
||||||
|
#endif
|
||||||
|
#ifndef DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2
|
||||||
|
#define DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2 (DPI_AWARENESS_CONTEXT)-4
|
||||||
|
#endif
|
||||||
|
typedef HRESULT(WINAPI* PFN_SetProcessDpiAwareness)(PROCESS_DPI_AWARENESS); // Shcore.lib + dll, Windows 8.1+
|
||||||
|
typedef HRESULT(WINAPI* PFN_GetDpiForMonitor)(HMONITOR, MONITOR_DPI_TYPE, UINT*, UINT*); // Shcore.lib + dll, Windows 8.1+
|
||||||
|
typedef DPI_AWARENESS_CONTEXT(WINAPI* PFN_SetThreadDpiAwarenessContext)(DPI_AWARENESS_CONTEXT); // User32.lib + dll, Windows 10 v1607+ (Creators Update)
|
||||||
|
|
||||||
|
// Helper function to enable DPI awareness without setting up a manifest
|
||||||
|
void ImGui_ImplWin32_EnableDpiAwareness()
|
||||||
|
{
|
||||||
|
if (_IsWindows10OrGreater())
|
||||||
|
{
|
||||||
|
static HINSTANCE user32_dll = ::LoadLibraryA("user32.dll"); // Reference counted per-process
|
||||||
|
if (PFN_SetThreadDpiAwarenessContext SetThreadDpiAwarenessContextFn = (PFN_SetThreadDpiAwarenessContext)::GetProcAddress(user32_dll, "SetThreadDpiAwarenessContext"))
|
||||||
|
{
|
||||||
|
SetThreadDpiAwarenessContextFn(DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (_IsWindows8Point1OrGreater())
|
||||||
|
{
|
||||||
|
static HINSTANCE shcore_dll = ::LoadLibraryA("shcore.dll"); // Reference counted per-process
|
||||||
|
if (PFN_SetProcessDpiAwareness SetProcessDpiAwarenessFn = (PFN_SetProcessDpiAwareness)::GetProcAddress(shcore_dll, "SetProcessDpiAwareness"))
|
||||||
|
{
|
||||||
|
SetProcessDpiAwarenessFn(PROCESS_PER_MONITOR_DPI_AWARE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#if _WIN32_WINNT >= 0x0600
|
||||||
|
::SetProcessDPIAware();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(_MSC_VER) && !defined(NOGDI)
|
||||||
|
#pragma comment(lib, "gdi32") // Link with gdi32.lib for GetDeviceCaps(). MinGW will require linking with '-lgdi32'
|
||||||
|
#endif
|
||||||
|
|
||||||
|
float ImGui_ImplWin32_GetDpiScaleForMonitor(void* monitor)
|
||||||
|
{
|
||||||
|
UINT xdpi = 96, ydpi = 96;
|
||||||
|
if (_IsWindows8Point1OrGreater())
|
||||||
|
{
|
||||||
|
static HINSTANCE shcore_dll = ::LoadLibraryA("shcore.dll"); // Reference counted per-process
|
||||||
|
static PFN_GetDpiForMonitor GetDpiForMonitorFn = nullptr;
|
||||||
|
if (GetDpiForMonitorFn == nullptr && shcore_dll != nullptr)
|
||||||
|
GetDpiForMonitorFn = (PFN_GetDpiForMonitor)::GetProcAddress(shcore_dll, "GetDpiForMonitor");
|
||||||
|
if (GetDpiForMonitorFn != nullptr)
|
||||||
|
{
|
||||||
|
GetDpiForMonitorFn((HMONITOR)monitor, MDT_EFFECTIVE_DPI, &xdpi, &ydpi);
|
||||||
|
IM_ASSERT(xdpi == ydpi); // Please contact me if you hit this assert!
|
||||||
|
return xdpi / 96.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#ifndef NOGDI
|
||||||
|
const HDC dc = ::GetDC(nullptr);
|
||||||
|
xdpi = ::GetDeviceCaps(dc, LOGPIXELSX);
|
||||||
|
ydpi = ::GetDeviceCaps(dc, LOGPIXELSY);
|
||||||
|
IM_ASSERT(xdpi == ydpi); // Please contact me if you hit this assert!
|
||||||
|
::ReleaseDC(nullptr, dc);
|
||||||
|
#endif
|
||||||
|
return xdpi / 96.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
float ImGui_ImplWin32_GetDpiScaleForHwnd(void* hwnd)
|
||||||
|
{
|
||||||
|
HMONITOR monitor = ::MonitorFromWindow((HWND)hwnd, MONITOR_DEFAULTTONEAREST);
|
||||||
|
return ImGui_ImplWin32_GetDpiScaleForMonitor(monitor);
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------
|
||||||
|
// Transparency related helpers (optional)
|
||||||
|
//--------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#if defined(_MSC_VER)
|
||||||
|
#pragma comment(lib, "dwmapi") // Link with dwmapi.lib. MinGW will require linking with '-ldwmapi'
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// [experimental]
|
||||||
|
// Borrowed from GLFW's function updateFramebufferTransparency() in src/win32_window.c
|
||||||
|
// (the Dwm* functions are Vista era functions but we are borrowing logic from GLFW)
|
||||||
|
void ImGui_ImplWin32_EnableAlphaCompositing(void* hwnd)
|
||||||
|
{
|
||||||
|
if (!_IsWindowsVistaOrGreater())
|
||||||
|
return;
|
||||||
|
|
||||||
|
BOOL composition;
|
||||||
|
if (FAILED(::DwmIsCompositionEnabled(&composition)) || !composition)
|
||||||
|
return;
|
||||||
|
|
||||||
|
BOOL opaque;
|
||||||
|
DWORD color;
|
||||||
|
if (_IsWindows8OrGreater() || (SUCCEEDED(::DwmGetColorizationColor(&color, &opaque)) && !opaque))
|
||||||
|
{
|
||||||
|
HRGN region = ::CreateRectRgn(0, 0, -1, -1);
|
||||||
|
DWM_BLURBEHIND bb = {};
|
||||||
|
bb.dwFlags = DWM_BB_ENABLE | DWM_BB_BLURREGION;
|
||||||
|
bb.hRgnBlur = region;
|
||||||
|
bb.fEnable = TRUE;
|
||||||
|
::DwmEnableBlurBehindWindow((HWND)hwnd, &bb);
|
||||||
|
::DeleteObject(region);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
DWM_BLURBEHIND bb = {};
|
||||||
|
bb.dwFlags = DWM_BB_ENABLE;
|
||||||
|
::DwmEnableBlurBehindWindow((HWND)hwnd, &bb);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#if defined(__GNUC__)
|
||||||
|
#pragma GCC diagnostic pop
|
||||||
|
#endif
|
||||||
|
#if defined(__clang__)
|
||||||
|
#pragma clang diagnostic pop
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // #ifndef IMGUI_DISABLE
|
||||||
@@ -0,0 +1,52 @@
|
|||||||
|
// dear imgui: Platform Backend for Windows (standard windows API for 32-bits AND 64-bits applications)
|
||||||
|
// This needs to be used along with a Renderer (e.g. DirectX11, OpenGL3, Vulkan..)
|
||||||
|
|
||||||
|
// Implemented features:
|
||||||
|
// [X] Platform: Clipboard support (for Win32 this is actually part of core dear imgui)
|
||||||
|
// [X] Platform: Mouse support. Can discriminate Mouse/TouchScreen/Pen.
|
||||||
|
// [X] Platform: Keyboard support. Since 1.87 we are using the io.AddKeyEvent() function. Pass ImGuiKey values to all key functions e.g. ImGui::IsKeyPressed(ImGuiKey_Space). [Legacy VK_* values will also be supported unless IMGUI_DISABLE_OBSOLETE_KEYIO is set]
|
||||||
|
// [X] Platform: Gamepad support. Enabled with 'io.ConfigFlags |= ImGuiConfigFlags_NavEnableGamepad'.
|
||||||
|
// [X] Platform: Mouse cursor shape and visibility. Disable with 'io.ConfigFlags |= ImGuiConfigFlags_NoMouseCursorChange'.
|
||||||
|
|
||||||
|
// You can use unmodified imgui_impl_* files in your project. See examples/ folder for examples of using this.
|
||||||
|
// Prefer including the entire imgui/ repository into your project (either as a copy or as a submodule), and only build the backends you need.
|
||||||
|
// Learn about Dear ImGui:
|
||||||
|
// - FAQ https://dearimgui.com/faq
|
||||||
|
// - Getting Started https://dearimgui.com/getting-started
|
||||||
|
// - Documentation https://dearimgui.com/docs (same as your local docs/ folder).
|
||||||
|
// - Introduction, links and more at the top of imgui.cpp
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include "imgui.h" // IMGUI_IMPL_API
|
||||||
|
#ifndef IMGUI_DISABLE
|
||||||
|
|
||||||
|
IMGUI_IMPL_API bool ImGui_ImplWin32_Init(void* hwnd);
|
||||||
|
IMGUI_IMPL_API bool ImGui_ImplWin32_InitForOpenGL(void* hwnd);
|
||||||
|
IMGUI_IMPL_API void ImGui_ImplWin32_Shutdown();
|
||||||
|
IMGUI_IMPL_API void ImGui_ImplWin32_NewFrame();
|
||||||
|
|
||||||
|
// Win32 message handler your application need to call.
|
||||||
|
// - Intentionally commented out in a '#if 0' block to avoid dragging dependencies on <windows.h> from this helper.
|
||||||
|
// - You should COPY the line below into your .cpp code to forward declare the function and then you can call it.
|
||||||
|
// - Call from your application's message handler. Keep calling your message handler unless this function returns TRUE.
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
extern IMGUI_IMPL_API LRESULT ImGui_ImplWin32_WndProcHandler(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// DPI-related helpers (optional)
|
||||||
|
// - Use to enable DPI awareness without having to create an application manifest.
|
||||||
|
// - Your own app may already do this via a manifest or explicit calls. This is mostly useful for our examples/ apps.
|
||||||
|
// - In theory we could call simple functions from Windows SDK such as SetProcessDPIAware(), SetProcessDpiAwareness(), etc.
|
||||||
|
// but most of the functions provided by Microsoft require Windows 8.1/10+ SDK at compile time and Windows 8/10+ at runtime,
|
||||||
|
// neither we want to require the user to have. So we dynamically select and load those functions to avoid dependencies.
|
||||||
|
IMGUI_IMPL_API void ImGui_ImplWin32_EnableDpiAwareness();
|
||||||
|
IMGUI_IMPL_API float ImGui_ImplWin32_GetDpiScaleForHwnd(void* hwnd); // HWND hwnd
|
||||||
|
IMGUI_IMPL_API float ImGui_ImplWin32_GetDpiScaleForMonitor(void* monitor); // HMONITOR monitor
|
||||||
|
|
||||||
|
// Transparency related helpers (optional) [experimental]
|
||||||
|
// - Use to enable alpha compositing transparency with the desktop.
|
||||||
|
// - Use together with e.g. clearing your framebuffer with zero-alpha.
|
||||||
|
IMGUI_IMPL_API void ImGui_ImplWin32_EnableAlphaCompositing(void* hwnd); // HWND hwnd
|
||||||
|
|
||||||
|
#endif // #ifndef IMGUI_DISABLE
|
||||||
Vendored
+205
@@ -0,0 +1,205 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project DefaultTargets="Build" ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<ItemGroup Label="ProjectConfigurations">
|
||||||
|
<ProjectConfiguration Include="Debug|Win32">
|
||||||
|
<Configuration>Debug</Configuration>
|
||||||
|
<Platform>Win32</Platform>
|
||||||
|
</ProjectConfiguration>
|
||||||
|
<ProjectConfiguration Include="Debug|x64">
|
||||||
|
<Configuration>Debug</Configuration>
|
||||||
|
<Platform>x64</Platform>
|
||||||
|
</ProjectConfiguration>
|
||||||
|
<ProjectConfiguration Include="Release|Win32">
|
||||||
|
<Configuration>Release</Configuration>
|
||||||
|
<Platform>Win32</Platform>
|
||||||
|
</ProjectConfiguration>
|
||||||
|
<ProjectConfiguration Include="Release|x64">
|
||||||
|
<Configuration>Release</Configuration>
|
||||||
|
<Platform>x64</Platform>
|
||||||
|
</ProjectConfiguration>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\gui.cpp" />
|
||||||
|
<ClCompile Include="..\..\..\..\framework\helpers\draw.cpp" />
|
||||||
|
<ClCompile Include="..\..\..\..\framework\helpers\fonts.cpp" />
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\helpers.cpp" />
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\notify.cpp" />
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\text_field.cpp" />
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\widgets.cpp" />
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\window.cpp" />
|
||||||
|
<ClCompile Include="..\..\backends\imgui_impl_dx11.cpp" />
|
||||||
|
<ClCompile Include="..\..\backends\imgui_impl_win32.cpp" />
|
||||||
|
<ClCompile Include="..\..\imgui.cpp" />
|
||||||
|
<ClCompile Include="..\..\imgui_draw.cpp" />
|
||||||
|
<ClCompile Include="..\..\imgui_freetype.cpp" />
|
||||||
|
<ClCompile Include="..\..\imgui_tables.cpp" />
|
||||||
|
<ClCompile Include="..\..\imgui_widgets.cpp" />
|
||||||
|
<ClCompile Include="main.cpp" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Library Include="..\..\..\freetype\win64\freetype.lib" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\data\fonts.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\draw.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\flags.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\fonts.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\functions.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\includes.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\widgets.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\settings\colors.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\settings\elements.h" />
|
||||||
|
<ClInclude Include="..\..\..\..\framework\settings\variables.h" />
|
||||||
|
<ClInclude Include="..\..\backends\imgui_impl_dx11.h" />
|
||||||
|
<ClInclude Include="..\..\backends\imgui_impl_win32.h" />
|
||||||
|
<ClInclude Include="..\..\imconfig.h" />
|
||||||
|
<ClInclude Include="..\..\imgui.h" />
|
||||||
|
<ClInclude Include="..\..\imgui_freetype.h" />
|
||||||
|
<ClInclude Include="..\..\imgui_internal.h" />
|
||||||
|
</ItemGroup>
|
||||||
|
<PropertyGroup Label="Globals">
|
||||||
|
<ProjectGuid>{9F316E83-5AE5-4939-A723-305A94F48005}</ProjectGuid>
|
||||||
|
<RootNamespace>example_win32_directx11</RootNamespace>
|
||||||
|
<TargetName>lumin_ui_demo</TargetName>
|
||||||
|
<WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
|
||||||
|
<VcpkgEnabled>false</VcpkgEnabled>
|
||||||
|
</PropertyGroup>
|
||||||
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
|
||||||
|
<ConfigurationType>Application</ConfigurationType>
|
||||||
|
<UseDebugLibraries>true</UseDebugLibraries>
|
||||||
|
<CharacterSet>Unicode</CharacterSet>
|
||||||
|
<PlatformToolset>v143</PlatformToolset>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
|
||||||
|
<ConfigurationType>Application</ConfigurationType>
|
||||||
|
<UseDebugLibraries>true</UseDebugLibraries>
|
||||||
|
<CharacterSet>Unicode</CharacterSet>
|
||||||
|
<PlatformToolset>v143</PlatformToolset>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
|
||||||
|
<ConfigurationType>Application</ConfigurationType>
|
||||||
|
<UseDebugLibraries>false</UseDebugLibraries>
|
||||||
|
<WholeProgramOptimization>true</WholeProgramOptimization>
|
||||||
|
<CharacterSet>Unicode</CharacterSet>
|
||||||
|
<PlatformToolset>v143</PlatformToolset>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
|
||||||
|
<ConfigurationType>Application</ConfigurationType>
|
||||||
|
<UseDebugLibraries>false</UseDebugLibraries>
|
||||||
|
<WholeProgramOptimization>true</WholeProgramOptimization>
|
||||||
|
<CharacterSet>Unicode</CharacterSet>
|
||||||
|
<PlatformToolset>v143</PlatformToolset>
|
||||||
|
</PropertyGroup>
|
||||||
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
|
||||||
|
<ImportGroup Label="ExtensionSettings">
|
||||||
|
</ImportGroup>
|
||||||
|
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||||
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
|
</ImportGroup>
|
||||||
|
<ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets">
|
||||||
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
|
</ImportGroup>
|
||||||
|
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||||
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
|
</ImportGroup>
|
||||||
|
<ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
|
||||||
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
|
</ImportGroup>
|
||||||
|
<PropertyGroup Label="UserMacros" />
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||||
|
<OutDir>$(ProjectDir)$(Configuration)\</OutDir>
|
||||||
|
<IntDir>$(ProjectDir)$(Configuration)\</IntDir>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
||||||
|
<OutDir>$(ProjectDir)$(Configuration)\</OutDir>
|
||||||
|
<IntDir>$(ProjectDir)$(Configuration)\</IntDir>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||||
|
<OutDir>$(ProjectDir)$(Configuration)\</OutDir>
|
||||||
|
<IntDir>$(ProjectDir)$(Configuration)\</IntDir>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
||||||
|
<OutDir>$(ProjectDir)$(Configuration)\</OutDir>
|
||||||
|
<IntDir>$(ProjectDir)$(Configuration)\</IntDir>
|
||||||
|
<IncludePath>$(SolutionDir)\thirdparty\imgui;$(SolutionDir)\thirdparty\freetype\include;$(IncludePath)</IncludePath>
|
||||||
|
<LibraryPath>$(SolutionDir)\thirdparty\freetype\win64;$(LibraryPath)</LibraryPath>
|
||||||
|
</PropertyGroup>
|
||||||
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||||
|
<ClCompile>
|
||||||
|
<WarningLevel>Level4</WarningLevel>
|
||||||
|
<Optimization>Disabled</Optimization>
|
||||||
|
<AdditionalIncludeDirectories>..\..;..\..\backends;%(AdditionalIncludeDirectories);</AdditionalIncludeDirectories>
|
||||||
|
<AdditionalOptions>/utf-8 /sdl /guard:cf %(AdditionalOptions)</AdditionalOptions>
|
||||||
|
</ClCompile>
|
||||||
|
<Link>
|
||||||
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
|
<AdditionalDependencies>d3d11.lib;d3dcompiler.lib;dxgi.lib;%(AdditionalDependencies)</AdditionalDependencies>
|
||||||
|
<AdditionalLibraryDirectories>%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>
|
||||||
|
<SubSystem>Windows</SubSystem>
|
||||||
|
<EntryPointSymbol>mainCRTStartup</EntryPointSymbol>
|
||||||
|
</Link>
|
||||||
|
</ItemDefinitionGroup>
|
||||||
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
||||||
|
<ClCompile>
|
||||||
|
<WarningLevel>Level4</WarningLevel>
|
||||||
|
<Optimization>Disabled</Optimization>
|
||||||
|
<AdditionalIncludeDirectories>..\..;..\..\backends;%(AdditionalIncludeDirectories);</AdditionalIncludeDirectories>
|
||||||
|
<AdditionalOptions>/utf-8 %(AdditionalOptions)</AdditionalOptions>
|
||||||
|
</ClCompile>
|
||||||
|
<Link>
|
||||||
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
|
<AdditionalDependencies>d3d11.lib;d3dcompiler.lib;dxgi.lib;%(AdditionalDependencies)</AdditionalDependencies>
|
||||||
|
<AdditionalLibraryDirectories>%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>
|
||||||
|
<SubSystem>Windows</SubSystem>
|
||||||
|
<EntryPointSymbol>mainCRTStartup</EntryPointSymbol>
|
||||||
|
</Link>
|
||||||
|
</ItemDefinitionGroup>
|
||||||
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||||
|
<ClCompile>
|
||||||
|
<WarningLevel>Level4</WarningLevel>
|
||||||
|
<Optimization>MaxSpeed</Optimization>
|
||||||
|
<FunctionLevelLinking>true</FunctionLevelLinking>
|
||||||
|
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||||
|
<AdditionalIncludeDirectories>..\..;..\..\backends;%(AdditionalIncludeDirectories);</AdditionalIncludeDirectories>
|
||||||
|
<BufferSecurityCheck>true</BufferSecurityCheck>
|
||||||
|
<AdditionalOptions>/utf-8 %(AdditionalOptions)</AdditionalOptions>
|
||||||
|
</ClCompile>
|
||||||
|
<Link>
|
||||||
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
|
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
||||||
|
<OptimizeReferences>true</OptimizeReferences>
|
||||||
|
<AdditionalOptions>/DYNAMICBASE /NXCOMPAT /guard:cf %(AdditionalOptions)</AdditionalOptions>
|
||||||
|
<AdditionalDependencies>d3d11.lib;d3dcompiler.lib;dxgi.lib;%(AdditionalDependencies)</AdditionalDependencies>
|
||||||
|
<AdditionalLibraryDirectories>%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>
|
||||||
|
<SubSystem>Windows</SubSystem>
|
||||||
|
<EntryPointSymbol>mainCRTStartup</EntryPointSymbol>
|
||||||
|
</Link>
|
||||||
|
</ItemDefinitionGroup>
|
||||||
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
||||||
|
<ClCompile>
|
||||||
|
<WarningLevel>Level4</WarningLevel>
|
||||||
|
<Optimization>MaxSpeed</Optimization>
|
||||||
|
<FunctionLevelLinking>true</FunctionLevelLinking>
|
||||||
|
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||||
|
<AdditionalIncludeDirectories>..\..;..\..\backends;%(AdditionalIncludeDirectories);</AdditionalIncludeDirectories>
|
||||||
|
<BufferSecurityCheck>true</BufferSecurityCheck>
|
||||||
|
<AdditionalOptions>/utf-8 /Zm1500 /sdl /guard:cf %(AdditionalOptions)</AdditionalOptions>
|
||||||
|
<LanguageStandard>stdcpp20</LanguageStandard>
|
||||||
|
<MultiProcessorCompilation>false</MultiProcessorCompilation>
|
||||||
|
</ClCompile>
|
||||||
|
<Link>
|
||||||
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
|
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
||||||
|
<OptimizeReferences>true</OptimizeReferences>
|
||||||
|
<AdditionalOptions>/DYNAMICBASE /NXCOMPAT /guard:cf %(AdditionalOptions)</AdditionalOptions>
|
||||||
|
<AdditionalDependencies>d3d11.lib;d3dcompiler.lib;dxgi.lib;%(AdditionalDependencies)</AdditionalDependencies>
|
||||||
|
<AdditionalLibraryDirectories>%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>
|
||||||
|
<SubSystem>Windows</SubSystem>
|
||||||
|
<EntryPointSymbol>mainCRTStartup</EntryPointSymbol>
|
||||||
|
</Link>
|
||||||
|
</ItemDefinitionGroup>
|
||||||
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
|
<ImportGroup Label="ExtensionTargets">
|
||||||
|
</ImportGroup>
|
||||||
|
</Project>
|
||||||
+138
@@ -0,0 +1,138 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<ItemGroup>
|
||||||
|
<ClCompile Include="main.cpp" />
|
||||||
|
<ClCompile Include="..\..\backends\imgui_impl_dx11.cpp">
|
||||||
|
<Filter>thirdparty\imgui\impl</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\backends\imgui_impl_win32.cpp">
|
||||||
|
<Filter>thirdparty\imgui\impl</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\imgui.cpp">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\imgui_draw.cpp">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\imgui_freetype.cpp">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\imgui_tables.cpp">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\imgui_widgets.cpp">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\gui.cpp">
|
||||||
|
<Filter>framework</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\helpers\draw.cpp">
|
||||||
|
<Filter>framework\helpers</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\helpers\fonts.cpp">
|
||||||
|
<Filter>framework\helpers</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\helpers.cpp">
|
||||||
|
<Filter>framework\widgets</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\notify.cpp">
|
||||||
|
<Filter>framework\widgets</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\window.cpp">
|
||||||
|
<Filter>framework\widgets</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\widgets.cpp">
|
||||||
|
<Filter>framework\widgets</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\..\framework\widgets\text_field.cpp">
|
||||||
|
<Filter>framework\widgets</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Filter Include="thirdparty">
|
||||||
|
<UniqueIdentifier>{ccc54d96-72f7-4436-8a83-fa3c95630349}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="thirdparty\freetype">
|
||||||
|
<UniqueIdentifier>{92aa3f18-0f62-4ee8-bc64-9dd79c9c15cc}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="thirdparty\imgui">
|
||||||
|
<UniqueIdentifier>{8e6165f3-0e1c-4cfc-a3c2-72543f8ca897}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="thirdparty\imgui\impl">
|
||||||
|
<UniqueIdentifier>{2516b7d7-b875-48cb-8877-76225056bfb1}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="framework">
|
||||||
|
<UniqueIdentifier>{f5b951e6-7363-43f2-a23d-fda1ec066176}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="framework\data">
|
||||||
|
<UniqueIdentifier>{a7ae9947-5960-4576-bffd-459ce63ce2e3}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="framework\headers">
|
||||||
|
<UniqueIdentifier>{3f5fea1a-9455-4e99-aadf-662fa3810326}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="framework\helpers">
|
||||||
|
<UniqueIdentifier>{bea8460b-cb50-498c-97a6-0c3de2303e3f}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="framework\settings">
|
||||||
|
<UniqueIdentifier>{294a9fd1-581b-4a05-a2d7-a217904f82cd}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="framework\widgets">
|
||||||
|
<UniqueIdentifier>{5dce1686-af54-4490-b0af-91f3d85e0a73}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Library Include="..\..\..\freetype\win64\freetype.lib">
|
||||||
|
<Filter>thirdparty\freetype</Filter>
|
||||||
|
</Library>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClInclude Include="..\..\backends\imgui_impl_dx11.h">
|
||||||
|
<Filter>thirdparty\imgui\impl</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\backends\imgui_impl_win32.h">
|
||||||
|
<Filter>thirdparty\imgui\impl</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\imconfig.h">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\imgui.h">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\imgui_freetype.h">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\imgui_internal.h">
|
||||||
|
<Filter>thirdparty\imgui</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\data\fonts.h">
|
||||||
|
<Filter>framework\data</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\draw.h">
|
||||||
|
<Filter>framework\headers</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\flags.h">
|
||||||
|
<Filter>framework\headers</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\fonts.h">
|
||||||
|
<Filter>framework\headers</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\functions.h">
|
||||||
|
<Filter>framework\headers</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\includes.h">
|
||||||
|
<Filter>framework\headers</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\headers\widgets.h">
|
||||||
|
<Filter>framework\headers</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\settings\colors.h">
|
||||||
|
<Filter>framework\settings</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\settings\elements.h">
|
||||||
|
<Filter>framework\settings</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\..\..\..\framework\settings\variables.h">
|
||||||
|
<Filter>framework\settings</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
</ItemGroup>
|
||||||
|
</Project>
|
||||||
@@ -0,0 +1,322 @@
|
|||||||
|
// Dear ImGui: standalone example application for DirectX 11
|
||||||
|
|
||||||
|
// Learn about Dear ImGui:
|
||||||
|
// - FAQ https://dearimgui.com/faq
|
||||||
|
// - Getting Started https://dearimgui.com/getting-started
|
||||||
|
// - Documentation https://dearimgui.com/docs (same as your local docs/ folder).
|
||||||
|
// - Introduction, links and more at the top of imgui.cpp
|
||||||
|
|
||||||
|
#include "../../framework/headers/includes.h"
|
||||||
|
#include "../../framework/data/fonts.h"
|
||||||
|
#include "imgui.h"
|
||||||
|
#include "imgui_impl_win32.h"
|
||||||
|
#include "imgui_impl_dx11.h"
|
||||||
|
#include "imgui_freetype.h"
|
||||||
|
#include <tchar.h>
|
||||||
|
#include <d3d11.h>
|
||||||
|
#include <dwmapi.h>
|
||||||
|
#pragma comment(lib, "dwmapi.lib")
|
||||||
|
|
||||||
|
// Data
|
||||||
|
static ID3D11Device* g_pd3dDevice = nullptr;
|
||||||
|
static ID3D11DeviceContext* g_pd3dDeviceContext = nullptr;
|
||||||
|
static IDXGISwapChain* g_pSwapChain = nullptr;
|
||||||
|
static bool g_SwapChainOccluded = false;
|
||||||
|
static UINT g_ResizeWidth = 0, g_ResizeHeight = 0;
|
||||||
|
static ID3D11RenderTargetView* g_mainRenderTargetView = nullptr;
|
||||||
|
|
||||||
|
// Forward declarations of helper functions
|
||||||
|
bool CreateDeviceD3D(HWND hWnd);
|
||||||
|
void CleanupDeviceD3D();
|
||||||
|
void CreateRenderTarget();
|
||||||
|
void CleanupRenderTarget();
|
||||||
|
void WarmFonts();
|
||||||
|
void MoveHostWindowFromImGui(HWND hWnd);
|
||||||
|
void ResizeHostWindowToGui(HWND hWnd);
|
||||||
|
LRESULT WINAPI WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
|
|
||||||
|
// Main code
|
||||||
|
int main(int, char**)
|
||||||
|
{
|
||||||
|
{
|
||||||
|
wchar_t exe_path[MAX_PATH];
|
||||||
|
if (::GetModuleFileNameW(nullptr, exe_path, MAX_PATH))
|
||||||
|
{
|
||||||
|
wchar_t* last_sep = wcsrchr(exe_path, L'\\');
|
||||||
|
if (last_sep) { *last_sep = L'\0'; ::SetCurrentDirectoryW(exe_path); }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create application window
|
||||||
|
//ImGui_ImplWin32_EnableDpiAwareness();
|
||||||
|
WNDCLASSEXW wc = { sizeof(wc), CS_CLASSDC, WndProc, 0L, 0L, GetModuleHandle(nullptr), nullptr, nullptr, nullptr, nullptr, L"ImGui Example", nullptr };
|
||||||
|
::RegisterClassExW(&wc);
|
||||||
|
const int window_width = 570;
|
||||||
|
const int window_height = 354;
|
||||||
|
const int window_x = (::GetSystemMetrics(SM_CXSCREEN) - window_width) / 2;
|
||||||
|
const int window_y = (::GetSystemMetrics(SM_CYSCREEN) - window_height) / 2;
|
||||||
|
HWND hwnd = ::CreateWindowExW(WS_EX_LAYERED, wc.lpszClassName, L"Lumin UI Demo", WS_POPUP, window_x, window_y, window_width, window_height, nullptr, nullptr, wc.hInstance, nullptr);
|
||||||
|
|
||||||
|
::SetLayeredWindowAttributes(hwnd, RGB(0, 0, 0), 255, LWA_ALPHA);
|
||||||
|
MARGINS margins = { -1 };
|
||||||
|
::DwmExtendFrameIntoClientArea(hwnd, &margins);
|
||||||
|
|
||||||
|
// Initialize Direct3D
|
||||||
|
if (!CreateDeviceD3D(hwnd))
|
||||||
|
{
|
||||||
|
CleanupDeviceD3D();
|
||||||
|
::UnregisterClassW(wc.lpszClassName, wc.hInstance);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Show the window
|
||||||
|
::ShowWindow(hwnd, SW_SHOWDEFAULT);
|
||||||
|
::UpdateWindow(hwnd);
|
||||||
|
|
||||||
|
// Setup Dear ImGui context
|
||||||
|
IMGUI_CHECKVERSION();
|
||||||
|
ImGui::CreateContext();
|
||||||
|
ImGuiIO& io = ImGui::GetIO(); (void)io;
|
||||||
|
io.ConfigFlags |= ImGuiConfigFlags_NavEnableKeyboard; // Enable Keyboard Controls
|
||||||
|
io.ConfigFlags |= ImGuiConfigFlags_NavEnableGamepad; // Enable Gamepad Controls
|
||||||
|
|
||||||
|
// Setup Dear ImGui style
|
||||||
|
ImGui::StyleColorsDark();
|
||||||
|
//ImGui::StyleColorsLight();
|
||||||
|
|
||||||
|
// Setup Platform/Renderer backends
|
||||||
|
ImGui_ImplWin32_Init(hwnd);
|
||||||
|
ImGui_ImplDX11_Init(g_pd3dDevice, g_pd3dDeviceContext);
|
||||||
|
WarmFonts();
|
||||||
|
font->update();
|
||||||
|
|
||||||
|
// Load Fonts
|
||||||
|
|
||||||
|
// Main loop
|
||||||
|
bool done = false;
|
||||||
|
while (!done)
|
||||||
|
{
|
||||||
|
// Poll and handle messages (inputs, window resize, etc.)
|
||||||
|
// See the WndProc() function below for our to dispatch events to the Win32 backend.
|
||||||
|
MSG msg;
|
||||||
|
while (::PeekMessage(&msg, nullptr, 0U, 0U, PM_REMOVE))
|
||||||
|
{
|
||||||
|
::TranslateMessage(&msg);
|
||||||
|
::DispatchMessage(&msg);
|
||||||
|
if (msg.message == WM_QUIT)
|
||||||
|
done = true;
|
||||||
|
}
|
||||||
|
if (done)
|
||||||
|
break;
|
||||||
|
|
||||||
|
// Handle window being minimized or screen locked
|
||||||
|
if (g_SwapChainOccluded && g_pSwapChain->Present(0, DXGI_PRESENT_TEST) == DXGI_STATUS_OCCLUDED)
|
||||||
|
{
|
||||||
|
::Sleep(10);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
g_SwapChainOccluded = false;
|
||||||
|
|
||||||
|
// Handle window resize (we don't resize directly in the WM_SIZE handler)
|
||||||
|
if (g_ResizeWidth != 0 && g_ResizeHeight != 0)
|
||||||
|
{
|
||||||
|
CleanupRenderTarget();
|
||||||
|
g_pSwapChain->ResizeBuffers(0, g_ResizeWidth, g_ResizeHeight, DXGI_FORMAT_UNKNOWN, 0);
|
||||||
|
g_ResizeWidth = g_ResizeHeight = 0;
|
||||||
|
CreateRenderTarget();
|
||||||
|
}
|
||||||
|
|
||||||
|
font->update();
|
||||||
|
|
||||||
|
// Start the Dear ImGui frame
|
||||||
|
ImGui_ImplDX11_NewFrame();
|
||||||
|
ImGui_ImplWin32_NewFrame();
|
||||||
|
ImGui::NewFrame();
|
||||||
|
|
||||||
|
gui->render();
|
||||||
|
MoveHostWindowFromImGui(hwnd);
|
||||||
|
ResizeHostWindowToGui(hwnd);
|
||||||
|
|
||||||
|
// Rendering
|
||||||
|
ImGui::Render();
|
||||||
|
const float clear_color_with_alpha[4] = { 0.f, 0.f, 0.f, 0.f };
|
||||||
|
g_pd3dDeviceContext->OMSetRenderTargets(1, &g_mainRenderTargetView, nullptr);
|
||||||
|
g_pd3dDeviceContext->ClearRenderTargetView(g_mainRenderTargetView, clear_color_with_alpha);
|
||||||
|
ImGui_ImplDX11_RenderDrawData(ImGui::GetDrawData());
|
||||||
|
|
||||||
|
// Present
|
||||||
|
HRESULT hr = g_pSwapChain->Present(1, 0); // Present with vsync
|
||||||
|
//HRESULT hr = g_pSwapChain->Present(0, 0); // Present without vsync
|
||||||
|
g_SwapChainOccluded = (hr == DXGI_STATUS_OCCLUDED);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cleanup
|
||||||
|
ImGui_ImplDX11_Shutdown();
|
||||||
|
ImGui_ImplWin32_Shutdown();
|
||||||
|
ImGui::DestroyContext();
|
||||||
|
|
||||||
|
CleanupDeviceD3D();
|
||||||
|
::DestroyWindow(hwnd);
|
||||||
|
::UnregisterClassW(wc.lpszClassName, wc.hInstance);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper functions
|
||||||
|
|
||||||
|
bool CreateDeviceD3D(HWND hWnd)
|
||||||
|
{
|
||||||
|
// Setup swap chain
|
||||||
|
DXGI_SWAP_CHAIN_DESC sd;
|
||||||
|
ZeroMemory(&sd, sizeof(sd));
|
||||||
|
sd.BufferCount = 2;
|
||||||
|
sd.BufferDesc.Width = 0;
|
||||||
|
sd.BufferDesc.Height = 0;
|
||||||
|
sd.BufferDesc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
|
||||||
|
sd.BufferDesc.RefreshRate.Numerator = 60;
|
||||||
|
sd.BufferDesc.RefreshRate.Denominator = 1;
|
||||||
|
sd.Flags = DXGI_SWAP_CHAIN_FLAG_ALLOW_MODE_SWITCH;
|
||||||
|
sd.BufferUsage = DXGI_USAGE_RENDER_TARGET_OUTPUT;
|
||||||
|
sd.OutputWindow = hWnd;
|
||||||
|
sd.SampleDesc.Count = 1;
|
||||||
|
sd.SampleDesc.Quality = 0;
|
||||||
|
sd.Windowed = TRUE;
|
||||||
|
sd.SwapEffect = DXGI_SWAP_EFFECT_DISCARD;
|
||||||
|
|
||||||
|
UINT createDeviceFlags = 0;
|
||||||
|
//createDeviceFlags |= D3D11_CREATE_DEVICE_DEBUG;
|
||||||
|
D3D_FEATURE_LEVEL featureLevel;
|
||||||
|
const D3D_FEATURE_LEVEL featureLevelArray[2] = { D3D_FEATURE_LEVEL_11_0, D3D_FEATURE_LEVEL_10_0, };
|
||||||
|
HRESULT res = D3D11CreateDeviceAndSwapChain(nullptr, D3D_DRIVER_TYPE_HARDWARE, nullptr, createDeviceFlags, featureLevelArray, 2, D3D11_SDK_VERSION, &sd, &g_pSwapChain, &g_pd3dDevice, &featureLevel, &g_pd3dDeviceContext);
|
||||||
|
if (res == DXGI_ERROR_UNSUPPORTED) // Try high-performance WARP software driver if hardware is not available.
|
||||||
|
res = D3D11CreateDeviceAndSwapChain(nullptr, D3D_DRIVER_TYPE_WARP, nullptr, createDeviceFlags, featureLevelArray, 2, D3D11_SDK_VERSION, &sd, &g_pSwapChain, &g_pd3dDevice, &featureLevel, &g_pd3dDeviceContext);
|
||||||
|
if (res != S_OK)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
CreateRenderTarget();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CleanupDeviceD3D()
|
||||||
|
{
|
||||||
|
CleanupRenderTarget();
|
||||||
|
if (g_pSwapChain) { g_pSwapChain->Release(); g_pSwapChain = nullptr; }
|
||||||
|
if (g_pd3dDeviceContext) { g_pd3dDeviceContext->Release(); g_pd3dDeviceContext = nullptr; }
|
||||||
|
if (g_pd3dDevice) { g_pd3dDevice->Release(); g_pd3dDevice = nullptr; }
|
||||||
|
}
|
||||||
|
|
||||||
|
void CreateRenderTarget()
|
||||||
|
{
|
||||||
|
ID3D11Texture2D* pBackBuffer;
|
||||||
|
g_pSwapChain->GetBuffer(0, IID_PPV_ARGS(&pBackBuffer));
|
||||||
|
g_pd3dDevice->CreateRenderTargetView(pBackBuffer, nullptr, &g_mainRenderTargetView);
|
||||||
|
pBackBuffer->Release();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CleanupRenderTarget()
|
||||||
|
{
|
||||||
|
if (g_mainRenderTargetView) { g_mainRenderTargetView->Release(); g_mainRenderTargetView = nullptr; }
|
||||||
|
}
|
||||||
|
|
||||||
|
void WarmFonts()
|
||||||
|
{
|
||||||
|
font->get(inter_medium, 10);
|
||||||
|
font->get(inter_medium, 11);
|
||||||
|
font->get(inter_semibold, 10);
|
||||||
|
font->get(inter_semibold, 11);
|
||||||
|
font->get(inter_semibold, 12);
|
||||||
|
font->get(inter_semibold, 13);
|
||||||
|
font->get(inter_semibold, 16);
|
||||||
|
font->get(inter_semibold, 18);
|
||||||
|
font->get(inter_semibold, 40);
|
||||||
|
font->get(icon_font, 14);
|
||||||
|
font->get(icon_font, 15);
|
||||||
|
font->get_file(flaticon_uicons_regular_rounded_path, 10.5f, true);
|
||||||
|
font->get_file(flaticon_uicons_regular_rounded_path, 13.5f, true);
|
||||||
|
font->get_file("C:\\Windows\\Fonts\\segmdl2.ttf", 11.f, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MoveHostWindowFromImGui(HWND hWnd)
|
||||||
|
{
|
||||||
|
static bool dragging = false;
|
||||||
|
static POINT drag_start_cursor = {};
|
||||||
|
static RECT drag_start_rect = {};
|
||||||
|
|
||||||
|
const bool can_start_drag = ImGui::IsWindowHovered(ImGuiHoveredFlags_AnyWindow) && !ImGui::IsAnyItemHovered() && !ImGui::IsAnyItemActive();
|
||||||
|
|
||||||
|
if (can_start_drag && ImGui::IsMouseClicked(ImGuiMouseButton_Left))
|
||||||
|
{
|
||||||
|
dragging = true;
|
||||||
|
::GetCursorPos(&drag_start_cursor);
|
||||||
|
::GetWindowRect(hWnd, &drag_start_rect);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ImGui::IsMouseDown(ImGuiMouseButton_Left))
|
||||||
|
dragging = false;
|
||||||
|
|
||||||
|
if (!dragging)
|
||||||
|
return;
|
||||||
|
|
||||||
|
POINT cursor = {};
|
||||||
|
::GetCursorPos(&cursor);
|
||||||
|
|
||||||
|
const int next_x = drag_start_rect.left + (cursor.x - drag_start_cursor.x);
|
||||||
|
const int next_y = drag_start_rect.top + (cursor.y - drag_start_cursor.y);
|
||||||
|
|
||||||
|
::SetWindowPos(hWnd, nullptr, next_x, next_y, 0, 0, SWP_NOSIZE | SWP_NOZORDER | SWP_NOACTIVATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ResizeHostWindowToGui(HWND hWnd)
|
||||||
|
{
|
||||||
|
const int width = elements->window.size.x > 1.f ? static_cast<int>(elements->window.size.x + 0.5f) : 1;
|
||||||
|
const int height = elements->window.size.y > 1.f ? static_cast<int>(elements->window.size.y + 0.5f) : 1;
|
||||||
|
|
||||||
|
RECT client_rect;
|
||||||
|
::GetClientRect(hWnd, &client_rect);
|
||||||
|
const int current_width = client_rect.right - client_rect.left;
|
||||||
|
const int current_height = client_rect.bottom - client_rect.top;
|
||||||
|
|
||||||
|
if (current_width == width && current_height == height)
|
||||||
|
return;
|
||||||
|
|
||||||
|
::SetWindowPos(hWnd, nullptr, 0, 0, width, height, SWP_NOMOVE | SWP_NOZORDER | SWP_NOACTIVATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Forward declare message handler from imgui_impl_win32.cpp
|
||||||
|
extern IMGUI_IMPL_API LRESULT ImGui_ImplWin32_WndProcHandler(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
|
|
||||||
|
// Win32 message handler
|
||||||
|
// You can read the io.WantCaptureMouse, io.WantCaptureKeyboard flags to tell if dear imgui wants to use your inputs.
|
||||||
|
// - When io.WantCaptureMouse is true, do not dispatch mouse input data to your main application, or clear/overwrite your copy of the mouse data.
|
||||||
|
// - When io.WantCaptureKeyboard is true, do not dispatch keyboard input data to your main application, or clear/overwrite your copy of the keyboard data.
|
||||||
|
// Generally you may always pass all inputs to dear imgui, and hide them from your application based on those two flags.
|
||||||
|
LRESULT WINAPI WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
|
{
|
||||||
|
if (ImGui_ImplWin32_WndProcHandler(hWnd, msg, wParam, lParam))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
switch (msg)
|
||||||
|
{
|
||||||
|
case WM_SIZE:
|
||||||
|
if (wParam == SIZE_MINIMIZED)
|
||||||
|
return 0;
|
||||||
|
g_ResizeWidth = (UINT)LOWORD(lParam); // Queue resize
|
||||||
|
g_ResizeHeight = (UINT)HIWORD(lParam);
|
||||||
|
return 0;
|
||||||
|
case WM_SYSCOMMAND:
|
||||||
|
if ((wParam & 0xfff0) == SC_KEYMENU) // Disable ALT application menu
|
||||||
|
return 0;
|
||||||
|
break;
|
||||||
|
case WM_KEYDOWN:
|
||||||
|
if (wParam == VK_ESCAPE)
|
||||||
|
{
|
||||||
|
::PostMessageW(hWnd, WM_CLOSE, 0, 0);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case WM_DESTROY:
|
||||||
|
::PostQuitMessage(0);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return ::DefWindowProcW(hWnd, msg, wParam, lParam);
|
||||||
|
}
|
||||||
+140
@@ -0,0 +1,140 @@
|
|||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// DEAR IMGUI COMPILE-TIME OPTIONS
|
||||||
|
// Runtime options (clipboard callbacks, enabling various features, etc.) can generally be set via the ImGuiIO structure.
|
||||||
|
// You can use ImGui::SetAllocatorFunctions() before calling ImGui::CreateContext() to rewire memory allocation functions.
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// A) You may edit imconfig.h (and not overwrite it when updating Dear ImGui, or maintain a patch/rebased branch with your modifications to it)
|
||||||
|
// B) or '#define IMGUI_USER_CONFIG "my_imgui_config.h"' in your project and then add directives in your own file without touching this template.
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// You need to make sure that configuration settings are defined consistently _everywhere_ Dear ImGui is used, which include the imgui*.cpp
|
||||||
|
// files but also _any_ of your code that uses Dear ImGui. This is because some compile-time options have an affect on data structures.
|
||||||
|
// Defining those options in imconfig.h will ensure every compilation unit gets to see the same data structure layouts.
|
||||||
|
// Call IMGUI_CHECKVERSION() from your .cpp file to verify that the data structures your files are using are matching the ones imgui.cpp is using.
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
//---- DayZ overlay integration: build the font atlas with FreeType (required by
|
||||||
|
// the Lumin framework font system, which sets ImGuiFreeTypeBuilderFlags).
|
||||||
|
#define IMGUI_ENABLE_FREETYPE
|
||||||
|
|
||||||
|
//---- Define assertion handler. Defaults to calling assert().
|
||||||
|
// If your macro uses multiple statements, make sure is enclosed in a 'do { .. } while (0)' block so it can be used as a single statement.
|
||||||
|
//#define IM_ASSERT(_EXPR) MyAssert(_EXPR)
|
||||||
|
//#define IM_ASSERT(_EXPR) ((void)(_EXPR)) // Disable asserts
|
||||||
|
|
||||||
|
//---- Define attributes of all API symbols declarations, e.g. for DLL under Windows
|
||||||
|
// Using Dear ImGui via a shared library is not recommended, because of function call overhead and because we don't guarantee backward nor forward ABI compatibility.
|
||||||
|
// - Windows DLL users: heaps and globals are not shared across DLL boundaries! You will need to call SetCurrentContext() + SetAllocatorFunctions()
|
||||||
|
// for each static/DLL boundary you are calling from. Read "Context and Memory Allocators" section of imgui.cpp for more details.
|
||||||
|
//#define IMGUI_API __declspec(dllexport) // MSVC Windows: DLL export
|
||||||
|
//#define IMGUI_API __declspec(dllimport) // MSVC Windows: DLL import
|
||||||
|
//#define IMGUI_API __attribute__((visibility("default"))) // GCC/Clang: override visibility when set is hidden
|
||||||
|
|
||||||
|
//---- Don't define obsolete functions/enums/behaviors. Consider enabling from time to time after updating to clean your code of obsolete function/names.
|
||||||
|
//#define IMGUI_DISABLE_OBSOLETE_FUNCTIONS
|
||||||
|
//#define IMGUI_DISABLE_OBSOLETE_KEYIO // 1.87+ disable legacy io.KeyMap[]+io.KeysDown[] in favor io.AddKeyEvent(). This is automatically done by IMGUI_DISABLE_OBSOLETE_FUNCTIONS.
|
||||||
|
|
||||||
|
//---- Disable all of Dear ImGui or don't implement standard windows/tools.
|
||||||
|
// It is very strongly recommended to NOT disable the demo windows and debug tool during development. They are extremely useful in day to day work. Please read comments in imgui_demo.cpp.
|
||||||
|
//#define IMGUI_DISABLE // Disable everything: all headers and source files will be empty.
|
||||||
|
//#define IMGUI_DISABLE_DEMO_WINDOWS // Disable demo windows: ShowDemoWindow()/ShowStyleEditor() will be empty.
|
||||||
|
//#define IMGUI_DISABLE_DEBUG_TOOLS // Disable metrics/debugger and other debug tools: ShowMetricsWindow(), ShowDebugLogWindow() and ShowIDStackToolWindow() will be empty.
|
||||||
|
|
||||||
|
//---- Don't implement some functions to reduce linkage requirements.
|
||||||
|
//#define IMGUI_DISABLE_WIN32_DEFAULT_CLIPBOARD_FUNCTIONS // [Win32] Don't implement default clipboard handler. Won't use and link with OpenClipboard/GetClipboardData/CloseClipboard etc. (user32.lib/.a, kernel32.lib/.a)
|
||||||
|
//#define IMGUI_ENABLE_WIN32_DEFAULT_IME_FUNCTIONS // [Win32] [Default with Visual Studio] Implement default IME handler (require imm32.lib/.a, auto-link for Visual Studio, -limm32 on command-line for MinGW)
|
||||||
|
//#define IMGUI_DISABLE_WIN32_DEFAULT_IME_FUNCTIONS // [Win32] [Default with non-Visual Studio compilers] Don't implement default IME handler (won't require imm32.lib/.a)
|
||||||
|
//#define IMGUI_DISABLE_WIN32_FUNCTIONS // [Win32] Won't use and link with any Win32 function (clipboard, IME).
|
||||||
|
//#define IMGUI_ENABLE_OSX_DEFAULT_CLIPBOARD_FUNCTIONS // [OSX] Implement default OSX clipboard handler (need to link with '-framework ApplicationServices', this is why this is not the default).
|
||||||
|
//#define IMGUI_DISABLE_DEFAULT_SHELL_FUNCTIONS // Don't implement default platform_io.Platform_OpenInShellFn() handler (Win32: ShellExecute(), require shell32.lib/.a, Mac/Linux: use system("")).
|
||||||
|
//#define IMGUI_DISABLE_DEFAULT_FORMAT_FUNCTIONS // Don't implement ImFormatString/ImFormatStringV so you can implement them yourself (e.g. if you don't want to link with vsnprintf)
|
||||||
|
//#define IMGUI_DISABLE_DEFAULT_MATH_FUNCTIONS // Don't implement ImFabs/ImSqrt/ImPow/ImFmod/ImCos/ImSin/ImAcos/ImAtan2 so you can implement them yourself.
|
||||||
|
//#define IMGUI_DISABLE_FILE_FUNCTIONS // Don't implement ImFileOpen/ImFileClose/ImFileRead/ImFileWrite and ImFileHandle at all (replace them with dummies)
|
||||||
|
//#define IMGUI_DISABLE_DEFAULT_FILE_FUNCTIONS // Don't implement ImFileOpen/ImFileClose/ImFileRead/ImFileWrite and ImFileHandle so you can implement them yourself if you don't want to link with fopen/fclose/fread/fwrite. This will also disable the LogToTTY() function.
|
||||||
|
//#define IMGUI_DISABLE_DEFAULT_ALLOCATORS // Don't implement default allocators calling malloc()/free() to avoid linking with them. You will need to call ImGui::SetAllocatorFunctions().
|
||||||
|
//#define IMGUI_DISABLE_SSE // Disable use of SSE intrinsics even if available
|
||||||
|
|
||||||
|
//---- Enable Test Engine / Automation features.
|
||||||
|
//#define IMGUI_ENABLE_TEST_ENGINE // Enable imgui_test_engine hooks. Generally set automatically by include "imgui_te_config.h", see Test Engine for details.
|
||||||
|
|
||||||
|
//---- Include imgui_user.h at the end of imgui.h as a convenience
|
||||||
|
// May be convenient for some users to only explicitly include vanilla imgui.h and have extra stuff included.
|
||||||
|
//#define IMGUI_INCLUDE_IMGUI_USER_H
|
||||||
|
//#define IMGUI_USER_H_FILENAME "my_folder/my_imgui_user.h"
|
||||||
|
|
||||||
|
//---- Pack colors to BGRA8 instead of RGBA8 (to avoid converting from one to another)
|
||||||
|
//#define IMGUI_USE_BGRA_PACKED_COLOR
|
||||||
|
|
||||||
|
//---- Use 32-bit for ImWchar (default is 16-bit) to support Unicode planes 1-16. (e.g. point beyond 0xFFFF like emoticons, dingbats, symbols, shapes, ancient languages, etc...)
|
||||||
|
//#define IMGUI_USE_WCHAR32
|
||||||
|
|
||||||
|
//---- Avoid multiple STB libraries implementations, or redefine path/filenames to prioritize another version
|
||||||
|
// By default the embedded implementations are declared static and not available outside of Dear ImGui sources files.
|
||||||
|
//#define IMGUI_STB_TRUETYPE_FILENAME "my_folder/stb_truetype.h"
|
||||||
|
//#define IMGUI_STB_RECT_PACK_FILENAME "my_folder/stb_rect_pack.h"
|
||||||
|
//#define IMGUI_STB_SPRINTF_FILENAME "my_folder/stb_sprintf.h" // only used if IMGUI_USE_STB_SPRINTF is defined.
|
||||||
|
//#define IMGUI_DISABLE_STB_TRUETYPE_IMPLEMENTATION
|
||||||
|
//#define IMGUI_DISABLE_STB_RECT_PACK_IMPLEMENTATION
|
||||||
|
//#define IMGUI_DISABLE_STB_SPRINTF_IMPLEMENTATION // only disabled if IMGUI_USE_STB_SPRINTF is defined.
|
||||||
|
|
||||||
|
//---- Use stb_sprintf.h for a faster implementation of vsnprintf instead of the one from libc (unless IMGUI_DISABLE_DEFAULT_FORMAT_FUNCTIONS is defined)
|
||||||
|
// Compatibility checks of arguments and formats done by clang and GCC will be disabled in order to support the extra formats provided by stb_sprintf.h.
|
||||||
|
//#define IMGUI_USE_STB_SPRINTF
|
||||||
|
|
||||||
|
//---- Use FreeType to build and rasterize the font atlas (instead of stb_truetype which is embedded by default in Dear ImGui)
|
||||||
|
// Requires FreeType headers to be available in the include path. Requires program to be compiled with 'misc/freetype/imgui_freetype.cpp' (in this repository) + the FreeType library (not provided).
|
||||||
|
// On Windows you may use vcpkg with 'vcpkg install freetype --triplet=x64-windows' + 'vcpkg integrate install'.
|
||||||
|
//#define IMGUI_ENABLE_FREETYPE
|
||||||
|
|
||||||
|
//---- Use FreeType+lunasvg library to render OpenType SVG fonts (SVGinOT)
|
||||||
|
// Requires lunasvg headers to be available in the include path + program to be linked with the lunasvg library (not provided).
|
||||||
|
// Only works in combination with IMGUI_ENABLE_FREETYPE.
|
||||||
|
// (implementation is based on Freetype's rsvg-port.c which is licensed under CeCILL-C Free Software License Agreement)
|
||||||
|
//#define IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
|
||||||
|
//---- Use stb_truetype to build and rasterize the font atlas (default)
|
||||||
|
// The only purpose of this define is if you want force compilation of the stb_truetype backend ALONG with the FreeType backend.
|
||||||
|
//#define IMGUI_ENABLE_STB_TRUETYPE
|
||||||
|
|
||||||
|
//---- Define constructor and implicit cast operators to convert back<>forth between your math types and ImVec2/ImVec4.
|
||||||
|
// This will be inlined as part of ImVec2 and ImVec4 class declarations.
|
||||||
|
/*
|
||||||
|
#define IM_VEC2_CLASS_EXTRA \
|
||||||
|
constexpr ImVec2(const MyVec2& f) : x(f.x), y(f.y) {} \
|
||||||
|
operator MyVec2() const { return MyVec2(x,y); }
|
||||||
|
|
||||||
|
#define IM_VEC4_CLASS_EXTRA \
|
||||||
|
constexpr ImVec4(const MyVec4& f) : x(f.x), y(f.y), z(f.z), w(f.w) {} \
|
||||||
|
operator MyVec4() const { return MyVec4(x,y,z,w); }
|
||||||
|
*/
|
||||||
|
//---- ...Or use Dear ImGui's own very basic math operators.
|
||||||
|
//#define IMGUI_DEFINE_MATH_OPERATORS
|
||||||
|
|
||||||
|
//---- Use 32-bit vertex indices (default is 16-bit) is one way to allow large meshes with more than 64K vertices.
|
||||||
|
// Your renderer backend will need to support it (most example renderer backends support both 16/32-bit indices).
|
||||||
|
// Another way to allow large meshes while keeping 16-bit indices is to handle ImDrawCmd::VtxOffset in your renderer.
|
||||||
|
// Read about ImGuiBackendFlags_RendererHasVtxOffset for details.
|
||||||
|
//#define ImDrawIdx unsigned int
|
||||||
|
|
||||||
|
//---- Override ImDrawCallback signature (will need to modify renderer backends accordingly)
|
||||||
|
//struct ImDrawList;
|
||||||
|
//struct ImDrawCmd;
|
||||||
|
//typedef void (*MyImDrawCallback)(const ImDrawList* draw_list, const ImDrawCmd* cmd, void* my_renderer_user_data);
|
||||||
|
//#define ImDrawCallback MyImDrawCallback
|
||||||
|
|
||||||
|
//---- Debug Tools: Macro to break in Debugger (we provide a default implementation of this in the codebase)
|
||||||
|
// (use 'Metrics->Tools->Item Picker' to pick widgets with the mouse and break into them for easy debugging.)
|
||||||
|
//#define IM_DEBUG_BREAK IM_ASSERT(0)
|
||||||
|
//#define IM_DEBUG_BREAK __debugbreak()
|
||||||
|
|
||||||
|
//---- Debug Tools: Enable slower asserts
|
||||||
|
//#define IMGUI_DEBUG_PARANOID
|
||||||
|
|
||||||
|
//---- Tip: You can add extra functions within the ImGui:: namespace from anywhere (e.g. your own sources/header files)
|
||||||
|
/*
|
||||||
|
namespace ImGui
|
||||||
|
{
|
||||||
|
void MyFunction(const char* name, MyMatrix44* mtx);
|
||||||
|
}
|
||||||
|
*/
|
||||||
+16684
File diff suppressed because it is too large
Load Diff
+3731
File diff suppressed because it is too large
Load Diff
+5612
File diff suppressed because it is too large
Load Diff
+950
@@ -0,0 +1,950 @@
|
|||||||
|
// dear imgui: FreeType font builder (used as a replacement for the stb_truetype builder)
|
||||||
|
// (code)
|
||||||
|
|
||||||
|
// Get the latest version at https://github.com/ocornut/imgui/tree/master/misc/freetype
|
||||||
|
// Original code by @vuhdo (Aleksei Skriabin). Improvements by @mikesart. Maintained since 2019 by @ocornut.
|
||||||
|
|
||||||
|
// CHANGELOG
|
||||||
|
// (minor and older changes stripped away, please see git history for details)
|
||||||
|
// 2023/11/13: added support for ImFontConfig::RasterizationDensity field for scaling render density without scaling metrics.
|
||||||
|
// 2023/08/01: added support for SVG fonts, enable by using '#define IMGUI_ENABLE_FREETYPE_LUNASVG' (#6591)
|
||||||
|
// 2023/01/04: fixed a packing issue which in some occurrences would prevent large amount of glyphs from being packed correctly.
|
||||||
|
// 2021/08/23: fixed crash when FT_Render_Glyph() fails to render a glyph and returns NULL.
|
||||||
|
// 2021/03/05: added ImGuiFreeTypeBuilderFlags_Bitmap to load bitmap glyphs.
|
||||||
|
// 2021/03/02: set 'atlas->TexPixelsUseColors = true' to help some backends with deciding of a prefered texture format.
|
||||||
|
// 2021/01/28: added support for color-layered glyphs via ImGuiFreeTypeBuilderFlags_LoadColor (require Freetype 2.10+).
|
||||||
|
// 2021/01/26: simplified integration by using '#define IMGUI_ENABLE_FREETYPE'. renamed ImGuiFreeType::XXX flags to ImGuiFreeTypeBuilderFlags_XXX for consistency with other API. removed ImGuiFreeType::BuildFontAtlas().
|
||||||
|
// 2020/06/04: fix for rare case where FT_Get_Char_Index() succeed but FT_Load_Glyph() fails.
|
||||||
|
// 2019/02/09: added RasterizerFlags::Monochrome flag to disable font anti-aliasing (combine with ::MonoHinting for best results!)
|
||||||
|
// 2019/01/15: added support for imgui allocators + added FreeType only override function SetAllocatorFunctions().
|
||||||
|
// 2019/01/10: re-factored to match big update in STB builder. fixed texture height waste. fixed redundant glyphs when merging. support for glyph padding.
|
||||||
|
// 2018/06/08: added support for ImFontConfig::GlyphMinAdvanceX, GlyphMaxAdvanceX.
|
||||||
|
// 2018/02/04: moved to main imgui repository (away from http://www.github.com/ocornut/imgui_club)
|
||||||
|
// 2018/01/22: fix for addition of ImFontAtlas::TexUvscale member.
|
||||||
|
// 2017/10/22: minor inconsequential change to match change in master (removed an unnecessary statement).
|
||||||
|
// 2017/09/26: fixes for imgui internal changes.
|
||||||
|
// 2017/08/26: cleanup, optimizations, support for ImFontConfig::RasterizerFlags, ImFontConfig::RasterizerMultiply.
|
||||||
|
// 2017/08/16: imported from https://github.com/Vuhdo/imgui_freetype into http://www.github.com/ocornut/imgui_club, updated for latest changes in ImFontAtlas, minor tweaks.
|
||||||
|
|
||||||
|
// About Gamma Correct Blending:
|
||||||
|
// - FreeType assumes blending in linear space rather than gamma space.
|
||||||
|
// - See https://www.freetype.org/freetype2/docs/reference/ft2-base_interface.html#FT_Render_Glyph
|
||||||
|
// - For correct results you need to be using sRGB and convert to linear space in the pixel shader output.
|
||||||
|
// - The default dear imgui styles will be impacted by this change (alpha values will need tweaking).
|
||||||
|
|
||||||
|
// FIXME: cfg.OversampleH, OversampleV are not supported (but perhaps not so necessary with this rasterizer).
|
||||||
|
|
||||||
|
#include "imgui.h"
|
||||||
|
#ifndef IMGUI_DISABLE
|
||||||
|
#include "imgui_freetype.h"
|
||||||
|
#include "imgui_internal.h" // ImMin,ImMax,ImFontAtlasBuild*,
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <ft2build.h>
|
||||||
|
#include FT_FREETYPE_H // <freetype/freetype.h>
|
||||||
|
#include FT_MODULE_H // <freetype/ftmodapi.h>
|
||||||
|
#include FT_GLYPH_H // <freetype/ftglyph.h>
|
||||||
|
#include FT_SYNTHESIS_H // <freetype/ftsynth.h>
|
||||||
|
|
||||||
|
#ifdef IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
#include FT_OTSVG_H // <freetype/otsvg.h>
|
||||||
|
#include FT_BBOX_H // <freetype/ftbbox.h>
|
||||||
|
#include <lunasvg.h>
|
||||||
|
#if !((FREETYPE_MAJOR >= 2) && (FREETYPE_MINOR >= 12))
|
||||||
|
#error IMGUI_ENABLE_FREETYPE_LUNASVG requires FreeType version >= 2.12
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#pragma warning (push)
|
||||||
|
#pragma warning (disable: 4505) // unreferenced local function has been removed (stb stuff)
|
||||||
|
#pragma warning (disable: 26812) // [Static Analyzer] The enum type 'xxx' is unscoped. Prefer 'enum class' over 'enum' (Enum.3).
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __GNUC__
|
||||||
|
#pragma GCC diagnostic push
|
||||||
|
#pragma GCC diagnostic ignored "-Wpragmas" // warning: unknown option after '#pragma GCC diagnostic' kind
|
||||||
|
#pragma GCC diagnostic ignored "-Wunused-function" // warning: 'xxxx' defined but not used
|
||||||
|
#ifndef __clang__
|
||||||
|
#pragma GCC diagnostic ignored "-Wsubobject-linkage" // warning: 'xxxx' has a field 'xxxx' whose type uses the anonymous namespace
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
// Data
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// Default memory allocators
|
||||||
|
static void* ImGuiFreeTypeDefaultAllocFunc(size_t size, void* user_data) { IM_UNUSED(user_data); return IM_ALLOC(size); }
|
||||||
|
static void ImGuiFreeTypeDefaultFreeFunc(void* ptr, void* user_data) { IM_UNUSED(user_data); IM_FREE(ptr); }
|
||||||
|
|
||||||
|
// Current memory allocators
|
||||||
|
static void* (*GImGuiFreeTypeAllocFunc)(size_t size, void* user_data) = ImGuiFreeTypeDefaultAllocFunc;
|
||||||
|
static void (*GImGuiFreeTypeFreeFunc)(void* ptr, void* user_data) = ImGuiFreeTypeDefaultFreeFunc;
|
||||||
|
static void* GImGuiFreeTypeAllocatorUserData = nullptr;
|
||||||
|
|
||||||
|
// Lunasvg support
|
||||||
|
#ifdef IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
static FT_Error ImGuiLunasvgPortInit(FT_Pointer* state);
|
||||||
|
static void ImGuiLunasvgPortFree(FT_Pointer* state);
|
||||||
|
static FT_Error ImGuiLunasvgPortRender(FT_GlyphSlot slot, FT_Pointer* _state);
|
||||||
|
static FT_Error ImGuiLunasvgPortPresetSlot(FT_GlyphSlot slot, FT_Bool cache, FT_Pointer* _state);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
// Code
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
// Glyph metrics:
|
||||||
|
// --------------
|
||||||
|
//
|
||||||
|
// xmin xmax
|
||||||
|
// | |
|
||||||
|
// |<-------- width -------->|
|
||||||
|
// | |
|
||||||
|
// | +-------------------------+----------------- ymax
|
||||||
|
// | | ggggggggg ggggg | ^ ^
|
||||||
|
// | | g:::::::::ggg::::g | | |
|
||||||
|
// | | g:::::::::::::::::g | | |
|
||||||
|
// | | g::::::ggggg::::::gg | | |
|
||||||
|
// | | g:::::g g:::::g | | |
|
||||||
|
// offsetX -|-------->| g:::::g g:::::g | offsetY |
|
||||||
|
// | | g:::::g g:::::g | | |
|
||||||
|
// | | g::::::g g:::::g | | |
|
||||||
|
// | | g:::::::ggggg:::::g | | |
|
||||||
|
// | | g::::::::::::::::g | | height
|
||||||
|
// | | gg::::::::::::::g | | |
|
||||||
|
// baseline ---*---------|---- gggggggg::::::g-----*-------- |
|
||||||
|
// / | | g:::::g | |
|
||||||
|
// origin | | gggggg g:::::g | |
|
||||||
|
// | | g:::::gg gg:::::g | |
|
||||||
|
// | | g::::::ggg:::::::g | |
|
||||||
|
// | | gg:::::::::::::g | |
|
||||||
|
// | | ggg::::::ggg | |
|
||||||
|
// | | gggggg | v
|
||||||
|
// | +-------------------------+----------------- ymin
|
||||||
|
// | |
|
||||||
|
// |------------- advanceX ----------->|
|
||||||
|
|
||||||
|
// A structure that describe a glyph.
|
||||||
|
struct GlyphInfo
|
||||||
|
{
|
||||||
|
int Width; // Glyph's width in pixels.
|
||||||
|
int Height; // Glyph's height in pixels.
|
||||||
|
FT_Int OffsetX; // The distance from the origin ("pen position") to the left of the glyph.
|
||||||
|
FT_Int OffsetY; // The distance from the origin to the top of the glyph. This is usually a value < 0.
|
||||||
|
float AdvanceX; // The distance from the origin to the origin of the next glyph. This is usually a value > 0.
|
||||||
|
bool IsColored; // The glyph is colored
|
||||||
|
};
|
||||||
|
|
||||||
|
// Font parameters and metrics.
|
||||||
|
struct FontInfo
|
||||||
|
{
|
||||||
|
uint32_t PixelHeight; // Size this font was generated with.
|
||||||
|
float Ascender; // The pixel extents above the baseline in pixels (typically positive).
|
||||||
|
float Descender; // The extents below the baseline in pixels (typically negative).
|
||||||
|
float LineSpacing; // The baseline-to-baseline distance. Note that it usually is larger than the sum of the ascender and descender taken as absolute values. There is also no guarantee that no glyphs extend above or below subsequent baselines when using this distance. Think of it as a value the designer of the font finds appropriate.
|
||||||
|
float LineGap; // The spacing in pixels between one row's descent and the next row's ascent.
|
||||||
|
float MaxAdvanceWidth; // This field gives the maximum horizontal cursor advance for all glyphs in the font.
|
||||||
|
};
|
||||||
|
|
||||||
|
// FreeType glyph rasterizer.
|
||||||
|
// NB: No ctor/dtor, explicitly call Init()/Shutdown()
|
||||||
|
struct FreeTypeFont
|
||||||
|
{
|
||||||
|
bool InitFont(FT_Library ft_library, const ImFontConfig& cfg, unsigned int extra_user_flags); // Initialize from an external data buffer. Doesn't copy data, and you must ensure it stays valid up to this object lifetime.
|
||||||
|
void CloseFont();
|
||||||
|
void SetPixelHeight(int pixel_height); // Change font pixel size. All following calls to RasterizeGlyph() will use this size
|
||||||
|
const FT_Glyph_Metrics* LoadGlyph(uint32_t in_codepoint);
|
||||||
|
const FT_Bitmap* RenderGlyphAndGetInfo(GlyphInfo* out_glyph_info);
|
||||||
|
void BlitGlyph(const FT_Bitmap* ft_bitmap, uint32_t* dst, uint32_t dst_pitch, unsigned char* multiply_table = nullptr);
|
||||||
|
~FreeTypeFont() { CloseFont(); }
|
||||||
|
|
||||||
|
// [Internals]
|
||||||
|
FontInfo Info; // Font descriptor of the current font.
|
||||||
|
FT_Face Face;
|
||||||
|
unsigned int UserFlags; // = ImFontConfig::RasterizerFlags
|
||||||
|
FT_Int32 LoadFlags;
|
||||||
|
FT_Render_Mode RenderMode;
|
||||||
|
float RasterizationDensity;
|
||||||
|
float InvRasterizationDensity;
|
||||||
|
};
|
||||||
|
|
||||||
|
// From SDL_ttf: Handy routines for converting from fixed point
|
||||||
|
#define FT_CEIL(X) (((X + 63) & -64) / 64)
|
||||||
|
|
||||||
|
bool FreeTypeFont::InitFont(FT_Library ft_library, const ImFontConfig& cfg, unsigned int extra_font_builder_flags)
|
||||||
|
{
|
||||||
|
FT_Error error = FT_New_Memory_Face(ft_library, (uint8_t*)cfg.FontData, (uint32_t)cfg.FontDataSize, (uint32_t)cfg.FontNo, &Face);
|
||||||
|
if (error != 0)
|
||||||
|
return false;
|
||||||
|
error = FT_Select_Charmap(Face, FT_ENCODING_UNICODE);
|
||||||
|
if (error != 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Convert to FreeType flags (NB: Bold and Oblique are processed separately)
|
||||||
|
UserFlags = cfg.FontBuilderFlags | extra_font_builder_flags;
|
||||||
|
|
||||||
|
LoadFlags = 0;
|
||||||
|
if ((UserFlags & ImGuiFreeTypeBuilderFlags_Bitmap) == 0)
|
||||||
|
LoadFlags |= FT_LOAD_NO_BITMAP;
|
||||||
|
|
||||||
|
if (UserFlags & ImGuiFreeTypeBuilderFlags_NoHinting)
|
||||||
|
LoadFlags |= FT_LOAD_NO_HINTING;
|
||||||
|
if (UserFlags & ImGuiFreeTypeBuilderFlags_NoAutoHint)
|
||||||
|
LoadFlags |= FT_LOAD_NO_AUTOHINT;
|
||||||
|
if (UserFlags & ImGuiFreeTypeBuilderFlags_ForceAutoHint)
|
||||||
|
LoadFlags |= FT_LOAD_FORCE_AUTOHINT;
|
||||||
|
if (UserFlags & ImGuiFreeTypeBuilderFlags_LightHinting)
|
||||||
|
LoadFlags |= FT_LOAD_TARGET_LIGHT;
|
||||||
|
else if (UserFlags & ImGuiFreeTypeBuilderFlags_MonoHinting)
|
||||||
|
LoadFlags |= FT_LOAD_TARGET_MONO;
|
||||||
|
else
|
||||||
|
LoadFlags |= FT_LOAD_TARGET_NORMAL;
|
||||||
|
|
||||||
|
if (UserFlags & ImGuiFreeTypeBuilderFlags_Monochrome)
|
||||||
|
RenderMode = FT_RENDER_MODE_MONO;
|
||||||
|
else
|
||||||
|
RenderMode = FT_RENDER_MODE_NORMAL;
|
||||||
|
|
||||||
|
if (UserFlags & ImGuiFreeTypeBuilderFlags_LoadColor)
|
||||||
|
LoadFlags |= FT_LOAD_COLOR;
|
||||||
|
|
||||||
|
RasterizationDensity = cfg.RasterizerDensity;
|
||||||
|
InvRasterizationDensity = 1.0f / RasterizationDensity;
|
||||||
|
|
||||||
|
memset(&Info, 0, sizeof(Info));
|
||||||
|
SetPixelHeight((uint32_t)cfg.SizePixels);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FreeTypeFont::CloseFont()
|
||||||
|
{
|
||||||
|
if (Face)
|
||||||
|
{
|
||||||
|
FT_Done_Face(Face);
|
||||||
|
Face = nullptr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void FreeTypeFont::SetPixelHeight(int pixel_height)
|
||||||
|
{
|
||||||
|
// Vuhdo: I'm not sure how to deal with font sizes properly. As far as I understand, currently ImGui assumes that the 'pixel_height'
|
||||||
|
// is a maximum height of an any given glyph, i.e. it's the sum of font's ascender and descender. Seems strange to me.
|
||||||
|
// NB: FT_Set_Pixel_Sizes() doesn't seem to get us the same result.
|
||||||
|
FT_Size_RequestRec req;
|
||||||
|
req.type = (UserFlags & ImGuiFreeTypeBuilderFlags_Bitmap) ? FT_SIZE_REQUEST_TYPE_NOMINAL : FT_SIZE_REQUEST_TYPE_REAL_DIM;
|
||||||
|
req.width = 0;
|
||||||
|
req.height = (uint32_t)(pixel_height * 64 * RasterizationDensity);
|
||||||
|
req.horiResolution = 0;
|
||||||
|
req.vertResolution = 0;
|
||||||
|
FT_Request_Size(Face, &req);
|
||||||
|
|
||||||
|
// Update font info
|
||||||
|
FT_Size_Metrics metrics = Face->size->metrics;
|
||||||
|
Info.PixelHeight = (uint32_t)(pixel_height * InvRasterizationDensity);
|
||||||
|
Info.Ascender = (float)FT_CEIL(metrics.ascender) * InvRasterizationDensity;
|
||||||
|
Info.Descender = (float)FT_CEIL(metrics.descender) * InvRasterizationDensity;
|
||||||
|
Info.LineSpacing = (float)FT_CEIL(metrics.height) * InvRasterizationDensity;
|
||||||
|
Info.LineGap = (float)FT_CEIL(metrics.height - metrics.ascender + metrics.descender) * InvRasterizationDensity;
|
||||||
|
Info.MaxAdvanceWidth = (float)FT_CEIL(metrics.max_advance) * InvRasterizationDensity;
|
||||||
|
}
|
||||||
|
|
||||||
|
const FT_Glyph_Metrics* FreeTypeFont::LoadGlyph(uint32_t codepoint)
|
||||||
|
{
|
||||||
|
uint32_t glyph_index = FT_Get_Char_Index(Face, codepoint);
|
||||||
|
if (glyph_index == 0)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
// If this crash for you: FreeType 2.11.0 has a crash bug on some bitmap/colored fonts.
|
||||||
|
// - https://gitlab.freedesktop.org/freetype/freetype/-/issues/1076
|
||||||
|
// - https://github.com/ocornut/imgui/issues/4567
|
||||||
|
// - https://github.com/ocornut/imgui/issues/4566
|
||||||
|
// You can use FreeType 2.10, or the patched version of 2.11.0 in VcPkg, or probably any upcoming FreeType version.
|
||||||
|
FT_Error error = FT_Load_Glyph(Face, glyph_index, LoadFlags);
|
||||||
|
if (error)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
// Need an outline for this to work
|
||||||
|
FT_GlyphSlot slot = Face->glyph;
|
||||||
|
#ifdef IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
IM_ASSERT(slot->format == FT_GLYPH_FORMAT_OUTLINE || slot->format == FT_GLYPH_FORMAT_BITMAP || slot->format == FT_GLYPH_FORMAT_SVG);
|
||||||
|
#else
|
||||||
|
#if ((FREETYPE_MAJOR >= 2) && (FREETYPE_MINOR >= 12))
|
||||||
|
IM_ASSERT(slot->format != FT_GLYPH_FORMAT_SVG && "The font contains SVG glyphs, you'll need to enable IMGUI_ENABLE_FREETYPE_LUNASVG in imconfig.h and install required libraries in order to use this font");
|
||||||
|
#endif
|
||||||
|
IM_ASSERT(slot->format == FT_GLYPH_FORMAT_OUTLINE || slot->format == FT_GLYPH_FORMAT_BITMAP);
|
||||||
|
#endif // IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
|
||||||
|
// Apply convenience transform (this is not picking from real "Bold"/"Italic" fonts! Merely applying FreeType helper transform. Oblique == Slanting)
|
||||||
|
if (UserFlags & ImGuiFreeTypeBuilderFlags_Bold)
|
||||||
|
FT_GlyphSlot_Embolden(slot);
|
||||||
|
if (UserFlags & ImGuiFreeTypeBuilderFlags_Oblique)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot_Oblique(slot);
|
||||||
|
//FT_BBox bbox;
|
||||||
|
//FT_Outline_Get_BBox(&slot->outline, &bbox);
|
||||||
|
//slot->metrics.width = bbox.xMax - bbox.xMin;
|
||||||
|
//slot->metrics.height = bbox.yMax - bbox.yMin;
|
||||||
|
}
|
||||||
|
|
||||||
|
return &slot->metrics;
|
||||||
|
}
|
||||||
|
|
||||||
|
const FT_Bitmap* FreeTypeFont::RenderGlyphAndGetInfo(GlyphInfo* out_glyph_info)
|
||||||
|
{
|
||||||
|
FT_GlyphSlot slot = Face->glyph;
|
||||||
|
FT_Error error = FT_Render_Glyph(slot, RenderMode);
|
||||||
|
if (error != 0)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
FT_Bitmap* ft_bitmap = &Face->glyph->bitmap;
|
||||||
|
out_glyph_info->Width = (int)ft_bitmap->width;
|
||||||
|
out_glyph_info->Height = (int)ft_bitmap->rows;
|
||||||
|
out_glyph_info->OffsetX = Face->glyph->bitmap_left;
|
||||||
|
out_glyph_info->OffsetY = -Face->glyph->bitmap_top;
|
||||||
|
out_glyph_info->AdvanceX = (float)FT_CEIL(slot->advance.x);
|
||||||
|
out_glyph_info->IsColored = (ft_bitmap->pixel_mode == FT_PIXEL_MODE_BGRA);
|
||||||
|
|
||||||
|
return ft_bitmap;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FreeTypeFont::BlitGlyph(const FT_Bitmap* ft_bitmap, uint32_t* dst, uint32_t dst_pitch, unsigned char* multiply_table)
|
||||||
|
{
|
||||||
|
IM_ASSERT(ft_bitmap != nullptr);
|
||||||
|
const uint32_t w = ft_bitmap->width;
|
||||||
|
const uint32_t h = ft_bitmap->rows;
|
||||||
|
const uint8_t* src = ft_bitmap->buffer;
|
||||||
|
const uint32_t src_pitch = ft_bitmap->pitch;
|
||||||
|
|
||||||
|
switch (ft_bitmap->pixel_mode)
|
||||||
|
{
|
||||||
|
case FT_PIXEL_MODE_GRAY: // Grayscale image, 1 byte per pixel.
|
||||||
|
{
|
||||||
|
if (multiply_table == nullptr)
|
||||||
|
{
|
||||||
|
for (uint32_t y = 0; y < h; y++, src += src_pitch, dst += dst_pitch)
|
||||||
|
for (uint32_t x = 0; x < w; x++)
|
||||||
|
dst[x] = IM_COL32(255, 255, 255, src[x]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (uint32_t y = 0; y < h; y++, src += src_pitch, dst += dst_pitch)
|
||||||
|
for (uint32_t x = 0; x < w; x++)
|
||||||
|
dst[x] = IM_COL32(255, 255, 255, multiply_table[src[x]]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case FT_PIXEL_MODE_MONO: // Monochrome image, 1 bit per pixel. The bits in each byte are ordered from MSB to LSB.
|
||||||
|
{
|
||||||
|
uint8_t color0 = multiply_table ? multiply_table[0] : 0;
|
||||||
|
uint8_t color1 = multiply_table ? multiply_table[255] : 255;
|
||||||
|
for (uint32_t y = 0; y < h; y++, src += src_pitch, dst += dst_pitch)
|
||||||
|
{
|
||||||
|
uint8_t bits = 0;
|
||||||
|
const uint8_t* bits_ptr = src;
|
||||||
|
for (uint32_t x = 0; x < w; x++, bits <<= 1)
|
||||||
|
{
|
||||||
|
if ((x & 7) == 0)
|
||||||
|
bits = *bits_ptr++;
|
||||||
|
dst[x] = IM_COL32(255, 255, 255, (bits & 0x80) ? color1 : color0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case FT_PIXEL_MODE_BGRA:
|
||||||
|
{
|
||||||
|
// FIXME: Converting pre-multiplied alpha to straight. Doesn't smell good.
|
||||||
|
#define DE_MULTIPLY(color, alpha) (ImU32)(255.0f * (float)color / (float)alpha + 0.5f)
|
||||||
|
if (multiply_table == nullptr)
|
||||||
|
{
|
||||||
|
for (uint32_t y = 0; y < h; y++, src += src_pitch, dst += dst_pitch)
|
||||||
|
for (uint32_t x = 0; x < w; x++)
|
||||||
|
{
|
||||||
|
uint8_t r = src[x * 4 + 2], g = src[x * 4 + 1], b = src[x * 4], a = src[x * 4 + 3];
|
||||||
|
dst[x] = IM_COL32(DE_MULTIPLY(r, a), DE_MULTIPLY(g, a), DE_MULTIPLY(b, a), a);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (uint32_t y = 0; y < h; y++, src += src_pitch, dst += dst_pitch)
|
||||||
|
{
|
||||||
|
for (uint32_t x = 0; x < w; x++)
|
||||||
|
{
|
||||||
|
uint8_t r = src[x * 4 + 2], g = src[x * 4 + 1], b = src[x * 4], a = src[x * 4 + 3];
|
||||||
|
dst[x] = IM_COL32(multiply_table[DE_MULTIPLY(r, a)], multiply_table[DE_MULTIPLY(g, a)], multiply_table[DE_MULTIPLY(b, a)], multiply_table[a]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#undef DE_MULTIPLY
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
IM_ASSERT(0 && "FreeTypeFont::BlitGlyph(): Unknown bitmap pixel mode!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
#ifndef STB_RECT_PACK_IMPLEMENTATION // in case the user already have an implementation in the _same_ compilation unit (e.g. unity builds)
|
||||||
|
#ifndef IMGUI_DISABLE_STB_RECT_PACK_IMPLEMENTATION
|
||||||
|
#define STBRP_ASSERT(x) do { IM_ASSERT(x); } while (0)
|
||||||
|
#define STBRP_STATIC
|
||||||
|
#define STB_RECT_PACK_IMPLEMENTATION
|
||||||
|
#endif
|
||||||
|
#ifdef IMGUI_STB_RECT_PACK_FILENAME
|
||||||
|
#include IMGUI_STB_RECT_PACK_FILENAME
|
||||||
|
#else
|
||||||
|
#include "imstb_rectpack.h"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
struct ImFontBuildSrcGlyphFT
|
||||||
|
{
|
||||||
|
GlyphInfo Info;
|
||||||
|
uint32_t Codepoint;
|
||||||
|
unsigned int* BitmapData; // Point within one of the dst_tmp_bitmap_buffers[] array
|
||||||
|
|
||||||
|
ImFontBuildSrcGlyphFT() { memset((void*)this, 0, sizeof(*this)); }
|
||||||
|
};
|
||||||
|
|
||||||
|
struct ImFontBuildSrcDataFT
|
||||||
|
{
|
||||||
|
FreeTypeFont Font;
|
||||||
|
stbrp_rect* Rects; // Rectangle to pack. We first fill in their size and the packer will give us their position.
|
||||||
|
const ImWchar* SrcRanges; // Ranges as requested by user (user is allowed to request too much, e.g. 0x0020..0xFFFF)
|
||||||
|
int DstIndex; // Index into atlas->Fonts[] and dst_tmp_array[]
|
||||||
|
int GlyphsHighest; // Highest requested codepoint
|
||||||
|
int GlyphsCount; // Glyph count (excluding missing glyphs and glyphs already set by an earlier source font)
|
||||||
|
ImBitVector GlyphsSet; // Glyph bit map (random access, 1-bit per codepoint. This will be a maximum of 8KB)
|
||||||
|
ImVector<ImFontBuildSrcGlyphFT> GlyphsList;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Temporary data for one destination ImFont* (multiple source fonts can be merged into one destination ImFont)
|
||||||
|
struct ImFontBuildDstDataFT
|
||||||
|
{
|
||||||
|
int SrcCount; // Number of source fonts targeting this destination font.
|
||||||
|
int GlyphsHighest;
|
||||||
|
int GlyphsCount;
|
||||||
|
ImBitVector GlyphsSet; // This is used to resolve collision when multiple sources are merged into a same destination font.
|
||||||
|
};
|
||||||
|
|
||||||
|
bool ImFontAtlasBuildWithFreeTypeEx(FT_Library ft_library, ImFontAtlas* atlas, unsigned int extra_flags)
|
||||||
|
{
|
||||||
|
IM_ASSERT(atlas->ConfigData.Size > 0);
|
||||||
|
|
||||||
|
ImFontAtlasBuildInit(atlas);
|
||||||
|
|
||||||
|
// Clear atlas
|
||||||
|
atlas->TexID = 0;
|
||||||
|
atlas->TexWidth = atlas->TexHeight = 0;
|
||||||
|
atlas->TexUvScale = ImVec2(0.0f, 0.0f);
|
||||||
|
atlas->TexUvWhitePixel = ImVec2(0.0f, 0.0f);
|
||||||
|
atlas->ClearTexData();
|
||||||
|
|
||||||
|
// Temporary storage for building
|
||||||
|
bool src_load_color = false;
|
||||||
|
ImVector<ImFontBuildSrcDataFT> src_tmp_array;
|
||||||
|
ImVector<ImFontBuildDstDataFT> dst_tmp_array;
|
||||||
|
src_tmp_array.resize(atlas->ConfigData.Size);
|
||||||
|
dst_tmp_array.resize(atlas->Fonts.Size);
|
||||||
|
memset((void*)src_tmp_array.Data, 0, (size_t)src_tmp_array.size_in_bytes());
|
||||||
|
memset((void*)dst_tmp_array.Data, 0, (size_t)dst_tmp_array.size_in_bytes());
|
||||||
|
|
||||||
|
// 1. Initialize font loading structure, check font data validity
|
||||||
|
for (int src_i = 0; src_i < atlas->ConfigData.Size; src_i++)
|
||||||
|
{
|
||||||
|
ImFontBuildSrcDataFT& src_tmp = src_tmp_array[src_i];
|
||||||
|
ImFontConfig& cfg = atlas->ConfigData[src_i];
|
||||||
|
FreeTypeFont& font_face = src_tmp.Font;
|
||||||
|
IM_ASSERT(cfg.DstFont && (!cfg.DstFont->IsLoaded() || cfg.DstFont->ContainerAtlas == atlas));
|
||||||
|
|
||||||
|
// Find index from cfg.DstFont (we allow the user to set cfg.DstFont. Also it makes casual debugging nicer than when storing indices)
|
||||||
|
src_tmp.DstIndex = -1;
|
||||||
|
for (int output_i = 0; output_i < atlas->Fonts.Size && src_tmp.DstIndex == -1; output_i++)
|
||||||
|
if (cfg.DstFont == atlas->Fonts[output_i])
|
||||||
|
src_tmp.DstIndex = output_i;
|
||||||
|
IM_ASSERT(src_tmp.DstIndex != -1); // cfg.DstFont not pointing within atlas->Fonts[] array?
|
||||||
|
if (src_tmp.DstIndex == -1)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Load font
|
||||||
|
if (!font_face.InitFont(ft_library, cfg, extra_flags))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Measure highest codepoints
|
||||||
|
src_load_color |= (cfg.FontBuilderFlags & ImGuiFreeTypeBuilderFlags_LoadColor) != 0;
|
||||||
|
ImFontBuildDstDataFT& dst_tmp = dst_tmp_array[src_tmp.DstIndex];
|
||||||
|
src_tmp.SrcRanges = cfg.GlyphRanges ? cfg.GlyphRanges : atlas->GetGlyphRangesDefault();
|
||||||
|
for (const ImWchar* src_range = src_tmp.SrcRanges; src_range[0] && src_range[1]; src_range += 2)
|
||||||
|
{
|
||||||
|
// Check for valid range. This may also help detect *some* dangling pointers, because a common
|
||||||
|
// user error is to setup ImFontConfig::GlyphRanges with a pointer to data that isn't persistent.
|
||||||
|
IM_ASSERT(src_range[0] <= src_range[1]);
|
||||||
|
src_tmp.GlyphsHighest = ImMax(src_tmp.GlyphsHighest, (int)src_range[1]);
|
||||||
|
}
|
||||||
|
dst_tmp.SrcCount++;
|
||||||
|
dst_tmp.GlyphsHighest = ImMax(dst_tmp.GlyphsHighest, src_tmp.GlyphsHighest);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 2. For every requested codepoint, check for their presence in the font data, and handle redundancy or overlaps between source fonts to avoid unused glyphs.
|
||||||
|
int total_glyphs_count = 0;
|
||||||
|
for (int src_i = 0; src_i < src_tmp_array.Size; src_i++)
|
||||||
|
{
|
||||||
|
ImFontBuildSrcDataFT& src_tmp = src_tmp_array[src_i];
|
||||||
|
ImFontBuildDstDataFT& dst_tmp = dst_tmp_array[src_tmp.DstIndex];
|
||||||
|
src_tmp.GlyphsSet.Create(src_tmp.GlyphsHighest + 1);
|
||||||
|
if (dst_tmp.GlyphsSet.Storage.empty())
|
||||||
|
dst_tmp.GlyphsSet.Create(dst_tmp.GlyphsHighest + 1);
|
||||||
|
|
||||||
|
for (const ImWchar* src_range = src_tmp.SrcRanges; src_range[0] && src_range[1]; src_range += 2)
|
||||||
|
for (int codepoint = src_range[0]; codepoint <= (int)src_range[1]; codepoint++)
|
||||||
|
{
|
||||||
|
if (dst_tmp.GlyphsSet.TestBit(codepoint)) // Don't overwrite existing glyphs. We could make this an option (e.g. MergeOverwrite)
|
||||||
|
continue;
|
||||||
|
uint32_t glyph_index = FT_Get_Char_Index(src_tmp.Font.Face, codepoint); // It is actually in the font? (FIXME-OPT: We are not storing the glyph_index..)
|
||||||
|
if (glyph_index == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Add to avail set/counters
|
||||||
|
src_tmp.GlyphsCount++;
|
||||||
|
dst_tmp.GlyphsCount++;
|
||||||
|
src_tmp.GlyphsSet.SetBit(codepoint);
|
||||||
|
dst_tmp.GlyphsSet.SetBit(codepoint);
|
||||||
|
total_glyphs_count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 3. Unpack our bit map into a flat list (we now have all the Unicode points that we know are requested _and_ available _and_ not overlapping another)
|
||||||
|
for (int src_i = 0; src_i < src_tmp_array.Size; src_i++)
|
||||||
|
{
|
||||||
|
ImFontBuildSrcDataFT& src_tmp = src_tmp_array[src_i];
|
||||||
|
src_tmp.GlyphsList.reserve(src_tmp.GlyphsCount);
|
||||||
|
|
||||||
|
IM_ASSERT(sizeof(src_tmp.GlyphsSet.Storage.Data[0]) == sizeof(ImU32));
|
||||||
|
const ImU32* it_begin = src_tmp.GlyphsSet.Storage.begin();
|
||||||
|
const ImU32* it_end = src_tmp.GlyphsSet.Storage.end();
|
||||||
|
for (const ImU32* it = it_begin; it < it_end; it++)
|
||||||
|
if (ImU32 entries_32 = *it)
|
||||||
|
for (ImU32 bit_n = 0; bit_n < 32; bit_n++)
|
||||||
|
if (entries_32 & ((ImU32)1 << bit_n))
|
||||||
|
{
|
||||||
|
ImFontBuildSrcGlyphFT src_glyph;
|
||||||
|
src_glyph.Codepoint = (ImWchar)(((it - it_begin) << 5) + bit_n);
|
||||||
|
//src_glyph.GlyphIndex = 0; // FIXME-OPT: We had this info in the previous step and lost it..
|
||||||
|
src_tmp.GlyphsList.push_back(src_glyph);
|
||||||
|
}
|
||||||
|
src_tmp.GlyphsSet.Clear();
|
||||||
|
IM_ASSERT(src_tmp.GlyphsList.Size == src_tmp.GlyphsCount);
|
||||||
|
}
|
||||||
|
for (int dst_i = 0; dst_i < dst_tmp_array.Size; dst_i++)
|
||||||
|
dst_tmp_array[dst_i].GlyphsSet.Clear();
|
||||||
|
dst_tmp_array.clear();
|
||||||
|
|
||||||
|
// Allocate packing character data and flag packed characters buffer as non-packed (x0=y0=x1=y1=0)
|
||||||
|
// (We technically don't need to zero-clear buf_rects, but let's do it for the sake of sanity)
|
||||||
|
ImVector<stbrp_rect> buf_rects;
|
||||||
|
buf_rects.resize(total_glyphs_count);
|
||||||
|
memset(buf_rects.Data, 0, (size_t)buf_rects.size_in_bytes());
|
||||||
|
|
||||||
|
// Allocate temporary rasterization data buffers.
|
||||||
|
// We could not find a way to retrieve accurate glyph size without rendering them.
|
||||||
|
// (e.g. slot->metrics->width not always matching bitmap->width, especially considering the Oblique transform)
|
||||||
|
// We allocate in chunks of 256 KB to not waste too much extra memory ahead. Hopefully users of FreeType won't mind the temporary allocations.
|
||||||
|
const int BITMAP_BUFFERS_CHUNK_SIZE = 256 * 1024;
|
||||||
|
int buf_bitmap_current_used_bytes = 0;
|
||||||
|
ImVector<unsigned char*> buf_bitmap_buffers;
|
||||||
|
buf_bitmap_buffers.push_back((unsigned char*)IM_ALLOC(BITMAP_BUFFERS_CHUNK_SIZE));
|
||||||
|
|
||||||
|
// 4. Gather glyphs sizes so we can pack them in our virtual canvas.
|
||||||
|
// 8. Render/rasterize font characters into the texture
|
||||||
|
int total_surface = 0;
|
||||||
|
int buf_rects_out_n = 0;
|
||||||
|
for (int src_i = 0; src_i < src_tmp_array.Size; src_i++)
|
||||||
|
{
|
||||||
|
ImFontBuildSrcDataFT& src_tmp = src_tmp_array[src_i];
|
||||||
|
ImFontConfig& cfg = atlas->ConfigData[src_i];
|
||||||
|
if (src_tmp.GlyphsCount == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
src_tmp.Rects = &buf_rects[buf_rects_out_n];
|
||||||
|
buf_rects_out_n += src_tmp.GlyphsCount;
|
||||||
|
|
||||||
|
// Compute multiply table if requested
|
||||||
|
const bool multiply_enabled = (cfg.RasterizerMultiply != 1.0f);
|
||||||
|
unsigned char multiply_table[256];
|
||||||
|
if (multiply_enabled)
|
||||||
|
ImFontAtlasBuildMultiplyCalcLookupTable(multiply_table, cfg.RasterizerMultiply);
|
||||||
|
|
||||||
|
// Gather the sizes of all rectangles we will need to pack
|
||||||
|
const int padding = atlas->TexGlyphPadding;
|
||||||
|
for (int glyph_i = 0; glyph_i < src_tmp.GlyphsList.Size; glyph_i++)
|
||||||
|
{
|
||||||
|
ImFontBuildSrcGlyphFT& src_glyph = src_tmp.GlyphsList[glyph_i];
|
||||||
|
|
||||||
|
const FT_Glyph_Metrics* metrics = src_tmp.Font.LoadGlyph(src_glyph.Codepoint);
|
||||||
|
if (metrics == nullptr)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Render glyph into a bitmap (currently held by FreeType)
|
||||||
|
const FT_Bitmap* ft_bitmap = src_tmp.Font.RenderGlyphAndGetInfo(&src_glyph.Info);
|
||||||
|
if (ft_bitmap == nullptr)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Allocate new temporary chunk if needed
|
||||||
|
const int bitmap_size_in_bytes = src_glyph.Info.Width * src_glyph.Info.Height * 4;
|
||||||
|
if (buf_bitmap_current_used_bytes + bitmap_size_in_bytes > BITMAP_BUFFERS_CHUNK_SIZE)
|
||||||
|
{
|
||||||
|
buf_bitmap_current_used_bytes = 0;
|
||||||
|
buf_bitmap_buffers.push_back((unsigned char*)IM_ALLOC(BITMAP_BUFFERS_CHUNK_SIZE));
|
||||||
|
}
|
||||||
|
IM_ASSERT(buf_bitmap_current_used_bytes + bitmap_size_in_bytes <= BITMAP_BUFFERS_CHUNK_SIZE); // We could probably allocate custom-sized buffer instead.
|
||||||
|
|
||||||
|
// Blit rasterized pixels to our temporary buffer and keep a pointer to it.
|
||||||
|
src_glyph.BitmapData = (unsigned int*)(buf_bitmap_buffers.back() + buf_bitmap_current_used_bytes);
|
||||||
|
buf_bitmap_current_used_bytes += bitmap_size_in_bytes;
|
||||||
|
src_tmp.Font.BlitGlyph(ft_bitmap, src_glyph.BitmapData, src_glyph.Info.Width, multiply_enabled ? multiply_table : nullptr);
|
||||||
|
|
||||||
|
src_tmp.Rects[glyph_i].w = (stbrp_coord)(src_glyph.Info.Width + padding);
|
||||||
|
src_tmp.Rects[glyph_i].h = (stbrp_coord)(src_glyph.Info.Height + padding);
|
||||||
|
total_surface += src_tmp.Rects[glyph_i].w * src_tmp.Rects[glyph_i].h;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// We need a width for the skyline algorithm, any width!
|
||||||
|
// The exact width doesn't really matter much, but some API/GPU have texture size limitations and increasing width can decrease height.
|
||||||
|
// User can override TexDesiredWidth and TexGlyphPadding if they wish, otherwise we use a simple heuristic to select the width based on expected surface.
|
||||||
|
const int surface_sqrt = (int)ImSqrt((float)total_surface) + 1;
|
||||||
|
atlas->TexHeight = 0;
|
||||||
|
if (atlas->TexDesiredWidth > 0)
|
||||||
|
atlas->TexWidth = atlas->TexDesiredWidth;
|
||||||
|
else
|
||||||
|
atlas->TexWidth = (surface_sqrt >= 4096 * 0.7f) ? 4096 : (surface_sqrt >= 2048 * 0.7f) ? 2048 : (surface_sqrt >= 1024 * 0.7f) ? 1024 : 512;
|
||||||
|
|
||||||
|
// 5. Start packing
|
||||||
|
// Pack our extra data rectangles first, so it will be on the upper-left corner of our texture (UV will have small values).
|
||||||
|
const int TEX_HEIGHT_MAX = 1024 * 32;
|
||||||
|
const int num_nodes_for_packing_algorithm = atlas->TexWidth - atlas->TexGlyphPadding;
|
||||||
|
ImVector<stbrp_node> pack_nodes;
|
||||||
|
pack_nodes.resize(num_nodes_for_packing_algorithm);
|
||||||
|
stbrp_context pack_context;
|
||||||
|
stbrp_init_target(&pack_context, atlas->TexWidth - atlas->TexGlyphPadding, TEX_HEIGHT_MAX - atlas->TexGlyphPadding, pack_nodes.Data, pack_nodes.Size);
|
||||||
|
ImFontAtlasBuildPackCustomRects(atlas, &pack_context);
|
||||||
|
|
||||||
|
// 6. Pack each source font. No rendering yet, we are working with rectangles in an infinitely tall texture at this point.
|
||||||
|
for (int src_i = 0; src_i < src_tmp_array.Size; src_i++)
|
||||||
|
{
|
||||||
|
ImFontBuildSrcDataFT& src_tmp = src_tmp_array[src_i];
|
||||||
|
if (src_tmp.GlyphsCount == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
stbrp_pack_rects(&pack_context, src_tmp.Rects, src_tmp.GlyphsCount);
|
||||||
|
|
||||||
|
// Extend texture height and mark missing glyphs as non-packed so we won't render them.
|
||||||
|
// FIXME: We are not handling packing failure here (would happen if we got off TEX_HEIGHT_MAX or if a single if larger than TexWidth?)
|
||||||
|
for (int glyph_i = 0; glyph_i < src_tmp.GlyphsCount; glyph_i++)
|
||||||
|
if (src_tmp.Rects[glyph_i].was_packed)
|
||||||
|
atlas->TexHeight = ImMax(atlas->TexHeight, src_tmp.Rects[glyph_i].y + src_tmp.Rects[glyph_i].h);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 7. Allocate texture
|
||||||
|
atlas->TexHeight = (atlas->Flags & ImFontAtlasFlags_NoPowerOfTwoHeight) ? (atlas->TexHeight + 1) : ImUpperPowerOfTwo(atlas->TexHeight);
|
||||||
|
atlas->TexUvScale = ImVec2(1.0f / atlas->TexWidth, 1.0f / atlas->TexHeight);
|
||||||
|
if (src_load_color)
|
||||||
|
{
|
||||||
|
size_t tex_size = (size_t)atlas->TexWidth * atlas->TexHeight * 4;
|
||||||
|
atlas->TexPixelsRGBA32 = (unsigned int*)IM_ALLOC(tex_size);
|
||||||
|
memset(atlas->TexPixelsRGBA32, 0, tex_size);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
size_t tex_size = (size_t)atlas->TexWidth * atlas->TexHeight * 1;
|
||||||
|
atlas->TexPixelsAlpha8 = (unsigned char*)IM_ALLOC(tex_size);
|
||||||
|
memset(atlas->TexPixelsAlpha8, 0, tex_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 8. Copy rasterized font characters back into the main texture
|
||||||
|
// 9. Setup ImFont and glyphs for runtime
|
||||||
|
bool tex_use_colors = false;
|
||||||
|
for (int src_i = 0; src_i < src_tmp_array.Size; src_i++)
|
||||||
|
{
|
||||||
|
ImFontBuildSrcDataFT& src_tmp = src_tmp_array[src_i];
|
||||||
|
if (src_tmp.GlyphsCount == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// When merging fonts with MergeMode=true:
|
||||||
|
// - We can have multiple input fonts writing into a same destination font.
|
||||||
|
// - dst_font->ConfigData is != from cfg which is our source configuration.
|
||||||
|
ImFontConfig& cfg = atlas->ConfigData[src_i];
|
||||||
|
ImFont* dst_font = cfg.DstFont;
|
||||||
|
|
||||||
|
const float ascent = src_tmp.Font.Info.Ascender;
|
||||||
|
const float descent = src_tmp.Font.Info.Descender;
|
||||||
|
ImFontAtlasBuildSetupFont(atlas, dst_font, &cfg, ascent, descent);
|
||||||
|
const float font_off_x = cfg.GlyphOffset.x;
|
||||||
|
const float font_off_y = cfg.GlyphOffset.y + IM_ROUND(dst_font->Ascent);
|
||||||
|
|
||||||
|
const int padding = atlas->TexGlyphPadding;
|
||||||
|
for (int glyph_i = 0; glyph_i < src_tmp.GlyphsCount; glyph_i++)
|
||||||
|
{
|
||||||
|
ImFontBuildSrcGlyphFT& src_glyph = src_tmp.GlyphsList[glyph_i];
|
||||||
|
stbrp_rect& pack_rect = src_tmp.Rects[glyph_i];
|
||||||
|
IM_ASSERT(pack_rect.was_packed);
|
||||||
|
if (pack_rect.w == 0 && pack_rect.h == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
GlyphInfo& info = src_glyph.Info;
|
||||||
|
IM_ASSERT(info.Width + padding <= pack_rect.w);
|
||||||
|
IM_ASSERT(info.Height + padding <= pack_rect.h);
|
||||||
|
const int tx = pack_rect.x + padding;
|
||||||
|
const int ty = pack_rect.y + padding;
|
||||||
|
|
||||||
|
// Register glyph
|
||||||
|
float x0 = info.OffsetX * src_tmp.Font.InvRasterizationDensity + font_off_x;
|
||||||
|
float y0 = info.OffsetY * src_tmp.Font.InvRasterizationDensity + font_off_y;
|
||||||
|
float x1 = x0 + info.Width * src_tmp.Font.InvRasterizationDensity;
|
||||||
|
float y1 = y0 + info.Height * src_tmp.Font.InvRasterizationDensity;
|
||||||
|
float u0 = (tx) / (float)atlas->TexWidth;
|
||||||
|
float v0 = (ty) / (float)atlas->TexHeight;
|
||||||
|
float u1 = (tx + info.Width) / (float)atlas->TexWidth;
|
||||||
|
float v1 = (ty + info.Height) / (float)atlas->TexHeight;
|
||||||
|
dst_font->AddGlyph(&cfg, (ImWchar)src_glyph.Codepoint, x0, y0, x1, y1, u0, v0, u1, v1, info.AdvanceX * src_tmp.Font.InvRasterizationDensity);
|
||||||
|
|
||||||
|
ImFontGlyph* dst_glyph = &dst_font->Glyphs.back();
|
||||||
|
IM_ASSERT(dst_glyph->Codepoint == src_glyph.Codepoint);
|
||||||
|
if (src_glyph.Info.IsColored)
|
||||||
|
dst_glyph->Colored = tex_use_colors = true;
|
||||||
|
|
||||||
|
// Blit from temporary buffer to final texture
|
||||||
|
size_t blit_src_stride = (size_t)src_glyph.Info.Width;
|
||||||
|
size_t blit_dst_stride = (size_t)atlas->TexWidth;
|
||||||
|
unsigned int* blit_src = src_glyph.BitmapData;
|
||||||
|
if (atlas->TexPixelsAlpha8 != nullptr)
|
||||||
|
{
|
||||||
|
unsigned char* blit_dst = atlas->TexPixelsAlpha8 + (ty * blit_dst_stride) + tx;
|
||||||
|
for (int y = 0; y < info.Height; y++, blit_dst += blit_dst_stride, blit_src += blit_src_stride)
|
||||||
|
for (int x = 0; x < info.Width; x++)
|
||||||
|
blit_dst[x] = (unsigned char)((blit_src[x] >> IM_COL32_A_SHIFT) & 0xFF);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
unsigned int* blit_dst = atlas->TexPixelsRGBA32 + (ty * blit_dst_stride) + tx;
|
||||||
|
for (int y = 0; y < info.Height; y++, blit_dst += blit_dst_stride, blit_src += blit_src_stride)
|
||||||
|
for (int x = 0; x < info.Width; x++)
|
||||||
|
blit_dst[x] = blit_src[x];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
src_tmp.Rects = nullptr;
|
||||||
|
}
|
||||||
|
atlas->TexPixelsUseColors = tex_use_colors;
|
||||||
|
|
||||||
|
// Cleanup
|
||||||
|
for (int buf_i = 0; buf_i < buf_bitmap_buffers.Size; buf_i++)
|
||||||
|
IM_FREE(buf_bitmap_buffers[buf_i]);
|
||||||
|
src_tmp_array.clear_destruct();
|
||||||
|
|
||||||
|
ImFontAtlasBuildFinish(atlas);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// FreeType memory allocation callbacks
|
||||||
|
static void* FreeType_Alloc(FT_Memory /*memory*/, long size)
|
||||||
|
{
|
||||||
|
return GImGuiFreeTypeAllocFunc((size_t)size, GImGuiFreeTypeAllocatorUserData);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void FreeType_Free(FT_Memory /*memory*/, void* block)
|
||||||
|
{
|
||||||
|
GImGuiFreeTypeFreeFunc(block, GImGuiFreeTypeAllocatorUserData);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void* FreeType_Realloc(FT_Memory /*memory*/, long cur_size, long new_size, void* block)
|
||||||
|
{
|
||||||
|
// Implement realloc() as we don't ask user to provide it.
|
||||||
|
if (block == nullptr)
|
||||||
|
return GImGuiFreeTypeAllocFunc((size_t)new_size, GImGuiFreeTypeAllocatorUserData);
|
||||||
|
|
||||||
|
if (new_size == 0)
|
||||||
|
{
|
||||||
|
GImGuiFreeTypeFreeFunc(block, GImGuiFreeTypeAllocatorUserData);
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (new_size > cur_size)
|
||||||
|
{
|
||||||
|
void* new_block = GImGuiFreeTypeAllocFunc((size_t)new_size, GImGuiFreeTypeAllocatorUserData);
|
||||||
|
memcpy(new_block, block, (size_t)cur_size);
|
||||||
|
GImGuiFreeTypeFreeFunc(block, GImGuiFreeTypeAllocatorUserData);
|
||||||
|
return new_block;
|
||||||
|
}
|
||||||
|
|
||||||
|
return block;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool ImFontAtlasBuildWithFreeType(ImFontAtlas* atlas)
|
||||||
|
{
|
||||||
|
// FreeType memory management: https://www.freetype.org/freetype2/docs/design/design-4.html
|
||||||
|
FT_MemoryRec_ memory_rec = {};
|
||||||
|
memory_rec.user = nullptr;
|
||||||
|
memory_rec.alloc = &FreeType_Alloc;
|
||||||
|
memory_rec.free = &FreeType_Free;
|
||||||
|
memory_rec.realloc = &FreeType_Realloc;
|
||||||
|
|
||||||
|
// https://www.freetype.org/freetype2/docs/reference/ft2-module_management.html#FT_New_Library
|
||||||
|
FT_Library ft_library;
|
||||||
|
FT_Error error = FT_New_Library(&memory_rec, &ft_library);
|
||||||
|
if (error != 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// If you don't call FT_Add_Default_Modules() the rest of code may work, but FreeType won't use our custom allocator.
|
||||||
|
FT_Add_Default_Modules(ft_library);
|
||||||
|
|
||||||
|
#ifdef IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
// Install svg hooks for FreeType
|
||||||
|
// https://freetype.org/freetype2/docs/reference/ft2-properties.html#svg-hooks
|
||||||
|
// https://freetype.org/freetype2/docs/reference/ft2-svg_fonts.html#svg_fonts
|
||||||
|
SVG_RendererHooks hooks = { ImGuiLunasvgPortInit, ImGuiLunasvgPortFree, ImGuiLunasvgPortRender, ImGuiLunasvgPortPresetSlot };
|
||||||
|
FT_Property_Set(ft_library, "ot-svg", "svg-hooks", &hooks);
|
||||||
|
#endif // IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
|
||||||
|
bool ret = ImFontAtlasBuildWithFreeTypeEx(ft_library, atlas, atlas->FontBuilderFlags);
|
||||||
|
FT_Done_Library(ft_library);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
const ImFontBuilderIO* ImGuiFreeType::GetBuilderForFreeType()
|
||||||
|
{
|
||||||
|
static ImFontBuilderIO io;
|
||||||
|
io.FontBuilder_Build = ImFontAtlasBuildWithFreeType;
|
||||||
|
return &io;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImGuiFreeType::SetAllocatorFunctions(void* (*alloc_func)(size_t sz, void* user_data), void (*free_func)(void* ptr, void* user_data), void* user_data)
|
||||||
|
{
|
||||||
|
GImGuiFreeTypeAllocFunc = alloc_func;
|
||||||
|
GImGuiFreeTypeFreeFunc = free_func;
|
||||||
|
GImGuiFreeTypeAllocatorUserData = user_data;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
// For more details, see https://gitlab.freedesktop.org/freetype/freetype-demos/-/blob/master/src/rsvg-port.c
|
||||||
|
// The original code from the demo is licensed under CeCILL-C Free Software License Agreement (https://gitlab.freedesktop.org/freetype/freetype/-/blob/master/LICENSE.TXT)
|
||||||
|
struct LunasvgPortState
|
||||||
|
{
|
||||||
|
FT_Error err = FT_Err_Ok;
|
||||||
|
lunasvg::Matrix matrix;
|
||||||
|
std::unique_ptr<lunasvg::Document> svg = nullptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
static FT_Error ImGuiLunasvgPortInit(FT_Pointer* _state)
|
||||||
|
{
|
||||||
|
*_state = IM_NEW(LunasvgPortState)();
|
||||||
|
return FT_Err_Ok;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ImGuiLunasvgPortFree(FT_Pointer* _state)
|
||||||
|
{
|
||||||
|
IM_DELETE(*(LunasvgPortState**)_state);
|
||||||
|
}
|
||||||
|
|
||||||
|
static FT_Error ImGuiLunasvgPortRender(FT_GlyphSlot slot, FT_Pointer* _state)
|
||||||
|
{
|
||||||
|
LunasvgPortState* state = *(LunasvgPortState**)_state;
|
||||||
|
|
||||||
|
// If there was an error while loading the svg in ImGuiLunasvgPortPresetSlot(), the renderer hook still get called, so just returns the error.
|
||||||
|
if (state->err != FT_Err_Ok)
|
||||||
|
return state->err;
|
||||||
|
|
||||||
|
// rows is height, pitch (or stride) equals to width * sizeof(int32)
|
||||||
|
lunasvg::Bitmap bitmap((uint8_t*)slot->bitmap.buffer, slot->bitmap.width, slot->bitmap.rows, slot->bitmap.pitch);
|
||||||
|
state->svg->setMatrix(state->svg->matrix().identity()); // Reset the svg matrix to the default value
|
||||||
|
state->svg->render(bitmap, state->matrix); // state->matrix is already scaled and translated
|
||||||
|
state->err = FT_Err_Ok;
|
||||||
|
return state->err;
|
||||||
|
}
|
||||||
|
|
||||||
|
static FT_Error ImGuiLunasvgPortPresetSlot(FT_GlyphSlot slot, FT_Bool cache, FT_Pointer* _state)
|
||||||
|
{
|
||||||
|
FT_SVG_Document document = (FT_SVG_Document)slot->other;
|
||||||
|
LunasvgPortState* state = *(LunasvgPortState**)_state;
|
||||||
|
FT_Size_Metrics& metrics = document->metrics;
|
||||||
|
|
||||||
|
// This function is called twice, once in the FT_Load_Glyph() and another right before ImGuiLunasvgPortRender().
|
||||||
|
// If it's the latter, don't do anything because it's // already done in the former.
|
||||||
|
if (cache)
|
||||||
|
return state->err;
|
||||||
|
|
||||||
|
state->svg = lunasvg::Document::loadFromData((const char*)document->svg_document, document->svg_document_length);
|
||||||
|
if (state->svg == nullptr)
|
||||||
|
{
|
||||||
|
state->err = FT_Err_Invalid_SVG_Document;
|
||||||
|
return state->err;
|
||||||
|
}
|
||||||
|
|
||||||
|
lunasvg::Box box = state->svg->box();
|
||||||
|
double scale = std::min(metrics.x_ppem / box.w, metrics.y_ppem / box.h);
|
||||||
|
double xx = (double)document->transform.xx / (1 << 16);
|
||||||
|
double xy = -(double)document->transform.xy / (1 << 16);
|
||||||
|
double yx = -(double)document->transform.yx / (1 << 16);
|
||||||
|
double yy = (double)document->transform.yy / (1 << 16);
|
||||||
|
double x0 = (double)document->delta.x / 64 * box.w / metrics.x_ppem;
|
||||||
|
double y0 = -(double)document->delta.y / 64 * box.h / metrics.y_ppem;
|
||||||
|
|
||||||
|
// Scale and transform, we don't translate the svg yet
|
||||||
|
state->matrix.identity();
|
||||||
|
state->matrix.scale(scale, scale);
|
||||||
|
state->matrix.transform(xx, xy, yx, yy, x0, y0);
|
||||||
|
state->svg->setMatrix(state->matrix);
|
||||||
|
|
||||||
|
// Pre-translate the matrix for the rendering step
|
||||||
|
state->matrix.translate(-box.x, -box.y);
|
||||||
|
|
||||||
|
// Get the box again after the transformation
|
||||||
|
box = state->svg->box();
|
||||||
|
|
||||||
|
// Calculate the bitmap size
|
||||||
|
slot->bitmap_left = FT_Int(box.x);
|
||||||
|
slot->bitmap_top = FT_Int(-box.y);
|
||||||
|
slot->bitmap.rows = (unsigned int)(ImCeil((float)box.h));
|
||||||
|
slot->bitmap.width = (unsigned int)(ImCeil((float)box.w));
|
||||||
|
slot->bitmap.pitch = slot->bitmap.width * 4;
|
||||||
|
slot->bitmap.pixel_mode = FT_PIXEL_MODE_BGRA;
|
||||||
|
|
||||||
|
// Compute all the bearings and set them correctly. The outline is scaled already, we just need to use the bounding box.
|
||||||
|
double metrics_width = box.w;
|
||||||
|
double metrics_height = box.h;
|
||||||
|
double horiBearingX = box.x;
|
||||||
|
double horiBearingY = -box.y;
|
||||||
|
double vertBearingX = slot->metrics.horiBearingX / 64.0 - slot->metrics.horiAdvance / 64.0 / 2.0;
|
||||||
|
double vertBearingY = (slot->metrics.vertAdvance / 64.0 - slot->metrics.height / 64.0) / 2.0;
|
||||||
|
slot->metrics.width = FT_Pos(IM_ROUND(metrics_width * 64.0)); // Using IM_ROUND() assume width and height are positive
|
||||||
|
slot->metrics.height = FT_Pos(IM_ROUND(metrics_height * 64.0));
|
||||||
|
slot->metrics.horiBearingX = FT_Pos(horiBearingX * 64);
|
||||||
|
slot->metrics.horiBearingY = FT_Pos(horiBearingY * 64);
|
||||||
|
slot->metrics.vertBearingX = FT_Pos(vertBearingX * 64);
|
||||||
|
slot->metrics.vertBearingY = FT_Pos(vertBearingY * 64);
|
||||||
|
|
||||||
|
if (slot->metrics.vertAdvance == 0)
|
||||||
|
slot->metrics.vertAdvance = FT_Pos(metrics_height * 1.2 * 64.0);
|
||||||
|
|
||||||
|
state->err = FT_Err_Ok;
|
||||||
|
return state->err;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // #ifdef IMGUI_ENABLE_FREETYPE_LUNASVG
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#ifdef __GNUC__
|
||||||
|
#pragma GCC diagnostic pop
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#pragma warning (pop)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // #ifndef IMGUI_DISABLE
|
||||||
@@ -0,0 +1,51 @@
|
|||||||
|
// dear imgui: FreeType font builder (used as a replacement for the stb_truetype builder)
|
||||||
|
// (headers)
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include "imgui.h" // IMGUI_API
|
||||||
|
#ifndef IMGUI_DISABLE
|
||||||
|
|
||||||
|
// Forward declarations
|
||||||
|
struct ImFontAtlas;
|
||||||
|
struct ImFontBuilderIO;
|
||||||
|
|
||||||
|
// Hinting greatly impacts visuals (and glyph sizes).
|
||||||
|
// - By default, hinting is enabled and the font's native hinter is preferred over the auto-hinter.
|
||||||
|
// - When disabled, FreeType generates blurrier glyphs, more or less matches the stb_truetype.h
|
||||||
|
// - The Default hinting mode usually looks good, but may distort glyphs in an unusual way.
|
||||||
|
// - The Light hinting mode generates fuzzier glyphs but better matches Microsoft's rasterizer.
|
||||||
|
// You can set those flags globaly in ImFontAtlas::FontBuilderFlags
|
||||||
|
// You can set those flags on a per font basis in ImFontConfig::FontBuilderFlags
|
||||||
|
enum ImGuiFreeTypeBuilderFlags
|
||||||
|
{
|
||||||
|
ImGuiFreeTypeBuilderFlags_NoHinting = 1 << 0, // Disable hinting. This generally generates 'blurrier' bitmap glyphs when the glyph are rendered in any of the anti-aliased modes.
|
||||||
|
ImGuiFreeTypeBuilderFlags_NoAutoHint = 1 << 1, // Disable auto-hinter.
|
||||||
|
ImGuiFreeTypeBuilderFlags_ForceAutoHint = 1 << 2, // Indicates that the auto-hinter is preferred over the font's native hinter.
|
||||||
|
ImGuiFreeTypeBuilderFlags_LightHinting = 1 << 3, // A lighter hinting algorithm for gray-level modes. Many generated glyphs are fuzzier but better resemble their original shape. This is achieved by snapping glyphs to the pixel grid only vertically (Y-axis), as is done by Microsoft's ClearType and Adobe's proprietary font renderer. This preserves inter-glyph spacing in horizontal text.
|
||||||
|
ImGuiFreeTypeBuilderFlags_MonoHinting = 1 << 4, // Strong hinting algorithm that should only be used for monochrome output.
|
||||||
|
ImGuiFreeTypeBuilderFlags_Bold = 1 << 5, // Styling: Should we artificially embolden the font?
|
||||||
|
ImGuiFreeTypeBuilderFlags_Oblique = 1 << 6, // Styling: Should we slant the font, emulating italic style?
|
||||||
|
ImGuiFreeTypeBuilderFlags_Monochrome = 1 << 7, // Disable anti-aliasing. Combine this with MonoHinting for best results!
|
||||||
|
ImGuiFreeTypeBuilderFlags_LoadColor = 1 << 8, // Enable FreeType color-layered glyphs
|
||||||
|
ImGuiFreeTypeBuilderFlags_Bitmap = 1 << 9 // Enable FreeType bitmap glyphs
|
||||||
|
};
|
||||||
|
|
||||||
|
namespace ImGuiFreeType
|
||||||
|
{
|
||||||
|
// This is automatically assigned when using '#define IMGUI_ENABLE_FREETYPE'.
|
||||||
|
// If you need to dynamically select between multiple builders:
|
||||||
|
// - you can manually assign this builder with 'atlas->FontBuilderIO = ImGuiFreeType::GetBuilderForFreeType()'
|
||||||
|
// - prefer deep-copying this into your own ImFontBuilderIO instance if you use hot-reloading that messes up static data.
|
||||||
|
IMGUI_API const ImFontBuilderIO* GetBuilderForFreeType();
|
||||||
|
|
||||||
|
// Override allocators. By default ImGuiFreeType will use IM_ALLOC()/IM_FREE()
|
||||||
|
// However, as FreeType does lots of allocations we provide a way for the user to redirect it to a separate memory heap if desired.
|
||||||
|
IMGUI_API void SetAllocatorFunctions(void* (*alloc_func)(size_t sz, void* user_data), void (*free_func)(void* ptr, void* user_data), void* user_data = nullptr);
|
||||||
|
|
||||||
|
// Obsolete names (will be removed soon)
|
||||||
|
#ifndef IMGUI_DISABLE_OBSOLETE_FUNCTIONS
|
||||||
|
//static inline bool BuildFontAtlas(ImFontAtlas* atlas, unsigned int flags = 0) { atlas->FontBuilderIO = GetBuilderForFreeType(); atlas->FontBuilderFlags = flags; return atlas->Build(); } // Prefer using '#define IMGUI_ENABLE_FREETYPE'
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // #ifndef IMGUI_DISABLE
|
||||||
+3526
File diff suppressed because it is too large
Load Diff
+4464
File diff suppressed because it is too large
Load Diff
+10250
File diff suppressed because it is too large
Load Diff
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user