Win32Interop.Gdi32
The alpha-blending function for source and destination bitmaps, a global alpha value to be applied to the entire source bitmap, and format
information for the source bitmap.
The source bitmap is placed over the destination bitmap based on the alpha values of the source pixels.
This flag is set when the bitmap has an Alpha channel (that is, per-pixel alpha). Note that the APIs use premultiplied alpha, which means that
the red, green and blue channel values in the bitmap must be premultiplied with the alpha channel value. For example, if the alpha channel value
is x, the red, green and blue channels must be multiplied by x and divided by 0xff prior to the call.
The callback is an application-defined callback function that processes color profile data from
.
Pointer to the file name of the color profile.
Data supplied by the application that is passed to the callback function by the function.
The function is an application-defined callback function used with the
function. The type defines a pointer to this callback function. is a placeholder
for the application-defined function name.
Handle to the device context passed to .
Pointer to a structure representing the table of handles associated with the graphics objects (pens, brushes, and so
on) in the metafile. The first entry contains the enhanced-metafile handle.
Pointer to one of the records in the metafile. This record should not be modified. (If modification is necessary, it should be performed on a
copy of the record.)
Specifies the number of objects with associated handles in the handle table.
Pointer to optional data.
This function must return a nonzero value to continue enumeration; to stop enumeration, it must return zero.
An application must register the callback function by passing its address to the function.
The function is an application-defined callback function used with the function. It is
called when a print job is to be canceled during spooling. The type defines a pointer to this callback function.
is a placeholder for the application-defined function name.
A handle to the device context for the print job.
Specifies whether an error has occurred. This parameter is zero if no error has occurred; it is SP_OUTOFDISK if Print Manager is currently out of
disk space and more disk space will become available if the application waits.
The callback function should return TRUE to continue the print job or FALSE to cancel the print job.
Note: This is a blocking or synchronous function and might not return immediately. How quickly this function returns depends on run-time
factors such as network status, print server configuration, and printer driver implementation—factors that are difficult to predict when
writing an application. Calling this function from a thread that manages interaction with the user interface could make the application
appear to be unresponsive.
If the parameter is SP_OUTOFDISK, the application need not cancel the print job. If it does not cancel the job, it
must yield to Print Manager by calling thePeekMessage or GetMessage function.
The function is an application-defined callback function that processes Windows-format metafile records. This
function is called by the function. The type defines a pointer to this
callback function. is a placeholder for the application-defined function name.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
Handle to the device context passed to .
Pointer to a table of handles associated with the graphics objects (pens, brushes, and so on) in the metafile.
Pointer to one of the records in the metafile. This record should not be modified. (If modification is necessary, it should be performed on a
copy of the record.)
Specifies the number of objects with associated handles in the handle table.
Pointer to optional data.
This function must return a nonzero value to continue enumeration; to stop enumeration, it must return zero.
An application must register the callback function by passing its address to the function.
is a placeholder for the application-supplied function name.
The function is an application-defined callback function used with the function.
It is used to process the object data. The GOBJENUMPROC type defines a pointer to this callback function. is a
placeholder for the application-defined function name.
A pointer to a or structure describing the attributes of the object.
A pointer to the application-defined data passed by the function.
To continue enumeration, the callback function must return a nonzero value. This value is user-defined.
To stop enumeration, the callback function must return zero.
An application must register this function by passing its address to the function.
The function is an application-defined callback function used with the function. It is
used to process coordinates. The type defines a pointer to this callback function. is a
placeholder for the application-defined function name.
Specifies the x-coordinate, in logical units, of the current point.
Specifies the y-coordinate, in logical units, of the current point.
Pointer to the application-defined data.
This function does not return a value.
An application registers a function by passing its address to the function.
The function is an application defined callback function used with the
function. It is used to process the fonts. It is called once for each enumerated font. The FONTENUMPROC type defines a pointer to this callback
function. is a placeholder for the application defined function name.
A pointer to an structure that contains information about the logical attributes of the font. To obtain additional
information about the font, you can cast the result as an or structure.
A pointer to a structure that contains information about the physical attributes of a font. The function uses the
structure for TrueType fonts; and the structure for other fonts.
This can be an structure.
The type of the font. This parameter can be a combination of these values:
- DEVICE_FONTTYPE
- RASTER_FONTTYPE
- TRUETYPE_FONTTYPE
The application-defined data passed by the function.
The return value must be a nonzero value to continue enumeration; to stop enumeration, the return value must be zero.
An application must register this callback function by passing its address to the function.
When the graphics mode on the device context is set to GM_ADVANCED using the function and the
DEVICE_FONTTYPE flag is passed to the FontType parameter, this function returns a list of type 1 and OpenType fonts on the system. When the
graphics mode is not set to GM_ADVANCED, this function returns a list of type 1, OpenType, and TrueType fonts on the system.
Unlike the EnumFontFamProc callback function, receives extended information about a font. The
structure includes the localized name of the script (character set) and the
structure includes a font-coverage signature.
Collection of native methods in gdi32.dll.
The function retrieves optional palette entries from the specified enhanced metafile.
A handle to the enhanced metafile.
The number of entries to be retrieved from the optional palette.
A pointer to an array of structures that receives the palette colors. The array must contain at least as many
structures as there are entries specified by the parameter.
If the array pointer is NULL and the enhanced metafile contains an optional palette, the return value is the number of entries in the enhanced
metafile's palette; if the array pointer is a valid pointer and the enhanced metafile contains an optional palette, the return value is the
number of entries copied; if the metafile does not contain an optional palette, the return value is zero. Otherwise, the return value is
GDI_ERROR.
An application can store an optional palette in an enhanced metafile by calling the and
functions before creating the picture and storing it in the metafile. By doing this, the application can
achieve consistent colors when the picture is displayed on a variety of devices.
An application that displays a picture stored in an enhanced metafile can call the function to
determine whether the optional palette exists. If it does, the application can call the function
a second time to retrieve the palette entries and then create a logical palette (by using the function), select
it into its device context (by using the function), and then realize it (by using the
function). After the logical palette has been realized, calling the function
displays the picture using its original colors.
The function is available for use in the operating systems specified in the Requirements section.
It may be altered or unavailable in subsequent versions.
The function creates a font resource file for a scalable font.
Specifies whether the font is a read-only font. This parameter can be one of the following values.
-
0
The font has read/write permission.
-
1
The font has read-only permission and should be hidden from other applications in the system. When this flag is set, the font is not
enumerated by the or function.
A pointer to a null-terminated string specifying the name of the font resource file to create. If this parameter specifies an existing font
resource file, the function fails.
A pointer to a null-terminated string specifying the name of the scalable font file that this function uses to create the
font resource file.
A pointer to a null-terminated string specifying the path to the scalable font file.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
If specifies an existing font file, GetLastError returns ERROR_FILE_EXISTS
The function is used by applications that install TrueType fonts. An application uses the
function to create a font resource file (typically with a .fot file name extension) and then uses
the function to install the font. The TrueType font file (typically with a .ttf file name extension) must be
in the System subdirectory of the Windows directory to be used by the function.
The function currently supports only TrueType-technology scalable fonts.
When the parameter specifies only a file name and extension, the
parameter must specify a path. When the parameter specifies a full path, the
parameter must be NULL or a pointer to NULL.
When only a file name and extension are specified in the parameter and a path is specified in the
parameter, the string in is copied into the .fot file as the .ttf file
that belongs to this resource. When the function is called, the operating system assumes that the .ttf file
has been copied into the System directory (or into the main Windows directory in the case of a network installation). The .ttf file need not
be in this directory when the function is called, because the
parameter contains the directory information. A resource created in this manner does not contain absolute path information and can be used in
any installation.
When a path is specified in the parameter and NULL is specified in the
parameter, the string in is copied into the .fot file. In this case, when the
function is called, the .ttf file must be at the location specified in the parameter when the
function was called; the parameter is not needed. A resource
created in this manner contains absolute references to paths and drives and does not work if the .ttf file is moved to a different location.
The function retrieves an optional text description from an enhanced-format metafile and copies the
string to the specified buffer.
A handle to the enhanced metafile.
The size, in characters, of the buffer to receive the data. Only this many characters will be copied.
A pointer to a buffer that receives the optional text description.
If the optional text description exists and the buffer pointer is NULL, the return value is the length of the text string, in characters.
If the optional text description exists and the buffer pointer is a valid pointer, the return value is the number of characters copied into
the buffer.
If the optional text description does not exist, the return value is zero.
If the function fails, the return value is GDI_ERROR.
The optional text description contains two strings, the first identifying the application that created the enhanced metafile and the second
identifying the picture contained in the metafile. The strings are separated by a null character and terminated with two null charactersfor
example, "XYZ Graphics Editor\0Bald Eagle\0\0" where \0 represents the null character.
Where text arguments must use Unicode characters, use this function as a wide-character function. Where text arguments must use characters
from the Windows character set, use this function as an ANSI function.
The function creates an elliptical region.
Pointer to a structure that contains the coordinates of the upper-left and lower-right corners of the bounding rectangle of
the ellipse in logical units.
If the function succeeds, the return value is the handle to the region.
If the function fails, the return value is NULL.
When you no longer need the HRGN object, call the function to delete it.
A bounding rectangle defines the size, shape, and orientation of the region: The long sides of the rectangle define the length of the
ellipse's major axis; the short sides define the length of the ellipse's minor axis; and the center of the rectangle defines the intersection
of the major and minor axes.
The function removes the fonts added from a memory image file.
A handle to the font-resource. This handle is returned by the function.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero. No extended error information is available.
This function removes a font that was added by the function. To remove the font, specify the same path and
flags as were used in . This function will only remove the font that is specified by .
The function retrieves a range of palette entries from the system palette that is associated with the
specified device context (DC).
A handle to the device context.
The first entry to be retrieved from the system palette.
The number of entries to be retrieved from the system palette.
A pointer to an array of structures to receive the palette entries. The array must contain at least as many
structures as specified by the parameter. If this parameter is NULL, the function returns the total number of
entries in the palette.
If the function succeeds, the return value is the number of entries retrieved from the palette.
If the function fails, the return value is zero.
An application can determine whether a device supports palette operations by calling the function and specifying the
RASTERCAPS constant.
The function creates a discardable bitmap that is compatible with the specified device. The bitmap has
the same bits-per-pixel format and the same color palette as the device. An application can select this bitmap as the current bitmap for a
memory device that is compatible with the specified device.
This function is provided only for compatibility with 16-bit versions of Windows. Applications should use the
function.
A handle to a device context.
The width, in pixels, of the bitmap.
The height, in pixels, of the bitmap.
If the function succeeds, the return value is a handle to the compatible bitmap (DDB).
If the function fails, the return value is NULL.
When you no longer need the bitmap, call the function to delete it.
The function creates a logical brush that has the pattern specified by the device-independent bitmap
(DIB).
A pointer to a packed DIB consisting of a structure immediately followed by an array of bytes defining the pixels of
the bitmap.
Specifies whether the member of the structure contains a valid color table and,
if so, whether the entries in this color table contain explicit red, green, blue (RGB) values or palette indexes. The
parameter must be one of the following values.
-
DIB_PAL_COLORS
A color table is provided and consists of an array of 16-bit indexes into the logical palette of the device context into which the
brush is to be selected.
-
DIB_RGB_COLORS
A color table is provided and contains literal RGB values.
If the function succeeds, the return value identifies a logical brush.
If the function fails, the return value is NULL.
A brush is a bitmap that the system uses to paint the interiors of filled shapes.
After an application creates a brush by calling , it can select that brush into any device context by
calling the function.
When you no longer need the brush, call the function to delete it.
ICM: No color is done at brush creation. However, color management is performed when the brush is selected into an ICM-enabled device
context.
The function retrieves text metrics for TrueType fonts.
A handle to the device context.
The size, in bytes, of the array that receives the text metrics.
A pointer to an structure. If this parameter is NULL, the function returns the size of the buffer required for
the retrieved metric data.
If the function succeeds, the return value is nonzero or the size of the required buffer.
If the function fails, the return value is zero.
The structure contains most of the text metric information provided for TrueType fonts (including a
structure). The sizes returned in are in logical units; they depend on the current
mapping mode.
The function retrieves the index for the entry in the specified logical palette most closely matching a
specified color value.
A handle to a logical palette.
A color to be matched. To create a color value, use the RGB macro.
If the function succeeds, the return value is the index of an entry in a logical palette.
If the function fails, the return value is CLR_INVALID.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
If the given logical palette contains entries with the PC_EXPLICIT flag set, the return value is undefined.
The function retrieves information about a character string, such as character widths, caret
positioning, ordering within the string, and glyph rendering. The type of information returned depends on the
parameter and is based on the currently selected font in the specified display context. The function copies the information to the specified
structure or to one or more arrays specified by the structure.
Although this function was once adequate for working with character strings, a need to work with an increasing number of languages and
scripts has rendered it obsolete. It has been superseded by the functionality of the Uniscribe module. For more information, see Uniscribe.
It is recommended that an application use the function to determine whether the GCP_DIACRITIC, GCP_DBCS,
GCP_USEKERNING, GCP_LIGATE, GCP_REORDER, GCP_GLYPHSHAPE, and GCP_KASHIDA values are valid for the currently selected font. If not valid,
ignores the value.
The GCP_NODIACRITICS value is no longer defined and should not be used.
A handle to the device context.
A pointer to the character string to process. The string does not need to be zero-terminated, since specifies the
length of the string.
The length of the string pointed to by .
The maximum extent (in logical units) to which the string is processed. Characters that, if processed, would exceed this extent are ignored.
Computations for any required ordering or glyph arrays apply only to the included characters. This parameter is used only if the GCP_MAXEXTENT
value is specified in the parameter. As the function processes the input string, each character and its extent is
added to the output, extent, and other arrays only if the total extent has not yet exceeded the maximum. Once the limit is reached, processing
will stop.
A pointer to a structure that receives the results of the function.
Specifies how to process the string into the required arrays. This parameter can be one or more of the following values.
-
GCP_CLASSIN
Specifies that the array contains preset classifications for characters. The classifications may
be the same as on output. If the particular classification for a character is not known, the corresponding location in the array must
be set to zero. for more information about the classifications, see GCP_RESULTS. This is useful only if
returned the GCP_REORDER flag.
-
GCP_DIACRITIC
Determines how diacritics in the string are handled. If this value is not set, diacritics are treated as zero-width characters.
For example, a Hebrew string may contain diacritics, but you may not want to display them.
Use to determine whether a font supports diacritics. If it does, you can use or not use the
GCP_DIACRITIC flag in the call to , depending on the needs of your application.
-
GCP_DISPLAYZWG
For languages that need reordering or different glyph shapes depending on the positions of the characters within a word,
nondisplayable characters often appear in the code page. For example, in the Hebrew code page, there are Left-To-Right and
Right-To-Left markers, to help determine the final positioning of characters within the output strings. Normally these are not
displayed and are removed from the and arrays. You can use the
GCP_DISPLAYZWG flag to display these characters.
-
GCP_GLYPHSHAPE
Specifies that some or all characters in the string are to be displayed using shapes other than the standard shapes defined in the
currently selected font for the current code page. Some languages, such as Arabic, cannot support glyph creation unless this value is
specified. As a general rule, if returns this value for a string, this value must be used with
.
-
GCP_JUSTIFY
Adjusts the extents in the array so that the string length is the same as
. GCP_JUSTIFY may only be used in conjunction with GCP_MAXEXTENT.
-
GCP_KASHIDA
Use Kashidas as well as, or instead of, adjusted extents to modify the length of the string so that it is equal to the value
specified by . In the array, a Kashida is indicated by a negative
justification index. GCP_KASHIDA may be used only in conjunction with GCP_JUSTIFY and only if the font (and language) support
Kashidas. Use to determine whether the current font supports Kashidas.
Using Kashidas to justify the string can result in the number of glyphs required being greater than the number of characters in
the input string. Because of this, when Kashidas are used, the application cannot assume that setting the arrays to be the size
of the input string will be sufficient. (The maximum possible will be approximately dxPageWidth/dxAveCharWidth, where dxPageWidth
is the width of the document and dxAveCharWidth is the average character width as returned from a
call).
Note that just because returns the GCP_KASHIDA flag does not mean that it has to be used in
the call to , just that the option is available.
-
GCP_LIGATE
Use ligations wherever characters ligate. A ligation occurs where one glyph is used for two or more characters. For example, the
letters a and e can ligate to ?. For this to be used, however, both the language support and the font must support the required
glyphs (the example will not be processed by default in English).
Use to determine whether the current font supports ligation. If it does and a specific maximum
is required for the number of characters that will ligate, set the number in the first element of the
array. If normal ligation is required, set this value to zero. If GCP_LIGATE is not specified, no ligation will take place. See
GCP_RESULTS for more information.
If the GCP_REORDER value is usually required for the character set but is not specified, the output will be meaningless unless
the string being passed in is already in visual ordering (that is, the result that gets put into lpGcpResults->lpOutString in one
call to is the input string of a second call).
Note that just because returns the GCP_LIGATE flag does not mean that it has to be used in the
call to , just that the option is available.
-
GCP_MAXEXTENT
Compute extents of the string only as long as the resulting extent, in logical units, does not exceed the values specified by the
parameter.
-
GCP_NEUTRALOVERRIDE
Certain languages only. Override the normal handling of neutrals and treat them as strong characters that match the strings reading
order. Useful only with the GCP_REORDER flag.
-
GCP_NUMERICOVERRIDE
Certain languages only. Override the normal handling of numerics and treat them as strong characters that match the strings reading
order. Useful only with the GCP_REORDER flag.
-
GCP_NUMERICSLATIN
Arabic/Thai only. Use standard Latin glyphs for numbers and override the system default. To determine if this option is available in
the language of the font, use GetStringTypeEx to see if the language supports more than one number format.
-
GCP_NUMERICSLOCAL
Arabic/Thai only. Use local glyphs for numeric characters and override the system default. To determine if this option is available
in the language of the font, use GetStringTypeEx to see if the language supports more than one number format.
-
GCP_REORDER
Reorder the string. Use for languages that are not SBCS and left-to-right reading order. If this value is not specified, the
string is assumed to be in display order already.
If this flag is set for Semitic languages and the array is used, the first two elements of the
array are used to specify the reading order beyond the bounds of the string. GCP_CLASS_PREBOUNDRTL and GCP_CLASS_PREBOUNDLTR can
be used to set the order. If no preset order is required, set the values to zero. These values can be combined with other values
if the GCPCLASSIN flag is set.
If the GCP_REORDER value is not specified, the parameter is taken to be visual ordered for languages
where this is used, and the and fields are ignored.
Use to determine whether the current font supports reordering.
-
GCP_SYMSWAPOFF
Semitic languages only. Specifies that swappable characters are not reset. For example, in a right-to-left string, the '('
and ')' are not reversed.
-
GCP_USEKERNING
Use kerning pairs in the font (if any) when creating the widths arrays. Use to determine
whether the current font supports kerning pairs.
Note that just because returns the GCP_USEKERNING flag does not mean that it has to be used in
the call to , just that the option is available. Most TrueType fonts have a kerning table,
but you do not have to use it.
It is recommended that an application use the function to determine whether the GCP_DIACRITIC, GCP_DBCS,
GCP_USEKERNING, GCP_LIGATE, GCP_REORDER, GCP_GLYPHSHAPE, and GCP_KASHIDA values are valid for the currently selected font. If not valid,
ignores the value.
The GCP_NODIACRITICS value is no longer defined and should not be used.
If the function succeeds, the return value is the width and height of the string in logical units. The width is the low-order word and the
height is the high-order word.
If the function fails, the return value is zero.
ensures that an application can correctly process text regardless of the international setting and type
of fonts available. Applications use this function before using the function and in place of the
function (and occasionally in place of the and
functions).
Using to retrieve intercharacter spacing and index arrays is not always necessary unless justification
or kerning is required. For non-Latin fonts, applications can improve the speed at which the function renders text
by using to retrieve the intercharacter spacing and index arrays before calling
. This is especially useful when rendering the same text repeatedly or when using intercharacter spacing to position
the caret. If the output array is used in the call to , the ETO_GLYPH_INDEX flag
must be set.
checks the , ,
, , and members of the
structure and fills the corresponding arrays if these members are not set to NULL. If
cannot fill an array, it sets the corresponding member to NULL. To ensure retrieval of valid
information, the application is responsible for setting the member to a valid address before calling the function and for checking the value
of the member after the call. If the GCP_JUSTIFY or GCP_USEKERNING values are specified, the and/or
members must have valid addresses.
Note that the glyph indexes returned in GCP_RESULTS.lpGlyphs are specific to the current font in the device context and should only be used
to draw text in the device context while that font remains selected.
When computing justification, if the trailing characters in the string are spaces, the function reduces the length of the string and removes
the spaces prior to computing the justification. If the array consists of only spaces, the function returns an error.
expects an entry for each byte of a DBCS string, whereas
assigns an entry for each glyph. To correct this mismatch when using this combination of functions, either
use or expand the array with zero-width entries for the corresponding second
byte of a DBCS byte pair.
If the logical width is less than the width of the leading character in the input string, GCP_RESULTS.nMaxFit returns a bad value. For this
case, call for glyph indexes and the array. Then use the
array to do the extent calculation using the advance width of each character, where
is the number of characters whose glyph indexes advance width is less than the width of the leading
character.
The function retrieves the widths, in logical units, of consecutive characters in a specified range from the
current font.
Handle to the device context.
Specifies the code point of the first character in the group of consecutive characters where the ABC widths are sought.
Specifies the code point of the last character in the group of consecutive characters where the ABC widths are sought. This range is inclusive.
An error is returned if the specified last character precedes the specified first character.
Pointer to an array of structures that receives the character widths, in logical units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
Unlike the function that returns widths only for TrueType fonts, the
function retrieves widths for any font. The widths returned by this function are in the IEEE floating-point format.
If the current world-to-device transformation is not identified, the returned widths may be non-integer values, even if the corresponding
values in the device space are integers.
A spacing is the distance added to the current position before placing the glyph. B spacing is the width of the black part of the glyph. C
spacing is the distance added to the current position to provide white space to the right of the glyph. The total advanced width is specified
by A+B+C.
The ABC spaces are measured along the character base line of the selected font.
The ABC widths of the default character are used for characters outside the range of the currently selected font.
The function retrieves the setting for the current aspect-ratio filter.
Handle to a device context.
Pointer to a structure that receives the current aspect-ratio filter.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The aspect ratio is the ratio formed by the width and height of a pixel on a specified device.
The system provides a special filter, the aspect-ratio filter, to select fonts that were designed for a particular device. An application can
specify that the system should only retrieve fonts matching the specified aspect ratio by calling the function.
The function creates a bitmap compatible with the device that is associated with the specified device
context.
A handle to a device context.
The bitmap width, in pixels.
The bitmap height, in pixels.
If the function succeeds, the return value is a handle to the compatible bitmap (DDB).
If the function fails, the return value is NULL.
The color format of the bitmap created by the function matches the color format of the device
identified by the parameter. This bitmap can be selected into any memory device context that is compatible with the
original device.
Because memory device contexts allow both color and monochrome bitmaps, the format of the bitmap returned by the
function differs when the specified device context is a memory device context. However, a compatible
bitmap that was created for a nonmemory device context always possesses the same color format and uses the same color palette as the
specified device context.
Note: When a memory device context is created, it initially has a 1-by-1 monochrome bitmap selected into it. If this memory device context is
used in , the bitmap that is created is a monochrome bitmap. To create a color bitmap, use the HDC that
was used to create the memory device context, as shown in the following code:
The function sets the intercharacter spacing. Intercharacter spacing is added to each character, including
break characters, when the system writes a line of text.
A handle to the device context.
The amount of extra space, in logical units, to be added to each character. If the current mapping mode is not MM_TEXT, the
parameter is transformed and rounded to the nearest pixel.
If the function succeeds, the return value is the previous intercharacter spacing.
If the function fails, the return value is 0x80000000.
This function is supported mainly for compatibility with existing applications. New applications should generally avoid calling this
function, because it is incompatible with complex scripts (scripts that require text shaping; Arabic script is an example of this).
The recommended approach is that instead of calling this function and then , applications should call
and use its lpDx parameter to supply widths.
The function removes the fonts in the specified file from the system font table.
A pointer to a null-terminated string that names a font resource file.
The characteristics of the font to be removed from the system. In order for the font to be removed, the flags used must be the same as when the
font was added with the function. See the function for more information.
Reserved. Must be zero.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero. No extended error information is available.
This function will only remove the font if the flags specified are the same as when then font was added with the
function.
The function plays an enhanced-metafile record by executing the graphics device interface (GDI) functions
identified by the record.
A handle to the device context passed to the function.
A pointer to a table of handles to GDI objects used when playing the metafile. The first entry in this table contains the
enhanced-metafile handle.
A pointer to the enhanced-metafile record to be played.
The number of handles in the handle table.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
This is an enhanced-metafile function.
An application typically uses in conjunction with the function to process
and play an enhanced-format metafile one record at a time.
The , , and parameters must be exactly those passed to
the callback procedure by the function.
If does not recognize a record, it ignores the record and returns TRUE.
The function computes the width and height of the specified string of text.
A handle to the device context.
A pointer to a buffer that specifies the text string. The string does not need to be null-terminated, because the parameter
specifies the length of the string.
The length of the string pointed to by .
A pointer to a structure that receives the dimensions of the string, in logical units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function uses the currently selected font to compute the dimensions of the string. The width and
height, in logical units, are computed without considering any clipping.
Because some devices kern characters, the sum of the extents of the characters in a string may not be equal to the extent of the string.
The calculated string width takes into account the intercharacter spacing set by the function and the
justification set by . This is true for both displaying on a screen and for printing. However, if lpDx is
set in , does not take into account either intercharacter spacing or
justification. In addition, for EMF, the print result always takes both intercharacter spacing and justification into account.
When dealing with text displayed on a screen, the calculated string width takes into account the intercharacter spacing set by the
function and the justification set by . However, if lpDx is set in
, does not take into account either intercharacter spacing or justification.
However, when printing with EMF:
The function retrieves the number of characters in a specified string that will fit within a specified space
and fills an array with the text extent for each of those characters. (A text extent is the distance between the beginning of the space and a
character that will fit in the space.) This information is useful for word-wrapping calculations.
A handle to the device context.
A pointer to the null-terminated string for which extents are to be retrieved.
The number of characters in the string pointed to by the parameter. For an ANSI call it specifies the string length
in bytes and for a Unicode it specifies the string length in WORDs. Note that for the ANSI function, characters in SBCS code pages take one byte
each, while most characters in DBCS code pages take two bytes; for the Unicode function, most currently defined Unicode characters (those in the
Basic Multilingual Plane (BMP)) are one WORD while Unicode surrogates are two WORDs.
The maximum allowable width, in logical units, of the formatted string.
A pointer to an integer that receives a count of the maximum number of characters that will fit in the space specified by the
parameter. When the parameter is NULL, the parameter is
ignored.
A pointer to an array of integers that receives partial string extents. Each element in the array gives the distance, in logical units,
between the beginning of the string and one of the characters that fits in the space specified by the
parameter. This array must have at least as many elements as characters specified by the parameter because the
entire array is used internally. The function fills the array with valid extents for as many characters as are specified by the
parameter. Any values in the rest of the array should be ignored. If is NULL, the
function does not compute partial string widths.
For complex scripts, where a sequence of characters may be represented by any number of glyphs, the values in the
array up to the number specified by the parameter match one-to-one with code points. Again, you should ignore the
rest of the values in the array.
A pointer to a structure that receives the dimensions of the string, in logical units. This parameter cannot be NULL.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
If both the and parameters are NULL, calling the
function is equivalent to calling the function.
For the ANSI version of , the array has the same number of INT values as there
are bytes in . The INT values that correspond to the two bytes of a DBCS character are each the extent of the
entire composite character.
Note, the values for are not the same as the lpDx values for
. To use the values in , you must first process them.
When this function returns the text extent, it assumes that the text is horizontal, that is, that the escapement is always 0. This is true
for both the horizontal and vertical measurements of the text. Even if you use a font that specifies a nonzero escapement, this function
doesn't use the angle while it computes the text extent. The app must convert it explicitly. However, when the graphics mode is set to
GM_ADVANCED and the character orientation is 90 degrees from the print orientation, the values that this function return do not follow this
rule. When the character orientation and the print orientation match for a given string, this function returns the dimensions of the string
in the structure as { cx : 116, cy : 18 }. When the character orientation and the print orientation are 90 degrees apart
for the same string, this function returns the dimensions of the string in the structure as { cx : 18, cy : 116 }.
This function returns the extent of each successive character in a string. When these are rounded to logical units, you get different results
than what is returned from the , which returns the width of each individual character rounded to logical units.
The function retrieves the number of characters in a specified string that will fit within a specified space
and fills an array with the text extent for each of those characters. (A text extent is the distance between the beginning of the space and a
character that will fit in the space.) This information is useful for word-wrapping calculations.
A handle to the device context.
A pointer to an array of glyph indices for which extents are to be retrieved.
The number of glyphs in the array pointed to by the parameter.
The maximum allowable width, in logical units, of the formatted string.
A pointer to an integer that receives a count of the maximum number of characters that will fit in the space specified by the
parameter. When the parameter is NULL, the parameter is
ignored.
A pointer to an array of integers that receives partial glyph extents. Each element in the array gives the distance, in logical units, between
the beginning of the glyph indices array and one of the glyphs that fits in the space specified by the parameter.
Although this array should have at least as many elements as glyph indices specified by the parameter, the function fills
the array with extents only for as many glyph indices as are specified by the parameter. If
is NULL, the function does not compute partial string widths.
A pointer to a structure that receives the dimensions of the glyph indices array, in logical units. This value cannot be
NULL.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
If both the and parameters are NULL, calling the
function is equivalent to calling the function.
When this function returns the text extent, it assumes that the text is horizontal, that is, that the escapement is always 0. This is true
for both the horizontal and vertical measurements of the text. Even if you use a font that specifies a nonzero escapement, this function
doesn't use the angle while it computes the text extent. The app must convert it explicitly. However, when the graphics mode is set to
GM_ADVANCED and the character orientation is 90 degrees from the print orientation, the values that this function return do not follow this
rule. When the character orientation and the print orientation match for a given string, this function returns the dimensions of the string
in the structure as { cx : 116, cy : 18 }. When the character orientation and the print orientation are 90 degrees apart
for the same string, this function returns the dimensions of the string in the structure as { cx : 18, cy : 116 }.
The function retrieves the current intercharacter spacing for the specified device context.
Handle to the device context.
If the function succeeds, the return value is the current intercharacter spacing, in logical coordinates.
If the function fails, the return value is 0x8000000.
The intercharacter spacing defines the extra space, in logical units along the base line, that the or
functions add to each character as a line is written. The spacing is used to expand lines of text.
The function creates a rectangular region.
Pointer to a structure that contains the coordinates of the upper-left and lower-right corners of the rectangle that defines
the region in logical units.
If the function succeeds, the return value is the handle to the region.
If the function fails, the return value is NULL.
When you no longer need the HRGN object, call the function to delete it.
Region coordinates are represented as 27-bit signed integers.
The region will be exclusive of the bottom and right edges.
The function creates a halftone palette for the specified device context (DC).
A handle to the device context.
If the function succeeds, the return value is a handle to a logical halftone palette.
If the function fails, the return value is zero.
An application should create a halftone palette when the stretching mode of a device context is set to HALFTONE. The logical halftone palette
returned by should then be selected and realized into the device context before the
or function is called.
When you no longer need the palette, call the function to delete it.
The function specifies a logical font that has the characteristics in the specified structure. The font can
subsequently be selected as the current font for any device context.
Pointer to an structure that defines the characteristics of a multiple master font.
Note, this function ignores the member in .
If the function succeeds, the return value is the handle to the new structure.
If the function fails, the return value is zero. No extended error information is available.
The function creates a logical font with the characteristics specified in the
structure. When this font is selected by using the function, GDI's font mapper
attempts to match the logical font with an existing physical font. If it fails to find an exact match, it provides an alternative whose
characteristics match as many of the requested characteristics as possible.
When you no longer need the font, call the function to delete it.
The font mapper for , , and recognizes both the
English and the localized typeface name, regardless of locale.
The function creates a logical brush that has the pattern specified by the specified device-independent
bitmap (DIB). The brush can subsequently be selected into any device context that is associated with a device that supports raster
operations.
This function is provided only for compatibility with 16-bit versions of Windows. Applications should use the
function.
A handle to a global memory object containing a packed DIB, which consists of a structure immediately followed by an
array of bytes defining the pixels of the bitmap.
Specifies whether the member of the structure is initialized and, if so,
whether this member contains explicit red, green, blue (RGB) values or indexes into a logical palette. The
parameter must be one of the following values.
-
DIB_PAL_COLORS
A color table is provided and consists of an array of 16-bit indexes into the logical palette of the device context into which the
brush is to be selected.
-
DIB_RGB_COLORS
A color table is provided and contains literal RGB values.
If the function succeeds, the return value identifies a logical brush.
If the function fails, the return value is NULL.
When an application selects a two-color DIB pattern brush into a monochrome device context, the system does not acknowledge the colors
specified in the DIB; instead, it displays the pattern brush using the current background and foreground colors of the device context. Pixels
mapped to the first color of the DIB (offset 0 in the DIB color table) are displayed using the foreground color; pixels mapped to the second
color (offset 1 in the color table) are displayed using the background color.
When you no longer need the brush, call the function to delete it.
ICM: No color is done at brush creation. However, color management is performed when the brush is selected into an ICM-enabled device
context.
Translates character set information and sets all members of a destination structure to appropriate values.
Pointer to the member of a structure if is set to
TCI_SRCFONTSIG. Otherwise, this parameter is set to a DWORD value indicating the source.
Pointer to a structure that receives the translated character set information.
Flags specifying how to perform the translation. This parameter can be one of the following values.
-
TCI_SRCCHARSET
Source contains the character set value in the low word, and 0 in the high word.
-
TCI_SRCCODEPAGE
Source is a code page identifier in the low word and 0 in the high word.
-
TCI_SRCFONTSIG
Source is the code page bitfield portion of a structure. On input this should have only one Windows
code-page bit set, either for an ANSI code page value or for a common ANSI and OEM value (for OEM values, bits 32-63 must be
clear). On output, this has only one bit set.
If the TCI_SRCFONTSIG value is given, the parameter must be the address of the code-page bitfield. If
any other TCI_ value is given, the parameter must be a value not an address.
-
TCI_SRCLOCALE
Windows 2000: Source is the locale identifier (LCID) or language identifier of the keyboard layout. If it is a language identifier,
the value is in the low word.
Returns a nonzero value if successful, or 0 otherwise. To get extended error information, the application can call GetLastError.
The function specifies the amount of space the system should add to the break characters in a string of text.
The space is added when an application calls the or functions.
A handle to the device context.
The total extra space, in logical units, to be added to the line of text. If the current mapping mode is not MM_TEXT, the value identified by the
parameter is transformed and rounded to the nearest pixel.
The number of break characters in the line.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The break character is usually the space character (ASCII 32), but it may be defined by a font as some other character. The
function can be used to retrieve a font's break character.
The function distributes the specified extra space evenly among the break characters in the line.
The function is always used with the function. Sometimes the
function takes justification into account when computing the width of a specified line before
justification, and sometimes it does not. For more details on this, see . This width must be known before
an appropriate value can be computed.
can be used to justify a line that contains multiple strings in different fonts. In this case, each
string must be justified separately.
Because rounding errors can occur during justification, the system keeps a running error term that defines the current error value. When
justifying a line that contains multiple runs, automatically uses this error term when it computes the
extent of the next run, allowing to blend the error into the new run. After each line has been justified, this error
term must be cleared to prevent it from being incorporated into the next line. The term can be cleared by calling
with set to zero.
The function assigns preferred dimensions to a bitmap. These dimensions can be used by applications; however,
they are not used by the system.
A handle to the bitmap. The bitmap cannot be a DIB-section bitmap.
The width, in 0.1-millimeter units, of the bitmap.
The height, in 0.1-millimeter units, of the bitmap.
A pointer to a structure to receive the previous dimensions of the bitmap. This pointer can be NULL.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
An application can retrieve the dimensions assigned to a bitmap with the function by calling the
function.
The bitmap identified by cannot be a DIB section, which is a bitmap created by the
function. If the bitmap is a DIB section, the function fails.
The function changes the world transformation for a device context using the specified mode.
A handle to the device context.
A pointer to an structure used to modify the world transformation for the given device context.
Specifies how the transformation data modifies the current world transformation. This parameter must be one of the following values.
-
MWT_IDENTITY
Resets the current world transformation by using the identity matrix. If this mode is specified, the structure
pointed to by is ignored.
-
MWT_LEFTMULTIPLY
Multiplies the current transformation by the data in the structure. (The data in the
structure becomes the left multiplicand, and the data for the current transformation becomes the right multiplicand.)
-
MWT_RIGHTMULTIPLY
Multiplies the current transformation by the data in the structure. (The data in the
structure becomes the right multiplicand, and the data for the current transformation becomes the left multiplicand.)
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function will fail unless graphics mode for the specified device context has been set to GM_ADVANCED by
previously calling the function. Likewise, it will not be possible to reset the graphics mode for the device
context to the default GM_COMPATIBLE mode, unless world transform has first been reset to the default identity transform by calling
or .
The function returns information about which Unicode characters are supported by a font. The information is
returned as a structure.
A handle to the device context.
A pointer to a structure that receives the glyph set information. If this parameter is NULL, the function returns the
size of the structure required to store the information.
If the function succeeds, it returns number of bytes written to the GLYPHSET structure or, if the parameter is NULL,
it returns the size of the GLYPHSET structure required to store the information.
If the function fails, it returns zero. No extended error information is available.
The function retrieves the record containing the header for the specified enhanced-format metafile.
A handle to the enhanced metafile for which the header is to be retrieved.
The size, in bytes, of the buffer to receive the data. Only this many bytes will be copied.
A pointer to an structure that receives the header record. If this parameter is NULL, the function returns the size
of the header record.
If the function succeeds and the structure pointer is NULL, the return value is the size of the record that contains the header; if the structure
pointer is a valid pointer, the return value is the number of bytes copied. Otherwise, it is zero.
An enhanced-metafile header contains such information as the metafile's size, in bytes; the dimensions of the picture stored in the metafile;
the number of records stored in the metafile; the offset to the optional text description; the size of the optional palette, and the
resolution of the device on which the picture was created.
The record that contains the enhanced-metafile header is always the first record in the metafile.
The function retrieves the current position in logical coordinates.
A handle to the device context.
A pointer to a structure that receives the logical coordinates of the current position.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function retrieves the dimensions of a compatible bitmap. The retrieved dimensions must have been set by
the function.
A handle to a compatible bitmap (DDB).
A pointer to a structure to receive the bitmap dimensions. For more information, see Remarks.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function returns a data structure that contains fields for the height and width of the bitmap, in .01-mm units. If those dimensions have not
yet been set, the structure that is returned will have zeros in those fields.
The function creates a region consisting of a series of polygons. The polygons can overlap.
A pointer to an array of structures that define the vertices of the polygons in logical units. The polygons are specified
consecutively. Each polygon is presumed closed and each vertex is specified only once.
A pointer to an array of integers, each of which specifies the number of points in one of the polygons in the array pointed to by
.
The total number of integers in the array pointed to by .
The fill mode used to determine which pixels are in the region. This parameter can be one of the following values.
-
ALTERNATE
Selects alternate mode (fills area between odd-numbered and even-numbered polygon sides on each scan line).
-
WINDING
Selects winding mode (fills any region with a nonzero winding value).
For more information about these modes, see the function.
If the function succeeds, the return value is the handle to the region.
If the function fails, the return value is zero.
When you no longer need the HRGN object, call the function to delete it.
Region coordinates are represented as 27-bit signed integers.
The function creates a bitmap with the specified width, height, and color format (color planes and
bits-per-pixel).
A pointer to a structure that contains information about the bitmap. If an application sets the
or members to zero, returns the handle to a
1-by-1 pixel, monochrome bitmap.
If the function succeeds, the return value is a handle to the bitmap.
If the function fails, the return value is NULL.
This function can return the following values.
The function creates a device-dependent bitmap.
After a bitmap is created, it can be selected into a device context by calling the function. However, the bitmap
can only be selected into a device context if the bitmap and the DC have the same format.
While the function can be used to create color bitmaps, for performance reasons applications should use
to create monochrome bitmaps and to create color bitmaps. Whenever
a color bitmap from is selected into a device context, the system must ensure that the bitmap matches the
format of the device context it is being selected into. Because takes a device context, it returns a
bitmap that has the same format as the specified device context. Thus, subsequent calls to are faster with a
color bitmap from than with a color bitmap returned from .
If the bitmap is monochrome, zeros represent the foreground color and ones represent the background color for the destination device
context.
When you no longer need the bitmap, call the function to delete it.
The function adds the font resource from a memory image to the system.
A pointer to a font resource.
The number of bytes in the font resource that is pointed to by .
Reserved. Must be 0.
A pointer to a variable that specifies the number of fonts installed.
If the function succeeds, the return value specifies the handle to the font added. This handle uniquely identifies the fonts that were installed
on the system. If the function fails, the return value is zero. No extended error information is available.
This function allows an application to get a font that is embedded in a document or a webpage. A font that is added by
is always private to the process that made the call and is not enumerable.
A memory image can contain more than one font. When this function succeeds, is a pointer to a DWORD whose value
is the number of fonts added to the system as a result of this call. For example, this number could be 2 for the vertical and horizontal
faces of an Asian font.
When the function succeeds, the caller of this function can free the memory pointed to by because the system has
made its own copy of the memory. To remove the fonts that were installed, call . However, when the
process goes away, the system will unload the fonts even if the process did not call RemoveFontMemResource.
The function allows an application to specify whether the system palette contains 2 or 20 static colors. The
default system palette contains 20 static colors. (Static colors cannot be changed when an application realizes a logical palette.)
A handle to the device context. This device context must refer to a device that supports color palettes.
The new use of the system palette. This parameter can be one of the following values.
-
SYSPAL_NOSTATIC
The system palette contains two static colors (black and white).
-
SYSPAL_NOSTATIC256
The system palette contains no static colors.
-
SYSPAL_STATIC
The system palette contains static colors that will not change when an application realizes its logical palette.
If the function succeeds, the return value is the previous system palette. It can be either SYSPAL_NOSTATIC, SYSPAL_NOSTATIC256, or
SYSPAL_STATIC.
If the function fails, the return value is SYSPAL_ERROR.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
When an application window moves to the foreground and the SYSPAL_NOSTATIC value is set, the application must call the
function to save the current system colors setting. It must also call to
set reasonable values using only black and white. When the application returns to the background or terminates, the previous system colors
must be restored.
If the function returns SYSPAL_ERROR, the specified device context is invalid or does not support color palettes.
An application must call this function only when its window is maximized and has the input focus.
If an application calls with set to SYSPAL_NOSTATIC, the system continues to
set aside two entries in the system palette for pure white and pure black, respectively.
After calling this function with set to SYSPAL_NOSTATIC, an application must take the following steps:
The function removes the fonts in the specified file from the system font table.
If the font was added using the function, you must use the function.
A pointer to a null-terminated string that names a font resource file.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
An application that adds or removes fonts from the system font table should notify other windows of the change by sending a
message to all top-level windows in the system. The application sends this message by calling the
function with the hwnd parameter set to HWND_BROADCAST.
If there are outstanding references to a font, the associated resource remains loaded until no device context is using it.
The function modifies the viewport origin for a device context using the specified horizontal and vertical
offsets.
A handle to the device context.
The horizontal offset, in device units.
The vertical offset, in device units.
A pointer to a structure. The previous viewport origin, in device units, is placed in this structure. If
is NULL, the previous viewport origin is not returned.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The new origin is the sum of the current origin and the horizontal and vertical offsets.
The function computes the width and height of the specified string of text.
Note: This function is provided only for compatibility with 16-bit versions of Windows. Applications should call the
function, which provides more accurate results.
A handle to the device context.
A pointer to the string that specifies the text. The string does not need to be zero-terminated, since specifies the
length of the string.
The length of the string pointed to by .
A pointer to a structure that receives the dimensions of the string, in logical units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function uses the currently selected font to compute the dimensions of the string. The width and
height, in logical units, are computed without considering any clipping. Also, this function assumes that the text is horizontal, that is,
that the escapement is always 0. This is true for both the horizontal and vertical measurements of the text. Even if using a font specifying
a nonzero escapement, this function will not use the angle while computing the text extent. The application must convert it explicitly.
Because some devices kern characters, the sum of the extents of the characters in a string may not be equal to the extent of the string.
The calculated string width takes into account the intercharacter spacing set by the function.
The function computes the width and height of the specified array of glyph indices.
Handle to the device context.
Pointer to array of glyph indices.
Specifies the number of glyph indices.
Pointer to a structure that receives the dimensions of the string, in logical units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function uses the currently selected font to compute the dimensions of the array of glyph indices. The
width and height, in logical units, are computed without considering any clipping.
When this function returns the text extent, it assumes that the text is horizontal, that is, that the escapement is always 0. This is true
for both the horizontal and vertical measurements of the text. Even if you use a font that specifies a nonzero escapement, this function
doesn't use the angle while it computes the text extent. The app must convert it explicitly. However, when the graphics mode is set to
GM_ADVANCED and the character orientation is 90 degrees from the print orientation, the values that this function return do not follow this
rule. When the character orientation and the print orientation match for a given string, this function returns the dimensions of the string
in the structure as { cx : 116, cy : 18 }. When the character orientation and the print orientation are 90 degrees apart
for the same string, this function returns the dimensions of the string in the structure as { cx : 18, cy : 116 }.
Because some devices kern characters, the sum of the extents of the individual glyph indices may not be equal to the extent of the entire
array of glyph indices.
The calculated string width takes into account the intercharacter spacing set by the function.
The function retrieves the current state of the system (physical) palette for the specified device context
(DC).
A handle to the device context.
If the function succeeds, the return value is the current state of the system palette. This parameter can be one of the following values.
By default, the system palette contains 20 static colors that are not changed when an application realizes its logical palette. An
application can gain access to most of these colors by calling the function.
The device context identified by the parameter must represent a device that supports color palettes.
An application can determine whether a device supports color palettes by calling the function and specifying the
RASTERCAPS constant.
The function returns information about the currently selected font for the specified display context.
Applications typically use this information and the function to prepare a character string for display.
Handle to a display device context.
The return value identifies characteristics of the currently selected font. The function returns 0 if the font is "normalized" and can be treated
as a simple Latin font; it returns GCP_ERROR if an error occurs. Otherwise, the function returns a combination of the following values.
The function enumerates all uniquely-named fonts in the system that match the font characteristics specified by
the structure. enumerates fonts based on typeface name, character set, or both.
A handle to the device context from which to enumerate the fonts.
A pointer to a structure that contains information about the fonts to enumerate. The function examines the following
members.
-
lfCharSet
-
lfFaceName
-
lfPitchAndFamily
A pointer to the application defined callback function. For more information, see the function.
An application defined value. The function passes this value to the callback function along with font information.
This parameter is not used and must be zero.
The return value is the last value returned by the callback function. This value depends on which font families are available for the specified
device.
The function does not use tagged typeface names to identify character sets. Instead, it always passes the
correct typeface name and a separate character set value to the callback function. The function enumerates fonts based on the values of the
and members in the structure.
As with , enumerates all font styles. Not all styles of a font cover the
same character sets. For example, Fontorama Bold might contain ANSI, Greek, and Cyrillic characters, but Fontorama Italic might contain only
ANSI characters. For this reason, it's best not to assume that a specified font covers a specific character set, even if it is the ANSI
character set. The following table shows the results of various combinations of values for and
.
Applies to: desktop apps only
The function obtains information about the pixel format identified by of
the device associated with . The function sets the members of the structure
pointed to by with that pixel format data.
Specifies the device context.
Index that specifies the pixel format. The pixel formats that a device context supports are identified by positive
one-based integer indexes.
The size, in bytes, of the structure pointed to by . The function stores no more than
bytes of data to that structure. Set this value to sizeof().
Pointer to a structure whose members the function sets with pixel format data. The function stores the
number of bytes copied to the structure in the structure's member. If, upon entry,
is NULL, the function writes no data to the structure. This is useful when you only want to obtain the maximum pixel
format index of a device context.
If the function succeeds, the return value is the maximum pixel format index of the device context. In addition, the function sets the
members of the structure pointed to by according to the specified pixel format.
If the function fails, the return value is zero. To get extended error information, call GetLastError.
The function creates a logical font that has the specified characteristics. The font can subsequently be
selected as the current font for any device context.
A pointer to a structure that defines the characteristics of the logical font.
If the function succeeds, the return value is a handle to a logical font.
If the function fails, the return value is NULL.
The function creates a logical font with the characteristics specified in the
structure. When this font is selected by using the function, GDI's font mapper attempts to match the logical font
with an existing physical font. If it fails to find an exact match, it provides an alternative whose characteristics match as many of the
requested characteristics as possible.
To get the appropriate font on different language versions of the OS, call with the desired font
characteristics in the structure, retrieve the appropriate typeface name, and create the font using
or .
When you no longer need the font, call the function to delete it.
The fonts for many East Asian languages have two typeface names: an English name and a localized name. and
take the localized typeface name only on a system locale that matches the language, while they take the
English typeface name on all other system locales. The best method is to try one name and, on failure, try the other. Note that
, , and return the English typeface name if the
system locale does not match the language of the font.
The font mapper for , , and recognizes both the
English and the localized typeface name, regardless of locale.
The function creates a logical brush that has the specified style, color, and pattern.
A pointer to a structure that contains information about the brush.
If the function succeeds, the return value identifies a logical brush.
If the function fails, the return value is NULL.
A brush is a bitmap that the system uses to paint the interiors of filled shapes.
After an application creates a brush by calling , it can select it into any device context by calling the
function.
A brush created by using a monochrome bitmap (one color plane, one bit per pixel) is drawn using the current text and background colors.
Pixels represented by a bit set to 0 are drawn with the current text color; pixels represented by a bit set to 1 are drawn with the current
background color.
When you no longer need the brush, call the function to delete it.
ICM: No color is done at brush creation. However, color management is performed when the brush is selected into an ICM-enabled device
context.
The function corrects the entries of a palette using the WCS 1.0 parameters in the specified device context.
Specifies a device context whose WCS parameters to use.
Specifies the handle to the palette to be color corrected.
Specifies the first entry in the palette to be color corrected.
Specifies the number of entries to color correct.
The function converts a metafile from the older Windows format to the new enhanced format and stores the new
metafile in memory.
The size, in bytes, of the buffer that contains the Windows-format metafile.
A pointer to a buffer that contains the Windows-format metafile data. (It is assumed that the data was obtained by using the
or function.)
A handle to a reference device context.
A pointer to a structure that contains the suggested size of the metafile picture and the mapping mode that was used
when the picture was created.
If the function succeeds, the return value is a handle to a memory-based enhanced metafile.
If the function fails, the return value is NULL.
Windows uses the reference device context's resolution data and the data in the structure to scale a picture. If
the parameter is NULL, the system uses resolution data for the current output device. If the
parameter is NULL, the system uses the MM_ANISOTROPIC mapping mode to scale the picture so that it fits the entire
device surface. The member of the structure is not used.
When the application no longer needs the enhanced metafile handle, it should delete it by calling the
function.
The handle returned by this function can be used with other enhanced-metafile functions.
If the reference device context is not identical to the device in which the metafile was originally created, some GDI functions that use
device units may not draw the picture correctly.
The function creates a memory-based enhanced-format metafile from the specified data.
Specifies the size, in bytes, of the data provided.
Pointer to a buffer that contains enhanced-metafile data. (It is assumed that the data in the buffer was obtained by calling the
function.)
If the function succeeds, the return value is a handle to a memory-based enhanced metafile.
If the function fails, the return value is NULL.
When the application no longer needs the enhanced-metafile handle, it should delete the handle by calling the
function.
The function does not accept metafile data in the Windows format. To import Windows-format metafiles, use
the function.
The function sets the gamma ramp on direct color display boards having drivers that support downloadable gamma
ramps in hardware.
Specifies the device context of the direct color display board in question.
Pointer to a buffer containing the gamma ramp to be set. The gamma ramp is specified in three arrays of 256 WORD elements each, which contain the
mapping between RGB values in the frame buffer and digital-analog-converter (DAC) values. The sequence of the arrays is red, green, blue. The RGB
values must be stored in the most significant bits of each WORD to increase DAC independence.
Direct color display modes do not use color lookup tables and are usually 16, 24, or 32 bit. Not all direct color video boards support loadable
gamma ramps. succeeds only for devices with drivers that support downloadable gamma ramps in hardware.
The function sets the color adjustment values for a device context (DC) using the specified values.
A handle to the device context.
A pointer to a structure containing the color adjustment values.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The color adjustment values are used to adjust the input color of the source bitmap for calls to the and
functions when HALFTONE mode is set.
The function modifies the viewport for a device context using the ratios formed by the specified multiplicands
and divisors.
A handle to the device context.
The amount by which to multiply the current horizontal extent.
The amount by which to divide the current horizontal extent.
The amount by which to multiply the current vertical extent.
The amount by which to divide the current vertical extent.
A pointer to a structure that receives the previous viewport extents, in device units. If is NULL,
this parameter is not used.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The viewport extents are modified as follows:
The function plays a Windows-format metafile record by executing the graphics device interface (GDI)
function contained within that record.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
A handle to a device context.
A pointer to a structure representing the table of handles to GDI objects used when playing the metafile.
A pointer to the Windows-format metafile record.
The number of handles in the handle table.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
To convert a Windows-format metafile into an enhanced-format metafile, use the function.
An application typically uses in conjunction with the function to process and
play a Windows-format metafile one record at a time.
The and parameters must be identical to those passed to the
callback procedure by .
If the function does not recognize a record, it ignores the record and returns TRUE.
The function converts the enhanced-format records from a metafile into Windows-format records and stores the
converted records in the specified buffer.
A handle to the enhanced metafile.
The size, in bytes, of the buffer into which the converted records are to be copied.
A pointer to the buffer that receives the converted records. If is NULL, returns
the number of bytes required to store the converted metafile records.
The mapping mode to use in the converted metafile.
A handle to the reference device context.
If the function succeeds and the buffer pointer is NULL, the return value is the number of bytes required to store the converted records; if
the function succeeds and the buffer pointer is a valid pointer, the return value is the size of the metafile data in bytes.
If the function fails, the return value is zero.
This function converts an enhanced metafile into a Windows-format metafile so that its picture can be displayed in an application that
recognizes the older format.
The system uses the reference device context to determine the resolution of the converted metafile.
The function does not invalidate the enhanced metafile handle. An application should call the
function to release the handle when it is no longer needed.
To create a scalable Windows-format metafile, specify MM_ANISOTROPIC as the parameter.
The upper-left corner of the metafile picture is always mapped to the origin of the reference device.
Retrieves information about the character set of the font that is currently selected into a specified device context.
Handle to a device context. The function obtains information about the font that is selected into this device context.
Pointer to a data structure that receives font-signature information.
If a TrueType font is currently selected into the device context, the structure receives information that
identifies the code page and Unicode subranges for which the font provides glyphs.
If a font other than TrueType is currently selected into the device context, the structure receives zeros. In
this case, the application should use the function to obtain generic font-signature information for the
character set.
The parameter specifies NULL if the application does not require the information. In
this case, the application can also call the function, which is equivalent to calling
with set to NULL.
Reserved; must be set to 0.
If successful, returns a value identifying the character set of the font currently selected into the specified device context. The following
character set identifiers are defined:
The function retrieves the contents of the specified enhanced-format metafile and copies them into a buffer.
A handle to the enhanced metafile.
The size, in bytes, of the buffer to receive the data.
A pointer to a buffer that receives the metafile data. The buffer must be sufficiently large to contain the data. If
is NULL, the function returns the size necessary to hold the data.
If the function succeeds and the buffer pointer is NULL, the return value is the size of the enhanced metafile, in bytes.
If the function succeeds and the buffer pointer is a valid pointer, the return value is the number of bytes copied to the buffer.
If the function fails, the return value is zero.
After the enhanced-metafile bits are retrieved, they can be used to create a memory-based metafile by calling the
function.
The function does not invalidate the enhanced-metafile handle. The application must call the
function to delete the handle when it is no longer needed.
The metafile contents retrieved by this function are in the enhanced format. To retrieve the metafile contents in the Windows format, use the
function.
The function gets the gamma ramp on direct color display boards having drivers that support downloadable gamma
ramps in hardware.
Specifies the device context of the direct color display board in question.
Points to a buffer where the function can place the current gamma ramp of the color display board. The gamma ramp is specified in three arrays of
256 WORD elements each, which contain the mapping between RGB values in the frame buffer and digital-analog-converter (DAC) values. The sequence
of the arrays is red, green, blue.
Direct color display modes do not use color lookup tables and are usually 16, 24, or 32 bit. Not all direct color video boards support loadable
gamma ramps. succeeds only for devices with drivers that support downloadable gamma ramps in hardware.
The function retrieves the color adjustment values for the specified device context (DC).
A handle to the device context.
A pointer to a structure that receives the color adjustment values.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function retrieves the fractional widths of consecutive characters in a specified range from the current
font.
A handle to the device context.
The code point of the first character in the group of consecutive characters.
The code point of the last character in the group of consecutive characters.
A pointer to a buffer that receives the character widths, in logical units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The returned widths are in the 32-bit IEEE floating-point format. (The widths are measured along the base line of the characters.)
If the parameter specifies the letter a and the parameter specifies the letter
z, retrieves the widths of all lowercase characters.
If a character does not exist in the current font, it is assigned the width of the default character.
The function creates a rectangular region with rounded corners.
Specifies the x-coordinate of the upper-left corner of the region in device units.
Specifies the y-coordinate of the upper-left corner of the region in device units.
Specifies the x-coordinate of the lower-right corner of the region in device units.
Specifies the y-coordinate of the lower-right corner of the region in device units.
Specifies the width of the ellipse used to create the rounded corners in device units.
Specifies the height of the ellipse used to create the rounded corners in device units.
If the function succeeds, the return value is the handle to the region.
If the function fails, the return value is NULL.
When you no longer need the HRGN object call the function to delete it.
Region coordinates are represented as 27-bit signed integers.
The function creates a logical brush with the specified bitmap pattern. The bitmap can be a DIB section bitmap,
which is created by the function, or it can be a device-dependent bitmap.
A handle to the bitmap to be used to create the logical brush.
If the function succeeds, the return value identifies a logical brush.
If the function fails, the return value is NULL.
A pattern brush is a bitmap that the system uses to paint the interiors of filled shapes.
After an application creates a brush by calling , it can select that brush into any device context by
calling the function.
You can delete a pattern brush without affecting the associated bitmap by using the function. Therefore, you can
then use this bitmap to create any number of pattern brushes.
A brush created by using a monochrome (1 bit per pixel) bitmap has the text and background colors of the device context to which it is drawn.
Pixels represented by a 0 bit are drawn with the current text color; pixels represented by a 1 bit are drawn with the current background
color.
ICM: No color is done at brush creation. However, color management is performed when the brush is selected into an ICM-enabled device
context.
The function creates a device context for an enhanced-format metafile. This device context can be used to store
a device-independent picture.
A handle to a reference device for the enhanced metafile. This parameter can be NULL; for more information, see Remarks.
A pointer to the file name for the enhanced metafile to be created. If this parameter is NULL, the enhanced metafile is memory based and its
contents are lost when it is deleted by using the function.
A pointer to a structure that specifies the dimensions (in .01-millimeter units) of the picture to be stored in the enhanced
metafile.
A pointer to a string that specifies the name of the application that created the picture, as well as the picture's title. This parameter can be
NULL; for more information, see Remarks.
If the function succeeds, the return value is a handle to the device context for the enhanced metafile.
If the function fails, the return value is NULL.
Where text arguments must use Unicode characters, use the function as a wide-character function. Where text
arguments must use characters from the Windows character set, use this function as an ANSI function.
The system uses the reference device identified by the parameter to record the resolution and units of the device
on which a picture originally appeared. If the parameter is NULL, it uses the current display device for
reference.
The and members of the structure pointed to by the
parameter must be less than the and members, respectively. Points along the edges of the
rectangle are included in the picture. If is NULL, the graphics device interface (GDI) computes the dimensions of
the smallest rectangle that surrounds the picture drawn by the application. The parameter should be provided where
possible.
The string pointed to by the parameter must contain a null character between the application name and the
picture name and must terminate with two null characters for example, "XYZ Graphics Editor\0Bald Eagle\0\0", where \0 represents the null
character. If is NULL, there is no corresponding entry in the enhanced-metafile header.
Applications use the device context created by this function to store a graphics picture in an enhanced metafile. The handle identifying this
device context can be passed to any GDI function.
After an application stores a picture in an enhanced metafile, it can display the picture on any output device by calling the
function. When displaying the picture, the system uses the rectangle pointed to by the
parameter and the resolution data from the reference device to position and scale the picture.
The device context returned by this function contains the same default attributes associated with any new device context.
Applications must use the function to convert an enhanced metafile to the older Windows metafile format.
The file name for the enhanced metafile should use the .emf extension.
The function creates a memory device context (DC) compatible with the specified device.
A handle to an existing DC. If this handle is NULL, the function creates a memory DC compatible with the application's current
screen.
If the function succeeds, the return value is the handle to a memory DC.
If the function fails, the return value is NULL.
A memory DC exists only in memory. When the memory DC is created, its display surface is exactly one monochrome pixel wide and one monochrome
pixel high. Before an application can use a memory DC for drawing operations, it must select a bitmap of the correct width and height into
the DC. To select a bitmap into a DC, use the function, specifying the height, width, and color
organization required.
When a memory DC is created, all attributes are set to normal default values. The memory DC can be used as a normal DC. You can set the
attributes; obtain the current settings of its attributes; and select pens, brushes, and regions.
The function can only be used with devices that support raster operations. An application can determine
whether a device supports these operations by calling the function.
When you no longer need the memory DC, call the function. We recommend that you call to
delete the DC. However, you can also call with the HDC to delete the DC.
If is NULL, the thread that calls owns the HDC that is created. When this thread is
destroyed, the HDC is no longer valid. Thus, if you create the HDC and pass it to another thread, then exit the first thread, the second
thread will not be able to use the HDC.
ICM: If the DC that is passed to this function is enabled for Image Color Management (ICM), the DC created by the function is ICM-enabled.
The source and destination color spaces are specified in the DC.
The function enables you to preview colors as they would appear on the target device.
Specifies the device context for previewing, generally the screen.
Specifies the target device context, generally a printer.
A constant that can have one of the following values.
-
CS_ENABLE
Map the colors to the target device's color gamut. This enables color proofing. All subsequent draw commands to the DC will render
colors as they would appear on the target device.
-
CS_DISABLE
Disable color proofing.
-
CS_DELETE_TRANSFORM
If color management is enabled for the target profile, disable it and delete the concatenated transform.
can be used to proof the colors of a color output device on another color output device. Setting the
parameter to CS_ENABLE causes all subsequent drawing commands to the DC to render colors as they would appear on
the target device. If is set to CS_DISABLE, proofing is turned off. However, the current color transform is not
deleted from the DC. It is just inactive.
When is called, the color transform for the target device is performed first, and then the transform to the
preview device is applied to the results of the first transform. This is used primarily for checking gamut mapping conditions. Before using
this function, you must enable WCS for both device contexts.
This function cannot be cascaded. While color mapping to the target is enabled by setting to CS_ENABLE,
application changes to the color space or gamut mapping method are ignored. Those changes then take effect when color mapping to the target
is disabled.
Note: A memory leak will not occur if an application does not delete a transform using CS_DELETE_TRANSFORM. The transform will be deleted
when either the device context (DC) is closed, or when the application color space is deleted. However if the transform is not going to be
used again, or if the application will not be performing any more color matching on the DC, it should explicitly delete the transform to free
the memory it occupies.
The parameter should only be set to CS_DELETE_TRANSFORM if color management is enabled before the
function is called.
The function determines whether a specified set of RGB triples lies in the output gamut of a specified device.
The RGB triples are interpreted in the input logical color space.
Handle to the device context whose output gamut to be checked.
Pointer to an array of RGB triples to check.
Pointer to the buffer in which the results are to be placed. This buffer must be at least as large as bytes.
The number of elements in the array of triples.
The function places the test results in the buffer pointed to by . Each byte in the buffer corresponds to an RGB
triple, and has an unsigned value between CM_IN_GAMUT (= 0) and CM_OUT_OF_GAMUT (= 255). The value 0 denotes that the color is in gamut,
while a nonzero value denotes that it is out of gamut. For any integer n such that 0 < n < 255, a result value of n + 1 indicates that
the corresponding color is at least as far out of gamut as would be indicated by a result value of n, as specified by the ICC Profile Format
Specification. For more information on the ICC Profile Format Specification, see the sources listed in Further Information.
Note that for this function to succeed, WCS must be enabled for the device context handle that is passed in through the
parameter. WCS can be enabled for a device context handle by calling the function.
The function adds the font resource from the specified file to the system. Fonts added with the
function can be marked as private and not enumerable.
A pointer to a null-terminated character string that contains a valid font file name. This parameter can specify any of the following
files.
-
.fon
Font resource file.
-
.fnt
Raw bitmap font file.
-
.ttf
Raw TrueType file.
-
.ttc
East Asian Windows: TrueType font collection.
-
.fot
TrueType resource file.
-
.otf
PostScript OpenType font.
-
.mmm
multiple master Type1 font resource file. It must be used with .pfm and .pfb files.
-
.pfb
Type 1 font bits file. It is used with a .pfm file.
-
.pfm
Type 1 font metrics file. It is used with a .pfb file.
To add a font whose information comes from several resource files, point to a string with the file names
separated by a | --for example, abcxxxxx.pfm | abcxxxxx.pfb.
The characteristics of the font to be added to the system. This parameter can be one of the following values.
-
FR_PRIVATE
Specifies that only the process that called the function can use this font. When the font name
matches a public font, the private font will be chosen. When the process terminates, the system will remove all fonts installed by
the process with the function.
-
FR_NOT_ENUM
Specifies that no process, including the process that called the function, can enumerate this font.
Reserved. Must be zero.
If the function succeeds, the return value specifies the number of fonts added.
If the function fails, the return value is zero. No extended error information is available.
This function allows a process to use fonts without allowing other processes access to the fonts.
When an application no longer needs a font resource it loaded by calling the function, it must remove the
resource by calling the function.
This function installs the font only for the current session. When the system restarts, the font will not be present. To have the font
installed even after restarting the system, the font must be listed in the registry.
The function closes any open figures in a path, strokes the outline of the path by using the current pen, and
fills its interior by using the current brush.
A handle to the device context.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The device context identified by the parameter must contain a closed path.
The function has the same effect as closing all the open figures in the path, and stroking and filling the
path separately, except that the filled region will not overlap the stroked region even if the pen is wide.
The function sets a two-dimensional linear transformation between world space and page space for the specified
device context. This transformation can be used to scale, rotate, shear, or translate graphics output.
A handle to the device context.
A pointer to an structure that contains the transformation data.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
For any coordinates (x, y) in world space, the transformed coordinates in page space (x', y') can be determined by the following algorithm:
The function sets the bitmap stretching mode in the specified device context.
A handle to the device context.
The stretching mode. This parameter can be one of the following values.
-
BLACKONWHITE
Performs a Boolean AND operation using the color values for the eliminated and existing pixels. If the bitmap is a monochrome bitmap,
this mode preserves black pixels at the expense of white pixels.
-
COLORONCOLOR
Deletes the pixels. This mode deletes all eliminated lines of pixels without trying to preserve their information.
-
HALFTONE
Maps pixels from the source rectangle into blocks of pixels in the destination rectangle. The average color over the destination
block of pixels approximates the color of the source pixels.
After setting the HALFTONE stretching mode, an application must call the function to set the brush
origin. If it fails to do so, brush misalignment occurs.
-
STRETCH_ANDSCANS
Same as BLACKONWHITE.
-
STRETCH_DELETESCANS
Same as COLORONCOLOR.
-
STRETCH_HALFTONE
Same as HALFTONE.
-
STRETCH_ORSCANS
Same as WHITEONBLACK.
-
WHITEONBLACK
Performs a Boolean OR operation using the color values for the eliminated and existing pixels. If the bitmap is a monochrome bitmap,
this mode preserves white pixels at the expense of black pixels.
If the function succeeds, the return value is the previous stretching mode.
If the function fails, the return value is zero.
This function can return the following value.
The stretching mode defines how the system combines rows or columns of a bitmap with existing pixels on a display device when an application
calls the function.
The BLACKONWHITE (STRETCH_ANDSCANS) and WHITEONBLACK (STRETCH_ORSCANS) modes are typically used to preserve foreground pixels in monochrome
bitmaps. The COLORONCOLOR (STRETCH_DELETESCANS) mode is typically used to preserve color in color bitmaps.
The HALFTONE mode is slower and requires more processing of the source image than the other three modes; but produces higher quality images.
Also note that must be called after setting the HALFTONE mode to avoid brush misalignment.
Additional stretching modes might also be available depending on the capabilities of the device driver.
The function sets RGB (red, green, blue) color values and flags in a range of entries in a logical palette.
A handle to the logical palette.
The first logical-palette entry to be set.
The number of logical-palette entries to be set.
A pointer to the first member of an array of structures containing the RGB values and flags.
If the function succeeds, the return value is the number of entries that were set in the logical palette.
If the function fails, the return value is zero.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
Even if a logical palette has been selected and realized, changes to the palette do not affect the physical palette in the surface.
must be called again to set the new logical palette into the surface.
The function creates a memory-based Windows-format metafile from the supplied data.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
Specifies the size, in bytes, of the Windows-format metafile.
Pointer to a buffer that contains the Windows-format metafile. (It is assumed that the data was obtained by using the
function.)
If the function succeeds, the return value is a handle to a memory-based Windows-format metafile.
If the function fails, the return value is NULL.
To convert a Windows-format metafile into an enhanced-format metafile, use the function.
When the application no longer needs the metafile handle returned by , it should delete it by calling the
function.
The function sets the pixels in the specified rectangle on the device that is associated with the destination
device context using color data from a DIB, JPEG, or PNG image.
A handle to the device context.
The x-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The y-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The width, in logical units, of the image.
The height, in logical units, of the image.
The x-coordinate, in logical units, of the lower-left corner of the image.
The y-coordinate, in logical units, of the lower-left corner of the image.
The starting scan line in the image.
The number of DIB scan lines contained in the array pointed to by the parameter.
A pointer to the color data stored as an array of bytes. For more information, see the following Remarks section.
A pointer to a structure that contains information about the DIB.
Indicates whether the member of the structure contains explicit red, green,
blue (RGB) values or indexes into a palette. For more information, see the following Remarks section.
The parameter must be one of the following values.
-
DIB_PAL_COLORS
The color table consists of an array of 16-bit indexes into the currently selected logical palette.
-
DIB_RGB_COLORS
The color table contains literal RGB values.
If the function succeeds, the return value is the number of scan lines set.
If zero scan lines are set (such as when is 0) or the function fails, the function returns zero.
If the driver cannot support the JPEG or PNG file image passed to , the function will fail and return
GDI_ERROR. If failure does occur, the application must fall back on its own JPEG or PNG support to decompress the image into a bitmap, and
then pass the bitmap to .
Optimal bitmap drawing speed is obtained when the bitmap bits are indexes into the system palette.
Applications can retrieve the system palette colors and indexes by calling the function. After the
colors and indexes are retrieved, the application can create the DIB. For more information about the system palette, see Colors.
The scan lines must be aligned on a DWORD except for RLE-compressed bitmaps.
The origin of a bottom-up DIB is the lower-left corner of the bitmap; the origin of a top-down DIB is the upper-left corner.
To reduce the amount of memory required to set bits from a large DIB on a device surface, an application can band the output by repeatedly
calling , placing a different portion of the bitmap into the array each time. The
values of the and parameters identify the portion of the bitmap contained in
the array.
The function returns an error if it is called by a process that is running in the background while a
full-screen MS-DOS session runs in the foreground.
The function modifies the window origin for a device context using the specified horizontal and vertical
offsets.
A handle to the device context.
The horizontal offset, in logical units.
The vertical offset, in logical units.
A pointer to a structure. The logical coordinates of the previous window origin are placed in this structure. If
is NULL, the previous origin is not returned.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function creates a new clipping region from the intersection of the current clipping region and the
specified rectangle.
A handle to the device context.
The x-coordinate, in logical units, of the upper-left corner of the rectangle.
The y-coordinate, in logical units, of the upper-left corner of the rectangle.
The x-coordinate, in logical units, of the lower-right corner of the rectangle.
The y-coordinate, in logical units, of the lower-right corner of the rectangle.
The return value specifies the new clipping region's type and can be one of the following values.
The lower and right-most edges of the given rectangle are excluded from the clipping region.
The function retrieves the current world-space to page-space transformation.
A handle to the device context.
A pointer to an structure that receives the current world-space to page-space transformation.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The precision of the transformation may be altered if an application calls the function prior to calling
. (This is because the internal format for storing transformation values uses a higher precision than a FLOAT
value.)
The function retrieves the current stretching mode. The stretching mode defines how color data is added to or
removed from bitmaps that are stretched or compressed when the function is called.
A handle to the device context.
If the function succeeds, the return value is the current stretching mode. This can be one of the following values.
The function returns flags indicating whether TrueType fonts are installed in the system.
A pointer to a structure that receives information about the rasterizer.
The number of bytes to be copied into the structure pointed to by the parameter.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function enables applications and printer drivers to determine whether TrueType fonts are installed.
If the TT_AVAILABLE flag is set in the member of the structure, at
least one TrueType font is installed. If the TT_ENABLED flag is set, TrueType is enabled for the system.
The actual number of bytes copied is either the member specified in the parameter or the length of the
structure, whichever is less.
The function retrieves a specified range of palette entries from the given logical palette.
A handle to the logical palette.
The first entry in the logical palette to be retrieved.
The number of entries in the logical palette to be retrieved.
A pointer to an array of structures to receive the palette entries. The array must contain at least as many
structures as specified by the parameter.
If the function succeeds and the handle to the logical palette is a valid pointer (not NULL), the return value is the number of entries
retrieved from the logical palette. If the function succeeds and handle to the logical palette is NULL, the return value is the number of
entries in the given palette.
If the function fails, the return value is zero.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
If the parameter specifies more entries than exist in the palette, the remaining members of the
structure are not altered.
The function retrieves the contents of a Windows-format metafile and copies them into the specified buffer.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
A handle to a Windows-format metafile.
The size, in bytes, of the buffer to receive the data.
A pointer to a buffer that receives the metafile data. The buffer must be sufficiently large to contain the data. If
is NULL, the function returns the number of bytes required to hold the data.
If the function succeeds and the buffer pointer is NULL, the return value is the number of bytes required for the buffer; if the function
succeeds and the buffer pointer is a valid pointer, the return value is the number of bytes copied.
If the function fails, the return value is zero.
After the Windows-metafile bits are retrieved, they can be used to create a memory-based metafile by calling the
function.
The function does not invalidate the metafile handle. An application must delete this handle by calling the
function.
To convert a Windows-format metafile into an enhanced-format metafile, use the function.
The function retrieves the color space definition identified by a specified handle.
Specifies the handle to a color space.
Points to a buffer to receive the structure.
Specifies the maximum size of the buffer.
The function retrieves the widths, in logical units, of consecutive characters in a specified range from the
current TrueType font. This function succeeds only with TrueType fonts.
A handle to the device context.
The first character in the group of consecutive characters from the current font.
The last character in the group of consecutive characters from the current font.
A pointer to an array of structures that receives the character widths, in logical units. This array must contain at least as
many structures as there are characters in the range specified by the and
parameters.
If the function succeeds, the return value is nonzero
If the function fails, the return value is zero.
The TrueType rasterizer provides ABC character spacing after a specific point size has been selected. A spacing is the distance added to the
current position before placing the glyph. B spacing is the width of the black part of the glyph. C spacing is the distance added to the
current position to provide white space to the right of the glyph. The total advanced width is specified by A+B+C.
When the function retrieves negative A or C widths for a character, that character includes underhangs or
overhangs.
To convert the ABC widths to font design units, an application should use the value stored in the
member of a structure. This value can be retrieved by calling the
function.
The ABC widths of the default character are used for characters outside the range of the currently selected font.
To retrieve the widths of characters in non-TrueType fonts, applications should use the function.
The function retrieves the widths, in logical units, of consecutive glyph indices in a specified range from the
current TrueType font. This function succeeds only with TrueType fonts.
A handle to the device context.
The first glyph index in the group of consecutive glyph indices from the current font. This parameter is only used if the
parameter is NULL.
The number of glyph indices.
A pointer to an array that contains glyph indices. If this parameter is NULL, the parameter is used instead. The
parameter specifies the number of glyph indices in this array.
A pointer to an array of structures that receives the character widths, in logical units. This array must contain at least as
many structures as there are glyph indices specified by the parameter.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The TrueType rasterizer provides ABC character spacing after a specific point size has been selected. A spacing is the distance added to the
current position before placing the glyph. B spacing is the width of the black part of the glyph. C spacing is the distance added to the
current position to provide white space to the right of the glyph. The total advanced width is specified by A+B+C.
When the function retrieves negative A or C widths for a character, that character includes underhangs or
overhangs.
To convert the ABC widths to font design units, an application should use the value stored in the
member of a structure. This value can be retrieved by calling the
function.
The ABC widths of the default character are used for characters outside the range of the currently selected font.
To retrieve the widths of glyph indices in non-TrueType fonts, applications should use the function.
The function enumerates the fonts in a specified font family that are available on a specified device.
Note: This function is provided only for compatibility with 16-bit versions of Windows. Applications should use the
function.
A handle to the device context from which to enumerate the fonts.
A pointer to a null-terminated string that specifies the family name of the desired fonts. If is NULL,
selects and enumerates one font of each available type family.
A pointer to the application defined callback function. For information, see .
A pointer to application-supplied data. The data is passed to the callback function along with the font information.
The return value is the last value returned by the callback function. Its meaning is implementation specific.
For each font having the typeface name specified by the parameter, the
function retrieves information about that font and passes it to the function pointed to by the
parameter. The application defined callback function can process the font information as desired. Enumeration continues until there are no
more fonts or the callback function returns zero.
When the graphics mode on the device context is set to GM_ADVANCED using the SetGraphicsMode function and the DEVICE_FONTTYPE flag is passed
to the FontType parameter, this function returns a list of type 1 and OpenType fonts on the system. When the graphics mode is not set to
GM_ADVANCED, this function returns a list of type 1, OpenType, and TrueType fonts on the system.
The fonts for many East Asian languages have two typeface names: an English name and a localized name. ,
, and return the English typeface name if the system locale does not match
the language of the font.
The function deletes an enhanced-format metafile or an enhanced-format metafile handle.
A handle to an enhanced metafile.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
If the parameter identifies an enhanced metafile stored in memory, the function deletes
the metafile. If identifies a metafile stored on a disk, the function deletes the metafile handle but does not destroy
the actual metafile. An application can retrieve the file by calling the function.
The function creates a logical cosmetic pen that has the style, width, and color specified in a structure.
Pointer to a structure that specifies the pen's style, width, and color.
If the function succeeds, the return value is a handle that identifies a logical cosmetic pen.
If the function fails, the return value is NULL.
After an application creates a logical pen, it can select that pen into a device context by calling the function.
After a pen is selected into a device context, it can be used to draw lines and curves.
When you no longer need the pen, call the function to delete it.
The function creates an elliptical region.
Specifies the x-coordinate in logical units, of the upper-left corner of the bounding rectangle of the ellipse.
Specifies the y-coordinate in logical units, of the upper-left corner of the bounding rectangle of the ellipse.
Specifies the x-coordinate in logical units, of the lower-right corner of the bounding rectangle of the ellipse.
Specifies the y-coordinate in logical units, of the lower-right corner of the bounding rectangle of the ellipse.
If the function succeeds, the return value is the handle to the region.
If the function fails, the return value is NULL.
When you no longer need the HRGN object, call the function to delete it.
A bounding rectangle defines the size, shape, and orientation of the region: The long sides of the rectangle define the length of the
ellipse's major axis; the short sides define the length of the ellipse's minor axis; and the center of the rectangle defines the intersection
of the major and minor axes.
The function creates a logical color space.
Pointer to the data structure.
When the color space is no longer needed, use to delete it.
Applies to: desktop apps only
The function attempts to match an appropriate pixel format supported by a device context to a given pixel
format specification.
Specifies the device context that the function examines to determine the best match for the pixel format descriptor pointed to by
.
Pointer to a structure that specifies the requested pixel format. In this context, the members of the
structure that points to are used as follows:
-
nSize
-
nVersion
-
dwFlags
-
iPixelType
-
cColorBits
-
cRedBits
-
cRedShift
-
cGreenBits
-
cGreenShift
-
cBlueBits
-
cBlueShift
-
cAlphaBits
-
cAlphaShift
-
cAccumBits
-
cAccumRedBits
-
cAccumGreenBits
-
cAccumBlueBits
-
cAccumAlphaBits
-
cDepthBits
-
cStencilBits
-
cAuxBuffers
-
iLayerType
-
bReserved
-
dwLayerMask
-
dwVisibleMask
-
dwDamageMask
If the function succeeds, the return value is a pixel format index (one-based) that is the closest match to the given pixel format
descriptor.
If the function fails, the return value is zero. To get extended error information, call GetLastError.
You must ensure that the pixel format matched by the function satisfies your requirements. For example, if you
request a pixel format with a 24-bit RGB color buffer but the device context offers only 8-bit RGB color buffers, the function returns a pixel
format with an 8-bit RGB color buffer.
The function manages color profiles and Color Management Modules in the system.
Reserved, must be set to zero.
Points to a string that specifies the ICC profile identifier for the color management DLL to use with the profile.
Points to a fully qualified ICC color profile file name or to a structure.
Specifies a function to execute. It can have one of the following values.
-
ICM_ADDPROFILE
Installs the ICC profile in the system.
-
ICM_DELETEPROFILE
Uninstalls the ICC profile from the system, but does not delete the file.
-
ICM_QUERYPROFILE
Determines whether the profile is already installed in the system.
-
ICM_SETDEFAULTPROFILE
Makes the profile first among equals.
-
ICM_REGISTERICMATCHER
Registers a CMM in the system. The parameter points to a fully qualified path for the CMM DLL. The
parameter points to a DWORD identifying the CMM.
-
ICM_UNREGISTERICMATCHER
Unregisters the CMM from the system. The parameter points to a DWORD identifying the CMM.
-
ICM_QUERYMATCH
Determines whether a profile exists based on the structure pointed to by the
parameter.
Not all parameters are used by all functions. The parameter specifies the function to execute.
This function is retained for backward compatibility and may be removed in future versions of ICM.
The function specifies which device point maps to the window origin (0,0).
A handle to the device context.
The x-coordinate, in device units, of the new viewport origin.
The y-coordinate, in device units, of the new viewport origin.
A pointer to a structure that receives the previous viewport origin, in device coordinates. If
is NULL, this parameter is not used.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
This function (along with and ) helps define the mapping from the logical coordinate
space (also known as a window) to the device coordinate space (the viewport).
specifies which device point maps to the logical point (0,0). It has the effect of shifting the axes so that the
logical point (0,0) no longer refers to the upper-left corner.
The function sets the horizontal and vertical extents of the viewport for a device context by using the specified
values.
A handle to the device context.
The horizontal extent, in device units, of the viewport.
The vertical extent, in device units, of the viewport.
A pointer to a structure that receives the previous viewport extents, in device units. If is NULL,
this parameter is not used.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The viewport refers to the device coordinate system of the device space. The extent is the maximum value of an axis. This function sets the
maximum values for the horizontal and vertical axes of the viewport in device coordinates (or pixels). When mapping between page space and
device space, and determine the scaling factor between the window and the
viewport. For more information, see Transformation of Coordinate Spaces.
When the following mapping modes are set, calls to the and functions are
ignored.
The function sets RGB (red, green, blue) color values in a range of entries in the color table of the DIB that is
currently selected into a specified device context.
A device context. A DIB must be selected into this device context.
A zero-based color table index that specifies the first color table entry to set.
The number of color table entries to set.
A pointer to an array of structures containing new color information for the DIB's color table.
If the function succeeds, the return value is the number of color table entries that the function sets.
If the function fails, the return value is zero.
This function should be called to set the color table for DIBs that use 1, 4, or 8 bpp. The member
of a bitmap's associated bitmap information header structure.
structure specifies the number of bits-per-pixel. Device-independent bitmaps with a
value greater than 8 do not have a color table.
The bV5BitCount member of a bitmap's associated BITMAPV5HEADER structure specifies the number of bits-per-pixel. Device-independent bitmaps
with a bV5BitCount value greater than 8 do not have a color table.
ICM: No color management is performed.
The function modifies the window for a device context using the ratios formed by the specified multiplicands and
divisors.
A handle to the device context.
The amount by which to multiply the current horizontal extent.
The amount by which to divide the current horizontal extent.
The amount by which to multiply the current vertical extent.
The amount by which to divide the current vertical extent.
A pointer to a structure that receives the previous window extents, in logical units. If is NULL,
this parameter is not used.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The window extents are modified as follows:
The function retrieves the x-coordinates and y-coordinates of the viewport origin for the specified device
context.
A handle to the device context.
A pointer to a structure that receives the coordinates of the origin, in device units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function retrieves the x-extent and y-extent of the current viewport for the specified device context.
A handle to the device context.
A pointer to a structure that receives the x- and y-extents, in device units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function retrieves the character-kerning pairs for the currently selected font for the specified device
context.
A handle to the device context.
The number of pairs in the array. If the font has more than kerning pairs, the
function returns an error.
A pointer to an array of structures that receives the kerning pairs. The array must contain at least as many
structures as specified by the parameter. If this parameter is NULL, the function returns the total number of
kerning pairs for the font.
If the function succeeds, the return value is the number of kerning pairs returned.
If the function fails, the return value is zero.
The function retrieves the outline or bitmap for a character in the TrueType font that is selected into the
specified device context.
A handle to the device context.
The character for which data is to be returned.
The format of the data that the function retrieves. This parameter can be one of the following values.
-
GGO_BEZIER
The function retrieves the curve data as a cubic BĂ©zier spline (not in quadratic spline format).
-
GGO_BITMAP
The function retrieves the glyph bitmap. For information about memory allocation, see the following Remarks section.
-
GGO_GLYPH_INDEX
Indicates that the parameter is a TrueType Glyph Index rather than a character code. See the
function for additional remarks on Glyph Indexing.
-
GGO_GRAY2_BITMAP
The function retrieves a glyph bitmap that contains five levels of gray.
-
GGO_GRAY4_BITMAP
The function retrieves a glyph bitmap that contains 17 levels of gray.
-
GGO_GRAY8_BITMAP
The function retrieves a glyph bitmap that contains 65 levels of gray.
-
GGO_METRICS
The function only retrieves the structure specified by . The
is ignored. This value affects the meaning of the function's return value upon failure; see the Return
Values section.
-
GGO_NATIVE
The function retrieves the curve data points in the rasterizer's native format and uses the font's design units.
-
GGO_UNHINTED
The function only returns unhinted outlines. This flag only works in conjunction with GGO_BEZIER and GGO_NATIVE.
Note that, for the GGO_GRAYn_BITMAP values, the function retrieves a glyph bitmap that contains n^2+1 (n squared plus one) levels of gray.
A pointer to the structure describing the placement of the glyph in the character cell.
The size, in bytes, of the buffer (*) where the function is to copy information about the outline character. If this
value is zero, the function returns the required size of the buffer.
A pointer to the buffer that receives information about the outline character. If this value is NULL, the function returns the required size of
the buffer.
A pointer to a structure specifying a transformation matrix for the character.
If GGO_BITMAP, GGO_GRAY2_BITMAP, GGO_GRAY4_BITMAP, GGO_GRAY8_BITMAP, or GGO_NATIVE is specified and the function succeeds, the return value
is greater than zero; otherwise, the return value is GDI_ERROR. If one of these flags is specified and the buffer size or address is zero,
the return value specifies the required buffer size, in bytes.
If GGO_METRICS is specified and the function fails, the return value is GDI_ERROR.
The glyph outline returned by the function is for a grid-fitted glyph. (A grid-fitted glyph is a glyph that
has been modified so that its bitmapped image conforms as closely as possible to the original design of the glyph.) If an application needs
an unmodified glyph outline, it can request the glyph outline for a character in a font whose size is equal to the font's em unit. The value
for a font's em unit is stored in the member of the structure.
The glyph bitmap returned by when GGO_BITMAP is specified is a DWORD-aligned, row-oriented, monochrome bitmap.
When GGO_GRAY2_BITMAP is specified, the bitmap returned is a DWORD-aligned, row-oriented array of bytes whose values range from 0 to 4. When
GGO_GRAY4_BITMAP is specified, the bitmap returned is a DWORD-aligned, row-oriented array of bytes whose values range from 0 to 16. When
GGO_GRAY8_BITMAP is specified, the bitmap returned is a DWORD-aligned, row-oriented array of bytes whose values range from 0 to 64.
The native buffer returned by when GGO_NATIVE is specified is a glyph outline. A glyph outline is returned as
a series of one or more contours defined by a structure followed by one or more curves. Each curve in the
contour is defined by a structure followed by a number of data points.
points are absolute positions, not relative moves. The starting point of a contour is given by the
member of the structure. The starting point of each curve is the last
point of the previous curve or the starting point of the contour. The count of data points in a curve is stored in the
member of
structure. The size of each contour in the buffer, in bytes, is stored in the
member of
structure. Additional curve definitions are packed into the buffer following preceding curves and additional
contours are packed into the buffer following preceding contours. The buffer contains as many contours as fit within the buffer returned by
.
The structure specifies the width of the character cell and the location of a glyph within the character cell.
The origin of the character cell is located at the left side of the cell at the baseline of the font. The location of the glyph origin is
relative to the character cell origin. The height of a character cell, the baseline, and other metrics global to the font are given by the
structure.
An application can alter the characters retrieved in bitmap or native format by specifying a 2-by-2 transformation matrix in the
parameter. For example the glyph can be modified by shear, rotation, scaling, or any combination of the three
using matrix multiplication.
Additional information on a glyph outlines is located in the TrueType and the OpenType technical specifications.
The function translates a string into an array of glyph indices. The function can be used to determine whether a
glyph exists in a font.
A handle to the device context.
A pointer to the string to be converted.
The length of both the length of the string pointed to by and the size (in WORDs) of the buffer pointed to by
.
This buffer must be of dimension c. On successful return, contains an array of glyph indices corresponding to the characters in the
string.
Specifies how glyphs should be handled if they are not supported. This parameter can be the following value.
-
GGI_MARK_NONEXISTING_GLYPHS
Marks unsupported glyphs with the hexadecimal value 0xffff.
If the function succeeds, it returns the number of bytes (for the ANSI function) or WORDs (for the Unicode function) converted.
If the function fails, the return value is GDI_ERROR.
This function attempts to identify a single-glyph representation for each character in the string pointed to by . While
this is useful for certain low-level purposes (such as manipulating font files), higher-level applications that wish to map a string to glyphs
will typically wish to use the Uniscribe functions.
The function retrieves RGB (red, green, blue) color values from a range of entries in the color table of the DIB
section bitmap that is currently selected into a specified device context.
A handle to a device context. A DIB section bitmap must be selected into this device context.
A zero-based color table index that specifies the first color table entry to retrieve.
The number of color table entries to retrieve.
A pointer to a buffer that receives an array of data structures containing color information from the DIB color table. The
buffer must be large enough to contain as many data structures as the value of .
If the function succeeds, the return value is the number of color table entries that the function retrieves.
If the function fails, the return value is zero.
The function should be called to retrieve the color table for DIB section bitmaps that use 1, 4, or 8 bpp. The
member of a bitmap associated structure specifies the number of
bits-per-pixel. DIB section bitmaps with a value greater than eight do not have a color table, but
they do have associated color masks. Call the function to retrieve those color masks.
The function retrieves a handle to an object of the specified type that has been selected into the specified
device context (DC).
A handle to the DC.
The object type to be queried. This parameter can be one of the following values.
-
OBJ_BITMAP
Returns the current selected bitmap.
-
OBJ_BRUSH
Returns the current selected brush.
-
OBJ_COLORSPACE
Returns the current color space.
-
OBJ_FONT
Returns the current selected font.
-
OBJ_PAL
Returns the current selected palette.
-
OBJ_PEN
Returns the current selected pen.
If the function succeeds, the return value is a handle to the specified object.
If the function fails, the return value is NULL.
An application can use the and functions to retrieve descriptions of the graphic objects
currently selected into the specified DC.
The function sets the maximum number of function calls that can be accumulated in the calling thread's current
batch. The system flushes the current batch whenever this limit is exceeded.
Specifies the batch limit to be set. A value of 0 sets the default limit. A value of 1 disables batching.
If the function succeeds, the return value is the previous batch limit.
If the function fails, the return value is zero.
Only GDI drawing functions that return Boolean values can be accumulated in the current batch; calls to any other GDI functions immediately
flush the current batch. Exceeding the batch limit or calling the function also flushes the current batch.
When the system accumulates a function call, the function returns TRUE to indicate it is in the batch. When the system flushes the current
batch and executes the function for the second time, the return value is either TRUE or FALSE, depending on whether the function succeeds.
This second return value is reported only if is used to flush the batch.
Note: The batch limit is maintained for each thread separately. In order to completely disable batching, call
(1) during the initialization of each thread.
The function returns the maximum number of function calls that can be accumulated in the calling thread's current
batch. The system flushes the current batch whenever this limit is exceeded.
If the function succeeds, the return value is the batch limit.
If the function fails, the return value is zero.
The batch limit is set by using the function. Setting the limit to 1 effectively disables batching.
Only GDI drawing functions that return Boolean values can be batched; calls to any other GDI functions immediately flush the current batch.
Exceeding the batch limit or calling the function also flushes the current batch.
When the system batches a function call, the function returns TRUE. The actual return value for the function is reported only if
is used to flush the batch.
Note: The batch limit is maintained for each thread separately. In order to completely disable batching, call
(1) during the initialization of each thread.
The function combines the specified region with the current clipping region using the specified mode.
A handle to the device context.
A handle to the region to be selected. This handle must not be NULL unless the RGN_COPY mode is specified.
The operation to be performed. It must be one of the following values.
-
RGN_AND
The new clipping region combines the overlapping areas of the current clipping region and the region identified by
.
-
RGN_COPY
The new clipping region is a copy of the region identified by . This is identical to
. If the region identified by is NULL, the new clipping region is the default
clipping region (the default clipping region is a null region).
-
RGN_DIFF
The new clipping region combines the areas of the current clipping region with those areas excluded from the region identified by
.
-
RGN_OR
The new clipping region combines the current clipping region and the region identified by .
-
RGN_XOR
The new clipping region combines the current clipping region and the region identified by but excludes any
overlapping areas.
The return value specifies the new clipping region's complexity; it can be one of the following values.
If an error occurs when this function is called, the previous clipping region for the specified device context is not affected.
The function assumes that the coordinates for the specified region are specified in device units.
Only a copy of the region identified by the parameter is used. The region itself can be reused after this call or it
can be deleted.
The function enumerates the different output color profiles that the system supports for a given device context.
Specifies the device context.
Specifies the procedure instance address of a callback function defined by the application. (See .)
Data supplied by the application that is passed to the callback function along with the color profile information.
The function returns a list of profiles that are associated with a device context (DC), and whose settings
match those of the DC. It is possible for a device context to contain device profiles that are not associated with particular hardware
devices, or device profiles that do not match the settings of the DC. The sRGB profile is an example. The
function is used to associate these types of profiles with a DC. The function can be used to retrieve a profile
that is not enumerated by the function.
The function removes and destroys a specified color space.
Specifies the handle to a color space to delete.
The function creates a logical brush that has the specified solid color.
The color of the brush. To create a color value, use the RGB macro.
If the function succeeds, the return value identifies a logical brush.
If the function fails, the return value is NULL.
When you no longer need the HBRUSH object, call the function to delete it.
A solid brush is a bitmap that the system uses to paint the interiors of filled shapes.
After an application creates a brush by calling , it can select that brush into any device context by calling
the function.
To paint with a system color brush, an application should use GetSysColorBrush (nIndex) instead of CreateSolidBrush(GetSysColor(nIndex)),
because returns a cached brush instead of allocating a new one.
ICM: No color management is done at brush creation. However, color management is performed when the brush is selected into an ICM-enabled
device context.
The function creates a polygonal region.
A pointer to an array of structures that define the vertices of the polygon in logical units. The polygon is presumed
closed. Each vertex can be specified only once.
The number of points in the array.
The fill mode used to determine which pixels are in the region. This parameter can be one of the following values.
-
ALTERNATE
Selects alternate mode (fills area between odd-numbered and even-numbered polygon sides on each scan line).
-
WINDING
Selects winding mode (fills any region with a nonzero winding value).
For more information about these modes, see the function.
If the function succeeds, the return value is the handle to the region.
If the function fails, the return value is NULL.
When you no longer need the HRGN object, call the function to delete it.
Region coordinates are represented as 27-bit signed integers.
Regions created by the Create[Shape]Rgn methods (such as and ) only include the
interior of the shape; the shape's outline is excluded from the region. This means that any point on a line between two sequential vertices
is not included in the region. If you were to call for such a point, it would return zero as the result.
The function creates a logical brush that has the specified hatch pattern and color.
The hatch style of the brush. This parameter can be one of the following values.
-
HS_BDIAGONAL
45-degree upward left-to-right hatch
-
HS_CROSS
Horizontal and vertical crosshatch
-
HS_DIAGCROSS
45-degree crosshatch
-
HS_FDIAGONAL
45-degree downward left-to-right hatch
-
HS_HORIZONTAL
Horizontal hatch
-
HS_VERTICAL
Vertical hatch
The foreground color of the brush that is used for the hatches. To create a color value, use the RGB macro.
If the function succeeds, the return value identifies a logical brush.
If the function fails, the return value is NULL.
A brush is a bitmap that the system uses to paint the interiors of filled shapes.
After an application creates a brush by calling , it can select that brush into any device context by calling
the function. It can also call to affect the rendering of the brush.
If an application uses a hatch brush to fill the backgrounds of both a parent and a child window with matching color, you must set the brush
origin before painting the background of the child window. You can do this by calling the function. Your
application can retrieve the current brush origin by calling the function.
When you no longer need the brush, call the function to delete it.
ICM: No color is defined at brush creation. However, color management is performed when the brush is selected into an ICM-enabled device
context.
The function creates a DIB that applications can write to directly. The function gives you a pointer to the
location of the bitmap bit values. You can supply a handle to a file-mapping object that the function will use to create the bitmap, or you can
let the system allocate the memory for the bitmap.
A handle to a device context. If the value of is DIB_PAL_COLORS, the function uses this device context's logical
palette to initialize the DIB colors.
A pointer to a structure that specifies various attributes of the DIB, including the bitmap dimensions and colors.
The type of data contained in the array member of the structure pointed to by
(either logical palette indexes or literal RGB values). The following values are defined.
-
DIB_PAL_COLORS
The member is an array of 16-bit indexes into the logical palette of the device context specified
by
.
-
DIB_RGB_COLORS
The structure contains an array of literal RGB values.
A pointer to a variable that receives a pointer to the location of the DIB bit values.
A handle to a file-mapping object that the function will use to create the DIB. This parameter can be NULL.
If is not NULL, it must be a handle to a file-mapping object created by calling the CreateFileMapping function
with the PAGE_READWRITE or PAGE_WRITECOPY flag. Read-only DIB sections are not supported. Handles created by other means will cause
to fail.
If is not NULL, the function locates the bitmap bit values at offset
in the file-mapping object referred to by . An application can later retrieve the
handle by calling the function with the returned by
.
If is NULL, the system allocates memory for the DIB. In this case, the function
ignores the parameter. An application cannot later obtain a handle to this memory. The dshSection member of the
DIBSECTION structure filled in by calling the function will be NULL.
The offset from the beginning of the file-mapping object referenced by where storage for the bitmap bit values is to
begin. This value is ignored if is NULL. The bitmap bit values are aligned on double word boundaries, so
must be a multiple of the size of a DWORD.
If the function succeeds, the return value is a handle to the newly created DIB, and * points to the bitmap bit
values.
If the function fails, the return value is NULL, and * is NULL.
This function can return the following value.
As noted above, if is NULL, the system allocates memory for the DIB. The system closes the handle to that memory
when you later delete the DIB by calling the function. If is not NULL, you must
close the memory handle yourself after calling to delete the bitmap.
You cannot paste a DIB section from one application into another application.
does not use the parameters
or
and will not provide resolution information in the structure.
You need to guarantee that the GDI subsystem has completed any drawing to a bitmap created by before you draw
to the bitmap yourself. Access to the bitmap must be synchronized. Do this by calling the function. This applies to
any use of the pointer to the bitmap bit values, including passing the pointer in calls to functions such as .
ICM: No color management is done.
The function copies the contents of an enhanced-format metafile to a specified file.
A handle to the enhanced metafile to be copied.
A pointer to the name of the destination file. If this parameter is NULL, the source metafile is copied to memory.
If the function succeeds, the return value is a handle to the copy of the enhanced metafile.
If the function fails, the return value is NULL.
Where text arguments must use Unicode characters, use the function as a wide-character function. Where text
arguments must use characters from the Windows character set, use this function as an ANSI function.
Applications can use metafiles stored in memory for temporary operations.
When the application no longer needs the enhanced-metafile handle, it should delete the handle by calling the
function.
The function concatenates two world-space to page-space transformations.
A pointer to an structure that receives the combined transformation.
A pointer to an structure that specifies the first transformation.
A pointer to an structure that specifies the second transformation.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
Applying the combined transformation has the same effect as applying the first transformation and then applying the second transformation.
The three transformations need not be distinct. For example, can point to the same
structure as .
The function closes an enhanced-metafile device context and returns a handle that identifies an enhanced-format
metafile.
Handle to an enhanced-metafile device context.
If the function succeeds, the return value is a handle to an enhanced metafile.
If the function fails, the return value is NULL.
An application can use the enhanced-metafile handle returned by the function to perform the following tasks:
The function adds the font resource from the specified file to the system font table. The font can
subsequently be used for text output by any application.
To mark a font as private or not enumerable, use the function.
A pointer to a null-terminated character string that contains a valid font file name. This parameter can specify any of the following
files.
-
.fon
Font resource file.
-
.fnt
Raw bitmap font file.
-
.ttf
Raw TrueType file.
-
.ttc
East Asian Windows: TrueType font collection.
-
.fot
TrueType resource file.
-
.otf
PostScript OpenType font.
-
.mmm
Multiple master Type1 font resource file. It must be used with .pfm and .pfb files.
-
.pfb
Type 1 font bits file. It is used with a .pfm file.
-
.pfm
Type 1 font metrics file. It is used with a .pfb file.
To add a font whose information comes from several resource files, have point to a string with the file
names separated by a "|" --for example, abcxxxxx.pfm | abcxxxxx.pfb.
If the function succeeds, the return value specifies the number of fonts added.
If the function fails, the return value is zero. No extended error information is available.
Any application that adds or removes fonts from the system font table should notify other windows of the change by sending a
message to all top-level windows in the operating system. The application should send this message by calling
the function and setting the hwnd parameter to HWND_BROADCAST.
When an application no longer needs a font resource that it loaded by calling the function, it must remove
that resource by calling the function.
This function installs the font only for the current session. When the system restarts, the font will not be present. To have the font
installed even after restarting the system, the font must be listed in the registry.
The function resets the origin of a brush or resets a logical palette. If the
parameter is a handle to a brush, directs the system to reset the origin of the brush the next time it is
selected. If the parameter is a handle to a logical palette, directs the system to
realize the palette as though it had not previously been realized. The next time the application calls the function
for the specified palette, the system completely remaps the logical palette to the system palette.
A handle to the logical palette to be reset.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function should not be used with stock objects. For example, the default palette, obtained by calling
(DEFAULT_PALETTE), is a stock object.
A palette identified by can be the currently selected palette of a device context.
If is a brush, does nothing, and the function returns TRUE. Use
to set the origin of a brush.
The function sets the polygon fill mode for functions that fill polygons.
A handle to the device context.
The new fill mode. This parameter can be one of the following values.
-
ALTERNATE
Selects alternate mode (fills the area between odd-numbered and even-numbered polygon sides on each scan line).
-
WINDING
Selects winding mode (fills any region with a nonzero winding value).
The return value specifies the previous filling mode. If an error occurs, the return value is zero.
In general, the modes differ only in cases where a complex, overlapping polygon must be filled (for example, a five-sided polygon that forms
a five-pointed star with a pentagon in the center). In such cases, ALTERNATE mode fills every other enclosed region within the polygon (that
is, the points of the star), but WINDING mode fills all regions (that is, the points and the pentagon).
When the fill mode is ALTERNATE, GDI fills the area between odd-numbered and even-numbered polygon sides on each scan line. That is, GDI
fills the area between the first and second side, between the third and fourth side, and so on.
When the fill mode is WINDING, GDI fills any region that has a nonzero winding value. This value is defined as the number of times a pen used
to draw the polygon would go around the region. The direction of each edge of the polygon is important.
The function sets the graphics mode for the specified device context.
A handle to the device context.
The graphics mode. This parameter can be one of the following values.
-
GM_COMPATIBLE
Sets the graphics mode that is compatible with 16-bit Windows. This is the default mode. If this value is specified, the application
can only modify the world-to-device transform by calling functions that set window and viewport extents and origins, but not by using
or ; calls to those functions will fail. Examples of functions
that set window and viewport extents and origins are and .
-
GM_ADVANCED
Sets the advanced graphics mode that allows world transformations. This value must be specified if the application will set or modify
the world transformation for the specified device context. In this mode all graphics, including text output, fully conform to the
world-to-device transformation specified in the device context.
If the function succeeds, the return value is the old graphics mode.
If the function fails, the return value is zero.
There are three areas in which graphics output differs according to the graphics mode:
function sets the current device context (DC) brush color to the specified color value. If the device cannot
represent the specified color value, the color is set to the nearest physical color.
A handle to the DC.
The new brush color.
If the function succeeds, the return value specifies the previous DC brush color as a value.
If the function fails, the return value is CLR_INVALID.
When the stock DC_BRUSH is selected in a DC, all the subsequent drawings will be done using the DC brush color until the stock brush is
deselected. The default DC_BRUSH color is WHITE.
The function returns the previous DC_BRUSH color, even if the stock brush DC_BRUSH is not selected in the DC: however, this will not be used
in drawing operations until the stock DC_BRUSH is selected in the DC.
The function with an argument of DC_BRUSH or DC_PEN can be used interchangeably with the
and functions.
ICM: Color management is performed if ICM is enabled.
The sets the drawing direction to be used for arc and rectangle functions.
A handle to the device context.
The new arc direction. This parameter can be one of the following values.
-
AD_COUNTERCLOCKWISE
Figures drawn counterclockwise.
-
AD_CLOCKWISE
Figures drawn clockwise.
If the function succeeds, the return value specifies the old arc direction.
If the function fails, the return value is zero.
The default direction is counterclockwise.
The function specifies the direction in which the following functions draw:
The function displays the picture stored in the specified enhanced-format metafile.
A handle to the device context for the output device on which the picture will appear.
A handle to the enhanced metafile.
A pointer to a structure that contains the coordinates of the bounding rectangle used to display the picture. The coordinates
are specified in logical units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
When an application calls the function, the system uses the picture frame in the enhanced-metafile header to
map the picture onto the rectangle pointed to by the parameter. (This picture may be sheared or rotated by setting
the world transform in the output device before calling .) Points along the edges of the rectangle are included
in the picture.
An enhanced-metafile picture can be clipped by defining the clipping region in the output device before playing the enhanced metafile.
If an enhanced metafile contains an optional palette, an application can achieve consistent colors by setting up a color palette on the
output device before calling . To retrieve the optional palette, use the
function.
An enhanced metafile can be embedded in a newly created enhanced metafile by calling and playing the source
enhanced metafile into the device context for the new enhanced metafile.
The states of the output device context are preserved by this function. Any object created but not deleted in the enhanced metafile is
deleted by this function.
To stop this function, an application can call the function from another thread to terminate the operation. In this
case, the function returns FALSE.
The function fills the specified buffer with the metrics for the currently selected font.
A handle to the device context.
A pointer to the structure that receives the text metrics.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
To determine whether a font is a TrueType font, first select it into a DC, then call , and then check for
TMPF_TRUETYPE in TEXTMETRIC.tmPitchAndFamily. Note that returns an uninitialized DC, which has "System" (a bitmap
font) as the default font; thus the need to select a font into the DC.
The function retrieves the current polygon fill mode.
Handle to the device context.
If the function succeeds, the return value specifies the polygon fill mode, which can be one of the following values.
The function retrieves a color value identifying a color from the system palette that will be displayed when the
specified color value is used.
A handle to the device context.
A color value that identifies a requested color. To create a color value, use the RGB macro.
If the function succeeds, the return value identifies a color from the system palette that corresponds to the given color value.
If the function fails, the return value is CLR_INVALID.
The function retrieves the current graphics mode for the specified device context.
A handle to the device context.
If the function succeeds, the return value is the current graphics mode. It can be one of the following values.
An application can set the graphics mode for a device context by calling the function.
The function creates a handle that identifies the enhanced-format metafile stored in the specified file.
A pointer to a null-terminated string that specifies the name of an enhanced metafile.
If the function succeeds, the return value is a handle to the enhanced metafile.
If the function fails, the return value is NULL.
When the application no longer needs an enhanced-metafile handle, it should delete the handle by calling the
function.
A Windows-format metafile must be converted to the enhanced format before it can be processed by the function.
To convert the file, use the function.
Where text arguments must use Unicode characters, use this function as a wide-character function. Where text arguments must use characters
from the Windows character set, use this function as an ANSI function.
The function retrieves the current brush color for the specified device context (DC).
A handle to the DC whose brush color is to be returned.
If the function succeeds, the return value is the value for the current DC brush color.
If the function fails, the return value is CLR_INVALID.
For information on setting the brush color, see .
ICM: Color management is performed if ICM is enabled.
The function retrieves the widths, in logical coordinates, of consecutive characters in a specified range from the
current font.
A handle to the device context.
The first character in the group of consecutive characters.
The last character in the group of consecutive characters, which must not precede the specified first character.
A pointer to a buffer that receives the character widths, in logical coordinates.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
cannot be used on TrueType fonts. To retrieve character widths for TrueType fonts, use
.
The range is inclusive; that is, the returned widths include the widths of the characters specified by the and
parameters.
If a character does not exist in the current font, it is assigned the width of the default character.
The function retrieves the current arc direction for the specified device context. Arc and rectangle functions use
the arc direction.
Handle to the device context.
The return value specifies the current arc direction; it can be any one of the following values:
The function creates a region from the specified region and transformation data.
A pointer to an structure that defines the transformation to be performed on the region. If this pointer is NULL, the
identity transformation is used.
The number of bytes pointed to by .
A pointer to a structure that contains the region data in logical units.
If the function succeeds, the return value is the value of the region.
If the function fails, the return value is NULL.
Region coordinates are represented as 27-bit signed integers.
An application can retrieve data for a region by calling the function.
The function creates a new clipping region that consists of the existing clipping region minus the specified
rectangle.
A handle to the device context.
The x-coordinate, in logical units, of the upper-left corner of the rectangle.
The y-coordinate, in logical units, of the upper-left corner of the rectangle.
The x-coordinate, in logical units, of the lower-right corner of the rectangle.
The y-coordinate, in logical units, of the lower-right corner of the rectangle.
The return value specifies the new clipping region's complexity; it can be one of the following values.
The lower and right edges of the specified rectangle are not excluded from the clipping region.
The function enumerates the records within an enhanced-format metafile by retrieving each record and passing it to
the specified callback function. The application-supplied callback function processes each record as required. The enumeration continues until
the last record is processed or when the callback function returns zero.
A handle to a device context. This handle is passed to the callback function.
A handle to an enhanced metafile.
A pointer to the application-supplied callback function. For more information, see the function.
A pointer to optional callback-function data.
A pointer to a structure that specifies the coordinates, in logical units, of the picture's upper-left and lower-right
corners.
If the callback function successfully enumerates all the records in the enhanced metafile, the return value is nonzero.
If the callback function does not successfully enumerate all the records in the enhanced metafile, the return value is zero.
Points along the edge of the rectangle pointed to by the parameter are included in the picture. If the
parameter is NULL, the system ignores .
If the callback function calls the function, must identify a valid device
context. The system uses the device context's transformation and mapping mode to transform the picture displayed by the
function.
You can use the function to embed one enhanced-metafile within another.
The function creates a device context for a Windows-format metafile.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
A pointer to the file name for the Windows-format metafile to be created. If this parameter is NULL, the Windows-format metafile is memory based
and its contents are lost when it is deleted by using the function.
If the function succeeds, the return value is a handle to the device context for the Windows-format metafile.
If the function fails, the return value is NULL.
Where text arguments must use Unicode characters, use the function as a wide-character function. Where text
arguments must use characters from the Windows character set, use this function as an ANSI function.
is a Windows-format metafile function. This function supports only 16-bit Windows-based applications, which are
listed in Windows-Format Metafiles. It does not record or play back GDI functions such as , which were not part of
16-bit Windows.
The device context created by this function can be used to record GDI output functions in a Windows-format metafile. It cannot be used with
GDI query functions such as . When the device context is used with a GDI output function, the return value of that
function becomes TRUE if the function is recorded and FALSE otherwise. When an object is selected by using the
function, only a copy of the object is recorded. The object still belongs to the application.
To create a scalable Windows-format metafile, record the graphics output in the MM_ANISOTROPIC mapping mode. The file cannot contain
functions that modify the viewport origin and extents, nor can it contain device-dependent functions such as the
function. Once created, the Windows metafile can be scaled and rendered to any output device-format by defining the viewport origin and
extents of the picture before playing it.
The function specifies which window point maps to the viewport origin (0,0).
A handle to the device context.
The x-coordinate, in logical units, of the new window origin.
The y-coordinate, in logical units, of the new window origin.
A pointer to a structure that receives the previous origin of the window, in logical units. If
is NULL, this parameter is not used.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
This helps define the mapping from the logical coordinate space (also known as a window) to the device coordinate space (the viewport).
specifies which logical point maps to the device point (0,0). It has the effect of shifting the axes so that the
logical point (0,0) no longer refers to the upper-left corner.
The function sets the horizontal and vertical extents of the window for a device context by using the specified
values.
A handle to the device context.
The window's horizontal extent in logical units.
The window's vertical extent in logical units.
A pointer to a structure that receives the previous window extents, in logical units. If is NULL,
this parameter is not used.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The window refers to the logical coordinate system of the page space. The extent is the maximum value of an axis. This function sets the
maximum values for the horizontal and vertical axes of the window (in logical coordinates). When mapping between page space and device space,
and determine the scaling factor between the window and the viewport. For more
information, see Transformation of Coordinate Spaces.
When the following mapping modes are set, calls to the and functions are
ignored:
Applies to: desktop apps only
The function sets the pixel format of the specified device context to the format specified by the
index.
Specifies the device context whose pixel format the function attempts to set.
Index that identifies the pixel format to set. The various pixel formats supported by a device context are identified by
one-based indexes.
Pointer to a structure that contains the logical pixel format specification. The system's metafile component
uses this structure to record the logical pixel format specification. The structure has no other effect upon the behavior of the
function.
If the function succeeds, the return value is TRUE.
If the function fails, the return value is FALSE. To get extended error information, call GetLastError.
If references a window, calling the function also changes the pixel format of the
window. Setting the pixel format of a window more than once can lead to significant complications for the Window Manager and for multithread
applications, so it is not allowed. An application can only set the pixel format of a window one time. Once a window's pixel format is set,
it cannot be changed.
You should select a pixel format in the device context before calling the wglCreateContext function. The wglCreateContext function creates a
rendering context for drawing on the device in the selected pixel format of the device context.
An OpenGL window has its own pixel format. Because of this, only device contexts retrieved for the client area of an OpenGL window are
allowed to draw into the window. As a result, an OpenGL window should be created with the WS_CLIPCHILDREN and WS_CLIPSIBLINGS styles.
Additionally, the window class attribute should not include the CS_PARENTDC style.
The function alters the algorithm the font mapper uses when it maps logical fonts to physical fonts.
A handle to the device context that contains the font-mapper flag.
Specifies whether the font mapper should attempt to match a font's aspect ratio to the current device's aspect ratio. If bit zero is set, the
mapper selects only matching fonts.
If the function succeeds, the return value is the previous value of the font-mapper flag.
If the function fails, the return value is GDI_ERROR.
If the parameter is set and no matching fonts exist, Windows chooses a new aspect ratio and retrieves a font that
matches this ratio.
The remaining bits of the parameter must be zero.
The function sets a specified color profile as the output profile for a specified device context (DC).
Specifies a device context in which to set the color profile.
Specifies the path name of the color profile to be set.
associates a color profile with a device context. It becomes the output profile for that device context. The
color profile does not have to be associated with any particular device. Device-independent profiles such as sRGB can also be used. If the
color profile is not associated with a hardware device, it will be returned by , but not by
.
Note that under Windows 95 or later, the PostScript device driver for printers assumes a CMYK color model. Therefore, all PostScript printers
must use a CMYK color profile. Windows 2000 does not have this limitation.
supports only RGB profiles in compatible DCs.
The function selects the current path as a clipping region for a device context, combining the new region with any
existing clipping region using the specified mode.
A handle to the device context of the path.
The way to use the path. This parameter can be one of the following values.
-
RGN_AND
The new clipping region includes the intersection (overlapping areas) of the current clipping region and the current path.
-
RGN_COPY
The new clipping region is the current path.
-
RGN_DIFF
The new clipping region includes the areas of the current clipping region with those of the current path excluded.
-
RGN_OR
The new clipping region includes the union (combined areas) of the current clipping region and the current path.
-
RGN_XOR
The new clipping region includes the union of the current clipping region and the current path but without the overlapping
areas.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The device context identified by the parameter must contain a closed path.
The function maps palette entries from the current logical palette to the system palette.
A handle to the device context into which a logical palette has been selected.
If the function succeeds, the return value is the number of entries in the logical palette mapped to the system palette.
If the function fails, the return value is GDI_ERROR.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
The function modifies the palette for the device associated with the specified device context. If the device
context is a memory DC, the color table for the bitmap selected into the DC is modified. If the device context is a display DC, the physical
palette for that device is modified.
A logical palette is a buffer between color-intensive applications and the system, allowing these applications to use as many colors as
needed without interfering with colors displayed by other windows.
When an application's window has the focus and it calls the function, the system attempts to realize as many of
the requested colors as possible. The same is also true for applications with inactive windows.
The function retrieves the x-coordinates and y-coordinates of the window origin for the specified device context.
A handle to the device context.
A pointer to a structure that receives the coordinates, in logical units, of the window origin.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
This function retrieves the x-extent and y-extent of the window for the specified device context.
A handle to the device context.
A pointer to a structure that receives the x- and y-extents in page-space units, that is, logical units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
Retrieves a character set identifier for the font that is currently selected into a specified device context.
A call to this function is equivalent to a call to passing NULL for the data buffer.
Handle to a device context. The function obtains a character set identifier for the font that is selected into this device context.
If successful, returns a value identifying the character set of the font that is currently selected into the specified device context. The
following character set identifiers are defined:
The function retrieves a handle to one of the stock pens, brushes, fonts, or palettes.
The type of stock object. This parameter can be one of the following values.
-
BLACK_BRUSH
Black brush.
-
DKGRAY_BRUSH
Dark gray brush.
-
DC_BRUSH
Solid color brush. The default color is white. The color can be changed by using the function. For
more information, see the Remarks section.
-
GRAY_BRUSH
Gray brush.
-
HOLLOW_BRUSH
Hollow brush (equivalent to NULL_BRUSH).
-
LTGRAY_BRUSH
Light gray brush.
-
NULL_BRUSH
Null brush (equivalent to HOLLOW_BRUSH).
-
WHITE_BRUSH
White brush.
-
BLACK_PEN
Black pen.
-
DC_PEN
Solid pen color. The default color is white. The color can be changed by using the function. For more
information, see the Remarks section.
-
NULL_PEN
Null pen. The null pen draws nothing.
-
WHITE_PEN
White pen.
-
ANSI_FIXED_FONT
Windows fixed-pitch (monospace) system font.
-
ANSI_VAR_FONT
Windows variable-pitch (proportional space) system font.
-
DEVICE_DEFAULT_FONT
Device-dependent font.
-
DEFAULT_GUI_FONT
Default font for user interface objects such as menus and dialog boxes. It is not recommended that you use DEFAULT_GUI_FONT or
SYSTEM_FONT to obtain the font used by dialogs and windows; for more information, see the remarks section.
The default font is Tahoma.
-
OEM_FIXED_FONT
Original equipment manufacturer (OEM) dependent fixed-pitch (monospace) font.
-
SYSTEM_FONT
System font. By default, the system uses the system font to draw menus, dialog box controls, and text. It is not recommended that
you use DEFAULT_GUI_FONT or SYSTEM_FONT to obtain the font used by dialogs and windows; for more information, see the remarks
section.
The default system font is Tahoma.
-
SYSTEM_FIXED_FONT
Fixed-pitch (monospace) system font. This stock object is provided only for compatibility with 16-bit Windows versions
earlier than 3.0.
-
DEFAULT_PALETTE
Default palette. This palette consists of the static colors in the system palette.
If the function succeeds, the return value is a handle to the requested logical object.
If the function fails, the return value is NULL.
It is not recommended that you employ this method to obtain the current font used by dialogs and windows. Instead, use the
function with the SPI_GETNONCLIENTMETRICS parameter to retrieve the current font.
will take into account the current theme and provides font information for captions, menus, and
message dialogs.
Use the DKGRAY_BRUSH, GRAY_BRUSH, and LTGRAY_BRUSH stock objects only in windows with the CS_HREDRAW and CS_VREDRAW styles. Using a gray
stock brush in any other style of window can lead to misalignment of brush patterns after a window is moved or sized. The origins of stock
brushes cannot be adjusted.
The HOLLOW_BRUSH and NULL_BRUSH stock objects are equivalent.
It is not necessary (but it is not harmful) to delete stock objects by calling .
Both DC_BRUSH and DC_PEN can be used interchangeably with other stock objects like BLACK_BRUSH and BLACK_PEN. For information on retrieving
the current pen or brush color, see and . See Setting the Pen or Brush Color for
an example of setting colors. The function with an argument of DC_BRUSH or DC_PEN can be used interchangeably
with the and functions.
Applies to: desktop apps only
The function obtains the index of the currently selected pixel format of the specified device context.
Specifies the device context of the currently selected pixel format index returned by the function.
If the function succeeds, the return value is the currently selected pixel format index of the specified device context. This is a positive,
one-based index value.
If the function fails, the return value is zero. To get extended error information, call GetLastError.
The function retrieves the file name of the current output color profile for a specified device context.
Specifies a device context from which to retrieve the color profile.
Pointer to a DWORD that contains the size of the buffer pointed to by . For the ANSI version of this function,
the size is in bytes. For the Unicode version, the size is in WCHARs. If this function is successful, on return this parameter contains the size
of the buffer actually used. However, if the buffer is not large enough, this function returns FALSE. In this case, the GetLastError function
returns ERROR_INSUFFICIENT_BUFFER and the DWORD pointed to by this parameter contains the size needed for the
buffer.
Points to the buffer that receives the path name of the profile.
obtains the file name of the current output profile regardless of whether or not color management is enabled for
the device context.
Given a device context, will output, through the parameter , the path name of
the file containing the color profile currently being used by the device context. It will also output, through the parameter
, the length of the string containing the path name.
It is possible that the profile name returned by will not be in the list of profiles returned by
. The function returns all color space profiles that are associated with a
device context (DC) whose settings match that of the DC. If the function is used to set the current profile, a
profile may be associated with the DC that does not match its settings. For instance, the function can be used
to associate the device-independent sRGB profile with a DC. This profile will be used as the current WCS profile for that DC, and calls to
will return its file name. However, the profile will not appear in the list of profiles that is returned from
.
If this function is called before any calls to the function, it can be used to get the default profile for a
device context.
The function deletes a Windows-format metafile or Windows-format metafile handle.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
A handle to a Windows-format metafile.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
If the metafile identified by the parameter is stored in memory (rather than on a disk), its content is lost when it is
deleted by using the function.
The function creates a compatible bitmap (DDB) from a DIB and, optionally, sets the bitmap bits.
A handle to a device context.
A pointer to a bitmap information header structure, .
If is CBM_INIT, the function uses the bitmap information header structure to obtain the desired width and height
of the bitmap as well as other information. Note that a positive value for the height indicates a bottom-up DIB while a negative value for
the height indicates a top-down DIB. Calling with as CBM_INIT is equivalent to
calling the function to create a DDB in the format of the device and then calling the
function to translate the DIB bits to the DDB.
Specifies how the system initializes the bitmap bits. The following value is defined.
-
CBM_INIT
If this flag is set, the system uses the data pointed to by the and
parameters to initialize the bitmap bits.
If this flag is clear, the data pointed to by those parameters is not used.
If is zero, the system does not initialize the bitmap bits.
A pointer to an array of bytes containing the initial bitmap data. The format of the data depends on the
member of the
structure to which the parameter points.
A pointer to a structure that describes the dimensions and color format of the array pointed to by the
parameter.
Specifies whether the member of the structure was initialized and, if so,
whether
contains explicit red, green, blue (RGB) values or palette indexes. The
parameter must be one of the following values.
-
DIB_PAL_COLORS
A color table is provided and consists of an array of 16-bit indexes into the logical palette of the device context into which the
bitmap is to be selected.
-
DIB_RGB_COLORS
A color table is provided and contains literal RGB values.
If the function succeeds, the return value is a handle to the compatible bitmap.
If the function fails, the return value is NULL.
The DDB that is created will be whatever bit depth your reference DC is. To create a bitmap that is of different bit depth, use
.
For a device to reach optimal bitmap-drawing speed, specify as CBM_INIT. Then, use the same color depth DIB as
the video mode. When the video is running 4- or 8-bpp, use DIB_PAL_COLORS.
The CBM_CREATDIB flag for the parameter is no longer supported.
When you no longer need the bitmap, call the function to delete it.
ICM: No color management is performed. The contents of the resulting bitmap are not color matched after the bitmap has been created.
The function replaces entries in the specified logical palette.
A handle to the logical palette.
The first logical palette entry to be replaced.
The number of entries to be replaced.
A pointer to the first member in an array of structures used to replace the current entries.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
The function only changes entries with the PC_RESERVED flag set in the corresponding
member of the structure.
If the given palette is associated with the active window, the colors in the palette are replaced immediately.
The function copies the color data for a rectangle of pixels in a DIB, JPEG, or PNG image to the specified
destination rectangle. If the destination rectangle is larger than the source rectangle, this function stretches the rows and columns of color
data to fit the destination rectangle. If the destination rectangle is smaller than the source rectangle, this function compresses the rows and
columns by using the specified raster operation.
A handle to the destination device context.
The x-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The y-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The width, in logical units, of the destination rectangle.
The height, in logical units, of the destination rectangle.
The x-coordinate, in pixels, of the source rectangle in the image.
The y-coordinate, in pixels, of the source rectangle in the image.
The width, in pixels, of the source rectangle in the image.
The height, in pixels, of the source rectangle in the image.
A pointer to the image bits, which are stored as an array of bytes. For more information, see the Remarks section.
A pointer to a structure that contains information about the DIB.
Specifies whether the member of the structure was provided and, if so, whether
contains explicit red, green, blue (RGB) values or indexes. The parameter must
be one of the following values.
-
DIB_PAL_COLORS
The array contains 16-bit indexes into the logical palette of the source device context.
-
DIB_RGB_COLORS
The color table contains literal RGB values.
For more information, see the Remarks section.
A raster-operation code that specifies how the source pixels, the destination device context's current brush, and the destination pixels are to
be combined to form the new image. For a list of some common raster operation codes, see .
If the function succeeds, the return value is the number of scan lines copied. Note that this value can be negative for mirrored content.
If the function fails, or no scan lines are copied, the return value is 0.
If the driver cannot support the JPEG or PNG file image passed to , the function will fail and return GDI_ERROR.
If failure does occur, the application must fall back on its own JPEG or PNG support to decompress the image into a bitmap, and then pass the
bitmap to .
The origin of a bottom-up DIB is the lower-left corner; the origin of a top-down DIB is the upper-left corner.
creates a mirror image of a bitmap if the signs of the and
parameters, or if the and parameters differ. If
and have different signs, the function creates a mirror image of the bitmap
along the x-axis. If and have different signs, the function creates a mirror
image of the bitmap along the y-axis.
creates a top-down image if the sign of the member of the
structure for the DIB is negative. For a code example, see Sizing a JPEG or PNG Image.
This function allows a JPEG or PNG image to be passed as the source image. How each parameter is used remains the same, except:
The function sets the limit for the length of miter joins for the specified device context.
Handle to the device context.
Specifies the new miter limit for the device context.
Pointer to a floating-point value that receives the previous miter limit. If this parameter is NULL, the previous miter
limit is not returned.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The miter length is defined as the distance from the intersection of the line walls on the inside of the join to the intersection of the line
walls on the outside of the join. The miter limit is the maximum allowed ratio of the miter length to the line width.
The default miter limit is 10.0.
function sets the current device context (DC) pen color to the specified color value. If the device cannot represent
the specified color value, the color is set to the nearest physical color.
A handle to the DC.
The new pen color.
If the function succeeds, the return value specifies the previous DC pen color as a value. If the function fails, the
return value is CLR_INVALID.
The function returns the previous DC_PEN color, even if the stock pen DC_PEN is not selected in the DC; however, this will not be used in
drawing operations until the stock DC_PEN is selected in the DC.
The function with an argument of DC_BRUSH or DC_PEN can be used interchangeably with the
and functions.
ICM: Color management is performed if ICM is enabled.
The function defines the input color space for a given device context.
Specifies the handle to a device context.
Identifies handle to the color space to set.
The function sets the brush origin that GDI assigns to the next brush an application selects into the specified
device context.
A handle to the device context.
The x-coordinate, in device units, of the new brush origin. If this value is greater than the brush width, its value is reduced using the modulus
operator ( % brush width).
The y-coordinate, in device units, of the new brush origin. If this value is greater than the brush height, its value is reduced using the
modulus operator ( % brush height).
A pointer to a structure that receives the previous brush origin.
This parameter can be NULL if the previous brush origin is not required.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
A brush is a bitmap that the system uses to paint the interiors of filled shapes.
The brush origin is a pair of coordinates specifying the location of one pixel in the bitmap. The default brush origin coordinates are (0,0).
For horizontal coordinates, the value 0 corresponds to the leftmost column of pixels; the width corresponds to the rightmost column. For
vertical coordinates, the value 0 corresponds to the uppermost row of pixels; the height corresponds to the lowermost row.
The system automatically tracks the origin of all window-managed device contexts and adjusts their brushes as necessary to maintain an
alignment of patterns on the surface. The brush origin that is set with this call is relative to the upper-left corner of the client area.
An application should call after setting the bitmap stretching mode to HALFTONE by using
. This must be done to avoid brush misalignment.
The system automatically tracks the origin of all window-managed device contexts and adjusts their brushes as necessary to maintain an
alignment of patterns on the surface.
The function controls the accumulation of bounding rectangle information for the specified device context. The
system can maintain a bounding rectangle for all drawing operations. An application can examine and set this rectangle. The drawing boundaries
are useful for invalidating bitmap caches.
A handle to the device context for which to accumulate bounding rectangles.
A pointer to a structure used to set the bounding rectangle. Rectangle dimensions are in logical coordinates. This parameter
can be NULL.
Specifies how the new rectangle will be combined with the accumulated rectangle. This parameter can be one of more of the following values.
-
DCB_ACCUMULATE
Adds the rectangle specified by the parameter to the bounding rectangle (using a rectangle union
operation). Using both DCB_RESET and DCB_ACCUMULATE sets the bounding rectangle to the rectangle specified by the
parameter.
-
DCB_DISABLE
Turns off boundary accumulation.
-
DCB_ENABLE
Turns on boundary accumulation, which is disabled by default.
-
DCB_RESET
Clears the bounding rectangle.
If the function succeeds, the return value specifies the previous state of the bounding rectangle. This state can be a combination of the
following values.
The DCB_SET value is a combination of the bit values DCB_ACCUMULATE and DCB_RESET. Applications that check the DCB_RESET bit to determine whether
the bounding rectangle is empty must also check the DCB_ACCUMULATE bit. The bounding rectangle is empty only if the DCB_RESET bit is 1 and the
DCB_ACCUMULATE bit is 0.
The function sets the bits of color data for a bitmap to the specified values.
Note: This function is provided only for compatibility with 16-bit versions of Windows. Applications should use the
function.
A handle to the bitmap to be set. This must be a compatible bitmap (DDB).
The number of bytes pointed to by the parameter.
A pointer to an array of bytes that contain color data for the specified bitmap.
If the function succeeds, the return value is the number of bytes used in setting the bitmap bits.
If the function fails, the return value is zero.
The array identified by must be WORD aligned.
The function selects the specified logical palette into a device context.
A handle to the device context.
A handle to the logical palette to be selected.
Specifies whether the logical palette is forced to be a background palette. If this value is TRUE, the function
causes the logical palette to be mapped to the colors already in the physical palette in the best possible way. This is always done, even if
the window for which the palette is realized belongs to a thread without active focus.
If this value is FALSE, causes the logical palette to be copied into the device palette when the application is
in the foreground. (If the parameter is a memory device context, this parameter is ignored.)
If the function succeeds, the return value is a handle to the device context's previous logical palette.
If the function fails, the return value is NULL.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
An application can select a logical palette into more than one device context only if device contexts are compatible. Otherwise
fails. To create a device context that is compatible with another device context, call
with the first device context as the parameter. If a logical palette is selected into more than one device
context, changes to the logical palette will affect all device contexts for which it is selected.
An application might call the function with the parameter set to TRUE if
the child windows of a top-level window each realize their own palettes. However, only the child window that needs to realize its palette
must set to TRUE; other child windows must set this value to FALSE.
The function selects a region as the current clipping region for the specified device context.
A handle to the device context.
A handle to the region to be selected.
The return value specifies the region's complexity and can be one of the following values.
Only a copy of the selected region is used. The region itself can be selected for any number of other device contexts or it can be deleted.
The function assumes that the coordinates for a region are specified in device units.
To remove a device-context's clipping region, specify a NULL region handle.
The function increases or decreases the size of a logical palette based on the specified value.
A handle to the palette to be changed.
The number of entries in the palette after it has been resized.
The number of entries is limited to 1024.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
If an application calls to reduce the size of the palette, the entries remaining in the resized palette are
unchanged. If the application calls to enlarge the palette, the additional palette entries are set to black (the
red, green, and blue values are all 0) and their flags are set to zero.
The function moves the clipping region of a device context by the specified offsets.
A handle to the device context.
The number of logical units to move left or right.
The number of logical units to move up or down.
The return value specifies the new region's complexity and can be one of the following values.
The function fills the specified buffer with data describing a region. This data includes the dimensions of the
rectangles that make up the region.
A handle to the region.
The size, in bytes, of the buffer.
A pointer to a structure that receives the information. The dimensions of the region are in logical units. If this
parameter is NULL, the return value contains the number of bytes needed for the region data.
If the function succeeds and specifies an adequate number of bytes, the return value is always
. If is too small or the function fails, the return value is 0. If
is NULL, the return value is the required number of bytes.
If the function fails, the return value is zero.
The function is used in conjunction with the function.
The retrieves the type of the specified object.
A handle to the graphics object.
If the function succeeds, the return value identifies the object. This value can be one of the following.
The function retrieves the miter limit for the specified device context.
Handle to the device context.
Pointer to a floating-point value that receives the current miter limit.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The miter limit is used when drawing geometric lines that have miter joins.
The function retrieves device-specific information for the specified device.
A handle to the DC.
The item to be returned. This parameter can be one of the following values.
-
DRIVERVERSION
The device driver version.
-
TECHNOLOGY
Device technology. It can be any one of the following values.
If the parameter is a handle to the DC of an enhanced metafile, the device technology is that of the
referenced device as specified to the function. To determine whether it is an enhanced metafile
DC, use the function.
-
HORZSIZE
Width, in millimeters, of the physical screen.
-
VERTSIZE
Height, in millimeters, of the physical screen.
-
HORZRES
Width, in pixels, of the screen; or for printers, the width, in pixels, of the printable area of the page.
-
VERTRES
Height, in raster lines, of the screen; or for printers, the height, in pixels, of the printable area of the page.
-
LOGPIXELSX
Number of pixels per logical inch along the screen width. In a system with multiple display monitors, this value is the same
for all monitors.
-
LOGPIXELSY
Number of pixels per logical inch along the screen height. In a system with multiple display monitors, this value is the
same for all monitors.
-
BITSPIXEL
Number of adjacent color bits for each pixel.
-
PLANES
Number of color planes.
-
NUMBRUSHES
Number of device-specific brushes.
-
NUMPENS
Number of device-specific pens.
-
NUMFONTS
Number of device-specific fonts.
-
NUMCOLORS
Number of entries in the device's color table, if the device has a color depth of no more than 8 bits per pixel. For devices with
greater color depths, 1 is returned.
-
ASPECTX
Relative width of a device pixel used for line drawing.
-
ASPECTY
Relative height of a device pixel used for line drawing.
-
ASPECTXY
Diagonal width of the device pixel used for line drawing.
-
PDEVICESIZE
Reserved.
-
CLIPCAPS
Flag that indicates the clipping capabilities of the device. If the device can clip to a rectangle, it is 1. Otherwise, it
is 0.
-
SIZEPALETTE
Number of entries in the system palette. This index is valid only if the device driver sets the RC_PALETTE bit in the RASTERCAPS
index and is available only if the driver is compatible with 16-bit Windows.
-
NUMRESERVED
Number of reserved entries in the system palette. This index is valid only if the device driver sets the RC_PALETTE bit in the
RASTERCAPS index and is available only if the driver is compatible with 16-bit Windows.
-
COLORRES
Actual color resolution of the device, in bits per pixel. This index is valid only if the device driver sets the RC_PALETTE bit in
the RASTERCAPS index and is available only if the driver is compatible with 16-bit Windows.
-
PHYSICALWIDTH
For printing devices: the width of the physical page, in device units. For example, a printer set to print at 600 dpi on 8.5-x11-inch
paper has a physical width value of 5100 device units. Note that the physical page is almost always greater than the printable area
of the page, and never smaller.
-
PHYSICALHEIGHT
For printing devices: the height of the physical page, in device units. For example, a printer set to print at 600 dpi on
8.5-by-11-inch paper has a physical height value of 6600 device units. Note that the physical page is almost always greater than the
printable area of the page, and never smaller.
-
PHYSICALOFFSETX
For printing devices: the distance from the left edge of the physical page to the left edge of the printable area, in device units.
For example, a printer set to print at 600 dpi on 8.5-by-11-inch paper, that cannot print on the leftmost 0.25-inch of paper, has a
horizontal physical offset of 150 device units.
-
PHYSICALOFFSETY
For printing devices: the distance from the top edge of the physical page to the top edge of the printable area, in device units. For
example, a printer set to print at 600 dpi on 8.5-by-11-inch paper, that cannot print on the topmost 0.5-inch of paper, has a
vertical physical offset of 300 device units.
-
VREFRESH
For display devices: the current vertical refresh rate of the device, in cycles per second (Hz).
A vertical refresh rate value of 0 or 1 represents the display hardware's default refresh rate. This default rate is typically
set by switches on a display card or computer motherboard, or by a configuration program that does not use display functions such
as .
-
SCALINGFACTORX
Scaling factor for the x-axis of the printer.
-
SCALINGFACTORY
Scaling factor for the y-axis of the printer.
-
BLTALIGNMENT
Preferred horizontal drawing alignment, expressed as a multiple of pixels. For best drawing performance, windows should be
horizontally aligned to a multiple of this value. A value of zero indicates that the device is accelerated, and any alignment may be
used.
-
SHADEBLENDCAPS
Value that indicates the shading and blending capabilities of the device. See Remarks for further comments.
-
RASTERCAPS
Value that indicates the raster capabilities of the device, as shown in the following table.
-
CURVECAPS
Value that indicates the curve capabilities of the device, as shown in the following table.
-
LINECAPS
Value that indicates the line capabilities of the device, as shown in the following table:
-
POLYGONALCAPS
Value that indicates the polygon capabilities of the device, as shown in the following table.
-
TEXTCAPS
Value that indicates the text capabilities of the device, as shown in the following table.
-
COLORMGMTCAPS
Value that indicates the color management capabilities of the device.
The return value specifies the value of the desired item.
When is BITSPIXEL and the device has 15bpp or 16bpp, the return value is 16.
When is SHADEBLENDCAPS:
The function retrieves the current pen color for the specified device context (DC).
A handle to the DC whose brush color is to be returned.
If the function succeeds, the return value is a value for the current DC pen color.
If the function fails, the return value is CLR_INVALID.
For information on setting the pen color, see .
ICM: Color management is performed if ICM is enabled.
The function retrieves the handle to the input color space from a specified device context.
Specifies a device context that is to have its input color space handle retrieved.
obtains the handle to the input color space regardless of whether color management is enabled for the device
context.
The function retrieves the widths, in logical coordinates, of consecutive characters in a specified range from
the current font.
Note: This function is provided only for compatibility with 16-bit versions of Windows. Applications should call the
function, which provides more accurate results.
A handle to the device context.
The first character in the group of consecutive characters.
The last character in the group of consecutive characters, which must not precede the specified first character.
A pointer to a buffer that receives the character widths, in logical coordinates.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
cannot be used on TrueType fonts. To retrieve character widths for TrueType fonts, use
.
The range is inclusive; that is, the returned widths include the widths of the characters specified by the and
parameters.
If a character does not exist in the current font, it is assigned the width of the default character.
The function retrieves the widths, in logical coordinates, of consecutive glyph indices in a specified range from
the current font.
A handle to the device context.
The first glyph index in the group of consecutive glyph indices.
The number of glyph indices.
A pointer to an array of glyph indices. If this parameter is not NULL, it is used instead of the parameter.
A pointer to a buffer that receives the widths, in logical coordinates.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function processes a consecutive glyph indices if the parameter is NULL with the
parameter indicating the first glyph index to process and the parameter indicating how
many glyph indices to process. Otherwise the function processes the array of glyph indices pointed to by the
parameter with the parameter indicating how many glyph indices to process.
If a character does not exist in the current font, it is assigned the width of the default character.
The function retrieves the current brush origin for the specified device context. This function replaces the
GetBrushOrg function.
A handle to the device context.
A pointer to a structure that receives the brush origin, in device coordinates.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
A brush is a bitmap that the system uses to paint the interiors of filled shapes.
The brush origin is a set of coordinates with values between 0 and 7, specifying the location of one pixel in the bitmap. The default brush
origin coordinates are (0,0). For horizontal coordinates, the value 0 corresponds to the leftmost column of pixels; the value 7 corresponds
to the rightmost column. For vertical coordinates, the value 0 corresponds to the uppermost row of pixels; the value 7 corresponds to the
lowermost row. When the system positions the brush at the start of any painting operation, it maps the origin of the brush to the location in
the window's client area specified by the brush origin. For example, if the origin is set to (2,3), the system maps the origin of the brush
(0,0) to the location (2,3) on the window's client area.
If an application uses a brush to fill the backgrounds of both a parent and a child window with matching colors, it may be necessary to set
the brush origin after painting the parent window but before painting the child window.
The system automatically tracks the origin of all window-managed device contexts and adjusts their brushes as necessary to maintain an
alignment of patterns on the surface.
The function obtains the current accumulated bounding rectangle for a specified device context.
The system maintains an accumulated bounding rectangle for each application. An application can retrieve and set this rectangle.
A handle to the device context whose bounding rectangle the function will return.
A pointer to the structure that will receive the current bounding rectangle. The application's rectangle is returned in
logical coordinates, and the bounding rectangle is returned in screen coordinates.
Specifies how the function will behave. This parameter can be the following value.
-
DCB_RESET
Clears the bounding rectangle after returning it. If this flag is not set, the bounding rectangle will not be cleared.
The return value specifies the state of the accumulated bounding rectangle; it can be one of the following values.
The DCB_SET value is a combination of the bit values DCB_ACCUMULATE and DCB_RESET. Applications that check the DCB_RESET bit to determine whether
the bounding rectangle is empty must also check the DCB_ACCUMULATE bit. The bounding rectangle is empty only if the DCB_RESET bit is 1 and the
DCB_ACCUMULATE bit is 0.
The function copies the bitmap bits of a specified device-dependent bitmap into a buffer.
Note: This function is provided only for compatibility with 16-bit versions of Windows. Applications should use the
function.
A handle to the device-dependent bitmap.
The number of bytes to copy from the bitmap into the buffer.
A pointer to a buffer to receive the bitmap bits. The bits are stored as an array of byte values.
If the function succeeds, the return value is the number of bytes copied to the buffer.
If the function fails, the return value is zero.
The function creates a rectangular region.
Specifies the x-coordinate of the upper-left corner of the region in logical units.
Specifies the y-coordinate of the upper-left corner of the region in logical units.
Specifies the x-coordinate of the lower-right corner of the region in logical units.
Specifies the y-coordinate of the lower-right corner of the region in logical units.
If the function succeeds, the return value is the handle to the region.
If the function fails, the return value is NULL.
When you no longer need the HRGN object, call the function to delete it.
Region coordinates are represented as 27-bit signed integers.
Regions created by the Create[shape]Rgn methods (such as and ) only include the
interior of the shape; the shape's outline is excluded from the region. This means that any point on a line between two sequential vertices
is not included in the region. If you were to call for such a point, it would return zero as the result.
The function creates a logical palette.
A pointer to a structure that contains information about the colors in the logical palette.
If the function succeeds, the return value is a handle to a logical palette.
If the function fails, the return value is NULL.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
Once an application creates a logical palette, it can select that palette into a device context by calling the
function. A palette selected into a device context can be realized by calling the function.
When you no longer need the palette, call the function to delete it.
The function copies the content of a Windows-format metafile to the specified file.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
A handle to the source Windows-format metafile.
A pointer to the name of the destination file. If this parameter is NULL, the source metafile is copied to memory.
If the function succeeds, the return value is a handle to the copy of the Windows-format metafile.
If the function fails, the return value is NULL.
Where text arguments must use Unicode characters, use this function as a wide-character function. Where text arguments must use characters
from the Windows character set, use this function as an ANSI function.
When the application no longer needs the Windows-format metafile handle, it should delete the handle by calling the
function.
The function closes a metafile device context and returns a handle that identifies a Windows-format metafile.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
Handle to a metafile device context used to create a Windows-format metafile.
If the function succeeds, the return value is a handle to a Windows-format metafile.
If the function fails, the return value is NULL.
To convert a Windows-format metafile into a new enhanced-format metafile, use the function.
When an application no longer needs the Windows-format metafile handle, it should delete the handle by calling the
function.
The function updates the client area of the specified device context by remapping the current colors in the client
area to the currently realized logical palette.
A handle to the device context.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
An application can determine whether a device supports palette operations by calling the function and specifying
the RASTERCAPS constant.
An inactive window with a realized logical palette may call as an alternative to redrawing its client area when
the system palette changes.
The function typically updates a client area faster than redrawing the area. However, because
performs the color translation based on the color of each pixel before the system palette changed, each call to
this function results in the loss of some color accuracy.
This function must be called soon after a message is received.
The function sets the text color for the specified device context to the specified color.
A handle to the device context.
The color of the text.
If the function succeeds, the return value is a color reference for the previous text color as a value.
If the function fails, the return value is CLR_INVALID.
The text color is used to draw the face of each character written by the and functions. The text
color is also used in converting bitmaps from color to monochrome and vice versa.
The function sets the text-alignment flags for the specified device context.
A handle to the device context.
The text alignment by using a mask of the values in the following list. Only one flag can be chosen from those that affect horizontal and
vertical alignment. In addition, only one of the two flags that alter the current position can be chosen.
-
TA_BASELINE
The reference point will be on the base line of the text.
-
TA_BOTTOM
The reference point will be on the bottom edge of the bounding rectangle.
-
TA_TOP
The reference point will be on the top edge of the bounding rectangle.
-
TA_CENTER
The reference point will be aligned horizontally with the center of the bounding rectangle.
-
TA_LEFT
The reference point will be on the left edge of the bounding rectangle.
-
TA_RIGHT
The reference point will be on the right edge of the bounding rectangle.
-
TA_NOUPDATECP
The current position is not updated after each text output call. The reference point is passed to the text output function.
-
TA_RTLREADING
Middle East language edition of Windows: The text is laid out in right to left reading order, as opposed to the default left to right
order. This applies only when the font selected into the device context is either Hebrew or Arabic.
-
TA_UPDATECP
The current position is updated after each text output call. The current position is used as the reference point.
When the current font has a vertical default base line, as with Kanji, the following values must be used instead of TA_BASELINE and
TA_CENTER.
-
VTA_BASELINE
The reference point will be on the base line of the text.
-
VTA_CENTER
The reference point will be aligned vertically with the center of the bounding rectangle.
The default values are TA_LEFT, TA_TOP, and TA_NOUPDATECP.
If the function succeeds, the return value is the previous text-alignment setting.
If the function fails, the return value is GDI_ERROR.
The and functions use the text-alignment flags to position a string of text on a display or
other device. The flags specify the relationship between a reference point and a rectangle that bounds the text. The reference point is
either the current position or a point passed to a text output function.
The rectangle that bounds the text is formed by the character cells in the text string.
The best way to get left-aligned text is to use either
The function sets the application-defined abort function that allows a print job to be canceled during spooling.
Handle to the device context for the print job.
Pointer to the application-defined abort function. For more information about the callback function, see the callback
function.
If the function succeeds, the return value is greater than zero.
If the function fails, the return value is SP_ERROR.
Note: This is a blocking or synchronous function and might not return immediately. How quickly this function returns depends on run-time factors
such as network status, print server configuration, and printer driver implementation—factors that are difficult to predict when writing an
application. Calling this function from a thread that manages interaction with the user interface could make the application appear to be
unresponsive.
The function selects an object into the specified device context (DC). The new object replaces the previous object of
the same type.
A handle to the DC.
A handle to the object to be selected. The specified object must have been created by using one of the following functions.
-
Bitmap
, , ,
,
Bitmaps can only be selected into memory DC's. A single bitmap cannot be selected into more than one DC at the same time.
-
Brush
, , ,
, ,
-
Font
,
-
Pen
,
-
Region
, , ,
, ,
If the selected object is not a region and the function succeeds, the return value is a handle to the object being replaced. If the selected
object is a region and the function succeeds, the return value is one of the following values.
This function returns the previously selected object of the specified type. An application should always replace a new object with the
original, default object after it has finished drawing with the new object.
An application cannot select a single bitmap into more than one DC at a time.
ICM: If the object being selected is a brush or a pen, color management is performed.
The function determines whether any part of the specified rectangle is within the boundaries of a region.
Handle to the region.
Pointer to a structure containing the coordinates of the rectangle in logical units. The lower and right edges of the
rectangle are not included.
If any part of the specified rectangle lies within the boundaries of the region, the return value is nonzero.
If no part of the specified rectangle lies within the boundaries of the region, the return value is zero.
The function draws several strings using the font and text colors currently selected in the specified device context.
A handle to the device context.
A pointer to an array of structures describing the strings to be drawn. The array contains one structure for each string
to be drawn.
The number of structures in the array.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
Each structure contains the coordinates of a reference point that Windows uses to align the corresponding string of
text. An application can specify how the reference point is used by calling the function. An application can
determine the current text-alignment setting for the specified device context by calling the function.
To draw a single string of text, the application should call the function.
The function draws multiple series of connected line segments.
A handle to the device context.
A pointer to an array of structures that contains the vertices of the polylines, in logical units. The polylines are
specified consecutively.
A pointer to an array of variables specifying the number of points in the array for the corresponding polyline. Each
entry must be greater than or equal to two.
The total number of entries in the array.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The line segments are drawn by using the current pen. The figures formed by the segments are not filled.
The current position is neither used nor updated by this function.
The function draws one or more BĂ©zier curves.
A handle to a device context.
A pointer to an array of structures that contains the endpoints and control points, in logical units.
The number of points in the array. This value must be three times the number of curves to be drawn because each BĂ©zier
curve requires two control points and an ending point.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
This function draws cubic BĂ©zier curves by using the control points specified by the parameter. The first curve is
drawn from the current position to the third point by using the first two points as control points. For each subsequent curve, the function
needs exactly three more points, and uses the ending point of the previous curve as the starting point for the next.
moves the current position to the ending point of the last BĂ©zier curve. The figure is not filled.
This function draws lines by using the current pen.
The function displays the picture stored in the given Windows-format metafile on the specified device.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
Handle to a device context.
Handle to a Windows-format metafile.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
To convert a Windows-format metafile into an enhanced format metafile, use the function.
A Windows-format metafile can be played multiple times.
A Windows-format metafile can be embedded in a second Windows-format metafile by calling the function and playing
the source metafile into the device context for the target metafile.
Any object created but not deleted in the Windows-format metafile is deleted by this function.
To stop this function, an application can call the function from another thread to terminate the operation. In this
case, the function returns FALSE.
The function creates a region from the path that is selected into the specified device context. The resulting region
uses device coordinates.
Handle to a device context that contains a closed path.
If the function succeeds, the return value identifies a valid region.
If the function fails, the return value is zero.
When you no longer need the HRGN object call the function to delete it.
The device context identified by the parameter must contain a closed path.
After converts a path into a region, the system discards the closed path from the specified device context.
The function retrieves the typeface name of the font that is selected into the specified device context.
A handle to the device context.
The length of the buffer pointed to by . For the ANSI function it is a BYTE count and for the Unicode function it
is a WORD count. Note that for the ANSI function, characters in SBCS code pages take one byte each, while most characters in DBCS code pages take
two bytes; for the Unicode function, most currently defined Unicode characters (those in the Basic Multilingual Plane (BMP)) are one WORD while
Unicode surrogates are two WORDs.
A pointer to the buffer that receives the typeface name. If this parameter is NULL, the function returns the number of characters in the name,
including the terminating null character.
If the function succeeds, the return value is the number of characters copied to the buffer.
If the function fails, the return value is zero.
The typeface name is copied as a null-terminated character string.
If the name is longer than the number of characters specified by the parameter, the name is truncated.
The function retrieves the current text color for the specified device context.
Handle to the device context.
If the function succeeds, the return value is the current text color as a value.
If the function fails, the return value is CLR_INVALID. No extended error information is available.
The text color defines the foreground color of characters drawn by using the or function.
The function retrieves the text-alignment setting for the specified device context.
A handle to the device context.
If the function succeeds, the return value is the status of the text-alignment flags. For more information about the return value, see the
Remarks section. The return value is a combination of the following values.
The bounding rectangle is a rectangle bounding all of the character cells in a string of text. Its dimensions can be obtained by calling the
function.
The text-alignment flags determine how the and functions align a string of text in relation
to the string's reference point provided to or .
The text-alignment flags are not necessarily single bit flags and may be equal to zero. The flags must be examined in groups of related
flags, as shown in the following list.
The function copies the system clipping region of a specified device context to a specific region.
A handle to the device context.
A handle to a region. Before the function is called, this identifies an existing region. After the function returns, this identifies a copy of
the current system region. The old region identified by is overwritten.
This parameter must be SYSRGN.
If the function succeeds, the return value is 1. If the function fails, the return value is -1. If the region to be retrieved is NULL, the return
value is 0. If the function fails or the region to be retrieved is NULL, is not initialized.
When using the SYSRGN flag, note that the system clipping region might not be current because of window movements. Nonetheless, it is safe to
retrieve and use the system clipping region within the - block during
processing. In this case, the system region is the intersection of the update region and the current visible area of the window. Any window
movement following the return of and before will result in a new
message. Any other use of the SYSRGN flag may result in painting errors in your application.
The region returned is in screen coordinates.
The function fills an area of the display surface with the current brush.
A handle to a device context.
The x-coordinate, in logical units, of the point where filling is to start.
The y-coordinate, in logical units, of the point where filling is to start.
The color of the boundary or of the area to be filled. The interpretation of depends on the value of the
parameter. To create a color value, use the RGB macro.
The type of fill operation to be performed. This parameter must be one of the following values.
-
FLOODFILLBORDER
The fill area is bounded by the color specified by the parameter. This style is identical to the filling
performed by the function.
-
FLOODFILLSURFACE
The fill area is defined by the color that is specified by . Filling continues outward in all directions
as long as the color is encountered. This style is useful for filling areas with multicolored boundaries.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The following are some of the reasons this function might fail:
The function creates a logical cosmetic or geometric pen that has the specified style, width, and brush attributes.
A combination of type, style, end cap, and join attributes. The values from each category are combined by using the bitwise OR operator ( |
).
The pen type can be one of the following values.
-
PS_GEOMETRIC
The pen is geometric.
-
PS_COSMETIC
The pen is cosmetic.
The pen style can be one of the following values.
-
PS_ALTERNATE
The pen sets every other pixel. (This style is applicable only for cosmetic pens.)
-
PS_SOLID
The pen is solid.
-
PS_DASH
The pen is dashed.
-
PS_DOT
The pen is dotted.
-
PS_DASHDOT
The pen has alternating dashes and dots.
-
PS_DASHDOTDOT
The pen has alternating dashes and double dots.
-
PS_NULL
The pen is invisible.
-
PS_USERSTYLE
The pen uses a styling array supplied by the user.
-
PS_INSIDEFRAME
The pen is solid. When this pen is used in any GDI drawing function that takes a bounding rectangle, the dimensions of the figure are
shrunk so that it fits entirely in the bounding rectangle, taking into account the width of the pen. This applies only to geometric
pens.
The end cap is only specified for geometric pens. The end cap can be one of the following values.
-
PS_ENDCAP_ROUND
End caps are round.
-
PS_ENDCAP_SQUARE
End caps are square.
-
PS_ENDCAP_FLAT
End caps are flat.
The join is only specified for geometric pens. The join can be one of the following values.
-
PS_JOIN_BEVEL
Joins are beveled.
-
PS_JOIN_MITER
Joins are mitered when they are within the current limit set by the function. If it exceeds this limit,
the join is beveled.
-
PS_JOIN_ROUND
Joins are round.
The width of the pen. If the parameter is PS_GEOMETRIC, the width is given in logical units. If
is PS_COSMETIC, the width must be set to 1.
A pointer to a structure. If is PS_COSMETIC, the member
specifies the color of the pen and the member must be set to BS_SOLID. If is PS_GEOMETRIC,
all members must be used to specify the brush attributes of the pen.
The length, in DWORD units, of the array. This value must be zero if
is not PS_USERSTYLE.
The style count is limited to 16.
A pointer to an array. The first value specifies the length of the first dash in a user-defined style, the second value specifies the length
of the first space, and so on. This pointer must be NULL if is not PS_USERSTYLE.
If the array is exceeded during line drawing, the pointer is reset to the beginning of the array. When this
happens and is an even number, the pattern of dashes and spaces repeats. However, if
is odd, the pattern reverses when the pointer is reset -- the first element of
now refers to spaces, the second refers to dashes, and so forth.
If the function succeeds, the return value is a handle that identifies a logical pen.
If the function fails, the return value is zero.
A geometric pen can have any width and can have any of the attributes of a brush, such as dithers and patterns. A cosmetic pen can only be a
single pixel wide and must be a solid color, but cosmetic pens are generally faster than geometric pens.
The width of a geometric pen is always specified in world units. The width of a cosmetic pen is always 1.
End caps and joins are only specified for geometric pens.
After an application creates a logical pen, it can select that pen into a device context by calling the function.
After a pen is selected into a device context, it can be used to draw lines and curves.
If is PS_COSMETIC and PS_USERSTYLE, the entries in the array specify lengths of
dashes and spaces in style units. A style unit is defined by the device where the pen is used to draw a line.
If is PS_GEOMETRIC and PS_USERSTYLE, the entries in the array specify lengths of
dashes and spaces in logical units.
If is PS_ALTERNATE, the style unit is ignored and every other pixel is set.
If the member of the structure pointed to by is BS_PATTERN,
the bitmap pointed to by the member of that structure cannot be a DIB section. A DIB section is a bitmap
created by
. If that bitmap is a DIB section, the function fails.
When an application no longer requires a specified pen, it should call the function to delete the pen.
ICM: No color management is done at pen creation. However, color management is performed when the pen is selected into an ICM-enabled device
context.
The function enumerates the records within a Windows-format metafile by retrieving each record and passing it to
the specified callback function. The application-supplied callback function processes each record as required. The enumeration continues
until the last record is processed or when the callback function returns zero.
Note: This function is provided only for compatibility with Windows-format metafiles. Enhanced-format metafiles provide superior
functionality and are recommended for new applications. The corresponding function for an enhanced-format metafile is
.
Handle to a device context. This handle is passed to the callback function.
Handle to a Windows-format metafile.
Pointer to an application-supplied callback function. For more information, see .
Pointer to optional data.
If the callback function successfully enumerates all the records in the Windows-format metafile, the return value is nonzero.
If the callback function does not successfully enumerate all the records in the Windows-format metafile, the return value is zero.
To convert a Windows-format metafile into an enhanced-format metafile, use the function.
You can use the function to embed one Windows-format metafile within another.
The function deletes a logical pen, brush, font, bitmap, region, or palette, freeing all system resources associated
with the object. After the object is deleted, the specified handle is no longer valid.
A handle to a logical pen, brush, font, bitmap, region, or palette.
If the function succeeds, the return value is nonzero.
If the specified handle is not valid or is currently selected into a DC, the return value is zero.
Do not delete a drawing object (pen or brush) while it is still selected into a DC.
When a pattern brush is deleted, the bitmap associated with the brush is not deleted. The bitmap must be deleted independently.
The function creates a bitmap with the specified width, height, and color format (color planes and bits-per-pixel).
The bitmap width, in pixels.
The bitmap height, in pixels.
The number of color planes used by the device.
The number of bits required to identify the color of a single pixel.
A pointer to an array of color data used to set the colors in a rectangle of pixels. Each scan line in the rectangle must be word aligned (scan
lines that are not word aligned must be padded with zeros). If this parameter is NULL, the contents of the new bitmap is undefined.
If the function succeeds, the return value is a handle to a bitmap.
If the function fails, the return value is NULL.
This function can return the following value.
The function creates a device-dependent bitmap.
After a bitmap is created, it can be selected into a device context by calling the function. However, the bitmap
can only be selected into a device context if the bitmap and the DC have the same format.
The function can be used to create color bitmaps. However, for performance reasons applications should use
to create monochrome bitmaps and to create color bitmaps. Whenever a color
bitmap returned from is selected into a device context, the system checks that the bitmap matches the format of
the device context it is being selected into. Because takes a device context, it returns a bitmap that
has the same format as the specified device context. Thus, subsequent calls to are faster with a color bitmap
from than with a color bitmap returned from .
If the bitmap is monochrome, zeros represent the foreground color and ones represent the background color for the destination device
context.
If an application sets the or parameters to zero, returns
the handle to a 1-by-1 pixel, monochrome bitmap.
When you no longer need the bitmap, call the function to delete it.
Applies to: desktop apps only
The function exchanges the front and back buffers if the current pixel format for the window referenced by the
specified device context includes a back buffer.
Specifies a device context. If the current pixel format for the window referenced by this device context includes a back buffer, the function
exchanges the front and back buffers.
If the function succeeds, the return value is TRUE.
If the function fails, the return value is FALSE. To get extended error information, call GetLastError.
If the current pixel format for the window referenced by the device context does not include a back buffer, this call has no effect and the
content of the back buffer is undefined when the function returns.
With multithread applications, flush the drawing commands in any other threads drawing to the same window before calling
.
The function determines whether any part of the specified rectangle lies within the clipping region of a device
context.
A handle to the device context.
A pointer to a structure that contains the logical coordinates of the specified rectangle.
If the current transform does not have a rotation and the rectangle lies within the clipping region, the return value is TRUE (1).
If the current transform does not have a rotation and the rectangle does not lie within the clipping region, the return value is FALSE (0).
If the current transform has a rotation and the rectangle lies within the clipping region, the return value is 2.
If the current transform has a rotation and the rectangle does not lie within the clipping region, the return value is 1.
All other return values are considered error codes. If the any parameter is not valid, the return value is undefined.
The function draws a series of closed polygons. Each polygon is outlined by using the current pen and filled by using
the current brush and polygon fill mode. The polygons drawn by this function can overlap.
A handle to the device context.
A pointer to an array of structures that define the vertices of the polygons, in logical coordinates. The polygons are
specified consecutively. Each polygon is closed automatically by drawing a line from the last vertex to the first. Each vertex should be
specified once.
A pointer to an array of integers, each of which specifies the number of points in the corresponding polygon. Each integer must be greater than
or equal to 2.
The total number of polygons.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The current position is neither used nor updated by this function.
Any extra points are ignored. To draw the polygons with more points, divide your data into groups, each of which have less than the maximum
number of points, and call the function for each group of points. Note, it is best to have a polygon in only one of the groups.
The function retrieves font metric data for a TrueType font.
A handle to the device context.
The name of a font metric table from which the font data is to be retrieved. This parameter can identify one of the metric tables documented in
the TrueType Font Files specification published by Microsoft Corporation. If this parameter is zero, the information is retrieved starting at the
beginning of the file for TrueType font files or from the beginning of the data for the currently selected font for TrueType Collection files. To
retrieve the data from the beginning of the file for TrueType Collection files specify 'ttcf' (0x66637474).
The offset from the beginning of the font metric table to the location where the function should begin retrieving information. If this parameter
is zero, the information is retrieved starting at the beginning of the table specified by the parameter. If this
value is greater than or equal to the size of the table, an error occurs.
A pointer to a buffer that receives the font information. If this parameter is NULL, the function returns the size of the buffer required for the
font data.
The length, in bytes, of the information to be retrieved. If this parameter is zero, returns the size of the data
specified in the parameter.
If the function succeeds, the return value is the number of bytes returned.
If the function fails, the return value is GDI_ERROR.
This function is intended to be used to retrieve TrueType font information directly from the font file by font-manipulation applications. For
information about embedding fonts see the Font Embedding Reference.
An application can sometimes use the function to save a TrueType font with a document. To do this, the application
determines whether the font can be embedded by checking the member of the
structure. If bit 1 of is set, embedding is not permitted for the font. If bit 1 is clear, the
font can be embedded. If bit 2 is set, the embedding is read-only. If embedding is permitted, the application can retrieve the entire font
file, specifying zero for the , , and parameters.
If an application attempts to use this function to retrieve information for a non-TrueType font, an error occurs.
The function transforms any curves in the path that is selected into the current device context (DC), turning each
curve into a sequence of lines.
A handle to a DC that contains a valid path.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function draws text using the currently selected font, background color, and text color. You can optionally provide
dimensions to be used for clipping, opaquing, or both.
A handle to the device context.
The x-coordinate, in logical coordinates, of the reference point used to position the string.
The y-coordinate, in logical coordinates, of the reference point used to position the string.
Specifies how to use the application-defined rectangle. This parameter can be one or more of the following values.
-
ETO_CLIPPED
The text will be clipped to the rectangle.
-
ETO_GLYPH_INDEX
The array refers to an array returned from and should be parsed
directly by GDI as no further language-specific processing is required. Glyph indexing only applies to TrueType fonts, but the
flag can be used for bitmap and vector fonts to indicate that no further language processing is necessary and GDI should process
the string directly. Note that all glyph indexes are 16-bit values even though the string is assumed to be an array of 8-bit
values for raster fonts.
For ExtTextOutW, the glyph indexes are saved to a metafile. However, to display the correct characters the metafile must be
played back using the same font. For ExtTextOutA, the glyph indexes are not saved.
-
ETO_IGNORELANGUAGE
Reserved for system use. If an application sets this flag, it loses international scripting support and in some cases it may
display no text at all.
-
ETO_NUMERICSLATIN
To display numbers, use European digits.
-
ETO_NUMERICSLOCAL
To display numbers, use digits appropriate to the locale.
-
ETO_OPAQUE
The current background color should be used to fill the rectangle.
-
ETO_PDY
When this is set, the array pointed to by contains pairs of values. The first value of each pair is, as
usual, the distance between origins of adjacent character cells, but the second value is the displacement along the vertical
direction of the font.
-
ETO_RTLREADING
Middle East language edition of Windows: If this value is specified and a Hebrew or Arabic font is selected into the device context,
the string is output using right-to-left reading order. If this value is not specified, the string is output in left-to-right order.
The same effect can be achieved by setting the TA_RTLREADING value in . This value is preserved for
backward compatibility.
The ETO_GLYPH_INDEX and ETO_RTLREADING values cannot be used together. Because ETO_GLYPH_INDEX implies that all language processing has been
completed, the function ignores the ETO_RTLREADING flag if also specified.
A pointer to an optional structure that specifies the dimensions, in logical coordinates, of a rectangle that is used for
clipping, opaquing, or both.
A pointer to a string that specifies the text to be drawn. The string does not need to be zero-terminated, since
specifies the length of the string.
The length of the string pointed to by .
This value may not exceed 8192.
A pointer to an optional array of values that indicate the distance between origins of adjacent character cells. For example, lpDx[i] logical
units separate the origins of character cell i and character cell i + 1.
If the string is drawn, the return value is nonzero. However, if the ANSI version of is called with
ETO_GLYPH_INDEX, the function returns TRUE even though the function does nothing.
If the function fails, the return value is zero.
The current text-alignment settings for the specified device context determine how the reference point is used to position the text. The
text-alignment settings are retrieved by calling the function. The text-alignment settings are altered by calling
the function. You can use the following values for text alignment. Only one flag can be chosen from those that
affect horizontal and vertical alignment. In addition, only one of the two flags that alter the current position can be chosen.
The function enumerates the pens or brushes available for the specified device context (DC). This function calls the
application-defined callback function once for each available object, supplying data describing that object. continues
calling the callback function until the callback function returns zero or until all of the objects have been enumerated.
A handle to the DC.
The object type. This parameter can be OBJ_BRUSH or OBJ_PEN.
A pointer to the application-defined callback function. For more information about the callback function, see the
function.
A pointer to the application-defined data. The data is passed to the callback function along with the object information.
If the function succeeds, the return value is the last value returned by the callback function. Its meaning is user-defined.
If the objects cannot be enumerated (for example, there are too many objects), the function returns zero without calling the callback
function.
The function creates a logical font with the specified characteristics. The logical font can subsequently be selected
as the font for any device.
The height, in logical units, of the font's character cell or character. The character height value (also known as the em height) is the
character cell height value minus the internal-leading value. The font mapper interprets the value specified in
in the following manner.
-
> 0
The font mapper transforms this value into device units and matches it against the cell height of the available fonts.
-
0
The font mapper uses a default height value when it searches for a match.
-
< 0
The font mapper transforms this value into device units and matches its absolute value against the character height of the
available fonts.
For all height comparisons, the font mapper looks for the largest font that does not exceed the requested size.
This mapping occurs when the font is used for the first time.
For the MM_TEXT mapping mode, you can use the following formula to specify a height for a font with a specified point size:
The average width, in logical units, of characters in the requested font. If this value is zero, the font mapper chooses a closest match value.
The closest match value is determined by comparing the absolute values of the difference between the current device's aspect ratio and the
digitized aspect ratio of available fonts.
The angle, in tenths of degrees, between the escapement vector and the x-axis of the device. The escapement vector is parallel to the base
line of a row of text.
When the graphics mode is set to GM_ADVANCED, you can specify the escapement angle of the string independently of the orientation angle of
the string's characters.
When the graphics mode is set to GM_COMPATIBLE, specifies both the escapement and orientation. You should set
and to the same value.
The angle, in tenths of degrees, between each character's base line and the x-axis of the device.
The weight of the font in the range 0 through 1000. For example, 400 is normal and 700 is bold. If this value is zero, a default weight is
used.
The following values are defined for convenience.
-
FW_DONTCARE
0
-
FW_THIN
100
-
FW_EXTRALIGHT
200
-
FW_ULTRALIGHT
200
-
FW_LIGHT
300
-
FW_NORMAL
400
-
FW_REGULAR
400
-
FW_MEDIUM
500
-
FW_SEMIBOLD
600
-
FW_DEMIBOLD
600
-
FW_BOLD
700
-
FW_EXTRABOLD
800
-
FW_ULTRABOLD
800
-
FW_HEAVY
900
-
FW_BLACK
900
Specifies an italic font if set to TRUE.
Specifies an underlined font if set to TRUE.
A strikeout font if set to TRUE.
The character set. The following values are predefined:
Korean language edition of Windows:
Middle East language edition of Windows:
Thai language edition of Windows:
The OEM_CHARSET value specifies a character set that is operating-system dependent.
DEFAULT_CHARSET is set to a value based on the current system locale. For example, when the system locale is English (United States), it is
set as ANSI_CHARSET.
Fonts with other character sets may exist in the operating system. If an application uses a font with an unknown character set, it should not
attempt to translate or interpret strings that are rendered with that font.
To ensure consistent results when creating a font, do not specify OEM_CHARSET or DEFAULT_CHARSET. If you specify a typeface name in the
parameter, make sure that the value matches the character set of the typeface
specified in .
The output precision. The output precision defines how closely the output must match the requested font's height, width, character
orientation, escapement, pitch, and font type. It can be one of the following values.
-
OUT_CHARACTER_PRECIS
Not used.
-
OUT_DEFAULT_PRECIS
The default font mapper behavior.
-
OUT_DEVICE_PRECIS
Instructs the font mapper to choose a Device font when the system contains multiple fonts with the same name.
-
OUT_OUTLINE_PRECIS
This value instructs the font mapper to choose from TrueType and other outline-based fonts.
-
OUT_PS_ONLY_PRECIS
Instructs the font mapper to choose from only PostScript fonts. If there are no PostScript fonts installed in the system, the font
mapper returns to default behavior.
-
OUT_RASTER_PRECIS
Instructs the font mapper to choose a raster font when the system contains multiple fonts with the same name.
-
OUT_STRING_PRECIS
This value is not used by the font mapper, but it is returned when raster fonts are enumerated.
-
OUT_STROKE_PRECIS
This value is not used by the font mapper, but it is returned when TrueType, other outline-based fonts, and vector fonts are
enumerated.
-
OUT_TT_ONLY_PRECIS
Instructs the font mapper to choose from only TrueType fonts. If there are no TrueType fonts installed in the system, the font mapper
returns to default behavior.
-
OUT_TT_PRECIS
Instructs the font mapper to choose a TrueType font when the system contains multiple fonts with the same name.
Applications can use the OUT_DEVICE_PRECIS, OUT_RASTER_PRECIS, OUT_TT_PRECIS, and OUT_PS_ONLY_PRECIS values to control how the font mapper
chooses a font when the operating system contains more than one font with a specified name. For example, if an operating system contains a
font named Symbol in raster and TrueType form, specifying OUT_TT_PRECIS forces the font mapper to choose the TrueType version. Specifying
OUT_TT_ONLY_PRECIS forces the font mapper to choose a TrueType font, even if it must substitute a TrueType font of another name.
The clipping precision. The clipping precision defines how to clip characters that are partially outside the clipping region. It can be one
or more of the following values.
-
CLIP_CHARACTER_PRECIS
Not used.
-
CLIP_DEFAULT_PRECIS
Specifies default clipping behavior.
-
CLIP_DFA_DISABLE
Windows XP SP1: Turns off font association for the font. Note that this flag is not guaranteed to have any effect on any platform
after Windows Server 2003.
-
CLIP_EMBEDDED
You must specify this flag to use an embedded read-only font.
-
CLIP_LH_ANGLES
When this value is used, the rotation for all fonts depends on whether the orientation of the coordinate system is left-handed
or right-handed.
If not used, device fonts always rotate counterclockwise, but the rotation of other fonts is dependent on the orientation of
the coordinate system.
For more information about the orientation of coordinate systems, see the description of the
parameter
-
CLIP_MASK
Not used.
-
CLIP_DFA_OVERRIDE
Turns off font association for the font. This is identical to CLIP_DFA_DISABLE, but it can have problems in some situations; the
recommended flag to use is CLIP_DFA_DISABLE.
-
CLIP_STROKE_PRECIS
Not used by the font mapper, but is returned when raster, vector, or TrueType fonts are enumerated.
For compatibility, this value is always returned when enumerating fonts.
-
CLIP_TT_ALWAYS
Not used.
The output quality. The output quality defines how carefully GDI must attempt to match the logical-font attributes to those of an actual
physical font. It can be one of the following values.
-
ANTIALIASED_QUALITY
Font is antialiased, or smoothed, if the font supports it and the size of the font is not too small or too large.
-
CLEARTYPE_QUALITY
If set, text is rendered (when possible) using ClearType antialiasing method. See Remarks for more information.
-
DEFAULT_QUALITY
Appearance of the font does not matter.
-
DRAFT_QUALITY
Appearance of the font is less important than when the PROOF_QUALITY value is used. For GDI raster fonts, scaling is enabled, which
means that more font sizes are available, but the quality may be lower. Bold, italic, underline, and strikeout fonts are synthesized,
if necessary.
-
NONANTIALIASED_QUALITY
Font is never antialiased, that is, font smoothing is not done.
-
PROOF_QUALITY
Character quality of the font is more important than exact matching of the logical-font attributes. For GDI raster fonts, scaling is
disabled and the font closest in size is chosen. Although the chosen font size may not be mapped exactly when PROOF_QUALITY is used,
the quality of the font is high and there is no distortion of appearance. Bold, italic, underline, and strikeout fonts are
synthesized, if necessary.
If the output quality is DEFAULT_QUALITY, DRAFT_QUALITY, or PROOF_QUALITY, then the font is antialiased if the SPI_GETFONTSMOOTHING system
parameter is TRUE. Users can control this system parameter from the Control Panel. (The precise wording of the setting in the Control panel
depends on the version of Windows, but it will be words to the effect of "Smooth edges of screen fonts".)
The pitch and family of the font. The two low-order bits specify the pitch of the font and can be one of the following values:
The four high-order bits specify the font family and can be one of the following values.
-
FF_DECORATIVE
Novelty fonts. Old English is an example.
-
FF_DONTCARE
Use default font.
-
FF_MODERN
Fonts with constant stroke width, with or without serifs. Pica, Elite, and Courier New are examples.
-
FF_ROMAN
Fonts with variable stroke width and with serifs. MS Serif is an example.
-
FF_SCRIPT
Fonts designed to look like handwriting. Script and Cursive are examples.
-
FF_SWISS
Fonts with variable stroke width and without serifs. MS?Sans Serif is an example.
An application can specify a value for the parameter by using the Boolean OR operator to join a pitch
constant with a family constant.
Font families describe the look of a font in a general way. They are intended for specifying fonts when the exact typeface requested is not
available.
A pointer to a null-terminated string that specifies the typeface name of the font. The length of this string must not exceed 32 characters,
including the terminating null character. The function can be used to enumerate the typeface names of all
currently available fonts. For more information, see the Remarks.
If is NULL or empty string, GDI uses the first font that matches the other specified attributes.
If the function succeeds, the return value is a handle to a logical font.
If the function fails, the return value is NULL.
When you no longer need the font, call the function to delete it.
To help protect the copyrights of vendors who provide fonts for Windows, applications should always report the exact name of a selected font.
Because available fonts can vary from system to system, do not assume that the selected font is always the same as the requested font. For
example, if you request a font named Palatino, but no such font is available on the system, the font mapper will substitute a font that has
similar attributes but a different name. Always report the name of the selected font to the user.
To get the appropriate font on different language versions of the OS, call with the desired font
characteristics in the structure, then retrieve the appropriate typeface name and create the font using
or .
The font mapper for ,, and recognizes both the
English and the localized typeface name, regardless of locale.
The following situations do not support ClearType antialiasing:
The function closes an open figure in a path.
Handle to the device context in which the figure will be closed.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function closes the figure by drawing a line from the current position to the first point of the figure
(usually, the point specified by the most recent call to the function) and then connects the lines by using the line
join style. If a figure is closed by using the function instead of , end caps are used to
create the corner instead of a join.
The function should only be called if there is an open path bracket in the specified device context.
A figure in a path is open unless it is explicitly closed by using this function. (A figure can be open even if the current point and the
starting point of the figure are the same.)
After a call to , adding a line or curve to the path starts a new figure.
The function renders the specified path by using the current pen.
Handle to a device context that contains the completed path.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The path, if it is to be drawn by , must have been completed through a call to . Calling this
function on a path for which has not been called will cause this function to fail and return zero. Unlike other path
drawing functions such as , will not attempt to close the path by drawing a straight
line from the first point on the path to the last point on the path.
The function copies a bitmap from a source rectangle into a destination rectangle, stretching or compressing the bitmap
to fit the dimensions of the destination rectangle, if necessary. The system stretches or compresses the bitmap according to the stretching mode
currently set in the destination device context.
A handle to the destination device context.
The x-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The y-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The width, in logical units, of the destination rectangle.
The height, in logical units, of the destination rectangle.
A handle to the source device context.
The x-coordinate, in logical units, of the upper-left corner of the source rectangle.
The y-coordinate, in logical units, of the upper-left corner of the source rectangle.
The width, in logical units, of the source rectangle.
The height, in logical units, of the source rectangle.
The raster operation to be performed. Raster operation codes define how the system combines colors in output operations that involve a brush,
a source bitmap, and a destination bitmap.
See for a list of common raster operation codes (ROPs). Note that the CAPTUREBLT ROP generally cannot be used for
printing device contexts.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
stretches or compresses the source bitmap in memory and then copies the result to the destination rectangle. This
bitmap can be either a compatible bitmap (DDB) or the output from . The color data for pattern or destination
pixels is merged after the stretching or compression occurs.
When an enhanced metafile is being recorded, an error occurs (and the function returns FALSE) if the source device context identifies an
enhanced-metafile device context.
If the specified raster operation requires a brush, the system uses the brush currently selected into the destination device context.
The destination coordinates are transformed by using the transformation currently specified for the destination device context; the source
coordinates are transformed by using the transformation currently specified for the source device context.
If the source transformation has a rotation or shear, an error occurs.
If destination, source, and pattern bitmaps do not have the same color format, converts the source and pattern
bitmaps to match the destination bitmap.
If must convert a monochrome bitmap to a color bitmap, it sets white bits (1) to the background color and black
bits (0) to the foreground color. To convert a color bitmap to a monochrome bitmap, it sets pixels that match the background color to white
(1) and sets all other pixels to black (0). The foreground and background colors of the device context with color are used.
creates a mirror image of a bitmap if the signs of the and
parameters or if the and parameters differ. If
and have different signs, the function creates a mirror image of the bitmap
along the x-axis. If and have different signs, the function creates a mirror
image of the bitmap along the y-axis.
Not all devices support the function. For more information, see the .
ICM: No color management is performed when a blit operation occurs.
When used in a multiple monitor system, both and must refer to the same device or the
function will fail. To transfer data between DCs for different devices, convert the memory bitmap to a DIB by calling
. To display the DIB to the second device, call or .
The function converts a region into a rectangular region with the specified coordinates.
Handle to the region.
Specifies the x-coordinate of the upper-left corner of the rectangular region in logical units.
Specifies the y-coordinate of the upper-left corner of the rectangular region in logical units.
Specifies the x-coordinate of the lower-right corner of the rectangular region in logical units.
Specifies the y-coordinate of the lower-right corner of the rectangular region in logical units.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The region does not include the lower and right boundaries of the rectangle.
The function intersects the current clipping region for the specified device context with the current metaregion and
saves the combined region as the new metaregion for the specified device context. The clipping region is reset to a null region.
A handle to the device context.
The return value specifies the new clipping region's complexity and can be one of the following values.
The current clipping region of a device context is defined by the intersection of its clipping region and its metaregion.
The function should only be called after an application's original device context was saved by calling the
function.
The function sets the mapping mode of the specified device context. The mapping mode defines the unit of measure used
to transform page-space units into device-space units, and also defines the orientation of the device's x and y axes.
A handle to the device context.
The new mapping mode. This parameter can be one of the following values.
-
MM_ANISOTROPIC
Logical units are mapped to arbitrary units with arbitrarily scaled axes. Use the and
functions to specify the units, orientation, and scaling.
-
MM_HIENGLISH
Each logical unit is mapped to 0.001 inch. Positive x is to the right; positive y is up.
-
MM_HIMETRIC
Each logical unit is mapped to 0.01 millimeter. Positive x is to the right; positive y is up.
-
MM_ISOTROPIC
Logical units are mapped to arbitrary units with equally scaled axes; that is, one unit along the x-axis is equal to one unit along
the y-axis. Use the and functions to specify the units and the
orientation of the axes. Graphics device interface (GDI) makes adjustments as necessary to ensure the x and y units remain the same
size (When the window extent is set, the viewport will be adjusted to keep the units isotropic).
-
MM_LOENGLISH
Each logical unit is mapped to 0.01 inch. Positive x is to the right; positive y is up.
-
MM_LOMETRIC
Each logical unit is mapped to 0.1 millimeter. Positive x is to the right; positive y is up.
-
MM_TEXT
Each logical unit is mapped to one device pixel. Positive x is to the right; positive y is down.
-
MM_TWIPS
Each logical unit is mapped to one twentieth of a printer's point (1/1440 inch, also called a twip). Positive x is to the
right; positive y is up.
If the function succeeds, the return value identifies the previous mapping mode.
If the function fails, the return value is zero.
The MM_TEXT mode allows applications to work in device pixels, whose size varies from device to device.
The MM_HIENGLISH, MM_HIMETRIC, MM_LOENGLISH, MM_LOMETRIC, and MM_TWIPS modes are useful for applications drawing in physically meaningful
units (such as inches or millimeters).
The MM_ISOTROPIC mode ensures a 1:1 aspect ratio.
The MM_ANISOTROPIC mode allows the x-coordinates and y-coordinates to be adjusted independently.
The function causes Image Color Management to be enabled, disabled, or queried on a given device context (DC).
Identifies handle to the device context.
Turns on and off image color management. This parameter can take one of the following constant values.
-
ICM_ON
Turns on color management. Turns off old-style color correction of halftones.
-
ICM_OFF
Turns off color management. Turns on old-style color correction of halftones.
-
ICM_QUERY
Queries the current state of color management.
-
ICM_DONE_OUTSIDEDC
Turns off color management inside DC. Under Windows 2000, also turns off old-style color correction of halftones. Not
supported under Windows 95.
If the system cannot find an ICC color profile to match the state of the device, fails and returns zero.
Once WCS is enabled for a device context (DC), colors passed into the DC using most Win32 API functions are color matched. The primary
exceptions are and . The assumption is that when performing a bit block transfer (blit) from
one DC to another, the two DCs are already compatible and need no color correction. If this is not the case, color correction may be
performed. Specifically, if a device independent bitmap (DIB) is used as the source for a blit, and the blit is performed into a DC that has
WCS enabled, color matching will be performed. If this is not what you want, turn WCS off for the destination DC by calling
before calling or .
If the function is used to create a bitmap in a DC, it is possible for the bitmap to be color matched
twice, once when it is created and once when a blit is performed. The reason is that a bitmap in a DC created by the
function acquires the current brush, pens, and palette of the source DC. However, WCS will be disabled by
default for the new DC. If WCS is later enabled for the new DC by using the function, a color correction will be
done. To prevent double color corrections through the use of the function, use the
function to turn WCS off for the source DC before the function is called.
When a compatible DC is created from a printer's DC (see ), the default is for color matching to always be
performed if it is enabled for the printer's DC. The default color profile for the printer is used when a blit is performed into the
printer's DC using or . If this is not what you want, turn WCS off for the
printer's DC by calling before calling or .
Also, when printing to a printer's DC with WCS turned on, the function needs to be called after every call to the
function to turn back on WCS. The function calls the and
functions, which result in WCS being turned off for the printer's DC.
The function sets the current background color to the specified color value, or to the nearest physical color if the
device cannot represent the specified color value.
A handle to the device context.
The new background color. To make a value, use the RGB macro.
If the function succeeds, the return value specifies the previous background color as a value.
If the function fails, the return value is CLR_INVALID.
This function fills the gaps between styled lines drawn using a pen created by the function; it does not fill the
gaps between styled lines drawn using a pen created by the function. The function also
sets the background colors for and .
If the background mode is OPAQUE, the background color is used to fill gaps between styled lines, gaps between hatched lines in brushes, and
character cells. The background color is also used when converting bitmaps from color to monochrome and vice versa.
The function determines whether the specified point is inside the specified region.
Handle to the region to be examined.
Specifies the x-coordinate of the point in logical units.
Specifies the y-coordinate of the point in logical units.
If the specified point is in the region, the return value is nonzero.
If the specified point is not in the region, the return value is zero.
The function draws one or more straight lines.
A handle to the device context.
A pointer to an array of structures that contains the vertices of the line, in logical units.
The number of points in the array.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
Unlike the function, the function uses and updates the current position.
A line is drawn from the current position to the first point specified by the parameter by using the current pen.
For each additional line, the function draws from the ending point of the previous line to the next point specified by
.
moves the current position to the ending point of the last line.
If the line segments drawn by this function form a closed figure, the figure is not filled.
The function draws one or more BĂ©zier curves.
A handle to a device context.
A pointer to an array of structures that contain the endpoints and control points of the curve(s), in logical units.
The number of points in the array. This value must be one more than three times the number of curves to be drawn,
because each BĂ©zier curve requires two control points and an endpoint, and the initial curve requires an additional starting point.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function draws cubic BĂ©zier curves by using the endpoints and control points specified by the
parameter. The first curve is drawn from the first point to the fourth point by using the second and third points as
control points. Each subsequent curve in the sequence needs exactly three more points: the ending point of the previous curve is used as the
starting point, the next two points in the sequence are control points, and the third is the ending point.
The current position is neither used nor updated by the function. The figure is not filled.
This function draws lines by using the current pen.
The function retrieves information for the specified graphics object.
A handle to the graphics object of interest. This can be a handle to one of the following: a logical bitmap, a brush, a font, a palette, a pen,
or a device independent bitmap created by calling the function.
The number of bytes of information to be written to the buffer.
A pointer to a buffer that receives the information about the specified graphics object.
The following table shows the type of information the buffer receives for each type of graphics object you can specify with
.
-
HBITMAP
-
HBITMAP returned from a call to CreateDIBSection
DIBSECTION, if is set to sizeof (DIBSECTION), or , if
is set to sizeof (BITMAP).
-
HPALETTE
A WORD count of the number of entries in the logical palette
-
HPEN returned from a call to ExtCreatePen
-
HPEN
-
HBRUSH
-
HFONT
If the parameter is NULL, the function return value is the number of bytes required to store the information it
writes to the buffer for the specified graphics object.
If the function succeeds, and is a valid pointer, the return value is the number of bytes stored into the
buffer.
If the function succeeds, and is NULL, the return value is the number of bytes required to hold the information
the function would store into the buffer.
If the function fails, the return value is zero.
The buffer pointed to by the parameter must be sufficiently large to receive the information about the graphics
object. Depending on the graphics object, the function uses a , DIBSECTION, ,
, , or structure, or a count of table entries (for a logical palette).
If is a handle to a bitmap created by calling , and the specified buffer is large
enough, the function returns a DIBSECTION structure. In addition, the member of the
structure contained within the DIBSECTION will contain a pointer to the bitmap's bit values.
If is a handle to a bitmap created by any other means, returns only the width, height,
and color format information of the bitmap. You can obtain the bitmap's bit values by calling the or
function.
If is a handle to a logical palette, retrieves a 2-byte integer that specifies the
number of entries in the palette. The function does not retrieve the structure defining the palette. To retrieve
information about palette entries, an application can call the function.
If is a handle to a font, the that is returned is the used to
create the font. If Windows had to make some interpolation of the font because the precise could not be represented,
the interpolation will not be reflected in the . For example, if you ask for a vertical version of a font that doesn't
support vertical painting, the indicates the font is vertical, but Windows will paint it horizontally.
The function retrieves the current metaregion for the specified device context.
A handle to the device context.
A handle to an existing region before the function is called. After the function returns, this parameter is a handle to a copy of the current
metaregion.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
If the function succeeds, is a handle to a copy of the current metaregion. Subsequent changes to this copy will not
affect the current metaregion.
The current clipping region of a device context is defined by the intersection of its clipping region and its metaregion.
The function retrieves the current mapping mode.
A handle to the device context.
If the function succeeds, the return value specifies the mapping mode.
If the function fails, the return value is zero.
The following are the various mapping modes.
The function retrieves the final translation origin for a specified device context (DC). The final translation origin
specifies an offset that the system uses to translate device coordinates into client coordinates (for coordinates in an application's window).
A handle to the DC whose final translation origin is to be retrieved.
A pointer to a structure that receives the final translation origin, in device coordinates.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The final translation origin is relative to the physical origin of the screen.
The function retrieves a handle identifying the current application-defined clipping region for the specified device
context.
A handle to the device context.
A handle to an existing region before the function is called. After the function returns, this parameter is a handle to a copy of the current
clipping region.
If the function succeeds and there is no clipping region for the given device context, the return value is zero. If the function succeeds and
there is a clipping region for the given device context, the return value is 1. If an error occurs, the return value is -1.
An application-defined clipping region is a clipping region identified by the function. It is not a clipping
region created when the application calls the function.
If the function succeeds, the parameter is a handle to a copy of the current clipping region. Subsequent changes to
this copy will not affect the current clipping region.
The function retrieves the dimensions of the tightest bounding rectangle that can be drawn around the current visible
area on the device. The visible area is defined by the current clipping region or clip path, as well as any overlapping windows.
A handle to the device context.
A pointer to a structure that is to receive the rectangle dimensions, in logical units.
If the function succeeds, the return value specifies the clipping box's complexity and can be one of the following values.
The function returns the current background color for the specified device context.
Handle to the device context whose background color is to be returned.
If the function succeeds, the return value is a value for the current background color.
If the function fails, the return value is CLR_INVALID.
The function copies a comment from a buffer into a specified enhanced-format metafile.
A handle to an enhanced-metafile device context.
The length of the comment buffer, in bytes.
A pointer to the buffer that contains the comment.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
A comment can include any kind of private information, for example, the source of a picture and the date it was created. A comment should
begin with an application signature, followed by the data.
Comments should not contain application-specific or position-specific data. Position-specific data specifies the location of a record, and it
should not be included because one metafile may be embedded within another metafile.
A public comment is a comment that begins with the comment signature identifier GDICOMMENT_IDENTIFIER. The following public comments are
defined.
The function enumerates the fonts available on a specified device. For each font with the specified typeface name,
the function retrieves information about that font and passes it to the application defined callback function. This
callback function can process the font information as desired. Enumeration continues until there are no more fonts or the callback function
returns zero.
Note: This function is provided only for compatibility with 16-bit versions of Windows. Applications should use the
function.
A handle to the device context from which to enumerate the fonts.
A pointer to a null-terminated string that specifies the typeface name of the desired fonts. If is NULL,
randomly selects and enumerates one font of each available typeface.
A pointer to the application defined callback function. For more information, see .
A pointer to any application-defined data. The data is passed to the callback function along with the font information.
The return value is the last value returned by the callback function. Its meaning is defined by the application.
Use instead of . The function differs from the
function in that it retrieves the style names associated with a TrueType font. With
, you can retrieve information about font styles that cannot be enumerated using the
function.
The fonts for many East Asian languages have two typeface names: an English name and a localized name. ,
, and return the English typeface name if the system locale does not match
the language of the font.
The function provides drawing capabilities of the specified video display that are not directly available through the
graphics device interface (GDI).
A handle to the DC for the specified video display.
The escape function to be performed.
The number of bytes of data pointed to by the parameter.
A pointer to the input structure required for the specified escape.
If the function is successful, the return value is greater than zero except for the QUERYESCSUPPORT draw escape, which checks for
implementation only.
If the escape is not implemented, the return value is zero.
If an error occurred, the return value is less than zero.
When an application calls the function, the data identified by and
is passed directly to the specified display driver.
The function combines two regions and stores the result in a third region. The two regions are combined according to
the specified mode.
A handle to a new region with dimensions defined by combining two other regions. (This region must exist before is
called.)
A handle to the first of two regions to be combined.
A handle to the second of two regions to be combined.
A mode indicating how the two regions will be combined. This parameter can be one of the following values.
-
RGN_AND
Creates the intersection of the two combined regions.
-
RGN_COPY
Creates a copy of the region identified by .
-
RGN_DIFF
Combines the parts of that are not part of .
-
RGN_OR
Creates the union of two combined regions.
-
RGN_XOR
Creates the union of two combined regions except for any overlapping areas.
The return value specifies the type of the resulting region. It can be one of the following values.
The three regions need not be distinct. For example, the parameter can equal the
parameter.
The function redefines the current path as the area that would be painted if the path were stroked using the pen
currently selected into the given device context.
A handle to a device context that contains a closed path.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function is successful only if the current pen is a geometric pen created by the
function, or if the pen is created with the function and has a width, in device units, of more than one.
The device context identified by the parameter must contain a closed path.
Any BĂ©zier curves in the path are converted to sequences of straight lines approximating the widened curves. As such, no BĂ©zier curves remain
in the path after is called.
The function prepares the printer driver to accept data.
A handle to the device context for the print job.
If the function succeeds, the return value is greater than zero.
If the function fails, the return value is less than or equal to zero.
Note: This is a blocking or synchronous function and might not return immediately. How quickly this function returns depends on run-time
factors such as network status, print server configuration, and printer driver implementation—factors that are difficult to predict when
writing an application. Calling this function from a thread that manages interaction with the user interface could make the application
appear to be unresponsive.
The system disables the function between calls to the and functions.
This means that you cannot change the device mode except at page boundaries. After calling , you can call
to change the device mode, if necessary. Note that a call to resets all device context
attributes back to default values.
Neither nor resets the device context attributes. Device context attributes remain constant
across subsequent pages. You do not need to re-select objects and set up the mapping mode again before printing the next page; however, doing
so will produce the same results and reduce code differences between versions of Windows.
The function starts a print job.
A handle to the device context for the print job.
A pointer to a structure containing the name of the document file and the name of the output file.
If the function succeeds, the return value is greater than zero. This value is the print job identifier for the document.
If the function fails, the return value is less than or equal to zero.
Note: This is a blocking or synchronous function and might not return immediately. How quickly this function returns depends on run-time
factors such as network status, print server configuration, and printer driver implementation—factors that are difficult to predict when
writing an application. Calling this function from a thread that manages interaction with the user interface could make the application
appear to be unresponsive.
Applications should call the function immediately before beginning a print job. Using this function ensures that
multipage documents are not interspersed with other print jobs.
Applications can use the value returned by to retrieve or set the priority of a print job. Call the GetJob or SetJob
function and supply this value as one of the required arguments.
The function sets the pixel at the specified coordinates to the closest approximation of the specified color. The point
must be in the clipping region and the visible part of the device surface.
A handle to the device context.
The x-coordinate, in logical units, of the point to be set.
The y-coordinate, in logical units, of the point to be set.
The color to be used to paint the point. To create a color value, use the RGB macro.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
Not all devices support the function. For more information, see the description of the RC_BITBLT capability in the
function.
is faster than because it does not need to return the color value of the point actually
painted.
The function changes the layout of a device context (DC).
A handle to the DC.
The DC layout. This parameter can be one or more of the following values.
-
LAYOUT_BITMAPORIENTATIONPRESERVED
Disables any reflection during and operations.
-
LAYOUT_RTL
Sets the default horizontal layout to be right to left.
If the function succeeds, it returns the previous layout of the DC.
If the function fails, it returns GDI_ERROR.
The layout specifies the order in which text and graphics are revealed in a window or a device context. The default is left to right. The
function changes this to be right to left, which is the standard in Arabic and Hebrew cultures.
Once the LAYOUT_RTL flag is selected, flags normally specifying right or left are reversed. To avoid confusion, consider defining alternate
words for standard flags, such as those in the following table.
The function sets the pixels in a compatible bitmap (DDB) using the color data found in the specified DIB.
A handle to a device context.
A handle to the compatible bitmap (DDB) that is to be altered using the color data from the specified DIB.
The starting scan line for the device-independent color data in the array pointed to by the parameter.
The number of scan lines found in the array containing device-independent color data.
A pointer to the DIB color data, stored as an array of bytes. The format of the bitmap values depends on the
member of the structure pointed to by the
parameter.
A pointer to a structure that contains information about the DIB.
Indicates whether the member of the structure was provided and, if so, whether
contains explicit red, green, blue (RGB) values or palette indexes. The
parameter must be one of the following values.
-
DIB_PAL_COLORS
The color table consists of an array of 16-bit indexes into the logical palette of the device context identified by the
parameter.
-
DIB_RGB_COLORS
The color table is provided and contains literal RGB values.
If the function succeeds, the return value is the number of scan lines copied.
If the function fails, the return value is zero.
This can be the following value.
Optimal bitmap drawing speed is obtained when the bitmap bits are indexes into the system palette.
Applications can retrieve the system palette colors and indexes by calling the function. After the
colors and indexes are retrieved, the application can create the DIB. For more information, see System Palette.
The device context identified by the parameter is used only if the DIB_PAL_COLORS constant is set for the
parameter; otherwise it is ignored.
The bitmap identified by the parameter must not be selected into a device context when the application calls this
function.
The scan lines must be aligned on a DWORD except for RLE-compressed bitmaps.
The origin for bottom-up DIBs is the lower-left corner of the bitmap; the origin for top-down DIBs is the upper-left corner of the bitmap.
ICM: Color management is performed if color management has been enabled with a call to with the iEnableICM
parameter set to ICM_ON. If the bitmap specified by has a
that specifies the gamma and endpoints members, or a that specifies either the
gamma and endpoints members or the profileData and profileSize members, then the call treats the bitmap's pixels as being expressed in the
color space described by those members, rather than in the device context's source color space.
The function sets the background mix mode of the specified device context. The background mix mode is used with text,
hatched brushes, and pen styles that are not solid lines.
A handle to the device context.
The background mode. This parameter can be one of the following values.
-
OPAQUE
Background is filled with the current background color before the text, hatched brush, or pen is drawn.
-
TRANSPARENT
Background remains untouched.
If the function succeeds, the return value specifies the previous background mode.
If the function fails, the return value is zero.
The function affects the line styles for lines drawn using a pen created by the function.
does not affect lines drawn using a pen created by the function.
The function draws a rectangle with rounded corners. The rectangle is outlined by using the current pen and filled by
using the current brush.
A handle to the device context.
The x-coordinate, in logical coordinates, of the upper-left corner of the rectangle.
The y-coordinate, in logical coordinates, of the upper-left corner of the rectangle.
The x-coordinate, in logical coordinates, of the lower-right corner of the rectangle.
The y-coordinate, in logical coordinates, of the lower-right corner of the rectangle.
The width, in logical coordinates, of the ellipse used to draw the rounded corners.
The height, in logical coordinates, of the ellipse used to draw the rounded corners.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The current position is neither used nor updated by this function.
The function restores a device context (DC) to the specified state. The DC is restored by popping state information off
a stack created by earlier calls to the function.
A handle to the DC.
The saved state to be restored. If this parameter is positive, represents a specific instance of the state to be
restored. If this parameter is negative, represents an instance relative to the current state. For example, -1
restores the most recently saved state.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The stack can contain the state information for several instances of the DC. If the state specified by the specified parameter is not at the top
of the stack, deletes all state information between the top of the stack and the specified instance.
The function draws a rectangle. The rectangle is outlined by using the current pen and filled by using the current
brush.
A handle to the device context.
The x-coordinate, in logical coordinates, of the upper-left corner of the rectangle.
The y-coordinate, in logical coordinates, of the upper-left corner of the rectangle.
The x-coordinate, in logical coordinates, of the lower-right corner of the rectangle.
The y-coordinate, in logical coordinates, of the lower-right corner of the rectangle.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The current position is neither used nor updated by .
The rectangle that is drawn excludes the bottom and right edges.
If a PS_NULL pen is used, the dimensions of the rectangle are 1 pixel less in height and 1 pixel less in width.
The function determines whether the specified point is within the clipping region of a device context.
A handle to the device context.
The x-coordinate, in logical units, of the point.
The y-coordinate, in logical units, of the point.
If the specified point is within the clipping region of the device context, the return value is TRUE(1).
If the specified point is not within the clipping region of the device context, the return value is FALSE(0).
If the is not valid, the return value is (BOOL)-1.
The function moves a region by the specified offsets.
Handle to the region to be moved.
Specifies the number of logical units to move left or right.
Specifies the number of logical units to move up or down.
The return value specifies the new region's complexity. It can be one of the following values.
The function inverts the colors in the specified region.
Handle to the device context.
Handle to the region for which colors are inverted. The region's coordinates are presumed to be logical coordinates.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
On monochrome screens, the function makes white pixels black and black pixels white. On color screens, this inversion is
dependent on the type of technology used to generate the colors for the screen.
The function retrieves the bounding rectangle of the specified region.
A handle to the region.
A pointer to a structure that receives the bounding rectangle in logical units.
The return value specifies the region's complexity. It can be one of the following values:
The function returns the layout of a device context (DC).
A handle to the device context.
If the function succeeds, it returns the layout flags for the current device context.
If the function fails, it returns GDI_ERROR. For extended error information, call GetLastError.
The layout specifies the order in which text and graphics are revealed in a window or device context. The default is left to right. The
function tells you if the default has been changed through a call to . For more information, see
"Window Layout and Mirroring" in Window Features.
The function retrieves the bits of the specified compatible bitmap and copies them into a buffer as a DIB using the
specified format.
A handle to the device context.
A handle to the bitmap. This must be a compatible bitmap (DDB).
The first scan line to retrieve.
The number of scan lines to retrieve.
A pointer to a buffer to receive the bitmap data. If this parameter is NULL, the function passes the dimensions and format of the bitmap to the
structure pointed to by the parameter.
A pointer to a structure that specifies the desired format for the DIB data.
The format of the member of the structure. It must be one of the following
values.
-
DIB_PAL_COLORS
The color table should consist of an array of 16-bit indexes into the current logical palette.
-
DIB_RGB_COLORS
The color table should consist of literal red, green, blue (RGB) values.
If the parameter is non-NULL and the function succeeds, the return value is the number of scan lines copied from
the bitmap.
If the parameter is NULL and successfully fills the structure,
the return value is nonzero.
If the function fails, the return value is zero.
This function can return the following value.
If the requested format for the DIB matches its internal format, the RGB values for the bitmap are copied. If the requested format doesn't match
the internal format, a color table is synthesized. The following table describes the color table synthesized for each format.
The function returns the current background mix mode for a specified device context. The background mix mode of a device
context affects text, hatched brushes, and pen styles that are not solid lines.
Handle to the device context whose background mode is to be returned.
If the function succeeds, the return value specifies the current background mix mode, either OPAQUE or TRANSPARENT.
If the function fails, the return value is zero.
The function fills an area of the display surface with the current brush. The area is assumed to be bounded as
specified by the parameter.
Note: The function is included only for compatibility with 16-bit versions of Windows. Applications should use the
function with FLOODFILLBORDER specified.
A handle to a device context.
The x-coordinate, in logical units, of the point where filling is to start.
The y-coordinate, in logical units, of the point where filling is to start.
The color of the boundary or the area to be filled. To create a color value, use the RGB macro.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The following are reasons this function might fail:
The function enables an application to access device capabilities that are not available through GDI.
A handle to the device context.
The escape function to be performed. It can be one of the following or it can be an application-defined escape function.
-
CHECKJPEGFORMAT
Checks whether the printer supports a JPEG image.
-
CHECKPNGFORMAT
Checks whether the printer supports a PNG image.
-
DRAWPATTERNRECT
Draws a white, gray-scale, or black rectangle.
-
GET_PS_FEATURESETTING
Gets information on a specified feature setting for a PostScript driver.
-
GETTECHNOLOGY
Reports on whether or not the driver is a Postscript driver.
-
PASSTHROUGH
Allows the application to send data directly to a printer. Supported in compatibility mode and GDI-centric mode.
-
POSTSCRIPT_DATA
Allows the application to send data directly to a printer. Supported only in compatibility mode.
-
POSTSCRIPT_IDENTIFY
Sets a PostScript driver to GDI-centric or PostScript-centric mode.
-
POSTSCRIPT_INJECTION
Inserts a block of raw data in a PostScript job stream.
-
POSTSCRIPT_PASSTHROUGH
Sends data directly to a PostScript printer driver. Supported in compatibility mode and PostScript-centric mode.
-
QUERYESCSUPPORT
Determines whether a particular escape is implemented by the device driver.
-
SPCLPASSTHROUGH2
Enables applications to include private procedures and other resources at the document level-save context.
The number of bytes of data pointed to by the parameter.
A pointer to the input structure required for the specified escape. See also Remarks.
The number of bytes of data pointed to by the parameter.
A pointer to the structure that receives output from this escape. This parameter must not be NULL if is called as a
query function. If no data is to be returned in this structure, set to 0. See also Remarks.
The return value specifies the outcome of the function. It is greater than zero if the function is successful, except for the QUERYESCSUPPORT
printer escape, which checks for implementation only. The return value is zero if the escape is not implemented. A return value less than zero
indicates an error.
Note: This is a blocking or synchronous function and might not return immediately. How quickly this function returns depends on run-time
factors such as network status, print server configuration, and printer driver implementation—factors that are difficult to predict when
writing an application. Calling this function from a thread that manages interaction with the user interface could make the application
appear to be unresponsive.
Use this function to pass a driver-defined escape value to a device.
Use the Escape function to pass one of the system-defined escape values to a device, unless the escape is one of the defined escapes in
. might not work properly with the system-defined escapes. In particular, escapes in
which is a pointer to a structure that contains a member that is a pointer will fail.
Note, that the behavior described in this article is the expected behavior, but it is up to the driver to comply with this model.
The variables referenced by and should not be the same or overlap. If the
input and the output buffer size variables overlap, they may not contain the correct values after the call returns. For the best results,
and should refer to different variables.
The function creates a logical pen that has the specified style, width, and color. The pen can subsequently be selected
into a device context and used to draw lines and curves.
The pen style. It can be any one of the following values.
-
PS_SOLID
The pen is solid.
-
PS_DASH
The pen is dashed. This style is valid only when the pen width is one or less in device units.
-
PS_DOT
The pen is dotted. This style is valid only when the pen width is one or less in device units.
-
PS_DASHDOT
The pen has alternating dashes and dots. This style is valid only when the pen width is one or less in device units.
-
PS_DASHDOTDOT
The pen has alternating dashes and double dots. This style is valid only when the pen width is one or less in device units.
-
PS_NULL
The pen is invisible.
-
PS_INSIDEFRAME
The pen is solid. When this pen is used in any GDI drawing function that takes a bounding rectangle, the dimensions of the figure are
shrunk so that it fits entirely in the bounding rectangle, taking into account the width of the pen. This applies only to geometric
pens.
The width of the pen, in logical units. If is zero, the pen is a single pixel wide, regardless of the current
transformation.
returns a pen with the specified width bit with the PS_SOLID style if you specify a width greater than one for the
following styles: PS_DASH, PS_DOT, PS_DASHDOT, PS_DASHDOTDOT.
A color reference for the pen color. To generate a structure, use the RGB macro.
If the function succeeds, the return value is a handle that identifies a logical pen.
If the function fails, the return value is NULL.
After an application creates a logical pen, it can select that pen into a device context by calling the function.
After a pen is selected into a device context, it can be used to draw lines and curves.
If the value specified by the parameter is zero, a line drawn with the created pen always is a single pixel wide
regardless of the current transformation.
If the value specified by is greater than 1, the parameter must be PS_NULL,
PS_SOLID, or PS_INSIDEFRAME.
If the value specified by is greater than 1 and is PS_INSIDEFRAME, the line
associated with the pen is drawn inside the frame of all primitives except polygons and polylines.
If the value specified by is greater than 1, is PS_INSIDEFRAME, and the color
specified by the parameter does not match one of the entries in the logical palette, the system draws lines by
using a dithered color. Dithered colors are not available with solid pens.
When you no longer need the pen, call the function to delete it.
ICM: No color management is done at creation. However, color management is performed when the pen is selected into an ICM-enabled device
context.
The function creates an information context for the specified device. The information context provides a fast way to get
information about the device without creating a device context (DC). However, GDI drawing functions cannot accept a handle to an information
context.
A pointer to a null-terminated character string that specifies the name of the device driver (for example, Epson).
A pointer to a null-terminated character string that specifies the name of the specific output device being used, as shown by the Print Manager
(for example, Epson FX-80). It is not the printer model name. The parameter must be used.
This parameter is ignored and should be set to NULL. It is provided only for compatibility with 16-bit Windows.
A pointer to a structure containing device-specific initialization data for the device driver. The DocumentProperties
function retrieves this structure filled in for a specified device. The parameter must be NULL if the device driver
is to use the default initialization (if any) specified by the user.
If the function succeeds, the return value is the handle to an information context.
If the function fails, the return value is NULL.
When you no longer need the information DC, call the function.
The function creates a device context (DC) for a device using the specified name.
A pointer to a null-terminated character string that specifies either DISPLAY or the name of a specific display device. For printing, we
recommend that you pass NULL to because GDI ignores for printer devices.
A pointer to a null-terminated character string that specifies the name of the specific output device being used, as shown by the Print
Manager (for example, Epson FX-80). It is not the printer model name. The parameter must be used.
To obtain valid names for displays, call .
If is DISPLAY or the device name of a specific display device, then must be
NULL or that same device name. If is NULL, then a DC is created for the primary display device.
If there are multiple monitors on the system, calling CreateDC(TEXT("DISPLAY"),NULL,NULL,NULL) will create a DC covering all the monitors.
This parameter is ignored and should be set to NULL. It is provided only for compatibility with 16-bit Windows.
A pointer to a structure containing device-specific initialization data for the device driver. The DocumentProperties
function retrieves this structure filled in for a specified device. The
parameter must be NULL if the device driver is to use the default initialization (if any) specified by the user.
If is DISPLAY, must be NULL; GDI then uses the display device's current
.
If the function succeeds, the return value is the handle to a DC for the specified device.
If the function fails, the return value is NULL.
Note that the handle to the DC can only be used by a single thread at any one time.
For parameters and , call to obtain
valid names for displays.
When you no longer need the DC, call the function.
If or is DISPLAY, the thread that calls owns the HDC
that is created. When this thread is destroyed, the HDC is no longer valid. Thus, if you create the HDC and pass it to another thread, then
exit the first thread, the second thread will not be able to use the HDC.
When you call to create the HDC> for a display device, you must pass to
either NULL or a pointer to that matches the current of the display device that
specifies. We recommend to pass NULL and not to try to exactly match the for the
current display device.
When you call to create the HDC for a printer device, the printer driver validates the
. If the printer driver determines that the is invalid (that is, printer driver can’t convert or
consume the DEVMODE), the printer driver provides a default to create the HDC for the printer device.
ICM: To enable ICM, set the member of the structure (pointed to by the
parameter) to the appropriate value.
The function opens a path bracket in the specified device context.
A handle to the device context.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
After a path bracket is open, an application can begin calling GDI drawing functions to define the points that lie in the path. An
application can close an open path bracket by calling the function.
When an application calls for a device context, any previous paths are discarded from that device context. The
following list shows which drawing functions can be used.
The function closes and discards any paths in the specified device context.
Handle to the device context from which a path will be discarded.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
If there is an open path bracket in the given device context, the path bracket is closed and the path is discarded. If there is a closed path in
the device context, the path is discarded.
The function writes a character string at the specified location, using the currently selected font, background color, and
text color.
A handle to the device context.
The x-coordinate, in logical coordinates, of the reference point that the system uses to align the string.
The y-coordinate, in logical coordinates, of the reference point that the system uses to align the string.
A pointer to the string to be drawn. The string does not need to be zero-terminated, because specifies the length
of the string.
The length of the string pointed to by , in characters.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The interpretation of the reference point depends on the current text-alignment mode. An application can retrieve this mode by calling the
function; an application can alter this mode by calling the function. You can use the
following values for text alignment. Only one flag can be chosen from those that affect horizontal and vertical alignment. In addition, only
one of the two flags that alter the current position can be chosen.
The function sets the pixel at the specified coordinates to the specified color.
A handle to the device context.
The x-coordinate, in logical units, of the point to be set.
The y-coordinate, in logical units, of the point to be set.
The color to be used to paint the point. To create a color value, use the RGB macro.
If the function succeeds, the return value is the RGB value that the function sets the pixel to. This value may differ from the color
specified by ; that occurs when an exact match for the specified color cannot be found.
If the function fails, the return value is -1.
This can be the following value.
The function fails if the pixel coordinates lie outside of the current clipping region.
Not all devices support the function. For more information, see .
The function updates the specified printer or plotter device context (DC) using the specified information.
A handle to the DC to update.
A pointer to a structure containing information about the new DC.
If the function succeeds, the return value is a handle to the original DC.
If the function fails, the return value is NULL.
An application will typically use the function when a window receives a message.
can also be used to change the paper orientation or paper bins while printing a document.
The function cannot be used to change the driver name, device name, or the output port. When the user changes the port
connection or device name, the application must delete the original DC and create a new DC with the new information.
An application can pass an information DC to the function. In that situation, will always
return a printer DC.
ICM: The color profile of the DC specified by the parameter will be reset based on the information contained in the
member of the structure.
The function draws a series of line segments by connecting the points in the specified array.
A handle to a device context.
A pointer to an array of structures, in logical units.
The number of points in the array. This number must be greater than or equal to two.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The lines are drawn from the first point through subsequent points by using the current pen. Unlike the or
functions, the function neither uses nor updates the current position.
The function draws a set of line segments and BĂ©zier curves.
A handle to a device context.
A pointer to an array of structures that contains the endpoints for each line segment and the endpoints and control points
for each BĂ©zier curve, in logical units.
A pointer to an array that specifies how each point in the array is used. This parameter can be one of the following
values.
-
PT_MOVETO
Specifies that this point starts a disjoint figure. This point becomes the new current position.
-
PT_LINETO
Specifies that a line is to be drawn from the current position to this point, which then becomes the new current position.
-
PT_BEZIERTO
Specifies that this point is a control point or ending point for a BĂ©zier curve.
PT_BEZIERTO types always occur in sets of three. The current position defines the starting point for the BĂ©zier curve. The first
two PT_BEZIERTO points are the control points, and the third PT_BEZIERTO point is the ending point. The ending point becomes the
new current position. If there are not three consecutive PT_BEZIERTO points, an error results.
A PT_LINETO or PT_BEZIERTO type can be combined with the following value by using the bitwise operator OR to indicate that the corresponding
point is the last point in a figure and the figure is closed.
-
PT_CLOSEFIGURE
Specifies that the figure is automatically closed after the PT_LINETO or PT_BEZIERTO type for this point is done. A line is drawn
from this point to the most recent PT_MOVETO or point.
This value is combined with the PT_LINETO type for a line, or with the PT_BEZIERTO type of the ending point for a BĂ©zier curve,
by using the bitwise operator OR.
The current position is set to the ending point of the closing line.
The total number of points in the array, the same as the number of bytes in the array.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function can be used in place of consecutive calls to , , and
functions to draw disjoint figures. The lines and curves are drawn using the current pen and figures are not
filled. If there is an active path started by calling , adds to the path.
The points contained in the array and in the array indicate whether each point is part
of a , , or operation. It is also possible to close figures.
This function updates the current position.
The function paints the specified region by using the brush currently selected into the device context.
Handle to the device context.
Handle to the region to be filled. The region's coordinates are presumed to be logical coordinates.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function updates the current position to the specified point and optionally returns the previous position.
Handle to a device context.
Specifies the x-coordinate, in logical units, of the new position, in logical units.
Specifies the y-coordinate, in logical units, of the new position, in logical units.
Pointer to a structure that receives the previous current position. If this parameter is a NULL pointer, the previous
position is not returned.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function affects all drawing functions.
The function retrieves the red, green, blue (RGB) color value of the pixel at the specified coordinates.
A handle to the device context.
The x-coordinate, in logical units, of the pixel to be examined.
The y-coordinate, in logical units, of the pixel to be examined.
The return value is the value that specifies the RGB of the pixel. If the pixel is outside of the current clipping
region, the return value is CLR_INVALID (0xFFFFFFFF defined in Wingdi.h).
The pixel must be within the boundaries of the current clipping region.
Not all devices support . An application should call to determine whether a specified
device supports this function.
A bitmap must be selected within the device context, otherwise, CLR_INVALID is returned on all pixels.
The function flushes the calling thread's current batch.
If all functions in the current batch succeed, the return value is nonzero.
If not all functions in the current batch succeed, the return value is zero, indicating that at least one function returned an error.
Batching enhances drawing performance by minimizing the amount of time needed to call GDI drawing functions that return Boolean values. The
system accumulates the parameters for calls to these functions in the current batch and then calls the functions when the batch is flushed by any
of the following means:
The function draws a border around the specified region by using the specified brush.
Handle to the device context.
Handle to the region to be enclosed in a border. The region's coordinates are presumed to be in logical units.
Handle to the brush to be used to draw the border.
Specifies the width, in logical units, of vertical brush strokes.
Specifies the height, in logical units, of horizontal brush strokes.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function closes any open figures in the current path and fills the path's interior by using the current brush and
polygon-filling mode.
A handle to a device context that contains a valid path.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
After its interior is filled, the path is discarded from the DC identified by the parameter.
The function checks the two specified regions to determine whether they are identical. The function considers two regions
identical if they are equal in size and shape.
Handle to a region.
Handle to a region.
If the two regions are equal, the return value is nonzero.
If the two regions are not equal, the return value is zero. A return value of ERROR means at least one of the region handles is invalid.
The function deletes the specified device context (DC).
A handle to the device context.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
An application must not delete a DC whose handle was obtained by calling the function. Instead, it must call the
function to free the DC.
The function cancels any pending operation on the specified device context (DC).
A handle to the DC.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function is used by multithreaded applications to cancel lengthy drawing operations. If thread A initiates a
lengthy drawing operation, thread B may cancel that operation by calling this function.
If an operation is canceled, the affected thread returns an error and the result of its drawing operation is undefined. The results are also
undefined if no drawing operation was in progress when the function was called.
The function draws a line segment and an arc. The line segment is drawn from the current position to the beginning of the
arc. The arc is drawn along the perimeter of a circle with the given radius and center. The length of the arc is defined by the given start and
sweep angles.
Handle to a device context.
Specifies the x-coordinate, in logical units, of the center of the circle.
Specifies the y-coordinate, in logical units, of the center of the circle.
Specifies the radius, in logical units, of the circle. This value must be positive.
Specifies the start angle, in degrees, relative to the x-axis.
Specifies the sweep angle, in degrees, relative to the starting angle.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function moves the current position to the ending point of the arc.
The arc drawn by this function may appear to be elliptical, depending on the current transformation and mapping mode. Before drawing the arc,
draws the line segment from the current position to the beginning of the arc.
The arc is drawn by constructing an imaginary circle around the specified center point with the specified radius. The starting point of the
arc is determined by measuring counterclockwise from the x-axis of the circle by the number of degrees in the start angle. The ending point
is similarly located by measuring counterclockwise from the starting point by the number of degrees in the sweep angle.
If the sweep angle is greater than 360 degrees, the arc is swept multiple times.
This function draws lines by using the current pen. The figure is not filled.
The function stops the current print job and erases everything drawn since the last call to the
function.
Handle to the device context for the print job.
If the function succeeds, the return value is greater than zero.
If the function fails, the return value is SP_ERROR.
Note: This is a blocking or synchronous function and might not return immediately. How quickly this function returns depends on run-time
factors such as network status, print server configuration, and printer driver implementation—factors that are difficult to predict when
writing an application. Calling this function from a thread that manages interaction with the user interface could make the application
appear to be unresponsive.
Applications should call the function to stop a print job if an error occurs, or to stop a print job after the user
cancels that job. To end a successful print job, an application should call the function.
If Print Manager was used to start the print job, calling erases the entire spool job, so that the printer receives
nothing. If Print Manager was not used to start the print job, the data may already have been sent to the printer. In this case, the printer
driver resets the printer (when possible) and ends the print job.
The function sets the current foreground mix mode. GDI uses the foreground mix mode to combine pens and interiors of
filled objects with the colors already on the screen. The foreground mix mode defines how colors from the brush or pen and the colors in the
existing image are to be combined.
A handle to the device context.
The mix mode. This parameter can be one of the following values.
-
R2_BLACK
Pixel is always 0.
-
R2_COPYPEN
Pixel is the pen color.
-
R2_MASKNOTPEN
Pixel is a combination of the colors common to both the screen and the inverse of the pen.
-
R2_MASKPEN
Pixel is a combination of the colors common to both the pen and the screen.
-
R2_MASKPENNOT
Pixel is a combination of the colors common to both the pen and the inverse of the screen.
-
R2_MERGENOTPEN
Pixel is a combination of the screen color and the inverse of the pen color.
-
R2_MERGEPEN
Pixel is a combination of the pen color and the screen color.
-
R2_MERGEPENNOT
Pixel is a combination of the pen color and the inverse of the screen color.
-
R2_NOP
Pixel remains unchanged.
-
R2_NOT
Pixel is the inverse of the screen color.
-
R2_NOTCOPYPEN
Pixel is the inverse of the pen color.
-
R2_NOTMASKPEN
Pixel is the inverse of the R2_MASKPEN color.
-
R2_NOTMERGEPEN
Pixel is the inverse of the R2_MERGEPEN color.
-
R2_NOTXORPEN
Pixel is the inverse of the R2_XORPEN color.
-
R2_WHITE
Pixel is always 1.
-
R2_XORPEN
Pixel is a combination of the colors in the pen and in the screen, but not in both.
If the function succeeds, the return value specifies the previous mix mode.
If the function fails, the return value is zero.
Mix modes define how GDI combines source and destination colors when drawing with the current pen. The mix modes are binary raster operation
codes, representing all possible Boolean functions of two variables, using the binary operations AND, OR, and XOR (exclusive OR), and the unary
operation NOT. The mix mode is for raster devices only; it is not available for vector devices.
The function draws a polygon consisting of two or more vertices connected by straight lines. The polygon is outlined by
using the current pen and filled by using the current brush and polygon fill mode.
A handle to the device context.
A pointer to an array of structures that specify the vertices of the polygon, in logical coordinates.
The number of vertices in the array. This value must be greater than or equal to 2.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The polygon is closed automatically by drawing a line from the last vertex to the first.
The current position is neither used nor updated by the function.
Any extra points are ignored. To draw a line with more points, divide your data into groups, each of which have less than the maximum number
of points, and call the function for each group of points. Remember to connect the line segments.
The function combines the color data for the source and destination bitmaps using the specified mask and raster operation.
A handle to the destination device context.
The x-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The y-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The width, in logical units, of the destination rectangle and source bitmap.
The height, in logical units, of the destination rectangle and source bitmap.
A handle to the device context from which the bitmap is to be copied. It must be zero if the parameter specifies a
raster operation that does not include a source.
The x-coordinate, in logical units, of the upper-left corner of the source bitmap.
The y-coordinate, in logical units, of the upper-left corner of the source bitmap.
A handle to the monochrome mask bitmap combined with the color bitmap in the source device context.
The horizontal pixel offset for the mask bitmap specified by the parameter.
The vertical pixel offset for the mask bitmap specified by the parameter.
The foreground and background ternary raster operation codes (ROPs) that the function uses to control the combination of source and
destination data. The background raster operation code is stored in the high-order byte of the high-order word of this value; the foreground
raster operation code is stored in the low-order byte of the high-order word of this value; the low-order word of this value is ignored, and
should be zero. The macro MAKEROP4 creates such combinations of foreground and background raster operation codes.
For a discussion of foreground and background in the context of this function, see the following Remarks section.
For a list of common raster operation codes (ROPs), see the function. Note that the CAPTUREBLT ROP generally cannot be
used for printing device contexts.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function uses device-dependent bitmaps.
A value of 1 in the mask specified by indicates that the foreground raster operation code specified by
should be applied at that location. A value of 0 in the mask indicates that the background raster operation code
specified by should be applied at that location.
If the raster operations require a source, the mask rectangle must cover the source rectangle. If it does not, the function will fail. If the
raster operations do not require a source, the mask rectangle must cover the destination rectangle. If it does not, the function will fail.
If a rotation or shear transformation is in effect for the source device context when this function is called, an error occurs. However,
other types of transformation are allowed.
If the color formats of the source, pattern, and destination bitmaps differ, this function converts the pattern or source format, or both, to
match the destination format.
If the mask bitmap is not a monochrome bitmap, an error occurs.
When an enhanced metafile is being recorded, an error occurs (and the function returns FALSE) if the source device context identifies an
enhanced-metafile device context.
Not all devices support the function. An application should call the function with the
nIndex parameter as RC_BITBLT to determine whether a device supports this function.
If no mask bitmap is supplied, this function behaves exactly like , using the foreground raster operation code.
ICM: No color management is performed when blits occur.
When used in a multiple monitor system, both and must refer to the same device or the
function will fail. To transfer data between DCs for different devices, convert the memory bitmap (compatible bitmap, or DDB) to a DIB by
calling . To display the DIB to the second device, call or .
The function determines which pixels should be highlighted for a line defined by the specified starting and ending points.
Specifies the x-coordinate, in logical units, of the line's starting point.
Specifies the y-coordinate, in logical units, of the line's starting point.
Specifies the x-coordinate, in logical units, of the line's ending point.
Specifies the y-coordinate, in logical units, of the line's ending point.
Pointer to an application-defined callback function. For more information, see the callback function.
Pointer to the application-defined data.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function passes the coordinates for each point along the line, except for the line's ending point, to the
application-defined callback function. In addition to passing the coordinates of a point, this function passes any existing
application-defined data.
The coordinates passed to the callback function match pixels on a video display only if the default transformations and mapping modes are
used.
The function retrieves the foreground mix mode of the specified device context. The mix mode specifies how the pen or
interior color and the color already on the screen are combined to yield a new color.
Handle to the device context.
If the function succeeds, the return value specifies the foreground mix mode.
If the function fails, the return value is zero.
Following are the foreground mix modes.
The function retrieves the coordinates defining the endpoints of lines and the control points of curves found in the path
that is selected into the specified device context.
A handle to a device context that contains a closed path.
A pointer to an array of structures that receives the line endpoints and curve control points, in logical coordinates.
A pointer to an array of bytes that receives the vertex types. This parameter can be one of the following values.
-
PT_MOVETO
Specifies that the corresponding point in the parameter starts a disjoint figure.
-
PT_LINETO
Specifies that the previous point and the corresponding point in are the endpoints of a line.
-
PT_BEZIERTO
Specifies that the corresponding point in is a control point or ending point for a BĂ©zier curve.
PT_BEZIERTO values always occur in sets of three. The point in the path immediately preceding them defines the starting point for
the BĂ©zier curve. The first two PT_BEZIERTO points are the control points, and the third PT_BEZIERTO point is the ending (if
hard-coded) point.
A PT_LINETO or PT_BEZIERTO value may be combined with the following value (by using the bitwise operator OR) to indicate that the
corresponding point is the last point in a figure and the figure should be closed.
-
PT_CLOSEFIGURE
Specifies that the figure is automatically closed after the corresponding line or curve is drawn. The figure is closed by drawing a
line from the line or curve endpoint to the point corresponding to the last PT_MOVETO.
The total number of structures that can be stored in the array pointed to by . This value must
be the same as the number of bytes that can be placed in the array pointed to by .
If the parameter is nonzero, the return value is the number of points enumerated. If is 0,
the return value is the total number of points in the path (and writes nothing to the buffers). If
is nonzero and is less than the number of points in the path, the return value is 1.
The device context identified by the parameter must contain a closed path.
The points of the path are returned in logical coordinates. Points are stored in the path in device coordinates, so
changes the points from device coordinates to logical coordinates by using the inverse of the current transformation.
The function may be called before to convert all curves in the path into line segments.
The function fills a region by using the specified brush.
Handle to the device context.
Handle to the region to be filled. The region's coordinates are presumed to be in logical units.
Handle to the brush to be used to fill the region.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function closes a path bracket and selects the path defined by the bracket into the specified device context.
A handle to the device context into which the new path is selected.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function notifies the device that the application has finished writing to a page. This function is typically used to
direct the device driver to advance to a new page.
A handle to the device context for the print job.
If the function succeeds, the return value is greater than zero.
If the function fails, the return value is less than or equal to zero.
Note: This is a blocking or synchronous function and might not return immediately. How quickly this function returns depends on run-time
factors such as network status, print server configuration, and printer driver implementation—factors that are difficult to predict when
writing an application. Calling this function from a thread that manages interaction with the user interface could make the application
appear to be unresponsive.
Use the function to change the device mode, if necessary, after calling the function. Note that
a call to resets all device context attributes back to default values. Neither nor
resets the device context attributes. Device context attributes remain constant across subsequent pages. You do not
need to re-select objects and set up the mapping mode again before printing the next page; however, doing so will produce the same results
and reduce code differences between versions of Windows.
When a page in a spooled file exceeds approximately 350 MB, it may fail to print and not send an error message. For example, this can occur
when printing large EMF files. The page size limit depends on many factors including the amount of virtual memory available, the amount of
memory allocated by calling processes, and the amount of fragmentation in the process heap.
The function draws an ellipse. The center of the ellipse is the center of the specified bounding rectangle. The ellipse is
outlined by using the current pen and is filled by using the current brush.
A handle to the device context.
The x-coordinate, in logical coordinates, of the upper-left corner of the bounding rectangle.
The y-coordinate, in logical coordinates, of the upper-left corner of the bounding rectangle.
The x-coordinate, in logical coordinates, of the lower-right corner of the bounding rectangle.
The y-coordinate, in logical coordinates, of the lower-right corner of the bounding rectangle.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The current position is neither used nor updated by .
The function saves the current state of the specified device context (DC) by copying data describing selected objects and
graphic modes (such as the bitmap, brush, palette, font, pen, region, drawing mode, and mapping mode) to a context stack.
A handle to the DC whose state is to be saved.
If the function succeeds, the return value identifies the saved state.
If the function fails, the return value is zero.
The function can be used any number of times to save any number of instances of the DC state.
A saved state can be restored by using the function.
The function performs a bit-block transfer of the bits of color data from the specified rectangle in the source device
context to the specified parallelogram in the destination device context. If the given bitmask handle identifies a valid monochrome bitmap, the
function uses this bitmap to mask the bits of color data from the source rectangle.
A handle to the destination device context.
A pointer to an array of three points in logical space that identify three corners of the destination parallelogram. The upper-left corner of the
source rectangle is mapped to the first point in this array, the upper-right corner to the second point in this array, and the lower-left corner
to the third point. The lower-right corner of the source rectangle is mapped to the implicit fourth point in the parallelogram.
A handle to the source device context.
The x-coordinate, in logical units, of the upper-left corner of the source rectangle.
The y-coordinate, in logical units, of the upper-left corner of the source rectangle.
The width, in logical units, of the source rectangle.
The height, in logical units, of the source rectangle.
A handle to an optional monochrome bitmap that is used to mask the colors of the source rectangle.
The x-coordinate, in logical units, of the upper-left corner of the monochrome bitmap.
The y-coordinate, in logical units, of the upper-left corner of the monochrome bitmap.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function works with device-dependent bitmaps.
The fourth vertex of the parallelogram (D) is defined by treating the first three points (A, B, and C ) as vectors and computing D = B +CA.
If the bitmask exists, a value of one in the mask indicates that the source pixel color should be copied to the destination. A value of zero
in the mask indicates that the destination pixel color is not to be changed. If the mask rectangle is smaller than the source and destination
rectangles, the function replicates the mask pattern.
Scaling, translation, and reflection transformations are allowed in the source device context; however, rotation and shear transformations
are not. If the mask bitmap is not a monochrome bitmap, an error occurs. The stretching mode for the destination device context is used to
determine how to stretch or compress the pixels, if that is necessary.
When an enhanced metafile is being recorded, an error occurs if the source device context identifies an enhanced-metafile device context.
The destination coordinates are transformed according to the destination device context; the source coordinates are transformed according to
the source device context. If the source transformation has a rotation or shear, an error is returned.
If the destination and source rectangles do not have the same color format, converts the source rectangle to match the
destination rectangle.
Not all devices support the function. For more information, see the description of the RC_BITBLT raster capability in
the function.
If the source and destination device contexts represent incompatible devices, returns an error.
When used in a multiple monitor system, both and must refer to the same device or the
function will fail. To transfer data between DCs for different devices, convert the memory bitmap to a DIB by calling
. To display the DIB to the second device, call or .
The function paints the specified rectangle using the brush that is currently selected into the specified device context.
The brush color and the surface color or colors are combined by using the specified raster operation.
A handle to the device context.
The x-coordinate, in logical units, of the upper-left corner of the rectangle to be filled.
The y-coordinate, in logical units, of the upper-left corner of the rectangle to be filled.
The width, in logical units, of the rectangle.
The height, in logical units, of the rectangle.
The raster operation code. This code can be one of the following values.
-
PATCOPY
Copies the specified pattern into the destination bitmap.
-
PATINVERT
Combines the colors of the specified pattern with the colors of the destination rectangle by using the Boolean XOR operator.
-
DSTINVERT
Inverts the destination rectangle.
-
BLACKNESS
Fills the destination rectangle using the color associated with index 0 in the physical palette. (This color is black for the default
physical palette.)
-
WHITENESS
Fills the destination rectangle using the color associated with index 1 in the physical palette. (This color is white for the default
physical palette.)
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The values of the parameter for this function are a limited subset of the full 256 ternary raster-operation codes;
in particular, an operation code that refers to a source rectangle cannot be used.
Not all devices support the function. For more information, see the description of the RC_BITBLT capability in the
function.
The function converts logical coordinates into device coordinates. The conversion depends on the mapping mode of the device
context, the settings of the origins and extents for the window and viewport, and the world transformation.
A handle to the device context.
A pointer to an array of structures. The x-coordinates and y-coordinates contained in each of the
structures will be transformed.
The number of points in the array.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function fails if the logical coordinates exceed 32 bits, or if the converted device coordinates exceed 27 bits. In
the case of such an overflow, the results for all the points are undefined.
calculates complex floating-point arithmetic, and it has a caching system for efficiency. Therefore, the conversion
result of an initial call to might not exactly match the conversion result of a later call to . We
recommend not to write code that relies on the exact match of the conversion results from multiple calls to even if the
parameters that are passed to each call are identical.
The function draws a line from the current position up to, but not including, the specified point.
Handle to a device context.
Specifies the x-coordinate, in logical units, of the line's ending point.
Specifies the y-coordinate, in logical units, of the line's ending point.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The line is drawn by using the current pen and, if the pen is a geometric pen, the current brush.
If succeeds, the current position is set to the specified ending point.
The function ends a print job.
Handle to the device context for the print job.
If the function succeeds, the return value is greater than zero.
If the function fails, the return value is less than or equal to zero.
Note: This is a blocking or synchronous function and might not return immediately. How quickly this function returns depends on run-time
factors such as network status, print server configuration, and printer driver implementation—factors that are difficult to predict when
writing an application. Calling this function from a thread that manages interaction with the user interface could make the application
appear to be unresponsive.
Applications should call immediately after finishing a print job.
The function converts device coordinates into logical coordinates. The conversion depends on the mapping mode of the device
context, the settings of the origins and extents for the window and viewport, and the world transformation.
A handle to the device context.
A pointer to an array of structures. The x- and y-coordinates contained in each structure will be
transformed.
The number of points in the array.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The function fails if the device coordinates exceed 27 bits, or if the converted logical coordinates exceed 32 bits. In the
case of such an overflow, the results for all the points are undefined.
The function performs a bit-block transfer of the color data corresponding to a rectangle of pixels from the specified
source device context into a destination device context.
A handle to the destination device context.
The x-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The y-coordinate, in logical units, of the upper-left corner of the destination rectangle.
The width, in logical units, of the source and destination rectangles.
The height, in logical units, of the source and the destination rectangles.
A handle to the source device context.
The x-coordinate, in logical units, of the upper-left corner of the source rectangle.
The y-coordinate, in logical units, of the upper-left corner of the source rectangle.
A raster-operation code. These codes define how the color data for the source rectangle is to be combined with the color data for the
destination rectangle to achieve the final color.
The following list shows some common raster operation codes.
-
BLACKNESS
Fills the destination rectangle using the color associated with index 0 in the physical palette. (This color is black for the default
physical palette.)
-
CAPTUREBLT
Includes any windows that are layered on top of your window in the resulting image. By default, the image only contains your window.
Note that this generally cannot be used for printing device contexts.
-
DSTINVERT
Inverts the destination rectangle.
-
MERGECOPY
Merges the colors of the source rectangle with the brush currently selected in , by using the Boolean AND
operator.
-
MERGEPAINT
Merges the colors of the inverted source rectangle with the colors of the destination rectangle by using the Boolean OR
operator.
-
NOMIRRORBITMAP
Prevents the bitmap from being mirrored.
-
NOTSRCCOPY
Copies the inverted source rectangle to the destination.
-
NOTSRCERASE
Combines the colors of the source and destination rectangles by using the Boolean OR operator and then inverts the resultant
color.
-
PATCOPY
Copies the brush currently selected in , into the destination bitmap.
-
PATINVERT
Combines the colors of the brush currently selected in , with the colors of the destination rectangle by
using the Boolean XOR operator.
-
PATPAINT
Combines the colors of the brush currently selected in , with the colors of the inverted source rectangle
by using the Boolean OR operator. The result of this operation is combined with the colors of the destination rectangle by using the
Boolean OR operator.
-
SRCAND
Combines the colors of the source and destination rectangles by using the Boolean AND operator.
-
SRCCOPY
Copies the source rectangle directly to the destination rectangle.
-
SRCERASE
Combines the inverted colors of the destination rectangle with the colors of the source rectangle by using the Boolean AND
operator.
-
SRCINVERT
Combines the colors of the source and destination rectangles by using the Boolean XOR operator.
-
SRCPAINT
Combines the colors of the source and destination rectangles by using the Boolean OR operator.
-
WHITENESS
Fills the destination rectangle using the color associated with index 1 in the physical palette. (This color is white for the default
physical palette.)
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero. To get extended error information, call GetLastError.
only does clipping on the destination DC.
If a rotation or shear transformation is in effect in the source device context, returns an error. If other
transformations exist in the source device context (and a matching transformation is not in effect in the destination device context), the
rectangle in the destination device context is stretched, compressed, or rotated, as necessary.
If the color formats of the source and destination device contexts do not match, the function converts the source color
format to match the destination format.
When an enhanced metafile is being recorded, an error occurs if the source device context identifies an enhanced-metafile device context.
Not all devices support the function. For more information, see the RC_BITBLT raster capability entry in the
function as well as the following functions: , , and
.
returns an error if the source and destination device contexts represent different devices. To transfer data between
DCs for different devices, convert the memory bitmap to a DIB by calling . To display the DIB to the second device,
call or .
ICM: No color management is performed when blits occur.
The function draws a chord (a region bounded by the intersection of an ellipse and a line segment, called a secant). The
chord is outlined by using the current pen and filled by using the current brush.
A handle to the device context in which the chord appears.
The x-coordinate, in logical coordinates, of the upper-left corner of the bounding rectangle.
The y-coordinate, in logical coordinates, of the upper-left corner of the bounding rectangle.
The x-coordinate, in logical coordinates, of the lower-right corner of the bounding rectangle.
The y-coordinate, in logical coordinates, of the lower-right corner of the bounding rectangle.
The x-coordinate, in logical coordinates, of the endpoint of the radial defining the beginning of the chord.
The y-coordinate, in logical coordinates, of the endpoint of the radial defining the beginning of the chord.
The x-coordinate, in logical coordinates, of the endpoint of the radial defining the end of the chord.
The y-coordinate, in logical coordinates, of the endpoint of the radial defining the end of the chord.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The curve of the chord is defined by an ellipse that fits the specified bounding rectangle. The curve begins at the point where the ellipse
intersects the first radial and extends counterclockwise to the point where the ellipse intersects the second radial. The chord is closed by
drawing a line from the intersection of the first radial and the curve to the intersection of the second radial and the curve.
If the starting point and ending point of the curve are the same, a complete ellipse is drawn.
The current position is neither used nor updated by .
The function draws an elliptical arc.
A handle to the device context where drawing takes place.
The x-coordinate, in logical units, of the upper-left corner of the bounding rectangle.
The y-coordinate, in logical units, of the upper-left corner of the bounding rectangle.
The x-coordinate, in logical units, of the lower-right corner of the bounding rectangle.
The y-coordinate, in logical units, of the lower-right corner of the bounding rectangle.
The x-coordinate, in logical units, of the endpoint of the radial defining the starting point of the arc.
The y-coordinate, in logical units, of the endpoint of the radial defining the starting point of the arc.
The x-coordinate, in logical units, of the endpoint of the radial defining the ending point of the arc.
The y-coordinate, in logical units, of the endpoint of the radial defining the ending point of the arc.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
is similar to the function, except that the current position is updated.
The points (, ) and (,
) specify the bounding rectangle. An ellipse formed by the specified bounding rectangle defines the curve of the arc. The arc extends
counterclockwise from the point where it intersects the radial line from the center of the bounding rectangle to the (
, ) point. The arc ends where it intersects the radial line from the center of the
bounding rectangle to the (, ) point. If the starting point and ending point are
the same, a complete ellipse is drawn.
A line is drawn from the current position to the starting point of the arc. If no error occurs, the current position is set to the ending
point of the arc.
The arc is drawn using the current pen; it is not filled.
The function draws a pie-shaped wedge bounded by the intersection of an ellipse and two radials. The pie is outlined by using
the current pen and filled by using the current brush.
A handle to the device context.
The x-coordinate, in logical coordinates, of the upper-left corner of the bounding rectangle.
The y-coordinate, in logical coordinates, of the upper-left corner of the bounding rectangle.
The x-coordinate, in logical coordinates, of the lower-right corner of the bounding rectangle.
The y-coordinate, in logical coordinates, of the lower-right corner of the bounding rectangle.
The x-coordinate, in logical coordinates, of the endpoint of the first radial.
The y-coordinate, in logical coordinates, of the endpoint of the first radial.
The x-coordinate, in logical coordinates, of the endpoint of the second radial.
The y-coordinate, in logical coordinates, of the endpoint of the second radial.
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
The curve of the pie is defined by an ellipse that fits the specified bounding rectangle. The curve begins at the point where the ellipse
intersects the first radial and extends counterclockwise to the point where the ellipse intersects the second radial.
The current position is neither used nor updated by the function.
The function draws an elliptical arc.
A handle to the device context where drawing takes place.
The x-coordinate, in logical units, of the upper-left corner of the bounding rectangle.
The y-coordinate, in logical units, of the upper-left corner of the bounding rectangle.
The x-coordinate, in logical units, of the lower-right corner of the bounding rectangle.
The y-coordinate, in logical units, of the lower-right corner of the bounding rectangle.
The x-coordinate, in logical units, of the ending point of the radial line defining the starting point of the arc.
The y-coordinate, in logical units, of the ending point of the radial line defining the starting point of the arc.
The x-coordinate, in logical units, of the ending point of the radial line defining the ending point of the arc.
The y-coordinate, in logical units, of the ending point of the radial line defining the ending point of the arc.
If the arc is drawn, the return value is nonzero.
If the arc is not drawn, the return value is zero.
The points (, ) and (,
) specify the bounding rectangle. An ellipse formed by the specified bounding rectangle defines the curve of the arc. The arc extends in the
current drawing direction from the point where it intersects the radial from the center of the bounding rectangle to the (
, ) point. The arc ends where it intersects the radial from the center of the
bounding rectangle to the (, ) point. If the starting point and ending point are the
same, a complete ellipse is drawn.
The arc is drawn using the current pen; it is not filled.
The current position is neither used nor updated by .
Use the and functions to get and set the current drawing direction for a device
context. The default drawing direction is counterclockwise.
Applies to: desktop apps only
The function retrieves pixel format information for an enhanced metafile.
Identifies the enhanced metafile.
Specifies the size, in bytes, of the buffer into which the pixel format information is copied.
Pointer to a structure that contains the logical pixel format specification. The metafile uses this
structure to record the logical pixel format specification.
If the function succeeds and finds a pixel format, the return value is the size of the metafile's pixel format.
If no pixel format is present, the return value is zero.
If an error occurs and the function fails, the return value is GDI_ERROR. To get extended error information, call GetLastError.
When an enhanced metafile specifies a pixel format in its structure and the pixel format fits in the buffer, the
pixel format information is copied into . When is too small to contain the pixel format
of the metafile, the pixel format is not copied to the buffer. In either case, the function returns the size of the metafile's pixel format.
For information on metafile recording and other operations, see Enhanced Metafile Operations.
The structure contains data that describes a graphics device interface (GDI) function used to create part of a
picture in an enhanced-format metafile.
The record type.
The size of the record, in bytes.
An array of parameters passed to the GDI function identified by the record.
The structure contains the information used to create a font.
An structure that contains information about the logical attributes of the font.
A structure. This is zero-filled unless the font described is a multiple master OpenType font.
The structure specifies a world-space to page-space transformation.
The following.
-
Scaling
Horizontal scaling component
-
Rotation
Cosine of rotation angle
-
Reflection
Horizontal component
The following.
-
Shear
Horizontal proportionality constant
-
Rotation
Sine of the rotation angle
The following.
-
Shear
Vertical proportionality constant
-
Rotation
Negative sine of the rotation angle
The following.
-
Scaling
Vertical scaling component
-
Rotation
Cosine of rotation angle
-
Reflection
Vertical reflection component
The horizontal translation component, in logical units.
The vertical translation component, in logical units.
The structure defines the type, width, height, color format, and bit values of a bitmap.
The bitmap type. This member must be zero.
The width, in pixels, of the bitmap. The width must be greater than zero.
The height, in pixels, of the bitmap. The height must be greater than zero.
The number of bytes in each scan line. This value must be divisible by 2, because the system assumes that the bit values of a bitmap form an
array that is word aligned.
The count of color planes.
The number of bits required to indicate the color of a pixel.
A pointer to the location of the bit values for the bitmap. The member must be a pointer to an array of character (1-byte)
values.
The structure defines the style, color, and pattern of a physical brush. It is used by the
and functions.
The brush style. The member must be one of the following styles.
-
BS_DIBPATTERN
A pattern brush defined by a device-independent bitmap (DIB) specification. If is BS_DIBPATTERN, the
member contains a handle to a packed DIB. For more information, see discussion in .
-
BS_DIBPATTERN8X8
See BS_DIBPATTERN.
-
BS_DIBPATTERNPT
A pattern brush defined by a device-independent bitmap (DIB) specification. If is BS_DIBPATTERNPT, the
member contains a pointer to a packed DIB. For more information, see discussion in .
-
BS_HATCHED
Hatched brush.
-
BS_HOLLOW
Hollow brush.
-
BS_NULL
Same as BS_HOLLOW.
-
BS_PATTERN
Pattern brush defined by a memory bitmap.
-
BS_PATTERN8X8
See BS_PATTERN.
-
BS_SOLID
Solid brush.
The color in which the brush is to be drawn. If is the BS_HOLLOW or BS_PATTERN style, is
ignored.
If is BS_DIBPATTERN or BS_DIBPATTERNPT, the low-order word of specifies whether the
members of the structure contain explicit red, green, blue (RGB) values or
indexes into the currently realized logical palette. The member must be one of the following values.
-
DIB_PAL_COLORS
The color table consists of an array of 16-bit indexes into the currently realized logical palette.
-
DIB_RGB_COLORS
The color table contains literal RGB values.
If is BS_HATCHED or BS_SOLID, is a color value. To create a
color value, use the RGB macro.
A hatch style. The meaning depends on the brush style defined by .
If is BS_DIBPATTERN, the member contains a handle to a packed DIB. To obtain this handle, an
application calls the GlobalAlloc function with GMEM_MOVEABLE (or LocalAlloc with LMEM_MOVEABLE) to allocate a block of memory and then fills
the memory with the packed DIB. A packed DIB consists of a structure immediately followed by the array of bytes
that define the pixels of the bitmap.
If is BS_DIBPATTERNPT, the member contains a pointer to a packed DIB. The pointer derives from
the memory block created by LocalAlloc with LMEM_FIXED set or by GlobalAlloc with GMEM_FIXED set, or it is the pointer returned by a call
like LocalLock (handle_to_the_dib). A packed DIB consists of a structure immediately followed by the array of bytes
that define the pixels of the bitmap.
If is BS_HATCHED, the member specifies the orientation of the lines used to create the hatch.
It can be one of the following values.
-
HS_BDIAGONAL
A 45-degree upward, left-to-right hatch
-
HS_CROSS
Horizontal and vertical cross-hatch
-
HS_DIAGCROSS
45-degree crosshatch
-
HS_FDIAGONAL
A 45-degree downward, left-to-right hatch
-
HS_HORIZONTAL
Horizontal hatch
-
HS_VERTICAL
Vertical hatch
If is BS_PATTERN, is a handle to the bitmap that defines the pattern. The bitmap cannot be a
DIB section bitmap, which is created by the function.
If is BS_SOLID or BS_HOLLOW, is ignored.
Defines the metafile picture format used for exchanging metafile data through the clipboard.
The mapping mode in which the picture is drawn.
The size of the metafile picture for all modes except the MM_ISOTROPIC and MM_ANISOTROPIC modes. (For more information about these modes, see the
member.) The x-extent specifies the width of the rectangle within which the picture is drawn. The coordinates are in units
that correspond to the mapping mode.
The size of the metafile picture for all modes except the MM_ISOTROPIC and MM_ANISOTROPIC modes. The y-extent specifies the height of the
rectangle within which the picture is drawn. The coordinates are in units that correspond to the mapping mode. For MM_ISOTROPIC and
MM_ANISOTROPIC modes, which can be scaled, the and members contain an optional suggested size in
MM_HIMETRIC units. For MM_ANISOTROPIC pictures, and
can be zero when no suggested size is supplied. For MM_ISOTROPIC pictures, an aspect ratio must be supplied even when no
suggested size is given. (If a suggested size is given, the aspect ratio is implied by the size.) To give an aspect ratio without implying a
suggested size, set and to negative values whose ratio is the appropriate aspect ratio. The magnitude of
the negative and values is ignored; only the ratio is used.
A handle to a memory metafile.
The structure defines the color adjustment values used by the and
functions when the stretch mode is HALFTONE. You can set the color adjustment values by calling the
function.
The size, in bytes, of the structure.
Specifies how the output image should be prepared. This member may be set to NULL or any combination of the following values.
-
CA_NEGATIVE
Specifies that the negative of the original image should be displayed.
-
CA_LOG_FILTER
Specifies that a logarithmic function should be applied to the final density of the output colors. This will increase the color
contrast when the luminance is low.
The type of standard light source under which the image is viewed. This member may be set to one of the following values.
-
ILLUMINANT_DEVICE_DEFAULT
Device's default. Standard used by output devices.
-
ILLUMINANT_A
Tungsten lamp.
-
ILLUMINANT_B
Noon sunlight.
-
ILLUMINANT_C
NTSC daylight.
-
ILLUMINANT_D50
Normal print.
-
ILLUMINANT_D55
Bond paper print.
-
ILLUMINANT_D65
Standard daylight. Standard for CRTs and pictures.
-
ILLUMINANT_D75
Northern daylight.
-
ILLUMINANT_F2
Cool white lamp.
-
ILLUMINANT_TUNGSTEN
Same as ILLUMINANT_A.
-
ILLUMINANT_DAYLIGHT
Same as ILLUMINANT_C.
-
ILLUMINANT_FLUORESCENT
Same as ILLUMINANT_F2.
-
ILLUMINANT_NTSC
Same as ILLUMINANT_C.
Specifies the nth power gamma-correction value for the red primary of the source colors. The value must be in the range from 2500 to 65,000. A
value of 10,000 means no gamma correction.
Specifies the nth power gamma-correction value for the green primary of the source colors. The value must be in the range from 2500 to 65,000. A
value of 10,000 means no gamma correction.
Specifies the nth power gamma-correction value for the blue primary of the source colors. The value must be in the range from 2500 to 65,000. A
value of 10,000 means no gamma correction.
The black reference for the source colors. Any colors that are darker than this are treated as black. The value must be in the range from 0
to 4000.
The white reference for the source colors. Any colors that are lighter than this are treated as white. The value must be in the range from 6000
to 10,000.
The amount of contrast to be applied to the source object. The value must be in the range from -100 to 100. A value of 0 means no contrast
adjustment.
The amount of brightness to be applied to the source object. The value must be in the range from -100 to 100. A value of 0 means no brightness
adjustment.
The amount of colorfulness to be applied to the source object. The value must be in the range from -100 to 100. A value of 0 means no
colorfulness adjustment.
The amount of red or green tint adjustment to be applied to the source object. The value must be in the range from -100 to 100. Positive numbers
adjust toward red and negative numbers adjust toward green. Zero means no tint adjustment.
The structure specifies the color and usage of an entry in a logical palette. A logical palette is defined by a
structure.
The red intensity value for the palette entry.
The green intensity value for the palette entry.
The blue intensity value for the palette entry.
Indicates how the palette entry is to be used. This member may be set to 0 or one of the following values.
-
PC_EXPLICIT
Specifies that the low-order word of the logical palette entry designates a hardware palette index. This flag allows the application
to show the contents of the display device palette.
-
PC_NOCOLLAPSE
Specifies that the color be placed in an unused entry in the system palette instead of being matched to an existing color in the
system palette. If there are no unused entries in the system palette, the color is matched normally. Once this color is in the system
palette, colors in other logical palettes can be matched to this color.
-
PC_RESERVED
Specifies that the logical palette entry be used for palette animation. This flag prevents other windows from matching colors to the
palette entry since the color frequently changes. If an unused system-palette entry is available, the color is placed in that entry.
Otherwise, the color is not available for animation.
The structure defines the dimensions and color information for a DIB.
A structure that contains information about the dimensions of color format.
.
The member contains one of the following:
The number of entries in the array depends on the values of the and
members of the
structure.
The colors in the table appear in order of importance. For more information, see the Remarks section.
The structure defines the style, width, and color of a pen. The function uses the
structure.
The pen style, which can be one of the following values.
-
PS_SOLID
The pen is solid.
-
PS_DASH
The pen is dashed.
-
PS_DOT
The pen is dotted.
-
PS_DASHDOT
The pen has alternating dashes and dots.
-
PS_DASHDOTDOT
The pen has dashes and double dots.
-
PS_NULL
The pen is invisible.
-
PS_INSIDEFRAME
The pen is solid. When this pen is used in any GDI drawing function that takes a bounding rectangle, the dimensions of the figure are
shrunk so that it fits entirely in the bounding rectangle, taking into account the width of the pen. This applies only to geometric
pens.
The structure that contains the pen width, in logical units. If the pointer member is NULL, the pen is one pixel wide on
raster devices. The member in the structure for is not used.
The pen color. To generate a structure, use the RGB macro.
The structure contains information about a physical font.
A structure, containing information about a physical font.
An structure, containing information about the axes for the font. This is only used for multiple master fonts.
The structure contains information on all the axes of a multiple master font.
Reserved. Must be STAMP_AXESLIST.
Number of axes for a specified multiple master font.
An array of structures. Each structure contains information on an axis of a specified multiple
master font. This corresponds to the array in the structure.
The structure contains information about an axis of a multiple master font.
The minimum value for this axis.
The maximum value for this axis.
The name of the axis, specified as an array of characters.
The structure contains information about a physical font.
A structure.
A structure indicating the coverage of the font.
The structure contains data that describes a physical font.
The height (ascent + descent) of characters.
The ascent (units above the base line) of characters.
The descent (units below the base line) of characters.
The amount of leading (space) inside the bounds set by the member. Accent marks and other diacritical characters may
occur in this area. The designer may set this member to zero.
The amount of extra leading (space) that the application adds between rows. Since this area is outside the font, it contains no marks and is not
altered by text output calls in either OPAQUE or TRANSPARENT mode. The designer may set this member to zero.
The average width of characters in the font (generally defined as the width of the letter x). This value does not include overhang required for
bold or italic characters.
The width of the widest character in the font.
The weight of the font.
The extra width per string that may be added to some synthesized fonts. When synthesizing some attributes, such as bold or italic, graphics
device interface (GDI) or a device may have to add width to a string on both a per-character and per-string basis. For example, GDI makes a
string bold by expanding the spacing of each character and overstriking by an offset value; it italicizes a font by shearing the string. In
either case, there is an overhang past the basic string. For bold strings, the overhang is the distance by which the overstrike is offset.
For italic strings, the overhang is the amount the top of the font is sheared past the bottom of the font.
The member enables the application to determine how much of the character width returned by a
function call on a single character is the actual character width and how much is the per-string
extra width. The actual width is the extent minus the overhang.
The horizontal aspect of the device for which the font was designed.
The vertical aspect of the device for which the font was designed. The ratio of the and
members is the aspect ratio of the device for which the font was designed.
The value of the first character defined in the font.
The value of the last character defined in the font.
The value of the character to be substituted for characters that are not in the font.
The value of the character to be used to define word breaks for text justification.
An italic font if it is nonzero.
An underlined font if it is nonzero.
A strikeout font if it is nonzero.
The pitch and family of the selected font. The low-order bit (bit 0) specifies the pitch of the font. If it is 1, the font is variable pitch
(or proportional). If it is 0, the font is fixed pitch (or monospace). Bits 1 and 2 specify the font type. If both bits are 0, the font is a
raster font; if bit 1 is 1 and bit 2 is 0, the font is a vector font; if bit 1 is 0 and bit 2 is set, or if both bits are 1, the font is some
other type. Bit 3 is 1 if the font is a device font; otherwise, it is 0.
The four high-order bits designate the font family. The member can be combined with the hexadecimal value
0xF0 by using the bitwise AND operator and can then be compared with the font family names for an identical match. For more information about
the font families, see .
The character set of the font.
Specifies whether the font is italic, underscored, outlined, bold, and so forth. May be any reasonable combination of the following values.
-
0
NTM_ITALIC
-
5
NTM_BOLD
-
8
NTM_REGULAR
-
16
NTM_NONNEGATIVE_AC
-
17
NTM_PS_OPENTYPE
-
18
NTM_TT_OPENTYPE
-
19
NTM_MULTIPLEMASTER
-
20
NTM_TYPE1
-
21
NTM_DSIG
The size of the em square for the font. This value is in notional units (that is, the units for which the font was designed).
The height, in notional units, of the font. This value should be compared with the value of the member.
The average width of characters in the font, in notional units. This value should be compared with the value of the
member.
The structure contains information about a curve in the outline of a TrueType character.
The type of curve described by the structure. This member can be one of the following values.
-
TT_PRIM_LINE
Curve is a polyline.
-
TT_PRIM_QSPLINE
Curve is a quadratic BĂ©zier spline.
-
TT_PRIM_CSPLINE
Curve is a cubic BĂ©zier spline.
The number of structures in the array.
Specifies an array of structures that define the polyline or BĂ©zier spline.
The structure specifies the starting position and type of a contour in a TrueType character outline.
The number of bytes required by the structure and structure or structures required to
describe the contour of the character.
The type of character outline returned. Currently, this value must be TT_POLYGON_TYPE.
The starting point of the contour in the character outline.
The structure contains the coordinates of points that describe the outline of a character in a TrueType font.
The x-component of a point on the outline of a TrueType character.
The y-component of a point on the outline of a TrueType character.
The structure defines the pen style, width, and brush attributes for an extended pen. This structure is used by the
function when it retrieves a description of a pen that was created when an application called the
function.
A combination of pen type, style, end cap style, and join style. The values from each category can be retrieved by using a bitwise AND
operator with the appropriate mask.
The member masked with PS_TYPE_MASK has one of the following pen type values.
-
PS_GEOMETRIC
The pen is geometric.
-
PS_COSMETIC
The pen is cosmetic.
The member masked with PS_STYLE_MASK has one of the following pen styles values:
-
PS_DASH
The pen is dashed.
-
PS_DASHDOT
The pen has alternating dashes and dots.
-
PS_DASHDOTDOT
The pen has alternating dashes and double dots.
-
PS_DOT
The pen is dotted.
-
PS_INSIDEFRAME
The pen is solid. When this pen is used in any GDI drawing function that takes a bounding rectangle, the dimensions of the figure are
shrunk so that it fits entirely in the bounding rectangle, taking into account the width of the pen. This applies only to
PS_GEOMETRIC pens.
-
PS_NULL
The pen is invisible.
-
PS_SOLID
The pen is solid.
-
PS_USERSTYLE
The pen uses a styling array supplied by the user.
The following category applies only to PS_GEOMETRIC pens. The member masked with PS_ENDCAP_MASK has one of the
following end cap values.
-
PS_ENDCAP_FLAT
Line end caps are flat.
-
PS_ENDCAP_ROUND
Line end caps are round.
-
PS_ENDCAP_SQUARE
Line end caps are square.
The following category applies only to PS_GEOMETRIC pens. The member masked with PS_JOIN_MASK has one of the
following join values.
-
PS_JOIN_BEVEL
Line joins are beveled.
-
PS_JOIN_MITER
Line joins are mitered when they are within the current limit set by the function. A join is
beveled when it would exceed the limit.
-
PS_JOIN_ROUND
Line joins are round.
The width of the pen. If the member is PS_GEOMETRIC, this value is the width of the line in logical units. Otherwise,
the lines are cosmetic and this value is 1, which indicates a line with a width of one pixel.
The brush style of the pen. The member value can be one of the following.
-
BS_DIBPATTERN
Specifies a pattern brush defined by a DIB specification. If is BS_DIBPATTERN, the
member contains a handle to a packed DIB. For more information, see discussion in
///
-
BS_DIBPATTERNPT
Specifies a pattern brush defined by a DIB specification. If is BS_DIBPATTERNPT, the
member contains a pointer to a packed DIB. For more information, see discussion in .
///
-
BS_HATCHED
Specifies a hatched brush.
-
BS_HOLLOW
Specifies a hollow or NULL brush.
-
BS_PATTERN
Specifies a pattern brush defined by a memory bitmap.
-
BS_SOLID
Specifies a solid brush.
If is BS_SOLID or BS_HATCHED, specifies the color in which the pen is to be drawn. For
BS_HATCHED, the and functions determine the background color.
If is BS_HOLLOW or BS_PATTERN, is ignored.
If is BS_DIBPATTERN or BS_DIBPATTERNPT, the low-order word of specifies whether the
member of the structure contain explicit RGB values or indices into the
currently realized logical palette. The value must be one of the following.
-
DIB_PAL_COLORS
The color table consists of an array of 16-bit indices into the currently realized logical palette.
-
DIB_RGB_COLORS
The color table contains literal RGB values.
The RGB macro is used to generate a structure.
If is BS_PATTERN, is a handle to the bitmap that defines the pattern.
If is BS_SOLID or BS_HOLLOW, is ignored.
If is BS_DIBPATTERN, the member is a handle to a packed DIB. To obtain this handle, an
application calls the GlobalAlloc function with GMEM_MOVEABLE (or LocalAlloc with LMEM_MOVEABLE) to allocate a block of memory and then fills
the memory with the packed DIB. A packed DIB consists of a structure immediately followed by the array of bytes
that define the pixels of the bitmap.
If is BS_DIBPATTERNPT, the member is a pointer to a packed DIB. The pointer derives from
the memory block created by LocalAlloc with LMEM_FIXED set or by GlobalAlloc with GMEM_FIXED set, or it is the pointer returned by a call
like LocalLock (handle_to_the_dib). A packed DIB consists of a structure immediately followed by the array of bytes
that define the pixels of the bitmap.
If is BS_HATCHED, the member specifies the orientation of the lines used to create the
hatch. It can be one of the following values.
-
HS_BDIAGONAL
45-degree upward hatch (left to right)
-
HS_CROSS
Horizontal and vertical crosshatch
-
HS_DIAGCROSS
45-degree crosshatch
-
HS_FDIAGONAL
45-degree downward hatch (left to right)
-
HS_HORIZONTAL
Horizontal hatch
-
HS_VERTICAL
Vertical hatch
The number of entries in the style array in the member. This value is zero if does not
specify PS_USERSTYLE.
A user-supplied style array. The array is specified with a finite length, but it is used as if it repeated indefinitely. The first entry in
the array specifies the length of the first dash. The second entry specifies the length of the first gap. Thereafter, lengths of dashes and
gaps alternate.
If specifies geometric lines, the lengths are in logical units. Otherwise, the lines are cosmetic and lengths are in
device units.
The structure is the bitmap information header file. It is an extended version of the
structure.
The number of bytes required by the structure. Applications should use this member to determine which bitmap information header structure is
being used.
The width of the bitmap, in pixels.
If is BI_JPEG or BI_PNG, the member specifies the width of the decompressed JPEG or PNG
image in pixels.
The height of the bitmap, in pixels. If the value of is positive, the bitmap is a bottom-up DIB and its origin is
the lower-left corner. If value is negative, the bitmap is a top-down DIB and its origin is the upper-left corner.
If is negative, indicating a top-down DIB, must be either BI_RGB or BI_BITFIELDS.
Top-down DIBs cannot be compressed.
If is BI_JPEG or BI_PNG, the member specifies the height of the decompressed JPEG or
PNG image in pixels.
The number of planes for the target device. This value must be set to 1.
The number of bits that define each pixel and the maximum number of colors in the bitmap.
This member can be one of the following values.
-
0
The number of bits per pixel is specified or is implied by the JPEG or PNG file format.
-
1
The bitmap is monochrome, and the member of contains two entries. Each
bit in the bitmap array represents a pixel. If the bit is clear, the pixel is displayed with the color of the first entry in the
color table. If the bit is set, the pixel has the color of the second entry in the table. ///
-
4
The bitmap has a maximum of 16 colors, and the member of contains up to
16 entries. Each pixel in the bitmap is represented by a 4-bit index into the color table. For example, if the first byte in the
bitmap is 0x1F, the byte represents two pixels. The first pixel contains the color in the second table entry, and the second pixel
contains the color in the sixteenth table entry. ///
-
8
The bitmap has a maximum of 256 colors, and the member of contains up
to 256 entries. In this case, each byte in the array represents a single pixel. ///
-
16
If the member of the is BI_BITFIELDS, the
member contains three DWORD color masks that specify the red, green, and blue components, respectively, of each pixel. Each WORD
in the bitmap array represents a single pixel.
When the member is BI_BITFIELDS, bits set in each DWORD mask must be contiguous and should not
overlap the bits of another mask. All the bits in the pixel do not need to be used.
-
24
The bitmap has a maximum of 2^24 colors, and the member of is NULL.
Each 3-byte triplet in the bitmap array represents the relative intensities of blue, green, and red, respectively, for a pixel. The
color table is used for optimizing colors used on palette-based devices, and must contain the
number of entries specified by the member of the structure. ///
-
32
If the member of the is BI_BITFIELDS, the
member contains three DWORD color masks that specify the red, green, and blue components of each pixel. Each DWORD in the bitmap
array represents a single pixel.
Specifies that the bitmap is not compressed. The , , and
members specify the red, green, and blue components of each pixel. This is valid when used with 16- and 32-bpp bitmaps. This member can be
one of the following values.
-
BI_RGB
An uncompressed format.
-
BI_RLE8
A run-length encoded (RLE) format for bitmaps with 8 bpp. The compression format is a two-byte format consisting of a count byte
followed by a byte containing a color index. If is BI_RGB and the member is
16, 24, or 32, the bitmap array specifies the actual intensities of blue, green, and red rather than using color table indexes. For
more information, see Bitmap Compression. ///
-
BI_RLE4
An RLE format for bitmaps with 4 bpp. The compression format is a two-byte format consisting of a count byte followed by two
word-length color indexes. For more information, see Bitmap Compression.
-
BI_BITFIELDS
Specifies that the bitmap is not compressed and that the color masks for the red, green, and blue components of each pixel are
specified in the , , and members. This is valid when
used with 16- and 32-bpp bitmaps. ///
-
BI_JPEG
Specifies that the image is compressed using the JPEG file Interchange Format. JPEG compression trades off compression against loss;
it can achieve a compression ratio of 20:1 with little noticeable loss.
-
BI_PNG
Specifies that the image is compressed using the PNG file Interchange Format.
The size, in bytes, of the image. This may be set to zero for BI_RGB bitmaps.
If is BI_JPEG or BI_PNG, is the size of the JPEG or PNG image buffer.
The horizontal resolution, in pixels-per-meter, of the target device for the bitmap. An application can use this value to select a bitmap from a
resource group that best matches the characteristics of the current device.
The vertical resolution, in pixels-per-meter, of the target device for the bitmap.
The number of color indexes in the color table that are actually used by the bitmap. If this value is zero, the bitmap uses the maximum
number of colors corresponding to the value of the member for the compression mode specified by
.
If is nonzero and is less than 16, the member specifies the
actual number of colors the graphics engine or device driver accesses. If is 16 or greater, the
member specifies the size of the color table used to optimize performance of the system color palettes. If
equals 16 or 32, the optimal color palette starts immediately following the . If
is nonzero, the color table is used on palettized devices, and specifies the number of
entries.
The number of color indexes that are required for displaying the bitmap. If this value is zero, all colors are required.
Color mask that specifies the red component of each pixel, valid only if is set to BI_BITFIELDS.
Color mask that specifies the green component of each pixel, valid only if is set to BI_BITFIELDS.
Color mask that specifies the blue component of each pixel, valid only if is set to BI_BITFIELDS.
Color mask that specifies the alpha component of each pixel.
The color space of the DIB.
The following table specifies the values for .
-
LCS_CALIBRATED_RGB
This value implies that endpoints and gamma values are given in the appropriate fields.
-
LCS_sRGB
Specifies that the bitmap is in sRGB color space.
-
LCS_WINDOWS_COLOR_SPACE
This value indicates that the bitmap is in the system default color space, sRGB.
-
PROFILE_LINKED
This value indicates that points to the file name of the profile to use (gamma and endpoints values are
ignored).
-
PROFILE_EMBEDDED
This value indicates that points to a memory buffer that contains the profile to be used (gamma and
endpoints values are ignored).
See the structure for information that defines a logical color space.
A structure that specifies the x, y, and z coordinates of the three colors that correspond to the red, green, and
blue endpoints for the logical color space associated with the bitmap. This member is ignored unless the member
specifies LCS_CALIBRATED_RGB.
Toned response curve for red. Used if is set to LCS_CALIBRATED_RGB. Specify in unsigned fixed 16.16 format. The upper 16
bits are the unsigned integer value. The lower 16 bits are the fractional part.
Toned response curve for green. Used if is set to LCS_CALIBRATED_RGB. Specify in unsigned fixed 16.16 format. The upper
16 bits are the unsigned integer value. The lower 16 bits are the fractional part.
Toned response curve for blue. Used if is set to LCS_CALIBRATED_RGB. Specify in unsigned fixed 16.16 format. The upper
16 bits are the unsigned integer value. The lower 16 bits are the fractional part.
Rendering intent for bitmap. This can be one of the following values.
-
LCS_GM_ABS_COLORIMETRIC
Match
-
LCS_GM_BUSINESS
Graphic
-
LCS_GM_GRAPHICS
Proof
-
LCS_GM_IMAGES
Picture
The offset, in bytes, from the beginning of the structure to the start of the profile data. If the profile is
embedded, profile data is the actual profile, and it is linked. (The profile data is the null-terminated file name of the profile.) This cannot
be a Unicode string. It must be composed exclusively of characters from the Windows character set (code page 1252). These profile members are
ignored unless the member specifies PROFILE_LINKED or PROFILE_EMBEDDED.
Size, in bytes, of embedded profile data.
This member has been reserved. Its value should be set to zero.
The structure is the bitmap information header file. It is an extended version of the
structure.
Applications can use the structure for added functionality.
The number of bytes required by the structure. Applications should use this member to determine which bitmap information header structure is
being used.
The width of the bitmap, in pixels.
If is BI_JPEG or BI_PNG, specifies the width of the JPEG or PNG image in pixels.
The height of the bitmap, in pixels. If is positive, the bitmap is a bottom-up DIB and its origin is the lower-left
corner. If is negative, the bitmap is a top-down DIB and its origin is the upper-left corner.
If is negative, indicating a top-down DIB, must be either BI_RGB or BI_BITFIELDS.
Top-down DIBs cannot be compressed.
If is BI_JPEG or BI_PNG, specifies the height of the JPEG or PNG image in pixels.
The number of planes for the target device. This value must be set to 1.
The number of bits-per-pixel. The member of the structure determines the number of
bits that define each pixel and the maximum number of colors in the bitmap. This member must be one of the following values.
-
0
The number of bits-per-pixel is specified or is implied by the JPEG or PNG file format.
-
1
The bitmap is monochrome, and the member of contains two entries. Each
bit in the bitmap array represents a pixel. If the bit is clear, the pixel is displayed with the color of the first entry in the
table; if the bit is set, the pixel has the color of the second entry in the table. ///
-
4
The bitmap has a maximum of 16 colors, and the member of contains up to
16 entries. Each pixel in the bitmap is represented by a 4-bit index into the color table. For example, if the first byte in the
bitmap is 0x1F, the byte represents two pixels. The first pixel contains the color in the second table entry, and the second pixel
contains the color in the sixteenth table entry. ///
-
8
The bitmap has a maximum of 256 colors, and the member of contains up
to 256 entries. In this case, each byte in the array represents a single pixel. ///
-
16
If the member of the is BI_BITFIELDS, the
member contains three DWORD color masks that specify the red, green, and blue components of each pixel. Each WORD in the bitmap
array represents a single pixel.
-
24
The bitmap has a maximum of 2^24 colors, and the member of is NULL.
Each 3-byte triplet in the bitmap array represents the relative intensities of blue, green, and red for a pixel. The
color table is used for optimizing colors used on palette-based devices, and must contain the number of entries specified by the
member of the . ///
-
32
If the member of the is BI_BITFIELDS, the
member contains three DWORD color masks that specify the red, green, and blue components of each pixel. Each DWORD in the bitmap
array represents a single pixel.
The type of compression for a compressed bottom-up bitmap (top-down DIBs cannot be compressed). This member can be one of the following
values.
-
BI_RGB
An uncompressed format.
-
BI_RLE8
A run-length encoded (RLE) format for bitmaps with 8 bpp. The compression format is a 2-byte format consisting of a count byte
followed by a byte containing a color index. For more information, see Bitmap Compression.
-
BI_RLE4
An RLE format for bitmaps with 4 bpp. The compression format is a 2-byte format consisting of a count byte followed by two
word-length color indexes. For more information, see Bitmap Compression.
-
BI_BITFIELDS
Specifies that the bitmap is not compressed. The members , , and
specify the red, green, and blue components for each pixel. This is valid when used with 16- and 32-bpp
bitmaps. ///
-
BI_JPEG
Specifies that the image is compressed using the JPEG file interchange format. JPEG compression trades off compression against loss;
it can achieve a compression ratio of 20:1 with little noticeable loss.
-
BI_PNG
Specifies that the image is compressed using the PNG file interchange format.
The size, in bytes, of the image. This may be set to zero for BI_RGB bitmaps.
If is BI_JPEG or BI_PNG, is the size of the JPEG or PNG image buffer.
The horizontal resolution, in pixels-per-meter, of the target device for the bitmap. An application can use this value to select a bitmap from a
resource group that best matches the characteristics of the current device.
The vertical resolution, in pixels-per-meter, of the target device for the bitmap.
The number of color indexes in the color table that are actually used by the bitmap. If this value is zero, the bitmap uses the maximum
number of colors corresponding to the value of the member for the compression mode specified by
.
If is nonzero and the member is less than 16, the member
specifies the actual number of colors the graphics engine or device driver accesses. If is 16 or greater, the
member specifies the size of the color table used to optimize performance of the system color palettes. If
equals 16 or 32, the optimal color palette starts immediately following the .
The number of color indexes that are required for displaying the bitmap. If this value is zero, all colors are important.
Color mask that specifies the red component of each pixel, valid only if is set to BI_BITFIELDS.
Color mask that specifies the green component of each pixel, valid only if is set to BI_BITFIELDS.
Color mask that specifies the blue component of each pixel, valid only if is set to BI_BITFIELDS.
Color mask that specifies the alpha component of each pixel.
The color space of the DIB. The following table lists the value for .
-
LCS_CALIBRATED_RGB
This value indicates that endpoints and gamma values are given in the appropriate fields.
See the structure for information that defines a logical color space.
A structure that specifies the x, y, and z coordinates of the three colors that correspond to the red, green, and
blue endpoints for the logical color space associated with the bitmap. This member is ignored unless the member
specifies LCS_CALIBRATED_RGB.
Note A color space is a model for representing color numerically in terms of three or more coordinates. For example, the RGB color space
represents colors in terms of the red, green, and blue coordinates.
Tone response curve for red. This member is ignored unless color values are calibrated RGB values and is set to
LCS_CALIBRATED_RGB. Specify in unsigned fixed 16.16 format. The upper 16 bits are the unsigned integer value. The lower 16 bits are the
fractional part.
Tone response curve for green. Used if is set to LCS_CALIBRATED_RGB. Specify in unsigned fixed 16.16 format. The upper
16 bits are the unsigned integer value. The lower 16 bits are the fractional part.
Tone response curve for blue. Used if is set to LCS_CALIBRATED_RGB. Specify in unsigned fixed 16.16 format. The upper 16
bits are the unsigned integer value. The lower 16 bits are the fractional part.
The structure describes the pixel format of a drawing surface.
Specifies the size of this data structure. This value should be set to sizeof().
Specifies the version of this data structure. This value should be set to 1.
A set of bit flags that specify properties of the pixel buffer. The properties are generally not mutually exclusive; you can set any
combination of bit flags, with the exceptions noted. The following bit flag constants are defined.
-
PFD_DRAW_TO_WINDOW
The buffer can draw to a window or device surface.
-
PFD_DRAW_TO_BITMAP
The buffer can draw to a memory bitmap.
-
PFD_SUPPORT_GDI
The buffer supports GDI drawing. This flag and PFD_DOUBLEBUFFER are mutually exclusive in the current generic
implementation.
-
PFD_SUPPORT_OPENGL
The buffer supports OpenGL drawing.
-
PFD_GENERIC_ACCELERATED
The pixel format is supported by a device driver that accelerates the generic implementation. If this flag is clear and the
PFD_GENERIC_FORMAT flag is set, the pixel format is supported by the generic implementation only.
-
PFD_GENERIC_FORMAT
The pixel format is supported by the GDI software implementation, which is also known as the generic implementation. If this bit is
clear, the pixel format is supported by a device driver or hardware.
-
PFD_NEED_PALETTE
The buffer uses RGBA pixels on a palette-managed device. A logical palette is required to achieve the best results for this pixel
type. Colors in the palette should be specified according to the values of the , ,
, , , and members. The palette
should be created and realized in the device context before calling wglMakeCurrent.
-
PFD_NEED_SYSTEM_PALETTE
When this flag is set, you must call in your program to force a one-to-one mapping of
the logical palette and the system palette. If your OpenGL hardware supports multiple hardware palettes and the device driver can
allocate spare hardware palettes for OpenGL, this flag is typically clear.
This flag is not set in the generic pixel formats.
-
PFD_DOUBLEBUFFER
The buffer is double-buffered. This flag and PFD_SUPPORT_GDI are mutually exclusive in the current generic implementation.
-
PFD_STEREO
The buffer is stereoscopic. This flag is not supported in the current generic implementation.
-
PFD_SWAP_LAYER_BUFFERS
Indicates whether a device can swap individual layer planes with pixel formats that include double-buffered overlay or underlay
planes. Otherwise all layer planes are swapped together as a group. When this flag is set, wglSwapLayerBuffers is supported.
You can specify the following bit flags when calling .
-
PFD_DEPTH_DONTCARE
The requested pixel format can either have or not have a depth buffer. To select a pixel format without a depth buffer, you must
specify this flag. The requested pixel format can be with or without a depth buffer. Otherwise, only pixel formats with a depth
buffer are considered.
-
PFD_DOUBLEBUFFER_DONTCARE
The requested pixel format can be either single- or double-buffered.
-
PFD_STEREO_DONTCARE
The requested pixel format can be either monoscopic or stereoscopic.
With the glAddSwapHintRectWIN extension function, two new flags are included for the
pixel format structure.
-
PFD_SWAP_COPY
Specifies the content of the back buffer in the double-buffered main color plane following a buffer swap. Swapping the color buffers
causes the content of the back buffer to be copied to the front buffer. The content of the back buffer is not affected by the swap.
PFD_SWAP_COPY is a hint only and might not be provided by a driver.
-
PFD_SWAP_EXCHANGE
Specifies the content of the back buffer in the double-buffered main color plane following a buffer swap. Swapping the color buffers
causes the exchange of the back buffer's content with the front buffer's content. Following the swap, the back buffer's content
contains the front buffer's content before the swap. PFD_SWAP_EXCHANGE is a hint only and might not be provided by a driver.
Specifies the type of pixel data. The following types are defined.
-
PFD_TYPE_RGBA
RGBA pixels. Each pixel has four components in this order: red, green, blue, and alpha.
-
PFD_TYPE_COLORINDEX
Color-index pixels. Each pixel uses a color-index value.
Specifies the number of color bitplanes in each color buffer. For RGBA pixel types, it is the size of the color buffer, excluding the alpha
bitplanes. For color-index pixels, it is the size of the color-index buffer.
Specifies the number of red bitplanes in each RGBA color buffer.
Specifies the shift count for red bitplanes in each RGBA color buffer.
Specifies the number of green bitplanes in each RGBA color buffer.
Specifies the shift count for green bitplanes in each RGBA color buffer.
Specifies the number of blue bitplanes in each RGBA color buffer.
Specifies the shift count for blue bitplanes in each RGBA color buffer.
Specifies the number of alpha bitplanes in each RGBA color buffer. Alpha bitplanes are not supported.
Specifies the shift count for alpha bitplanes in each RGBA color buffer. Alpha bitplanes are not supported.
Specifies the total number of bitplanes in the accumulation buffer.
Specifies the number of red bitplanes in the accumulation buffer.
Specifies the number of green bitplanes in the accumulation buffer.
Specifies the number of blue bitplanes in the accumulation buffer.
Specifies the number of alpha bitplanes in the accumulation buffer.
Specifies the depth of the depth (z-axis) buffer.
Specifies the depth of the stencil buffer.
Specifies the number of auxiliary buffers. Auxiliary buffers are not supported.
Ignored. Earlier implementations of OpenGL used this member, but it is no longer used.
Specifies the number of overlay and underlay planes. Bits 0 through 3 specify up to 15 overlay planes and bits 4 through 7 specify up to 15
underlay planes.
Ignored. Earlier implementations of OpenGL used this member, but it is no longer used.
Specifies the transparent color or index of an underlay plane. When the pixel type is RGBA, is a transparent RGB
color value. When the pixel type is color index, it is a transparent index value.
Ignored. Earlier implementations of OpenGL used this member, but it is no longer used.
The structure describes a color consisting of relative intensities of red, green, and blue.
The intensity of blue in the color.
The intensity of green in the color.
The intensity of red in the color.
This member is reserved and must be zero.
The structure contains the values for a transformation matrix used by the function.
A fixed-point value for the M11 component of a 3 by 3 transformation matrix.
A fixed-point value for the M12 component of a 3 by 3 transformation matrix.
A fixed-point value for the M21 component of a 3 by 3 transformation matrix.
A fixed-point value for the M22 component of a 3 by 3 transformation matrix.
The structure contains a header and an array of rectangles that compose a region. The rectangles are sorted top to bottom,
left to right. They do not overlap.
A structure. The members of this structure specify the type of region (whether it is rectangular or trapezoidal),
the number of rectangles that make up the region, the size of the buffer that contains the rectangle structures, and so on.
Specifies an arbitrary-size buffer that contains the structures that make up the region.
The structure contains information about the dimensions and color format of a DIB.
The number of bytes required by the structure.
The width of the bitmap, in pixels.
If is BI_JPEG or BI_PNG, the member specifies the width of the decompressed JPEG or PNG
image file, respectively.
The height of the bitmap, in pixels. If is positive, the bitmap is a bottom-up DIB and its origin is the lower-left
corner. If is negative, the bitmap is a top-down DIB and its origin is the upper-left corner.
If is negative, indicating a top-down DIB, must be either BI_RGB or BI_BITFIELDS.
Top-down DIBs cannot be compressed.
If is BI_JPEG or BI_PNG, the member specifies the height of the decompressed JPEG or PNG
image file, respectively.
The number of planes for the target device. This value must be set to 1.
The number of bits-per-pixel. The member of the structure determines the number of
bits that define each pixel and the maximum number of colors in the bitmap. This member must be one of the following values.
-
0
The number of bits-per-pixel is specified or is implied by the JPEG or PNG format.
-
1
The bitmap is monochrome, and the member of contains two entries. Each
bit in the bitmap array represents a pixel. If the bit is clear, the pixel is displayed with the color of the first entry in the
table; if the bit is set, the pixel has the color of the second entry in the table. ///
-
4
The bitmap has a maximum of 16 colors, and the member of contains up to
16 entries. Each pixel in the bitmap is represented by a 4-bit index into the color table. For example, if the first byte in the
bitmap is 0x1F, the byte represents two pixels. The first pixel contains the color in the second table entry, and the second pixel
contains the color in the sixteenth table entry. ///
-
8
The bitmap has a maximum of 256 colors, and the member of contains up
to 256 entries. In this case, each byte in the array represents a single pixel. ///
-
16
If the member of the is BI_BITFIELDS, the
member contains three DWORD color masks that specify the red, green, and blue components, respectively, of each pixel. Each WORD
in the bitmap array represents a single pixel.
When the member is BI_BITFIELDS, bits set in each DWORD mask must be contiguous and should not
overlap the bits of another mask. All the bits in the pixel do not have to be used.
-
24
The bitmap has a maximum of 2^24 colors, and the member of is NULL.
Each 3-byte triplet in the bitmap array represents the relative intensities of blue, green, and red, respectively, for a pixel. The
color table is used for optimizing colors used on palette-based devices, and must contain the
number of entries specified by the member of the . ///
-
32
If the member of the is BI_BITFIELDS, the
member contains three DWORD color masks that specify the red, green, and blue components, respectively, of each pixel. Each DWORD
in the bitmap array represents a single pixel.
When the member is BI_BITFIELDS, bits set in each DWORD mask must be contiguous and should not
overlap the bits of another mask. All the bits in the pixel do not need to be used.
The type of compression for a compressed bottom-up bitmap (top-down DIBs cannot be compressed). This member can be one of the following
values.
-
BI_RGB
An uncompressed format.
-
BI_RLE8
A run-length encoded (RLE) format for bitmaps with 8 bpp. The compression format is a 2-byte format consisting of a count byte
followed by a byte containing a color index. For more information, see Bitmap Compression.
-
BI_RLE4
An RLE format for bitmaps with 4 bpp. The compression format is a 2-byte format consisting of a count byte followed by two
word-length color indexes. For more information, see Bitmap Compression.
-
BI_BITFIELDS
Specifies that the bitmap is not compressed and that the color table consists of three DWORD color masks that specify the red, green,
and blue components, respectively, of each pixel. This is valid when used with 16- and 32-bpp bitmaps.
-
BI_JPEG
Indicates that the image is a JPEG image.
-
BI_PNG
Indicates that the image is a PNG image.
The size, in bytes, of the image. This may be set to zero for BI_RGB bitmaps.
If is BI_JPEG or BI_PNG, indicates the size of the JPEG or PNG image buffer,
respectively.
The horizontal resolution, in pixels-per-meter, of the target device for the bitmap. An application can use this value to select a bitmap from a
resource group that best matches the characteristics of the current device.
The vertical resolution, in pixels-per-meter, of the target device for the bitmap.
The number of color indexes in the color table that are actually used by the bitmap. If this value is zero, the bitmap uses the maximum
number of colors corresponding to the value of the member for the compression mode specified by
.
If is nonzero and the member is less than 16, the member
specifies the actual number of colors the graphics engine or device driver accesses. If is 16 or greater, the
member specifies the size of the color table used to optimize performance of the system color palettes. If
equals 16 or 32, the optimal color palette starts immediately following the three DWORD masks.
When the bitmap array immediately follows the structure, it is a packed bitmap. Packed bitmaps are referenced by a
single pointer. Packed bitmaps require that the member must be either zero or the actual size of the color table.
The number of color indexes that are required for displaying the bitmap. If this value is zero, all colors are required.
The structure defines a logical palette.
The version number of the system.
The number of entries in the logical palette.
Specifies an array of structures that define the color and usage of each entry in the logical palette.
The structure describes how the function should draw a string of text.
The horizontal reference point for the string. The string is aligned to this point using the current text-alignment mode.
The vertical reference point for the string. The string is aligned to this point using the current text-alignment mode.
The length of the string pointed to by .
Pointer to a string of text to be drawn by the function. This string need not be null-terminated, since
specifies the length of the string.
Specifies whether the string is to be opaque or clipped and whether the string is accompanied by an array of character-width values. This
member can be one or more of the following values.
-
ETO_OPAQUE
The rectangle for each string is to be opaqued with the current background color.
-
ETO_CLIPPED
Each string is to be clipped to its specified rectangle.
A rectangle structure that contains the dimensions of the opaquing or clipping rectangle. This member is ignored if neither of the ETO_OPAQUE nor
the ETO_CLIPPED value is specified for the member.
Pointer to an array containing the width value for each character in the string.
The structure contains the input and output file names and other information used by the
function.
The size, in bytes, of the structure.
Pointer to a null-terminated string that specifies the name of the document.
Pointer to a null-terminated string that specifies the name of an output file. If this pointer is NULL, the output will be sent to the device
identified by the device context handle that was passed to the function.
Pointer to a null-terminated string that specifies the type of data used to record the print job. The legal values for this member can be found
by calling EnumPrintProcessorDatatypes and can include such values as raw, emf, or XPS_PASS. This member can be NULL. Note that the requested
data type might be ignored.
Specifies additional information about the print job. This member must be zero or one of the following values.
-
DI_APPBANDING
Applications that use banding should set this flag for optimal performance during printing.
-
DI_ROPS_READ_DESTINATION
The application will use raster operations that involve reading from the destination surface.
The structure contains metrics describing a TrueType font.
The size, in bytes, of the structure.
A structure containing further information about the font.
A value that causes the structure to be byte-aligned.
The PANOSE number for this font.
The nature of the font pattern. This member can be a combination of the following bits.
-
0
Italic
-
1
Underscore
-
2
Negative
-
3
Outline
-
4
Strikeout
-
5
Bold
Indicates whether the font is licensed. Licensed fonts must not be modified or exchanged. If bit 1 is set, the font may not be embedded in a
document. If bit 1 is clear, the font can be embedded. If bit 2 is set, the embedding is read-only.
The slope of the cursor. This value is 1 if the slope is vertical. Applications can use this value and the value of the
member to create an italic cursor that has the same slope as the main italic angle (specified by the
member).
The slope of the cursor. This value is zero if the slope is vertical. Applications can use this value and the value of the
member to create an italic cursor that has the same slope as the main italic angle (specified by the
member).
The main italic angle of the font, in tenths of a degree counterclockwise from vertical. Regular (roman) fonts have a value of zero. Italic fonts
typically have a negative italic angle (that is, they lean to the right).
The number of logical units defining the x- or y-dimension of the em square for this font. (The number of units in the x- and y-directions are
always the same for an em square.)
The maximum distance characters in this font extend above the base line. This is the typographic ascent for the font.
The maximum distance characters in this font extend below the base line. This is the typographic descent for the font.
The typographic line spacing.
Not supported.
Not supported.
The bounding box for the font.
The maximum distance characters in this font extend above the base line for the Macintosh computer.
The maximum distance characters in this font extend below the base line for the Macintosh computer.
The line-spacing information for the Macintosh computer.
The smallest recommended size for this font, in pixels per em-square.
The recommended horizontal and vertical size for subscripts in this font.
The recommended horizontal and vertical offset for subscripts in this font. The subscript offset is measured from the character origin to the
origin of the subscript character.
The recommended horizontal and vertical size for superscripts in this font.
The recommended horizontal and vertical offset for superscripts in this font. The superscript offset is measured from the character base line to
the base line of the superscript character.
The width of the strikeout stroke for this font. Typically, this is the width of the em dash for the font.
The position of the strikeout stroke relative to the base line for this font. Positive values are above the base line and negative values
are below.
The thickness of the underscore character for this font.
The position of the underscore character for this font.
The offset from the beginning of the structure to a string specifying the family name for the font.
The offset from the beginning of the structure to a string specifying the typeface name for the font. (This typeface name corresponds to the name
specified in the structure.)
The offset from the beginning of the structure to a string specifying the style name for the font.
The offset from the beginning of the structure to a string specifying the full name for the font. This name is unique for the font and often
contains a version number or other identifying information.
The structure contains information about characters in a string. This structure receives the results of the
function. For some languages, the first element in the arrays may contain more, language-dependent
information.
The size, in bytes, of the structure.
A pointer to the buffer that receives the output string or is NULL if the output string is not needed. The output string is a version of the
original string that is in the order that will be displayed on a specified device. Typically the output string is identical to the original
string, but may be different if the string needs reordering and the GCP_REORDER flag is set or if the original string exceeds the maximum extent
and the GCP_MAXEXTENT flag is set.
A pointer to the array that receives ordering indexes or is NULL if the ordering indexes are not needed. However, its meaning depends on the
other elements of . If glyph indexes are to be returned, the indexes are for the array; if
glyphs indexes are not returned and is requested, the indexes are for . For example, in the
latter case the value of [i] is the position of lpString[i] in the output string lpOutString.
This is typically used when returns the GCP_REORDER flag, which indicates that the original string
needs reordering. For example, in Hebrew, in which the text runs from right to left, the array gives the exact
locations of each element in the original string.
A pointer to the array that receives the distances between adjacent character cells or is NULL if these distances are not needed. If glyph
rendering is done, the distances are for the glyphs not the characters, so the resulting array can be used with the
function.
The distances in this array are in display order. To find the distance for the ith character in the original string, use the lpOrder array.
A pointer to the array that receives the caret position values or is NULL if caret positions are not needed. Each value specifies the caret
position immediately before the corresponding character. In some languages the position of the caret for each character may not be
immediately to the left of the character. For example, in Hebrew, in which the text runs from right to left, the caret position is to the
right of the character. If glyph ordering is done, matches the original string, not the output string. This means
that some adjacent values may be the same.
The values in this array are in input order. To find the caret position value for the ith character in the original string, use the array as
follows:
A pointer to the array that contains and/or receives character classifications. The values indicate how to lay out characters in the string
and are similar (but not identical) to the CT_CTYPE2 values returned by the GetStringTypeEx function. Each element of the array can be set to
zero or one of the following values.
-
GCPCLASS_ARABIC
Arabic character.
-
GCPCLASS_HEBREW
Hebrew character.
-
GCPCLASS_LATIN
Character from a Latin or other single-byte character set for a left-to-right language.
-
GCPCLASS_LATINNUMBER
Digit from a Latin or other single-byte character set for a left-to-right language.
-
GCPCLASS_LOCALNUMBER
Digit from the character set associated with the current font.
In addition, the following can be used when supplying values in the array with the GCP_CLASSIN flag.
-
GCPCLASS_LATINNUMERICSEPARATOR
Input only. Character used to separate Latin digits, such as a comma or decimal point.
-
GCPCLASS_LATINNUMERICTERMINATOR
Input only. Character used to terminate Latin digits, such as a plus or minus sign.
-
GCPCLASS_NEUTRAL
Input only. Character has no specific classification.
-
GCPCLASS_NUMERICSEPARATOR
Input only. Character used to separate digits, such as a comma or decimal point.
For languages that use the GCP_REORDER flag, the following values can also be used with the GCP_CLASSIN flag. Unlike the preceding values,
which can be used anywhere in the array, all of the following values are used only in the first location in the array.
All combine with other classifications.
Note that GCPCLASS_PREBOUNDLTR and GCPCLASS_PREBOUNDRTL are mutually exclusive, as are GCPCLASSPOSTBOUNDLTR and GCPCLASSPOSTBOUNDRTL.
-
GCPCLASS_PREBOUNDLTR
Set [0] to GCPCLASS_PREBOUNDLTR to bind the string to left-to-right reading order before the string.
-
GCPCLASS_PREBOUNDRTL
Set [0] to GCPCLASS_PREBOUNDRTL to bind the string to right-to-left reading order before the string.
-
GCPCLASS_POSTBOUNDLTR
Set [0] to GCPCLASS_POSTBOUNDLTR to bind the string to left-to-right reading order after the string.
-
GCPCLASS_POSTBOUNDRTL
Set [0] to GCPCLASS_POSTBOUNDRTL to bind the string to right-to-left reading order after the string.
To force the layout of a character to be carried out in a specific way, preset the classification for the corresponding array element; the
function leaves such preset classifications unchanged and computes classifications only for array elements that have been set to zero. Preset
classifications are used only if the GCP_CLASSIN flag is set and the array is supplied.
If does not return GCP_REORDER for the current font, only the GCPCLASS_LATIN value is meaningful.
A pointer to the array that receives the values identifying the glyphs used for rendering the string or is NULL if glyph rendering is not
needed. The number of glyphs in the array may be less than the number of characters in the original string if the string contains ligated
glyphs. Also if reordering is required, the order of the glyphs may not be sequential.
This array is useful if more than one operation is being done on a string which has any form of ligation, kerning or order-switching. Using
the values in this array for subsequent operations saves the time otherwise required to generate the glyph indices each time.
This array always contains glyph indices and the ETO_GLYPH_INDEX value must always be used when this array is used with the
function.
When GCP_LIGATE is used, you can limit the number of characters that will be ligated together. (In Arabic for example, three-character
ligations are common). This is done by setting the maximum required in lpGcpResults->lpGlyphs[0]. If no maximum is required, you should set
this field to zero.
For languages such as Arabic, where returns the GCP_GLYPHSHAPE flag, the glyphs for a character will
be different depending on whether the character is at the beginning, middle, or end of a word. Typically, the first character in the input
string will also be the first character in a word, and the last character in the input string will be treated as the last character in a
word. However, if the displayed string is a subset of the complete string, such as when displaying a section of scrolled text, this may not
be true. In these cases, it is desirable to force the first or last characters to be shaped as not being initial or final forms. To do this,
again, the first location in the array is used by performing an OR operation of the ligation value above with the
values GCPGLYPH_LINKBEFORE and/or GCPGLYPH_LINKAFTER. For example, a value of GCPGLYPH_LINKBEFORE | 2 means that two-character ligatures are
the maximum required, and the first character in the string should be treated as if it is in the middle of a word.
On input, this member must be set to the size of the arrays pointed to by the array pointer members. On output, this is set to the number of
glyphs filled in, in the output arrays. If glyph substitution is not required (that is, each input character maps to exactly one glyph), this
member is the same as it is on input.
The number of characters that fit within the extents specified by the nMaxExtent parameter of the
function. If the GCP_MAXEXTENT or GCP_JUSTIFY value is set, this value may be less than the number of
characters in the original string. This member is set regardless of whether the GCP_MAXEXTENT or GCP_JUSTIFY value is specified. Unlike
, which specifies the number of output glyphs, refers to the number of characters from the input
string. For Latin SBCS languages, this will be the same.
The structure contains the A, B, and C widths of a font character.
The A spacing of the character. The A spacing is the distance to add to the current position before drawing the character glyph.
The B spacing of the character. The B spacing is the width of the drawn portion of the character glyph.
The C spacing of the character. The C spacing is the distance to add to the current position to provide white space to the right of the character
glyph.
The structure is an array of handles, each of which identifies a graphics device interface (GDI) object.
An array of handles.
Contains information about a character set.
Character set value.
Windows ANSI code page identifier. For a list of identifiers, see Code Page Identifiers.
A structure that identifies the Unicode subrange and the specific Windows ANSI character set/code page. Only one
code page will be set when this structure is set by the function.
The structure contains information about a range of Unicode code points.
The size, in bytes, of this structure.
Flags describing the maximum size of the glyph indices. This member can be the following value.
-
GS_8BIT_INDICES
Treat glyph indices as 8-bit wide values. Otherwise, they are 16-bit wide values.
The total number of Unicode code points supported in the font.
The total number of Unicode ranges in .
Array of Unicode ranges that are supported in the font.
The structure contains enhanced-metafile data such as the dimensions of the picture stored in the enhanced
metafile, the count of records in the enhanced metafile, the resolution of the device on which the picture was created, and so on.
This structure is always the first record in an enhanced metafile.
The record type. This member must specify the value assigned to the EMR_HEADER constant.
The structure size, in bytes.
The dimensions, in device units, of the smallest rectangle that can be drawn around the picture stored in the metafile. This rectangle is
supplied by graphics device interface (GDI). Its dimensions include the right and bottom edges.
The dimensions, in .01 millimeter units, of a rectangle that surrounds the picture stored in the metafile. This rectangle must be supplied by the
application that creates the metafile. Its dimensions include the right and bottom edges.
A signature. This member must specify the value assigned to the ENHMETA_SIGNATURE constant.
The metafile version. The current version value is 0x10000.
The size of the enhanced metafile, in bytes.
The number of records in the enhanced metafile.
The number of handles in the enhanced-metafile handle table. (Index zero in this table is reserved.)
Reserved; must be zero.
The number of characters in the array that contains the description of the enhanced metafile's contents. This member should be set to zero if the
enhanced metafile does not contain a description string.
The offset from the beginning of the structure to the array that contains the description of the enhanced metafile's
contents. This member should be set to zero if the enhanced metafile does not contain a description string.
The number of entries in the enhanced metafile's palette.
The resolution of the reference device, in pixels.
The resolution of the reference device, in millimeters.
The size of the last recorded pixel format in a metafile. If a pixel format is set in a reference DC at the start of recording,
is set to the size of the . When no pixel format is set when a metafile is
recorded, this member is set to zero. If more than a single pixel format is set, the header points to the last pixel format.
The offset of pixel format used when recording a metafile. If a pixel format is set in a reference DC at the start of recording or during
recording, is set to the offset of the in the metafile. If no pixel format is
set when a metafile is recorded, this member is set to zero. If more than a single pixel format is set, the header points to the last pixel
format.
Indicates whether any OpenGL records are present in a metafile. is a simple Boolean flag that you can use to determine
whether an enhanced metafile requires OpenGL handling. When a metafile contains OpenGL records, is TRUE; otherwise it is
FALSE.
The size of the reference device, in micrometers.
The structure contains a Windows-format metafile record.
The size, in words, of the record.
The function number.
An array of words containing the function parameters, in reverse of the order they are passed to the function.
Contains information identifying the code pages and Unicode subranges for which a given font provides glyphs.
A 128-bit Unicode subset bitfield (USB) identifying up to 126 Unicode subranges. Each bit, except the two most significant bits, represents a
single subrange. The most significant bit is always 1 and identifies the bitfield as a font signature; the second most significant bit is
reserved and must be 0. Unicode subranges are numbered in accordance with the ISO 10646 standard. For more information, see Unicode Subset
Bitfields.
A 64-bit, code-page bitfield (CPB) that identifies a specific character set or code page. Code pages are in the lower 32 bits of this bitfield.
The high 32 are used for non-Windows code pages. For more information, see Code Page Bitfields.
The structure contains information about whether TrueType is installed. This structure is filled when an
application calls the function.
The size, in bytes, of the structure.
Specifies whether at least one TrueType font is installed and whether TrueType is enabled. This value is TT_AVAILABLE, TT_ENABLED, or both if
TrueType is on the system.
The language in the system's Setup.inf file.
The structure contains information that defines a logical color space.
Color space signature. At present, this member should always be set to LCS_SIGNATURE.
Version number; must be 0x400.
Size of this structure, in bytes.
Color space type. The member can be one of the following values.
-
LCS_CALIBRATED_RGB
Color values are calibrated RGB values. The values are translated using the endpoints specified by the
member before being passed to the device.
-
LCS_sRGB
Color values are values are sRGB values.
-
LCS_WINDOWS_COLOR_SPACE
Color values are Windows default color space color values.
If LCS_CALIBRATED_RGB is not specified, the member is ignored.
The gamut mapping method. This member can be one of the following values.
-
LCS_GM_ABS_COLORIMETRIC
Match
-
LCS_GM_BUSINESS
Graphic
-
LCS_GM_GRAPHICS
Proof
-
LCS_GM_IMAGES
Picture
Red, green, blue endpoints.
Scale of the red coordinate.
Scale of the green coordinate.
Scale of the blue coordinate.
A null-terminated string that names a color profile file. This member is typically set to zero, but may be used to set the color space to be
exactly as specified by the color profile. This is useful for devices that input color values for a specific printer, or when using an
installable image color matcher. If a color profile is specified, all other members of this structure should be set to reasonable values, even if
the values are not completely accurate.
The structure contains the width of a character in a TrueType font.
The A spacing of the character. The A spacing is the distance to add to the current position before drawing the character glyph.
The B spacing of the character. The B spacing is the width of the drawn portion of the character glyph.
The C spacing of the character. The C spacing is the distance to add to the current position to provide white space to the right of the character
glyph.
The structure defines a kerning pair.
The character code for the first character in the kerning pair.
The character code for the second character in the kerning pair.
The amount this pair will be kerned if they appear side by side in the same font and size. This value is typically negative, because pair kerning
usually results in two characters being set more tightly than normal. The value is specified in logical units; that is, it depends on the current
mapping mode.
The structure contains information about the placement and orientation of a glyph in a character cell.
The width of the smallest rectangle that completely encloses the glyph (its black box).
The height of the smallest rectangle that completely encloses the glyph (its black box).
The x- and y-coordinates of the upper left corner of the smallest rectangle that completely encloses the glyph.
The horizontal distance from the origin of the current character cell to the origin of the next character cell.
The vertical distance from the origin of the current character cell to the origin of the next character cell.
The structure contains information about an enumerated font.
A structure that contains values defining the font attributes.
The unique name of the font. For example, ABC Font Company TrueType Bold Italic Sans Serif.
The style of the font. For example, Bold Italic.
The script, that is, the character set, of the font. For example, Cyrillic.
The structure is used by an application to specify values for the axes of a multiple master font.
Reserved. Must be STAMP_DESIGNVECTOR.
Number of values in the array.
An array specifying the values of the axes of a multiple master OpenType font. This array corresponds to the
array in the structure.
The structure contains the integral and fractional parts of a fixed-point real number.
The fractional part of the number.
The integer part of the number.
The structure describes the data returned by the function.
The size, in bytes, of the header.
The type of region. This value must be RDH_RECTANGLES.
The number of rectangles that make up the region.
The size of the buffer required to receive the structures that make up the region. If the size is not
known, this member can be zero.
A bounding rectangle for the region in logical units.
The structure describes the PANOSE font-classification values for a TrueType font. These characteristics are then used to
associate the font with other fonts of similar appearance but different names.
For Latin fonts, one of one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_FAMILY_TEXT_DISPLAY
Text and display
-
PAN_FAMILY_SCRIPT
Script
-
PAN_FAMILY_DECORATIVE
Decorative
-
PAN_FAMILY_PICTORIAL
Pictorial
The serif style. For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_SERIF_COVE
Cove
-
PAN_SERIF_OBTUSE_COVE
Obtuse cove
-
PAN_SERIF_SQUARE_COVE
Square cove
-
PAN_SERIF_OBTUSE_SQUARE_COVE
Obtuse square cove
-
PAN_SERIF_SQUARE
Square
-
PAN_SERIF_THIN
Thin
-
PAN_SERIF_BONE
Bone
-
PAN_SERIF_EXAGGERATED
Exaggerated
-
PAN_SERIF_TRIANGLE
Triangle
-
PAN_SERIF_NORMAL_SANS
Normal sans serif
-
PAN_SERIF_OBTUSE_SANS
Obtuse sans serif
-
PAN_SERIF_PERP_SANS
Perp sans serif
-
PAN_SERIF_FLARED
Flared
-
PAN_SERIF_ROUNDED
Rounded
For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_WEIGHT_VERY_LIGHT
Very light
-
PAN_WEIGHT_LIGHT
Light
-
PAN_WEIGHT_THIN
Thin
-
PAN_WEIGHT_BOOK
Book
-
PAN_WEIGHT_MEDIUM
Medium
-
PAN_WEIGHT_DEMI
Demibold
-
PAN_WEIGHT_BOLD
Bold
-
PAN_WEIGHT_HEAVY
Heavy
-
PAN_WEIGHT_BLACK
Black
-
PAN_WEIGHT_NORD
Nord
For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_PROP_OLD_STYLE
Old style
-
PAN_PROP_MODERN
Modern
-
PAN_PROP_EVEN_WIDTH
Even width
-
PAN_PROP_EXPANDED
Expanded
-
PAN_PROP_CONDENSED
Condensed
-
PAN_PROP_VERY_EXPANDED
Very expanded
-
PAN_PROP_VERY_CONDENSED
Very condensed
-
PAN_PROP_MONOSPACED
Monospaced
For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_CONTRAST_NONE
None
-
PAN_CONTRAST_VERY_LOW
Very low
-
PAN_CONTRAST_LOW
Low
-
PAN_CONTRAST_MEDIUM_LOW
Medium low
-
PAN_CONTRAST_MEDIUM
Medium
-
PAN_CONTRAST_MEDIUM_HIGH
Medium high
-
PAN_CONTRAST_HIGH
High
-
PAN_CONTRAST_VERY_HIGH
Very high
For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_STROKE_GRADUAL_DIAG
Gradual/diagonal
-
PAN_STROKE_GRADUAL_TRAN
Gradual/transitional
-
PAN_STROKE_GRADUAL_VERT
Gradual/vertical
-
PAN_STROKE_GRADUAL_HORZ
Gradual/horizontal
-
PAN_STROKE_RAPID_VERT
Rapid/vertical
-
PAN_STROKE_RAPID_HORZ
Rapid/horizontal
-
PAN_STROKE_INSTANT_VERT
Instant/vertical
For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_STRAIGHT_ARMS_HORZ
Straight arms/horizontal
-
PAN_STRAIGHT_ARMS_WEDGE
Straight arms/wedge
-
PAN_STRAIGHT_ARMS_VERT
Straight arms/vertical
-
PAN_STRAIGHT_ARMS_SINGLE_SERIF
Straight arms/single-serif
-
PAN_STRAIGHT_ARMS_DOUBLE_SERIF
Straight arms/double-serif
-
PAN_BENT_ARMS_HORZ
Nonstraight arms/horizontal
-
PAN_BENT_ARMS_WEDGE
Nonstraight arms/wedge
-
PAN_BENT_ARMS_VERT
Nonstraight arms/vertical
-
PAN_BENT_ARMS_SINGLE_SERIF
Nonstraight arms/single-serif
-
PAN_BENT_ARMS_DOUBLE_SERIF
Nonstraight arms/double-serif
For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_LETT_NORMAL_CONTACT
Normal/contact
-
PAN_LETT_NORMAL_WEIGHTED
Normal/weighted
-
PAN_LETT_NORMAL_BOXED
Normal/boxed
-
PAN_LETT_NORMAL_FLATTENED
Normal/flattened
-
PAN_LETT_NORMAL_ROUNDED
Normal/rounded
-
PAN_LETT_NORMAL_OFF_CENTER
Normal/off center
-
PAN_LETT_NORMAL_SQUARE
Normal/square
-
PAN_LETT_OBLIQUE_CONTACT
Oblique/contact
-
PAN_LETT_OBLIQUE_WEIGHTED
Oblique/weighted
-
PAN_LETT_OBLIQUE_BOXED
Oblique/boxed
-
PAN_LETT_OBLIQUE_FLATTENED
Oblique/flattened
-
PAN_LETT_OBLIQUE_ROUNDED
Oblique/rounded
-
PAN_LETT_OBLIQUE_OFF_CENTER
Oblique/off center
-
PAN_LETT_OBLIQUE_SQUARE
Oblique/square
For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_MIDLINE_STANDARD_TRIMMED
Standard/trimmed
-
PAN_MIDLINE_STANDARD_POINTED
Standard/pointed
-
PAN_MIDLINE_STANDARD_SERIFED
Standard/serifed
-
PAN_MIDLINE_HIGH_TRIMMED
High/trimmed
-
PAN_MIDLINE_HIGH_POINTED
High/pointed
-
PAN_MIDLINE_HIGH_SERIFED
High/serifed
-
PAN_MIDLINE_CONSTANT_TRIMMED
Constant/trimmed
-
PAN_MIDLINE_CONSTANT_POINTED
Constant/pointed
-
PAN_MIDLINE_CONSTANT_SERIFED
Constant/serifed
-
PAN_MIDLINE_LOW_TRIMMED
Low/trimmed
-
PAN_MIDLINE_LOW_POINTED
Low/pointed
-
PAN_MIDLINE_LOW_SERIFED
Low/serifed
For Latin fonts, one of the following values.
-
PAN_ANY
Any
-
PAN_NO_FIT
No fit
-
PAN_XHEIGHT_CONSTANT_SMALL
Constant/small
-
PAN_XHEIGHT_CONSTANT_STD
Constant/standard
-
PAN_XHEIGHT_CONSTANT_LARGE
Constant/large
-
PAN_XHEIGHT_DUCKING_SMALL
Ducking/small
-
PAN_XHEIGHT_DUCKING_STD
Ducking/standard
-
PAN_XHEIGHT_DUCKING_LARGE
Ducking/large
The structure defines the coordinates of the upper-left and lower-right corners of a rectangle.
The x-coordinate of the upper-left corner of the rectangle.
The y-coordinate of the upper-left corner of the rectangle.
The x-coordinate of the lower-right corner of the rectangle.
The y-coordinate of the lower-right corner of the rectangle.
The structure contains the x, y, and z coordinates of the three colors that correspond to the red, green, and blue
endpoints for a specified logical color space.
The xyz coordinates of red endpoint.
The xyz coordinates of green endpoint.
The xyz coordinates of blue endpoint.
The structure specifies a range of Unicode characters.
Low Unicode code point in the range of supported Unicode code points.
Number of supported Unicode code points in this range.
The structure contains the x, y, and z coordinates of a specific color in a specified color space.
The x coordinate in fix point (2.30).
The y coordinate in fix point (2.30).
The z coordinate in fix point (2.30).
The ABCFLOAT structure contains the A, B, and C widths of a font character.
The A, B, and C widths are measured along the base line of the font.
The character increment (total width) of a character is the sum of the A, B, and C spaces. Either the A or the C space can be negative to
indicate underhangs or overhangs.
Specifies the A spacing of the character. The A spacing is the distance to add to the current position before drawing the character glyph.
Specifies the B spacing of the character. The B spacing is the width of the drawn portion of the character glyph.
Specifies the C spacing of the character. The C spacing is the distance to add to the current position to provide white space to the right of the
character glyph.