🛠️🐜 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.

1568 lines
40 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>Bitmap Handling - 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="#bitmap-handling" 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. Bitmap Handling
  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--nested">
  138. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" >
  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">
  170. <a href="ft2-color_management.html" class="md-nav__link">
  171. Glyph Color Management
  172. </a>
  173. </li>
  174. <li class="md-nav__item">
  175. <a href="ft2-layer_management.html" class="md-nav__link">
  176. Glyph Layer Management
  177. </a>
  178. </li>
  179. <li class="md-nav__item">
  180. <a href="ft2-glyph_management.html" class="md-nav__link">
  181. Glyph Management
  182. </a>
  183. </li>
  184. <li class="md-nav__item">
  185. <a href="ft2-mac_specific.html" class="md-nav__link">
  186. Mac Specific Interface
  187. </a>
  188. </li>
  189. <li class="md-nav__item">
  190. <a href="ft2-sizes_management.html" class="md-nav__link">
  191. Size Management
  192. </a>
  193. </li>
  194. <li class="md-nav__item">
  195. <a href="ft2-header_file_macros.html" class="md-nav__link">
  196. Header File Macros
  197. </a>
  198. </li>
  199. </ul>
  200. </nav>
  201. </li>
  202. <li class="md-nav__item md-nav__item--nested">
  203. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" >
  204. <label class="md-nav__link" for="__nav_5">
  205. Format-Specific API
  206. <span class="md-nav__icon md-icon"></span>
  207. </label>
  208. <nav class="md-nav" aria-label="Format-Specific API" data-md-level="1">
  209. <label class="md-nav__title" for="__nav_5">
  210. <span class="md-nav__icon md-icon"></span>
  211. Format-Specific API
  212. </label>
  213. <ul class="md-nav__list" data-md-scrollfix>
  214. <li class="md-nav__item">
  215. <a href="ft2-multiple_masters.html" class="md-nav__link">
  216. Multiple Masters
  217. </a>
  218. </li>
  219. <li class="md-nav__item">
  220. <a href="ft2-truetype_tables.html" class="md-nav__link">
  221. TrueType Tables
  222. </a>
  223. </li>
  224. <li class="md-nav__item">
  225. <a href="ft2-type1_tables.html" class="md-nav__link">
  226. Type 1 Tables
  227. </a>
  228. </li>
  229. <li class="md-nav__item">
  230. <a href="ft2-sfnt_names.html" class="md-nav__link">
  231. SFNT Names
  232. </a>
  233. </li>
  234. <li class="md-nav__item">
  235. <a href="ft2-bdf_fonts.html" class="md-nav__link">
  236. BDF and PCF Files
  237. </a>
  238. </li>
  239. <li class="md-nav__item">
  240. <a href="ft2-cid_fonts.html" class="md-nav__link">
  241. CID Fonts
  242. </a>
  243. </li>
  244. <li class="md-nav__item">
  245. <a href="ft2-pfr_fonts.html" class="md-nav__link">
  246. PFR Fonts
  247. </a>
  248. </li>
  249. <li class="md-nav__item">
  250. <a href="ft2-winfnt_fonts.html" class="md-nav__link">
  251. Window FNT Files
  252. </a>
  253. </li>
  254. <li class="md-nav__item">
  255. <a href="ft2-font_formats.html" class="md-nav__link">
  256. Font Formats
  257. </a>
  258. </li>
  259. <li class="md-nav__item">
  260. <a href="ft2-gasp_table.html" class="md-nav__link">
  261. Gasp Table
  262. </a>
  263. </li>
  264. </ul>
  265. </nav>
  266. </li>
  267. <li class="md-nav__item md-nav__item--nested">
  268. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" >
  269. <label class="md-nav__link" for="__nav_6">
  270. Controlling FreeType Modules
  271. <span class="md-nav__icon md-icon"></span>
  272. </label>
  273. <nav class="md-nav" aria-label="Controlling FreeType Modules" data-md-level="1">
  274. <label class="md-nav__title" for="__nav_6">
  275. <span class="md-nav__icon md-icon"></span>
  276. Controlling FreeType Modules
  277. </label>
  278. <ul class="md-nav__list" data-md-scrollfix>
  279. <li class="md-nav__item">
  280. <a href="ft2-auto_hinter.html" class="md-nav__link">
  281. The auto-hinter
  282. </a>
  283. </li>
  284. <li class="md-nav__item">
  285. <a href="ft2-cff_driver.html" class="md-nav__link">
  286. The CFF driver
  287. </a>
  288. </li>
  289. <li class="md-nav__item">
  290. <a href="ft2-t1_cid_driver.html" class="md-nav__link">
  291. The Type 1 and CID drivers
  292. </a>
  293. </li>
  294. <li class="md-nav__item">
  295. <a href="ft2-tt_driver.html" class="md-nav__link">
  296. The TrueType driver
  297. </a>
  298. </li>
  299. <li class="md-nav__item">
  300. <a href="ft2-pcf_driver.html" class="md-nav__link">
  301. The PCF driver
  302. </a>
  303. </li>
  304. <li class="md-nav__item">
  305. <a href="ft2-properties.html" class="md-nav__link">
  306. Driver properties
  307. </a>
  308. </li>
  309. <li class="md-nav__item">
  310. <a href="ft2-parameter_tags.html" class="md-nav__link">
  311. Parameter Tags
  312. </a>
  313. </li>
  314. <li class="md-nav__item">
  315. <a href="ft2-lcd_rendering.html" class="md-nav__link">
  316. Subpixel Rendering
  317. </a>
  318. </li>
  319. </ul>
  320. </nav>
  321. </li>
  322. <li class="md-nav__item md-nav__item--nested">
  323. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" >
  324. <label class="md-nav__link" for="__nav_7">
  325. Cache Sub-System
  326. <span class="md-nav__icon md-icon"></span>
  327. </label>
  328. <nav class="md-nav" aria-label="Cache Sub-System" data-md-level="1">
  329. <label class="md-nav__title" for="__nav_7">
  330. <span class="md-nav__icon md-icon"></span>
  331. Cache Sub-System
  332. </label>
  333. <ul class="md-nav__list" data-md-scrollfix>
  334. <li class="md-nav__item">
  335. <a href="ft2-cache_subsystem.html" class="md-nav__link">
  336. Cache Sub-System
  337. </a>
  338. </li>
  339. </ul>
  340. </nav>
  341. </li>
  342. <li class="md-nav__item md-nav__item--active md-nav__item--nested">
  343. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_8" type="checkbox" id="__nav_8" checked>
  344. <label class="md-nav__link" for="__nav_8">
  345. Support API
  346. <span class="md-nav__icon md-icon"></span>
  347. </label>
  348. <nav class="md-nav" aria-label="Support API" data-md-level="1">
  349. <label class="md-nav__title" for="__nav_8">
  350. <span class="md-nav__icon md-icon"></span>
  351. Support API
  352. </label>
  353. <ul class="md-nav__list" data-md-scrollfix>
  354. <li class="md-nav__item">
  355. <a href="ft2-computations.html" class="md-nav__link">
  356. Computations
  357. </a>
  358. </li>
  359. <li class="md-nav__item">
  360. <a href="ft2-list_processing.html" class="md-nav__link">
  361. List Processing
  362. </a>
  363. </li>
  364. <li class="md-nav__item">
  365. <a href="ft2-outline_processing.html" class="md-nav__link">
  366. Outline Processing
  367. </a>
  368. </li>
  369. <li class="md-nav__item">
  370. <a href="ft2-quick_advance.html" class="md-nav__link">
  371. Quick retrieval of advance values
  372. </a>
  373. </li>
  374. <li class="md-nav__item md-nav__item--active">
  375. <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
  376. <label class="md-nav__link md-nav__link--active" for="__toc">
  377. Bitmap Handling
  378. <span class="md-nav__icon md-icon"></span>
  379. </label>
  380. <a href="ft2-bitmap_handling.html" class="md-nav__link md-nav__link--active">
  381. Bitmap Handling
  382. </a>
  383. <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
  384. <label class="md-nav__title" for="__toc">
  385. <span class="md-nav__icon md-icon"></span>
  386. Table of contents
  387. </label>
  388. <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
  389. <li class="md-nav__item">
  390. <a href="#synopsis" class="md-nav__link">
  391. Synopsis
  392. </a>
  393. </li>
  394. <li class="md-nav__item">
  395. <a href="#ft_bitmap_init" class="md-nav__link">
  396. FT_Bitmap_Init
  397. </a>
  398. </li>
  399. <li class="md-nav__item">
  400. <a href="#ft_bitmap_copy" class="md-nav__link">
  401. FT_Bitmap_Copy
  402. </a>
  403. </li>
  404. <li class="md-nav__item">
  405. <a href="#ft_bitmap_embolden" class="md-nav__link">
  406. FT_Bitmap_Embolden
  407. </a>
  408. </li>
  409. <li class="md-nav__item">
  410. <a href="#ft_bitmap_convert" class="md-nav__link">
  411. FT_Bitmap_Convert
  412. </a>
  413. </li>
  414. <li class="md-nav__item">
  415. <a href="#ft_bitmap_blend" class="md-nav__link">
  416. FT_Bitmap_Blend
  417. </a>
  418. </li>
  419. <li class="md-nav__item">
  420. <a href="#ft_glyphslot_own_bitmap" class="md-nav__link">
  421. FT_GlyphSlot_Own_Bitmap
  422. </a>
  423. </li>
  424. <li class="md-nav__item">
  425. <a href="#ft_bitmap_done" class="md-nav__link">
  426. FT_Bitmap_Done
  427. </a>
  428. </li>
  429. </ul>
  430. </nav>
  431. </li>
  432. <li class="md-nav__item">
  433. <a href="ft2-raster.html" class="md-nav__link">
  434. Scanline Converter
  435. </a>
  436. </li>
  437. <li class="md-nav__item">
  438. <a href="ft2-glyph_stroker.html" class="md-nav__link">
  439. Glyph Stroker
  440. </a>
  441. </li>
  442. <li class="md-nav__item">
  443. <a href="ft2-system_interface.html" class="md-nav__link">
  444. System Interface
  445. </a>
  446. </li>
  447. <li class="md-nav__item">
  448. <a href="ft2-module_management.html" class="md-nav__link">
  449. Module Management
  450. </a>
  451. </li>
  452. <li class="md-nav__item">
  453. <a href="ft2-gzip.html" class="md-nav__link">
  454. GZIP Streams
  455. </a>
  456. </li>
  457. <li class="md-nav__item">
  458. <a href="ft2-lzw.html" class="md-nav__link">
  459. LZW Streams
  460. </a>
  461. </li>
  462. <li class="md-nav__item">
  463. <a href="ft2-bzip2.html" class="md-nav__link">
  464. BZIP2 Streams
  465. </a>
  466. </li>
  467. <li class="md-nav__item">
  468. <a href="ft2-debugging_apis.html" class="md-nav__link">
  469. External Debugging APIs
  470. </a>
  471. </li>
  472. </ul>
  473. </nav>
  474. </li>
  475. <li class="md-nav__item md-nav__item--nested">
  476. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_9" type="checkbox" id="__nav_9" >
  477. <label class="md-nav__link" for="__nav_9">
  478. Error Codes
  479. <span class="md-nav__icon md-icon"></span>
  480. </label>
  481. <nav class="md-nav" aria-label="Error Codes" data-md-level="1">
  482. <label class="md-nav__title" for="__nav_9">
  483. <span class="md-nav__icon md-icon"></span>
  484. Error Codes
  485. </label>
  486. <ul class="md-nav__list" data-md-scrollfix>
  487. <li class="md-nav__item">
  488. <a href="ft2-error_enumerations.html" class="md-nav__link">
  489. Error Enumerations
  490. </a>
  491. </li>
  492. <li class="md-nav__item">
  493. <a href="ft2-error_code_values.html" class="md-nav__link">
  494. Error Code Values
  495. </a>
  496. </li>
  497. </ul>
  498. </nav>
  499. </li>
  500. <li class="md-nav__item md-nav__item--nested">
  501. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_10" type="checkbox" id="__nav_10" >
  502. <label class="md-nav__link" for="__nav_10">
  503. Miscellaneous
  504. <span class="md-nav__icon md-icon"></span>
  505. </label>
  506. <nav class="md-nav" aria-label="Miscellaneous" data-md-level="1">
  507. <label class="md-nav__title" for="__nav_10">
  508. <span class="md-nav__icon md-icon"></span>
  509. Miscellaneous
  510. </label>
  511. <ul class="md-nav__list" data-md-scrollfix>
  512. <li class="md-nav__item">
  513. <a href="ft2-gx_validation.html" class="md-nav__link">
  514. TrueTypeGX/AAT Validation
  515. </a>
  516. </li>
  517. <li class="md-nav__item">
  518. <a href="ft2-incremental.html" class="md-nav__link">
  519. Incremental Loading
  520. </a>
  521. </li>
  522. <li class="md-nav__item">
  523. <a href="ft2-truetype_engine.html" class="md-nav__link">
  524. The TrueType Engine
  525. </a>
  526. </li>
  527. <li class="md-nav__item">
  528. <a href="ft2-ot_validation.html" class="md-nav__link">
  529. OpenType Validation
  530. </a>
  531. </li>
  532. </ul>
  533. </nav>
  534. </li>
  535. </ul>
  536. </nav>
  537. </div>
  538. </div>
  539. </div>
  540. <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
  541. <div class="md-sidebar__scrollwrap">
  542. <div class="md-sidebar__inner">
  543. <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
  544. <label class="md-nav__title" for="__toc">
  545. <span class="md-nav__icon md-icon"></span>
  546. Table of contents
  547. </label>
  548. <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
  549. <li class="md-nav__item">
  550. <a href="#synopsis" class="md-nav__link">
  551. Synopsis
  552. </a>
  553. </li>
  554. <li class="md-nav__item">
  555. <a href="#ft_bitmap_init" class="md-nav__link">
  556. FT_Bitmap_Init
  557. </a>
  558. </li>
  559. <li class="md-nav__item">
  560. <a href="#ft_bitmap_copy" class="md-nav__link">
  561. FT_Bitmap_Copy
  562. </a>
  563. </li>
  564. <li class="md-nav__item">
  565. <a href="#ft_bitmap_embolden" class="md-nav__link">
  566. FT_Bitmap_Embolden
  567. </a>
  568. </li>
  569. <li class="md-nav__item">
  570. <a href="#ft_bitmap_convert" class="md-nav__link">
  571. FT_Bitmap_Convert
  572. </a>
  573. </li>
  574. <li class="md-nav__item">
  575. <a href="#ft_bitmap_blend" class="md-nav__link">
  576. FT_Bitmap_Blend
  577. </a>
  578. </li>
  579. <li class="md-nav__item">
  580. <a href="#ft_glyphslot_own_bitmap" class="md-nav__link">
  581. FT_GlyphSlot_Own_Bitmap
  582. </a>
  583. </li>
  584. <li class="md-nav__item">
  585. <a href="#ft_bitmap_done" class="md-nav__link">
  586. FT_Bitmap_Done
  587. </a>
  588. </li>
  589. </ul>
  590. </nav>
  591. </div>
  592. </div>
  593. </div>
  594. <div class="md-content" data-md-component="content">
  595. <article class="md-content__inner md-typeset">
  596. <p><a href="https://www.freetype.org">FreeType</a> &raquo; <a href="../">Docs</a> &raquo; <a href="index.html#support-api">Support API</a> &raquo; Bitmap Handling</p>
  597. <hr />
  598. <h1 id="bitmap-handling">Bitmap Handling<a class="headerlink" href="#bitmap-handling" title="Permanent link">&para;</a></h1>
  599. <h2 id="synopsis">Synopsis<a class="headerlink" href="#synopsis" title="Permanent link">&para;</a></h2>
  600. <p>This section contains functions for handling <code><a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a></code> objects, automatically adjusting the target's bitmap buffer size as needed.</p>
  601. <p>Note that none of the functions changes the bitmap's &lsquo;flow&rsquo; (as indicated by the sign of the <code>pitch</code> field in <code><a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a></code>).</p>
  602. <p>To set the flow, assign an appropriate positive or negative value to the <code>pitch</code> field of the target <code><a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a></code> object after calling <code><a href="ft2-bitmap_handling.html#ft_bitmap_init">FT_Bitmap_Init</a></code> but before calling any of the other functions described here.</p>
  603. <h2 id="ft_bitmap_init">FT_Bitmap_Init<a class="headerlink" href="#ft_bitmap_init" title="Permanent link">&para;</a></h2>
  604. <p>Defined in FT_BITMAP_H (freetype/ftbitmap.h).</p>
  605. <div class = "codehilite"><pre><code> FT_EXPORT( <span class="keyword">void</span> )
  606. <b>FT_Bitmap_Init</b>( <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a> *abitmap );
  607. /* deprecated */
  608. FT_EXPORT( <span class="keyword">void</span> )
  609. FT_Bitmap_New( <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a> *abitmap );
  610. </code></pre></div>
  611. <p>Initialize a pointer to an <code><a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a></code> structure.</p>
  612. <h4>inout</h4>
  613. <table class="fields">
  614. <tr><td class="val" id="abitmap">abitmap</td><td class="desc">
  615. <p>A pointer to the bitmap structure.</p>
  616. </td></tr>
  617. </table>
  618. <h4>note</h4>
  619. <p>A deprecated name for the same function is <code>FT_Bitmap_New</code>.</p>
  620. <hr>
  621. <h2 id="ft_bitmap_copy">FT_Bitmap_Copy<a class="headerlink" href="#ft_bitmap_copy" title="Permanent link">&para;</a></h2>
  622. <p>Defined in FT_BITMAP_H (freetype/ftbitmap.h).</p>
  623. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  624. <b>FT_Bitmap_Copy</b>( <a href="ft2-base_interface.html#ft_library">FT_Library</a> library,
  625. <span class="keyword">const</span> <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a> *source,
  626. <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a> *target );
  627. </code></pre></div>
  628. <p>Copy a bitmap into another one.</p>
  629. <h4>input</h4>
  630. <table class="fields">
  631. <tr><td class="val" id="library">library</td><td class="desc">
  632. <p>A handle to a library object.</p>
  633. </td></tr>
  634. <tr><td class="val" id="source">source</td><td class="desc">
  635. <p>A handle to the source bitmap.</p>
  636. </td></tr>
  637. </table>
  638. <h4>output</h4>
  639. <table class="fields">
  640. <tr><td class="val" id="target">target</td><td class="desc">
  641. <p>A handle to the target bitmap.</p>
  642. </td></tr>
  643. </table>
  644. <h4>return</h4>
  645. <p>FreeType error code. 0&nbsp;means success.</p>
  646. <h4>note</h4>
  647. <p><code>source-&gt;buffer</code> and <code>target-&gt;buffer</code> must neither be equal nor overlap.</p>
  648. <hr>
  649. <h2 id="ft_bitmap_embolden">FT_Bitmap_Embolden<a class="headerlink" href="#ft_bitmap_embolden" title="Permanent link">&para;</a></h2>
  650. <p>Defined in FT_BITMAP_H (freetype/ftbitmap.h).</p>
  651. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  652. <b>FT_Bitmap_Embolden</b>( <a href="ft2-base_interface.html#ft_library">FT_Library</a> library,
  653. <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a>* bitmap,
  654. <a href="ft2-basic_types.html#ft_pos">FT_Pos</a> xStrength,
  655. <a href="ft2-basic_types.html#ft_pos">FT_Pos</a> yStrength );
  656. </code></pre></div>
  657. <p>Embolden a bitmap. The new bitmap will be about <code>xStrength</code> pixels wider and <code>yStrength</code> pixels higher. The left and bottom borders are kept unchanged.</p>
  658. <h4>input</h4>
  659. <table class="fields">
  660. <tr><td class="val" id="library">library</td><td class="desc">
  661. <p>A handle to a library object.</p>
  662. </td></tr>
  663. <tr><td class="val" id="xstrength">xStrength</td><td class="desc">
  664. <p>How strong the glyph is emboldened horizontally. Expressed in 26.6 pixel format.</p>
  665. </td></tr>
  666. <tr><td class="val" id="ystrength">yStrength</td><td class="desc">
  667. <p>How strong the glyph is emboldened vertically. Expressed in 26.6 pixel format.</p>
  668. </td></tr>
  669. </table>
  670. <h4>inout</h4>
  671. <table class="fields">
  672. <tr><td class="val" id="bitmap">bitmap</td><td class="desc">
  673. <p>A handle to the target bitmap.</p>
  674. </td></tr>
  675. </table>
  676. <h4>return</h4>
  677. <p>FreeType error code. 0&nbsp;means success.</p>
  678. <h4>note</h4>
  679. <p>The current implementation restricts <code>xStrength</code> to be less than or equal to&nbsp;8 if bitmap is of pixel_mode <code><a href="ft2-basic_types.html#ft_pixel_mode">FT_PIXEL_MODE_MONO</a></code>.</p>
  680. <p>If you want to embolden the bitmap owned by a <code><a href="ft2-base_interface.html#ft_glyphslotrec">FT_GlyphSlotRec</a></code>, you should call <code><a href="ft2-bitmap_handling.html#ft_glyphslot_own_bitmap">FT_GlyphSlot_Own_Bitmap</a></code> on the slot first.</p>
  681. <p>Bitmaps in <code><a href="ft2-basic_types.html#ft_pixel_mode">FT_PIXEL_MODE_GRAY2</a></code> and <code><a href="ft2-basic_types.html#ft_pixel_mode">FT_PIXEL_MODE_GRAY</a></code>@ format are converted to <code><a href="ft2-basic_types.html#ft_pixel_mode">FT_PIXEL_MODE_GRAY</a></code> format (i.e., 8bpp).</p>
  682. <hr>
  683. <h2 id="ft_bitmap_convert">FT_Bitmap_Convert<a class="headerlink" href="#ft_bitmap_convert" title="Permanent link">&para;</a></h2>
  684. <p>Defined in FT_BITMAP_H (freetype/ftbitmap.h).</p>
  685. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  686. <b>FT_Bitmap_Convert</b>( <a href="ft2-base_interface.html#ft_library">FT_Library</a> library,
  687. <span class="keyword">const</span> <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a> *source,
  688. <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a> *target,
  689. <a href="ft2-basic_types.html#ft_int">FT_Int</a> alignment );
  690. </code></pre></div>
  691. <p>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 &lsquo;pitch&rsquo;) a multiple of <code>alignment</code>.</p>
  692. <h4>input</h4>
  693. <table class="fields">
  694. <tr><td class="val" id="library">library</td><td class="desc">
  695. <p>A handle to a library object.</p>
  696. </td></tr>
  697. <tr><td class="val" id="source">source</td><td class="desc">
  698. <p>The source bitmap.</p>
  699. </td></tr>
  700. <tr><td class="val" id="alignment">alignment</td><td class="desc">
  701. <p>The pitch of the bitmap is a multiple of this argument. Common values are 1, 2, or 4.</p>
  702. </td></tr>
  703. </table>
  704. <h4>output</h4>
  705. <table class="fields">
  706. <tr><td class="val" id="target">target</td><td class="desc">
  707. <p>The target bitmap.</p>
  708. </td></tr>
  709. </table>
  710. <h4>return</h4>
  711. <p>FreeType error code. 0&nbsp;means success.</p>
  712. <h4>note</h4>
  713. <p>It is possible to call <code><a href="ft2-bitmap_handling.html#ft_bitmap_convert">FT_Bitmap_Convert</a></code> multiple times without calling <code><a href="ft2-bitmap_handling.html#ft_bitmap_done">FT_Bitmap_Done</a></code> (the memory is simply reallocated).</p>
  714. <p>Use <code><a href="ft2-bitmap_handling.html#ft_bitmap_done">FT_Bitmap_Done</a></code> to finally remove the bitmap object.</p>
  715. <p>The <code>library</code> argument is taken to have access to FreeType's memory handling functions.</p>
  716. <p><code>source-&gt;buffer</code> and <code>target-&gt;buffer</code> must neither be equal nor overlap.</p>
  717. <hr>
  718. <h2 id="ft_bitmap_blend">FT_Bitmap_Blend<a class="headerlink" href="#ft_bitmap_blend" title="Permanent link">&para;</a></h2>
  719. <p>Defined in FT_BITMAP_H (freetype/ftbitmap.h).</p>
  720. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  721. <b>FT_Bitmap_Blend</b>( <a href="ft2-base_interface.html#ft_library">FT_Library</a> library,
  722. <span class="keyword">const</span> <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a>* source,
  723. <span class="keyword">const</span> <a href="ft2-basic_types.html#ft_vector">FT_Vector</a> source_offset,
  724. <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a>* target,
  725. <a href="ft2-basic_types.html#ft_vector">FT_Vector</a> *atarget_offset,
  726. <a href="ft2-color_management.html#ft_color">FT_Color</a> color );
  727. </code></pre></div>
  728. <p>Blend a bitmap onto another bitmap, using a given color.</p>
  729. <h4>input</h4>
  730. <table class="fields">
  731. <tr><td class="val" id="library">library</td><td class="desc">
  732. <p>A handle to a library object.</p>
  733. </td></tr>
  734. <tr><td class="val" id="source">source</td><td class="desc">
  735. <p>The source bitmap, which can have any <code><a href="ft2-basic_types.html#ft_pixel_mode">FT_Pixel_Mode</a></code> format.</p>
  736. </td></tr>
  737. <tr><td class="val" id="source_offset">source_offset</td><td class="desc">
  738. <p>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.</p>
  739. </td></tr>
  740. <tr><td class="val" id="color">color</td><td class="desc">
  741. <p>The color used to draw <code>source</code> onto <code>target</code>.</p>
  742. </td></tr>
  743. </table>
  744. <h4>inout</h4>
  745. <table class="fields">
  746. <tr><td class="val" id="target">target</td><td class="desc">
  747. <p>A handle to an <code>FT_Bitmap</code> object. It should be either initialized as empty with a call to <code><a href="ft2-bitmap_handling.html#ft_bitmap_init">FT_Bitmap_Init</a></code>, or it should be of type <code><a href="ft2-basic_types.html#ft_pixel_mode">FT_PIXEL_MODE_BGRA</a></code>.</p>
  748. </td></tr>
  749. <tr><td class="val" id="atarget_offset">atarget_offset</td><td class="desc">
  750. <p>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.</p>
  751. </td></tr>
  752. </table>
  753. <h4>return</h4>
  754. <p>FreeType error code. 0&nbsp;means success.</p>
  755. <h4>note</h4>
  756. <p>This function doesn't perform clipping.</p>
  757. <p>The bitmap in <code>target</code> gets allocated or reallocated as needed; the vector <code>atarget_offset</code> is updated accordingly.</p>
  758. <p>In case of allocation or reallocation, the bitmap's pitch is set to <code>4 * width</code>. Both <code>source</code> and <code>target</code> must have the same bitmap flow (as indicated by the sign of the <code>pitch</code> field).</p>
  759. <p><code>source-&gt;buffer</code> and <code>target-&gt;buffer</code> must neither be equal nor overlap.</p>
  760. <h4>since</h4>
  761. <p>2.10</p>
  762. <hr>
  763. <h2 id="ft_glyphslot_own_bitmap">FT_GlyphSlot_Own_Bitmap<a class="headerlink" href="#ft_glyphslot_own_bitmap" title="Permanent link">&para;</a></h2>
  764. <p>Defined in FT_BITMAP_H (freetype/ftbitmap.h).</p>
  765. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  766. <b>FT_GlyphSlot_Own_Bitmap</b>( <a href="ft2-base_interface.html#ft_glyphslot">FT_GlyphSlot</a> slot );
  767. </code></pre></div>
  768. <p>Make sure that a glyph slot owns <code>slot-&gt;bitmap</code>.</p>
  769. <h4>input</h4>
  770. <table class="fields">
  771. <tr><td class="val" id="slot">slot</td><td class="desc">
  772. <p>The glyph slot.</p>
  773. </td></tr>
  774. </table>
  775. <h4>return</h4>
  776. <p>FreeType error code. 0&nbsp;means success.</p>
  777. <h4>note</h4>
  778. <p>This function is to be used in combination with <code><a href="ft2-bitmap_handling.html#ft_bitmap_embolden">FT_Bitmap_Embolden</a></code>.</p>
  779. <hr>
  780. <h2 id="ft_bitmap_done">FT_Bitmap_Done<a class="headerlink" href="#ft_bitmap_done" title="Permanent link">&para;</a></h2>
  781. <p>Defined in FT_BITMAP_H (freetype/ftbitmap.h).</p>
  782. <div class = "codehilite"><pre><code> FT_EXPORT( <a href="ft2-basic_types.html#ft_error">FT_Error</a> )
  783. <b>FT_Bitmap_Done</b>( <a href="ft2-base_interface.html#ft_library">FT_Library</a> library,
  784. <a href="ft2-basic_types.html#ft_bitmap">FT_Bitmap</a> *bitmap );
  785. </code></pre></div>
  786. <p>Destroy a bitmap object initialized with <code><a href="ft2-bitmap_handling.html#ft_bitmap_init">FT_Bitmap_Init</a></code>.</p>
  787. <h4>input</h4>
  788. <table class="fields">
  789. <tr><td class="val" id="library">library</td><td class="desc">
  790. <p>A handle to a library object.</p>
  791. </td></tr>
  792. <tr><td class="val" id="bitmap">bitmap</td><td class="desc">
  793. <p>The bitmap object to be freed.</p>
  794. </td></tr>
  795. </table>
  796. <h4>return</h4>
  797. <p>FreeType error code. 0&nbsp;means success.</p>
  798. <h4>note</h4>
  799. <p>The <code>library</code> argument is taken to have access to FreeType's memory handling functions.</p>
  800. <hr>
  801. </article>
  802. </div>
  803. </div>
  804. </main>
  805. <footer class="md-footer">
  806. <nav class="md-footer__inner md-grid" aria-label="Footer">
  807. <a href="ft2-quick_advance.html" class="md-footer__link md-footer__link--prev" aria-label="Previous: Quick retrieval of advance values" rel="prev">
  808. <div class="md-footer__button md-icon">
  809. <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>
  810. </div>
  811. <div class="md-footer__title">
  812. <div class="md-ellipsis">
  813. <span class="md-footer__direction">
  814. Previous
  815. </span>
  816. Quick retrieval of advance values
  817. </div>
  818. </div>
  819. </a>
  820. <a href="ft2-raster.html" class="md-footer__link md-footer__link--next" aria-label="Next: Scanline Converter" rel="next">
  821. <div class="md-footer__title">
  822. <div class="md-ellipsis">
  823. <span class="md-footer__direction">
  824. Next
  825. </span>
  826. Scanline Converter
  827. </div>
  828. </div>
  829. <div class="md-footer__button md-icon">
  830. <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>
  831. </div>
  832. </a>
  833. </nav>
  834. <div class="md-footer-meta md-typeset">
  835. <div class="md-footer-meta__inner md-grid">
  836. <div class="md-footer-copyright">
  837. <div class="md-footer-copyright__highlight">
  838. Copyright 2021 <a href = "https://www.freetype.org/license.html">The FreeType Project</a>.
  839. </div>
  840. Made with
  841. <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
  842. Material for MkDocs
  843. </a>
  844. </div>
  845. </div>
  846. </div>
  847. </footer>
  848. </div>
  849. <div class="md-dialog" data-md-component="dialog">
  850. <div class="md-dialog__inner md-typeset"></div>
  851. </div>
  852. <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>
  853. <script src="assets/javascripts/bundle.82b56eb2.min.js"></script>
  854. <script src="javascripts/extra.js"></script>
  855. </body>
  856. </html>