DWrite font docs

This commit is contained in:
Adrian Johnson 2022-03-05 16:31:50 +10:30
parent 135327c112
commit 989d368dc5
9 changed files with 137 additions and 3 deletions

View file

@ -27,6 +27,7 @@
<xi:include href="xml/cairo-font-options.xml"/>
<xi:include href="xml/cairo-ft.xml"/>
<xi:include href="xml/cairo-win32-fonts.xml"/>
<xi:include href="xml/cairo-dwrite-fonts.xml"/>
<xi:include href="xml/cairo-quartz-fonts.xml"/>
<xi:include href="xml/cairo-user-fonts.xml"/>
</chapter>

View file

@ -26,6 +26,12 @@ cairo_win32_scaled_font_get_logical_to_device
cairo_win32_scaled_font_get_device_to_logical
</SECTION>
<SECTION>
<FILE>cairo-dwrite-fonts</FILE>
CAIRO_HAS_DWRITE_FONT
cairo_dwrite_font_face_create_for_dwrite_fontface
</SECTION>
<SECTION>
<FILE>cairo-quartz-fonts</FILE>
CAIRO_HAS_QUARTZ_FONT

View file

@ -112,6 +112,7 @@ cairo_win32_scaled_font_get_device_to_logical (cairo_scaled_font_t *scaled_font,
/*
* Win32 DirectWrite font support
*/
cairo_public cairo_font_face_t *
cairo_dwrite_font_face_create_for_dwrite_fontface (void *dwrite_font_face);

View file

@ -178,6 +178,7 @@ cairo_feature_sources = {
'win32/cairo-win32-font.c',
],
'cairo-win32-dwrite-font': [
'win32/cairo-dwrite-font-public.c',
'win32/cairo-dwrite-font.cpp',
],
'cairo-gl': [

View file

@ -0,0 +1,118 @@
/* -*- Mode: c; tab-width: 8; c-basic-offset: 4; indent-tabs-mode: t; -*- */
/* Cairo - a vector graphics library with display and print output
*
* Copyright © 2022 Adrian Johnson
*
* This library is free software; you can redistribute it and/or
* modify it either under the terms of the GNU Lesser General Public
* License version 2.1 as published by the Free Software Foundation
* (the "LGPL") or, at your option, under the terms of the Mozilla
* Public License Version 1.1 (the "MPL"). If you do not alter this
* notice, a recipient may use your version of this file under either
* the MPL or the LGPL.
*
* You should have received a copy of the LGPL along with this library
* in the file COPYING-LGPL-2.1; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* You should have received a copy of the MPL along with this library
* in the file COPYING-MPL-1.1
*
* The contents of this file are subject to the Mozilla Public License
* Version 1.1 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY
* OF ANY KIND, either express or implied. See the LGPL or the MPL for
* the specific language governing rights and limitations.
*
* The Original Code is the cairo graphics library.
*
* The Initial Developer of the Original Code is Adrian Johnson
*
* Contributor(s):
* Adrian Johnson <ajohnson@redneon.com>
*/
/* gtkdoc won't scan .cpp files so we wrap the public API in cairo-dwrite-font.cpp
* with this .c wrapper containing the gtkdocs for cairo-dwrite-font.cpp.
*/
#include "cairo-win32-private.h"
/**
* SECTION:cairo-dwrite-fonts
* @Title: DWrite Fonts
* @Short_Description: Font support for Microsoft DWrite
* @See_Also: #cairo_font_face_t
*
* The Microsoft DWrite font backend is primarily used to render text on
* Microsoft Windows systems.
**/
/**
* CAIRO_HAS_DWRITE_FONT:
*
* Defined if the Microsoft DWrite font backend is available.
* This macro can be used to conditionally compile backend-specific code.
*
* Since: 1.18
**/
/**
* cairo_dwrite_font_face_create_for_dwrite_fontface:
* @dwrite_font_face: A pointer to an #IDWriteFontFace specifying the
* DWrite font to use.
*
* Creates a new font for the DWrite font backend based on a
* DWrite font face. This font can then be used with
* cairo_set_font_face() or cairo_scaled_font_create().
* Here is an example of how this function might be used:
* <informalexample><programlisting><![CDATA[
* #include <cairo-win32.h>
* #include <dwrite.h>
*
* IDWriteFactory* dWriteFactory = NULL;
* HRESULT hr = DWriteCreateFactory(
* DWRITE_FACTORY_TYPE_SHARED,
* __uuidof(IDWriteFactory),
* reinterpret_cast<IUnknown**>(&dWriteFactory));
*
* IDWriteFontCollection *systemCollection;
* hr = dWriteFactory->GetSystemFontCollection(&systemCollection);
*
* UINT32 idx;
* BOOL found;
* systemCollection->FindFamilyName(L"Segoe UI Emoji", &idx, &found);
*
* IDWriteFontFamily *family;
* systemCollection->GetFontFamily(idx, &family);
*
* IDWriteFont *dwritefont;
* DWRITE_FONT_WEIGHT weight = DWRITE_FONT_WEIGHT_NORMAL;
* DWRITE_FONT_STYLE style = DWRITE_FONT_STYLE_NORMAL;
* hr = family->GetFirstMatchingFont(weight, DWRITE_FONT_STRETCH_NORMAL, style, &dwritefont);
*
* IDWriteFontFace *dwriteface;
* hr = dwritefont->CreateFontFace(&dwriteface);
*
* cairo_font_face_t *face;
* face = cairo_dwrite_font_face_create_for_dwrite_fontface(dwriteface);
* cairo_set_font_face(cr, face);
* cairo_set_font_size(cr, 70);
* cairo_move_to(cr, 100, 100);
* cairo_show_text(cr, "😃");
* ]]></programlisting></informalexample>
*
* Return value: a newly created #cairo_font_face_t. Free with
* cairo_font_face_destroy() when you are done using it.
*
* Since: 1.18
**/
cairo_font_face_t*
cairo_dwrite_font_face_create_for_dwrite_fontface (void *dwrite_font_face)
{
return cairo_dwrite_font_face_create_for_dwrite_fontface_internal (dwrite_font_face);
}

View file

@ -1214,9 +1214,8 @@ _cairo_dwrite_has_color_glyphs(void *scaled_font)
return ((cairo_dwrite_font_face_t *)dwritesf->base.font_face)->have_color;
}
// WIN32 Helper Functions
cairo_font_face_t*
cairo_dwrite_font_face_create_for_dwrite_fontface(void* dwrite_font_face)
cairo_dwrite_font_face_create_for_dwrite_fontface_internal(void* dwrite_font_face)
{
IDWriteFontFace *dwriteface = static_cast<IDWriteFontFace*>(dwrite_font_face);
// Must do malloc and not C++ new, since Cairo frees this.

View file

@ -71,12 +71,16 @@
/**
* SECTION:cairo-win32-fonts
* @Title: Win32 Fonts
* @Title: Win32 GDI Fonts
* @Short_Description: Font support for Microsoft Windows
* @See_Also: #cairo_font_face_t
*
* The Microsoft Windows font backend is primarily used to render text on
* Microsoft Windows systems.
*
* Note: Win32 GDI fonts do not support color fonts. Use DWrite fonts
* if color font support is required.
**/
/**

View file

@ -271,6 +271,9 @@ cairo_int_status_t
_cairo_dwrite_scaled_font_create_win32_scaled_font (cairo_scaled_font_t *scaled_font,
cairo_scaled_font_t **new_font);
cairo_font_face_t*
cairo_dwrite_font_face_create_for_dwrite_fontface_internal(void* dwrite_font_face);
#endif /* CAIRO_HAS_DWRITE_FONT */
CAIRO_END_DECLS

View file

@ -1597,6 +1597,7 @@ _status_to_string (cairo_status_t status)
f(FREETYPE_ERROR);
f(WIN32_GDI_ERROR);
f(TAG_ERROR);
f(DWRITE_ERROR);
case CAIRO_STATUS_LAST_STATUS:
break;
}