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.