🛠️🐜 Antkeeper superbuild with dependencies included https://antkeeper.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1523 lines
39 KiB

  1. <!doctype html>
  2. <html lang="en" class="no-js">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1">
  6. <meta name="description" content="API Reference Documentation for FreeType-2.11.0">
  7. <meta name="author" content="FreeType Contributors">
  8. <link rel="icon" href="images/favico.ico">
  9. <meta name="generator" content="mkdocs-1.2.1, mkdocs-material-7.1.9">
  10. <title>Glyph Color Management - FreeType-2.11.0 API Reference</title>
  11. <link rel="stylesheet" href="assets/stylesheets/main.ca7ac06f.min.css">
  12. <link rel="stylesheet" href="assets/stylesheets/palette.f1a3b89f.min.css">
  13. <meta name="theme-color" content="#4cae4f">
  14. <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
  15. <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Noto+Serif:300,400,400i,700%7CRoboto+Mono&display=fallback">
  16. <style>:root{--md-text-font-family:"Noto Serif";--md-code-font-family:"Roboto Mono"}</style>
  17. <link rel="stylesheet" href="stylesheets/extra.css">
  18. </head>
  19. <body dir="ltr" data-md-color-scheme="" data-md-color-primary="green" data-md-color-accent="green">
  20. <script>function __prefix(e){return new URL(".",location).pathname+"."+e}function __get(e,t=localStorage){return JSON.parse(t.getItem(__prefix(e)))}</script>
  21. <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
  22. <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
  23. <label class="md-overlay" for="__drawer"></label>
  24. <div data-md-component="skip">
  25. <a href="#glyph-color-management" class="md-skip">
  26. Skip to content
  27. </a>
  28. </div>
  29. <div data-md-component="announce">
  30. </div>
  31. <header class="md-header" data-md-component="header">
  32. <nav class="md-header__inner md-grid" aria-label="Header">
  33. <a href="index.html" title="FreeType-2.11.0 API Reference" class="md-header__button md-logo" aria-label="FreeType-2.11.0 API Reference" data-md-component="logo">
  34. <img src="images/favico.ico" alt="logo">
  35. </a>
  36. <label class="md-header__button md-icon" for="__drawer">
  37. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg>
  38. </label>
  39. <div class="md-header__title" data-md-component="header-title">
  40. <div class="md-header__ellipsis">
  41. <div class="md-header__topic">
  42. <span class="md-ellipsis">
  43. FreeType-2.11.0 API Reference
  44. </span>
  45. </div>
  46. <div class="md-header__topic" data-md-component="header-topic">
  47. <span class="md-ellipsis">
  48. Glyph Color Management
  49. </span>
  50. </div>
  51. </div>
  52. </div>
  53. <label class="md-header__button md-icon" for="__search">
  54. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg>
  55. </label>
  56. <div class="md-search" data-md-component="search" role="dialog">
  57. <label class="md-search__overlay" for="__search"></label>
  58. <div class="md-search__inner" role="search">
  59. <form class="md-search__form" name="search">
  60. <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" data-md-state="active" required>
  61. <label class="md-search__icon md-icon" for="__search">
  62. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg>
  63. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
  64. </label>
  65. <button type="reset" class="md-search__icon md-icon" aria-label="Clear" tabindex="-1">
  66. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"/></svg>
  67. </button>
  68. </form>
  69. <div class="md-search__output">
  70. <div class="md-search__scrollwrap" data-md-scrollfix>
  71. <div class="md-search-result" data-md-component="search-result">
  72. <div class="md-search-result__meta">
  73. Initializing search
  74. </div>
  75. <ol class="md-search-result__list"></ol>
  76. </div>
  77. </div>
  78. </div>
  79. </div>
  80. </div>
  81. </nav>
  82. </header>
  83. <div class="md-container" data-md-component="container">
  84. <main class="md-main" data-md-component="main">
  85. <div class="md-main__inner md-grid">
  86. <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
  87. <div class="md-sidebar__scrollwrap">
  88. <div class="md-sidebar__inner">
  89. <nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
  90. <label class="md-nav__title" for="__drawer">
  91. <a href="index.html" title="FreeType-2.11.0 API Reference" class="md-nav__button md-logo" aria-label="FreeType-2.11.0 API Reference" data-md-component="logo">
  92. <img src="images/favico.ico" alt="logo">
  93. </a>
  94. FreeType-2.11.0 API Reference
  95. </label>
  96. <ul class="md-nav__list" data-md-scrollfix>
  97. <li class="md-nav__item">
  98. <a href="index.html" class="md-nav__link">
  99. TOC
  100. </a>
  101. </li>
  102. <li class="md-nav__item">
  103. <a href="ft2-index.html" class="md-nav__link">
  104. Index
  105. </a>
  106. </li>
  107. <li class="md-nav__item md-nav__item--nested">
  108. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_3" type="checkbox" id="__nav_3" >
  109. <label class="md-nav__link" for="__nav_3">
  110. General Remarks
  111. <span class="md-nav__icon md-icon"></span>
  112. </label>
  113. <nav class="md-nav" aria-label="General Remarks" data-md-level="1">
  114. <label class="md-nav__title" for="__nav_3">
  115. <span class="md-nav__icon md-icon"></span>
  116. General Remarks
  117. </label>
  118. <ul class="md-nav__list" data-md-scrollfix>
  119. <li class="md-nav__item">
  120. <a href="ft2-preamble.html" class="md-nav__link">
  121. Preamble
  122. </a>
  123. </li>
  124. <li class="md-nav__item">
  125. <a href="ft2-header_inclusion.html" class="md-nav__link">
  126. FreeType's header inclusion scheme
  127. </a>
  128. </li>
  129. <li class="md-nav__item">
  130. <a href="ft2-user_allocation.html" class="md-nav__link">
  131. User allocation
  132. </a>
  133. </li>
  134. </ul>
  135. </nav>
  136. </li>
  137. <li class="md-nav__item md-nav__item--active md-nav__item--nested">
  138. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" checked>
  139. <label class="md-nav__link" for="__nav_4">
  140. Core API
  141. <span class="md-nav__icon md-icon"></span>
  142. </label>
  143. <nav class="md-nav" aria-label="Core API" data-md-level="1">
  144. <label class="md-nav__title" for="__nav_4">
  145. <span class="md-nav__icon md-icon"></span>
  146. Core API
  147. </label>
  148. <ul class="md-nav__list" data-md-scrollfix>
  149. <li class="md-nav__item">
  150. <a href="ft2-version.html" class="md-nav__link">
  151. FreeType Version
  152. </a>
  153. </li>
  154. <li class="md-nav__item">
  155. <a href="ft2-basic_types.html" class="md-nav__link">
  156. Basic Data Types
  157. </a>
  158. </li>
  159. <li class="md-nav__item">
  160. <a href="ft2-base_interface.html" class="md-nav__link">
  161. Base Interface
  162. </a>
  163. </li>
  164. <li class="md-nav__item">
  165. <a href="ft2-glyph_variants.html" class="md-nav__link">
  166. Unicode Variation Sequences
  167. </a>
  168. </li>
  169. <li class="md-nav__item md-nav__item--active">
  170. <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
  171. <label class="md-nav__link md-nav__link--active" for="__toc">
  172. Glyph Color Management
  173. <span class="md-nav__icon md-icon"></span>
  174. </label>
  175. <a href="ft2-color_management.html" class="md-nav__link md-nav__link--active">
  176. Glyph Color Management
  177. </a>
  178. <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
  179. <label class="md-nav__title" for="__toc">
  180. <span class="md-nav__icon md-icon"></span>
  181. Table of contents
  182. </label>
  183. <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
  184. <li class="md-nav__item">
  185. <a href="#synopsis" class="md-nav__link">
  186. Synopsis
  187. </a>
  188. </li>
  189. <li class="md-nav__item">
  190. <a href="#ft_color" class="md-nav__link">
  191. FT_Color
  192. </a>
  193. </li>
  194. <li class="md-nav__item">
  195. <a href="#ft_palette_xxx" class="md-nav__link">
  196. FT_PALETTE_XXX
  197. </a>
  198. </li>
  199. <li class="md-nav__item">
  200. <a href="#ft_palette_data" class="md-nav__link">
  201. FT_Palette_Data
  202. </a>
  203. </li>
  204. <li class="md-nav__item">
  205. <a href="#ft_palette_data_get" class="md-nav__link">
  206. FT_Palette_Data_Get
  207. </a>
  208. </li>
  209. <li class="md-nav__item">
  210. <a href="#ft_palette_select" class="md-nav__link">
  211. FT_Palette_Select
  212. </a>
  213. </li>
  214. <li class="md-nav__item">
  215. <a href="#ft_palette_set_foreground_color" class="md-nav__link">
  216. FT_Palette_Set_Foreground_Color
  217. </a>
  218. </li>
  219. </ul>
  220. </nav>
  221. </li>
  222. <li class="md-nav__item">
  223. <a href="ft2-layer_management.html" class="md-nav__link">
  224. Glyph Layer Management
  225. </a>
  226. </li>
  227. <li class="md-nav__item">
  228. <a href="ft2-glyph_management.html" class="md-nav__link">
  229. Glyph Management
  230. </a>
  231. </li>
  232. <li class="md-nav__item">
  233. <a href="ft2-mac_specific.html" class="md-nav__link">
  234. Mac Specific Interface
  235. </a>
  236. </li>
  237. <li class="md-nav__item">
  238. <a href="ft2-sizes_management.html" class="md-nav__link">
  239. Size Management
  240. </a>
  241. </li>
  242. <li class="md-nav__item">
  243. <a href="ft2-header_file_macros.html" class="md-nav__link">
  244. Header File Macros
  245. </a>
  246. </li>
  247. </ul>
  248. </nav>
  249. </li>
  250. <li class="md-nav__item md-nav__item--nested">
  251. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" >
  252. <label class="md-nav__link" for="__nav_5">
  253. Format-Specific API
  254. <span class="md-nav__icon md-icon"></span>
  255. </label>
  256. <nav class="md-nav" aria-label="Format-Specific API" data-md-level="1">
  257. <label class="md-nav__title" for="__nav_5">
  258. <span class="md-nav__icon md-icon"></span>
  259. Format-Specific API
  260. </label>
  261. <ul class="md-nav__list" data-md-scrollfix>
  262. <li class="md-nav__item">
  263. <a href="ft2-multiple_masters.html" class="md-nav__link">
  264. Multiple Masters
  265. </a>
  266. </li>
  267. <li class="md-nav__item">
  268. <a href="ft2-truetype_tables.html" class="md-nav__link">
  269. TrueType Tables
  270. </a>
  271. </li>
  272. <li class="md-nav__item">
  273. <a href="ft2-type1_tables.html" class="md-nav__link">
  274. Type 1 Tables
  275. </a>
  276. </li>
  277. <li class="md-nav__item">
  278. <a href="ft2-sfnt_names.html" class="md-nav__link">
  279. SFNT Names
  280. </a>
  281. </li>
  282. <li class="md-nav__item">
  283. <a href="ft2-bdf_fonts.html" class="md-nav__link">
  284. BDF and PCF Files
  285. </a>
  286. </li>
  287. <li class="md-nav__item">
  288. <a href="ft2-cid_fonts.html" class="md-nav__link">
  289. CID Fonts
  290. </a>
  291. </li>
  292. <li class="md-nav__item">
  293. <a href="ft2-pfr_fonts.html" class="md-nav__link">
  294. PFR Fonts
  295. </a>
  296. </li>
  297. <li class="md-nav__item">
  298. <a href="ft2-winfnt_fonts.html" class="md-nav__link">
  299. Window FNT Files
  300. </a>
  301. </li>
  302. <li class="md-nav__item">
  303. <a href="ft2-font_formats.html" class="md-nav__link">
  304. Font Formats
  305. </a>
  306. </li>
  307. <li class="md-nav__item">
  308. <a href="ft2-gasp_table.html" class="md-nav__link">
  309. Gasp Table
  310. </a>
  311. </li>
  312. </ul>
  313. </nav>
  314. </li>
  315. <li class="md-nav__item md-nav__item--nested">
  316. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" >
  317. <label class="md-nav__link" for="__nav_6">
  318. Controlling FreeType Modules
  319. <span class="md-nav__icon md-icon"></span>
  320. </label>
  321. <nav class="md-nav" aria-label="Controlling FreeType Modules" data-md-level="1">
  322. <label class="md-nav__title" for="__nav_6">
  323. <span class="md-nav__icon md-icon"></span>
  324. Controlling FreeType Modules
  325. </label>
  326. <ul class="md-nav__list" data-md-scrollfix>
  327. <li class="md-nav__item">
  328. <a href="ft2-auto_hinter.html" class="md-nav__link">
  329. The auto-hinter
  330. </a>
  331. </li>
  332. <li class="md-nav__item">
  333. <a href="ft2-cff_driver.html" class="md-nav__link">
  334. The CFF driver
  335. </a>
  336. </li>
  337. <li class="md-nav__item">
  338. <a href="ft2-t1_cid_driver.html" class="md-nav__link">
  339. The Type 1 and CID drivers
  340. </a>
  341. </li>
  342. <li class="md-nav__item">
  343. <a href="ft2-tt_driver.html" class="md-nav__link">
  344. The TrueType driver
  345. </a>
  346. </li>
  347. <li class="md-nav__item">
  348. <a href="ft2-pcf_driver.html" class="md-nav__link">
  349. The PCF driver
  350. </a>
  351. </li>
  352. <li class="md-nav__item">
  353. <a href="ft2-properties.html" class="md-nav__link">
  354. Driver properties
  355. </a>
  356. </li>
  357. <li class="md-nav__item">
  358. <a href="ft2-parameter_tags.html" class="md-nav__link">
  359. Parameter Tags
  360. </a>
  361. </li>
  362. <li class="md-nav__item">
  363. <a href="ft2-lcd_rendering.html" class="md-nav__link">
  364. Subpixel Rendering
  365. </a>
  366. </li>
  367. </ul>
  368. </nav>
  369. </li>
  370. <li class="md-nav__item md-nav__item--nested">
  371. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" >
  372. <label class="md-nav__link" for="__nav_7">
  373. Cache Sub-System
  374. <span class="md-nav__icon md-icon"></span>
  375. </label>
  376. <nav class="md-nav" aria-label="Cache Sub-System" data-md-level="1">
  377. <label class="md-nav__title" for="__nav_7">
  378. <span class="md-nav__icon md-icon"></span>
  379. Cache Sub-System
  380. </label>
  381. <ul class="md-nav__list" data-md-scrollfix>
  382. <li class="md-nav__item">
  383. <a href="ft2-cache_subsystem.html" class="md-nav__link">
  384. Cache Sub-System
  385. </a>
  386. </li>
  387. </ul>
  388. </nav>
  389. </li>
  390. <li class="md-nav__item md-nav__item--nested">
  391. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_8" type="checkbox" id="__nav_8" >
  392. <label class="md-nav__link" for="__nav_8">
  393. Support API
  394. <span class="md-nav__icon md-icon"></span>
  395. </label>
  396. <nav class="md-nav" aria-label="Support API" data-md-level="1">
  397. <label class="md-nav__title" for="__nav_8">
  398. <span class="md-nav__icon md-icon"></span>
  399. Support API
  400. </label>
  401. <ul class="md-nav__list" data-md-scrollfix>
  402. <li class="md-nav__item">
  403. <a href="ft2-computations.html" class="md-nav__link">
  404. Computations
  405. </a>
  406. </li>
  407. <li class="md-nav__item">
  408. <a href="ft2-list_processing.html" class="md-nav__link">
  409. List Processing
  410. </a>
  411. </li>
  412. <li class="md-nav__item">
  413. <a href="ft2-outline_processing.html" class="md-nav__link">
  414. Outline Processing
  415. </a>
  416. </li>
  417. <li class="md-nav__item">
  418. <a href="ft2-quick_advance.html" class="md-nav__link">
  419. Quick retrieval of advance values
  420. </a>
  421. </li>
  422. <li class="md-nav__item">
  423. <a href="ft2-bitmap_handling.html" class="md-nav__link">
  424. Bitmap Handling
  425. </a>
  426. </li>
  427. <li class="md-nav__item">
  428. <a href="ft2-raster.html" class="md-nav__link">
  429. Scanline Converter
  430. </a>
  431. </li>
  432. <li class="md-nav__item">
  433. <a href="ft2-glyph_stroker.html" class="md-nav__link">
  434. Glyph Stroker
  435. </a>
  436. </li>
  437. <li class="md-nav__item">
  438. <a href="ft2-system_interface.html" class="md-nav__link">
  439. System Interface
  440. </a>
  441. </li>
  442. <li class="md-nav__item">
  443. <a href="ft2-module_management.html" class="md-nav__link">
  444. Module Management
  445. </a>
  446. </li>
  447. <li class="md-nav__item">
  448. <a href="ft2-gzip.html" class="md-nav__link">
  449. GZIP Streams
  450. </a>
  451. </li>
  452. <li class="md-nav__item">
  453. <a href="ft2-lzw.html" class="md-nav__link">
  454. LZW Streams
  455. </a>
  456. </li>
  457. <li class="md-nav__item">
  458. <a href="ft2-bzip2.html" class="md-nav__link">
  459. BZIP2 Streams
  460. </a>
  461. </li>
  462. <li class="md-nav__item">
  463. <a href="ft2-debugging_apis.html" class="md-nav__link">
  464. External Debugging APIs
  465. </a>
  466. </li>
  467. </ul>
  468. </nav>
  469. </li>
  470. <li class="md-nav__item md-nav__item--nested">
  471. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_9" type="checkbox" id="__nav_9" >
  472. <label class="md-nav__link" for="__nav_9">
  473. Error Codes
  474. <span class="md-nav__icon md-icon"></span>
  475. </label>
  476. <nav class="md-nav" aria-label="Error Codes" data-md-level="1">
  477. <label class="md-nav__title" for="__nav_9">
  478. <span class="md-nav__icon md-icon"></span>
  479. Error Codes
  480. </label>
  481. <ul class="md-nav__list" data-md-scrollfix>
  482. <li class="md-nav__item">
  483. <a href="ft2-error_enumerations.html" class="md-nav__link">
  484. Error Enumerations
  485. </a>
  486. </li>
  487. <li class="md-nav__item">
  488. <a href="ft2-error_code_values.html" class="md-nav__link">
  489. Error Code Values
  490. </a>
  491. </li>
  492. </ul>
  493. </nav>
  494. </li>
  495. <li class="md-nav__item md-nav__item--nested">
  496. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_10" type="checkbox" id="__nav_10" >
  497. <label class="md-nav__link" for="__nav_10">
  498. Miscellaneous
  499. <span class="md-nav__icon md-icon"></span>
  500. </label>
  501. <nav class="md-nav" aria-label="Miscellaneous" data-md-level="1">
  502. <label class="md-nav__title" for="__nav_10">
  503. <span class="md-nav__icon md-icon"></span>
  504. Miscellaneous
  505. </label>
  506. <ul class="md-nav__list" data-md-scrollfix>
  507. <li class="md-nav__item">
  508. <a href="ft2-gx_validation.html" class="md-nav__link">
  509. TrueTypeGX/AAT Validation
  510. </a>
  511. </li>
  512. <li class="md-nav__item">
  513. <a href="ft2-incremental.html" class="md-nav__link">
  514. Incremental Loading
  515. </a>
  516. </li>
  517. <li class="md-nav__item">
  518. <a href="ft2-truetype_engine.html" class="md-nav__link">
  519. The TrueType Engine
  520. </a>
  521. </li>
  522. <li class="md-nav__item">
  523. <a href="ft2-ot_validation.html" class="md-nav__link">
  524. OpenType Validation
  525. </a>
  526. </li>
  527. </ul>
  528. </nav>
  529. </li>
  530. </ul>
  531. </nav>
  532. </div>
  533. </div>
  534. </div>
  535. <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
  536. <div class="md-sidebar__scrollwrap">
  537. <div class="md-sidebar__inner">
  538. <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
  539. <label class="md-nav__title" for="__toc">
  540. <span class="md-nav__icon md-icon"></span>
  541. Table of contents
  542. </label>
  543. <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
  544. <li class="md-nav__item">
  545. <a href="#synopsis" class="md-nav__link">
  546. Synopsis
  547. </a>
  548. </li>
  549. <li class="md-nav__item">
  550. <a href="#ft_color" class="md-nav__link">
  551. FT_Color
  552. </a>
  553. </li>
  554. <li class="md-nav__item">
  555. <a href="#ft_palette_xxx" class="md-nav__link">
  556. FT_PALETTE_XXX
  557. </a>
  558. </li>
  559. <li class="md-nav__item">
  560. <a href="#ft_palette_data" class="md-nav__link">
  561. FT_Palette_Data
  562. </a>
  563. </li>
  564. <li class="md-nav__item">
  565. <a href="#ft_palette_data_get" class="md-nav__link">
  566. FT_Palette_Data_Get
  567. </a>
  568. </li>
  569. <li class="md-nav__item">
  570. <a href="#ft_palette_select" class="md-nav__link">
  571. FT_Palette_Select
  572. </a>
  573. </li>
  574. <li class="md-nav__item">
  575. <a href="#ft_palette_set_foreground_color" class="md-nav__link">
  576. FT_Palette_Set_Foreground_Color
  577. </a>
  578. </li>
  579. </ul>
  580. </nav>
  581. </div>
  582. </div>
  583. </div>
  584. <div class="md-content" data-md-component="content">
  585. <article class="md-content__inner md-typeset">
  586. <p><a href="https://www.freetype.org">FreeType</a> &raquo; <a href="../">Docs</a> &raquo; <a href="index.html#core-api">Core API</a> &raquo; Glyph Color Management</p>
  587. <hr />
  588. <h1 id="glyph-color-management">Glyph Color Management<a class="headerlink" href="#glyph-color-management" title="Permanent link">&para;</a></h1>
  589. <h2 id="synopsis">Synopsis<a class="headerlink" href="#synopsis" title="Permanent link">&para;</a></h2>
  590. <p>The functions described here allow access and manipulation of color palette entries in OpenType's &lsquo;CPAL&rsquo; tables.</p>
  591. <h2 id="ft_color">FT_Color<a class="headerlink" href="#ft_color" title="Permanent link">&para;</a></h2>
  592. <p>Defined in FT_COLOR_H (freetype/ftcolor.h).</p>
  593. <div class = "codehilite"><pre><code> <span class="keyword">typedef</span> <span class="keyword">struct</span> FT_Color_
  594. {
  595. <a href="ft2-basic_types.html#ft_byte">FT_Byte</a> blue;
  596. <a href="ft2-basic_types.html#ft_byte">FT_Byte</a> green;
  597. <a href="ft2-basic_types.html#ft_byte">FT_Byte</a> red;
  598. <a href="ft2-basic_types.html#ft_byte">FT_Byte</a> alpha;
  599. } <b>FT_Color</b>;
  600. </code></pre></div>
  601. <p>This structure models a BGRA color value of a &lsquo;CPAL&rsquo; palette entry.</p>
  602. <p>The used color space is sRGB; the colors are not pre-multiplied, and alpha values must be explicitly set.</p>
  603. <h4>fields</h4>
  604. <table class="fields">
  605. <tr><td class="val" id="blue">blue</td><td class="desc">
  606. <p>Blue value.</p>
  607. </td></tr>
  608. <tr><td class="val" id="green">green</td><td class="desc">
  609. <p>Green value.</p>
  610. </td></tr>
  611. <tr><td class="val" id="red">red</td><td class="desc">
  612. <p>Red value.</p>
  613. </td></tr>
  614. <tr><td class="val" id="alpha">alpha</td><td class="desc">
  615. <p>Alpha value, giving the red, green, and blue color's opacity.</p>
  616. </td></tr>
  617. </table>
  618. <h4>since</h4>
  619. <p>2.10</p>
  620. <hr>
  621. <h2 id="ft_palette_xxx">FT_PALETTE_XXX<a class="headerlink" href="#ft_palette_xxx" title="Permanent link">&para;</a></h2>
  622. <p>Defined in FT_COLOR_H (freetype/ftcolor.h).</p>
  623. <div class = "codehilite"><pre><code>#<span class="keyword">define</span> <a href="ft2-color_management.html#ft_palette_for_light_background">FT_PALETTE_FOR_LIGHT_BACKGROUND</a> 0x01
  624. #<span class="keyword">define</span> <a href="ft2-color_management.html#ft_palette_for_dark_background">FT_PALETTE_FOR_DARK_BACKGROUND</a> 0x02
  625. </code></pre></div>
  626. <p>A list of bit field constants used in the <code>palette_flags</code> array of the <code><a href="ft2-color_management.html#ft_palette_data">FT_Palette_Data</a></code> structure to indicate for which background a palette with a given index is usable.</p>
  627. <h4>values</h4>
  628. <table class="fields long">
  629. <tr><td class="val" id="ft_palette_for_light_background">FT_PALETTE_FOR_LIGHT_BACKGROUND</td><td class="desc">
  630. <p>The palette is appropriate to use when displaying the font on a light background such as white.</p>
  631. </td></tr>
  632. <tr><td class="val" id="ft_palette_for_dark_background">FT_PALETTE_FOR_DARK_BACKGROUND</td><td class="desc">
  633. <p>The palette is appropriate to use when displaying the font on a dark background such as black.</p>
  634. </td></tr>
  635. </table>
  636. <h4>since</h4>
  637. <p>2.10</p>
  638. <hr>
  639. <h2 id="ft_palette_data">FT_Palette_Data<a class="headerlink" href="#ft_palette_data" title="Permanent link">&para;</a></h2>
  640. <p>Defined in FT_COLOR_H (freetype/ftcolor.h).</p>
  641. <div class = "codehilite"><pre><code> <span class="keyword">typedef</span> <span class="keyword">struct</span> FT_Palette_Data_ {
  642. <a href="ft2-basic_types.html#ft_ushort">FT_UShort</a> num_palettes;
  643. <span class="keyword">const</span> <a href="ft2-basic_types.html#ft_ushort">FT_UShort</a>* palette_name_ids;
  644. <span class="keyword">const</span> <a href="ft2-basic_types.html#ft_ushort">FT_UShort</a>* palette_flags;
  645. <a href="ft2-basic_types.html#ft_ushort">FT_UShort</a> num_palette_entries;
  646. <span class="keyword">const</span> <a href="ft2-basic_types.html#ft_ushort">FT_UShort</a>* palette_entry_name_ids;
  647. } <b>FT_Palette_Data</b>;
  648. </code></pre></div>
  649. <p>This structure holds the data of the &lsquo;CPAL&rsquo; table.</p>
  650. <h4>fields</h4>
  651. <table class="fields">
  652. <tr><td class="val" id="num_palettes">num_palettes</td><td class="desc">
  653. <p>The number of palettes.</p>
  654. </td></tr>
  655. <tr><td class="val" id="palette_name_ids">palette_name_ids</td><td class="desc">
  656. <p>An optional read-only array of palette name IDs with <code>num_palettes</code> elements, corresponding to entries like &lsquo;dark&rsquo; or &lsquo;light&rsquo; in the font's &lsquo;name&rsquo; table.</p>
  657. <p>An empty name ID in the &lsquo;CPAL&rsquo; table gets represented as value 0xFFFF.</p>
  658. <p><code>NULL</code> if the font's &lsquo;CPAL&rsquo; table doesn't contain appropriate data.</p>
  659. </td></tr>
  660. <tr><td class="val" id="palette_flags">palette_flags</td><td class="desc">
  661. <p>An optional read-only array of palette flags with <code>num_palettes</code> elements. Possible values are an ORed combination of <code><a href="ft2-color_management.html#ft_palette_xxx">FT_PALETTE_FOR_LIGHT_BACKGROUND</a></code> and <code><a href="ft2-color_management.html#ft_palette_xxx">FT_PALETTE_FOR_DARK_BACKGROUND</a></code>.</p>
  662. <p><code>NULL</code> if the font's &lsquo;CPAL&rsquo; table doesn't contain appropriate data.</p>
  663. </td></tr>
  664. <tr><td class="val" id="num_palette_entries">num_palette_entries</td><td class="desc">
  665. <p>The number of entries in a single palette. All palettes have the same size.</p>
  666. </td></tr>
  667. <tr><td class="val" id="palette_entry_name_ids">palette_entry_name_ids</td><td class="desc">
  668. <p>An optional read-only array of palette entry name IDs with <code>num_palette_entries</code>. In each palette, entries with the same index have the same function. For example, index&nbsp;0 might correspond to string &lsquo;outline&rsquo; in the font's &lsquo;name&rsquo; table to indicate that this palette entry is used for outlines, index&nbsp;1 might correspond to &lsquo;fill&rsquo; to indicate the filling color palette entry, etc.</p>
  669. <p>An empty entry name ID in the &lsquo;CPAL&rsquo; table gets represented as value 0xFFFF.</p>
  670. <p><code>NULL</code> if the font's &lsquo;CPAL&rsquo; table doesn't contain appropriate data.</p>
  671. </td></tr>
  672. </table>
  673. <h4>note</h4>
  674. <p>Use function <code><a href="ft2-sfnt_names.html#ft_get_sfnt_name">FT_Get_Sfnt_Name</a></code> to map name IDs and entry name IDs to name strings.</p>
  675. <p>Use function <code><a href="ft2-color_management.html#ft_palette_select">FT_Palette_Select</a></code> to get the colors associated with a palette entry.</p>
  676. <h4>since</h4>
  677. <p>2.10</p>
  678. <hr>
  679. <h2 id="ft_palette_data_get">FT_Palette_Data_Get<a class="headerlink" href="#ft_palette_data_get" title="Permanent link">&para;</a></h2>
  680. <p>Defined in FT_COLOR_H (freetype/ftcolor.h).</p>
  681. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  682. <b>FT_Palette_Data_Get</b>( <a href="ft2-base_interface.html#ft_face">FT_Face</a> face,
  683. <a href="ft2-color_management.html#ft_palette_data">FT_Palette_Data</a> *apalette );
  684. </code></pre></div>
  685. <p>Retrieve the face's color palette data.</p>
  686. <h4>input</h4>
  687. <table class="fields">
  688. <tr><td class="val" id="face">face</td><td class="desc">
  689. <p>The source face handle.</p>
  690. </td></tr>
  691. </table>
  692. <h4>output</h4>
  693. <table class="fields">
  694. <tr><td class="val" id="apalette">apalette</td><td class="desc">
  695. <p>A pointer to an <code><a href="ft2-color_management.html#ft_palette_data">FT_Palette_Data</a></code> structure.</p>
  696. </td></tr>
  697. </table>
  698. <h4>return</h4>
  699. <p>FreeType error code. 0&nbsp;means success.</p>
  700. <h4>note</h4>
  701. <p>All arrays in the returned <code><a href="ft2-color_management.html#ft_palette_data">FT_Palette_Data</a></code> structure are read-only.</p>
  702. <p>This function always returns an error if the config macro <code>TT_CONFIG_OPTION_COLOR_LAYERS</code> is not defined in <code>ftoption.h</code>.</p>
  703. <h4>since</h4>
  704. <p>2.10</p>
  705. <hr>
  706. <h2 id="ft_palette_select">FT_Palette_Select<a class="headerlink" href="#ft_palette_select" title="Permanent link">&para;</a></h2>
  707. <p>Defined in FT_COLOR_H (freetype/ftcolor.h).</p>
  708. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  709. <b>FT_Palette_Select</b>( <a href="ft2-base_interface.html#ft_face">FT_Face</a> face,
  710. <a href="ft2-basic_types.html#ft_ushort">FT_UShort</a> palette_index,
  711. <a href="ft2-color_management.html#ft_color">FT_Color</a>* *apalette );
  712. </code></pre></div>
  713. <p>This function has two purposes.</p>
  714. <p>(1) It activates a palette for rendering color glyphs, and</p>
  715. <p>(2) it retrieves all (unmodified) color entries of this palette. This function returns a read-write array, which means that a calling application can modify the palette entries on demand.</p>
  716. <p>A corollary of (2) is that calling the function, then modifying some values, then calling the function again with the same arguments resets all color entries to the original &lsquo;CPAL&rsquo; values; all user modifications are lost.</p>
  717. <h4>input</h4>
  718. <table class="fields">
  719. <tr><td class="val" id="face">face</td><td class="desc">
  720. <p>The source face handle.</p>
  721. </td></tr>
  722. <tr><td class="val" id="palette_index">palette_index</td><td class="desc">
  723. <p>The palette index.</p>
  724. </td></tr>
  725. </table>
  726. <h4>output</h4>
  727. <table class="fields">
  728. <tr><td class="val" id="apalette">apalette</td><td class="desc">
  729. <p>An array of color entries for a palette with index <code>palette_index</code>, having <code>num_palette_entries</code> elements (as found in the <code>FT_Palette_Data</code> structure). If <code>apalette</code> is set to <code>NULL</code>, no array gets returned (and no color entries can be modified).</p>
  730. <p>In case the font doesn't support color palettes, <code>NULL</code> is returned.</p>
  731. </td></tr>
  732. </table>
  733. <h4>return</h4>
  734. <p>FreeType error code. 0&nbsp;means success.</p>
  735. <h4>note</h4>
  736. <p>The array pointed to by <code>apalette_entries</code> is owned and managed by FreeType.</p>
  737. <p>This function always returns an error if the config macro <code>TT_CONFIG_OPTION_COLOR_LAYERS</code> is not defined in <code>ftoption.h</code>.</p>
  738. <h4>since</h4>
  739. <p>2.10</p>
  740. <hr>
  741. <h2 id="ft_palette_set_foreground_color">FT_Palette_Set_Foreground_Color<a class="headerlink" href="#ft_palette_set_foreground_color" title="Permanent link">&para;</a></h2>
  742. <p>Defined in FT_COLOR_H (freetype/ftcolor.h).</p>
  743. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  744. <b>FT_Palette_Set_Foreground_Color</b>( <a href="ft2-base_interface.html#ft_face">FT_Face</a> face,
  745. <a href="ft2-color_management.html#ft_color">FT_Color</a> foreground_color );
  746. </code></pre></div>
  747. <p>&lsquo;COLR&rsquo; uses palette index 0xFFFF to indicate a &lsquo;text foreground color&rsquo;. This function sets this value.</p>
  748. <h4>input</h4>
  749. <table class="fields">
  750. <tr><td class="val" id="face">face</td><td class="desc">
  751. <p>The source face handle.</p>
  752. </td></tr>
  753. <tr><td class="val" id="foreground_color">foreground_color</td><td class="desc">
  754. <p>An <code>FT_Color</code> structure to define the text foreground color.</p>
  755. </td></tr>
  756. </table>
  757. <h4>return</h4>
  758. <p>FreeType error code. 0&nbsp;means success.</p>
  759. <h4>note</h4>
  760. <p>If this function isn't called, the text foreground color is set to white opaque (BGRA value 0xFFFFFFFF) if <code><a href="ft2-color_management.html#ft_palette_xxx">FT_PALETTE_FOR_DARK_BACKGROUND</a></code> is present for the current palette, and black opaque (BGRA value 0x000000FF) otherwise, including the case that no palette types are available in the &lsquo;CPAL&rsquo; table.</p>
  761. <p>This function always returns an error if the config macro <code>TT_CONFIG_OPTION_COLOR_LAYERS</code> is not defined in <code>ftoption.h</code>.</p>
  762. <h4>since</h4>
  763. <p>2.10</p>
  764. <hr>
  765. </article>
  766. </div>
  767. </div>
  768. </main>
  769. <footer class="md-footer">
  770. <nav class="md-footer__inner md-grid" aria-label="Footer">
  771. <a href="ft2-glyph_variants.html" class="md-footer__link md-footer__link--prev" aria-label="Previous: Unicode Variation Sequences" rel="prev">
  772. <div class="md-footer__button md-icon">
  773. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
  774. </div>
  775. <div class="md-footer__title">
  776. <div class="md-ellipsis">
  777. <span class="md-footer__direction">
  778. Previous
  779. </span>
  780. Unicode Variation Sequences
  781. </div>
  782. </div>
  783. </a>
  784. <a href="ft2-layer_management.html" class="md-footer__link md-footer__link--next" aria-label="Next: Glyph Layer Management" rel="next">
  785. <div class="md-footer__title">
  786. <div class="md-ellipsis">
  787. <span class="md-footer__direction">
  788. Next
  789. </span>
  790. Glyph Layer Management
  791. </div>
  792. </div>
  793. <div class="md-footer__button md-icon">
  794. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11H4z"/></svg>
  795. </div>
  796. </a>
  797. </nav>
  798. <div class="md-footer-meta md-typeset">
  799. <div class="md-footer-meta__inner md-grid">
  800. <div class="md-footer-copyright">
  801. <div class="md-footer-copyright__highlight">
  802. Copyright 2021 <a href = "https://www.freetype.org/license.html">The FreeType Project</a>.
  803. </div>
  804. Made with
  805. <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
  806. Material for MkDocs
  807. </a>
  808. </div>
  809. </div>
  810. </div>
  811. </footer>
  812. </div>
  813. <div class="md-dialog" data-md-component="dialog">
  814. <div class="md-dialog__inner md-typeset"></div>
  815. </div>
  816. <script id="__config" type="application/json">{"base": ".", "features": [], "translations": {"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.term.missing": "Missing", "select.version.title": "Select version"}, "search": "assets/javascripts/workers/search.477d984a.min.js", "version": null}</script>
  817. <script src="assets/javascripts/bundle.82b56eb2.min.js"></script>
  818. <script src="javascripts/extra.js"></script>
  819. </body>
  820. </html>