mirror of
https://review.haiku-os.org/haiku
synced 2025-01-22 06:16:03 +01:00
8fc951cebb
Make it clear that the values provided by the escapement_delta struct are an input to App Server which allows the user to specify extra horizontal space around each character and is not an output provided by App Server.
1505 lines
36 KiB
Plaintext
1505 lines
36 KiB
Plaintext
/*
|
|
* Copyright 2013 Haiku Inc. All rights reserved.
|
|
* Distributed under the terms of the MIT License.
|
|
*
|
|
* Authors:
|
|
* John Scipione, jscipione@gmail.com
|
|
*
|
|
* Corresponds to:
|
|
* headers/os/interface/Font.h hrev45178
|
|
* src/kits/interface/Font.cpp hrev45178
|
|
*/
|
|
|
|
|
|
/*!
|
|
\file Font.h
|
|
\ingroup interface
|
|
\ingroup libbe
|
|
\brief BFont class definition, unicode_block class definition, and
|
|
font-related struct and enum definitions.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_CHAR_SPACING
|
|
|
|
Position each character without adjustment. Best mode for printing.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_STRING_SPACING
|
|
|
|
Optimizes the position of each character within it's space. Collisions
|
|
are unlikely but characters may touch each other. Best mode to use when
|
|
the screen needs to match what appears on the printed page.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_BITMAP_SPACING
|
|
|
|
The widths of the characters are chosen so that they never collide and
|
|
rarely touch. Best mode for drawing small amounts of text.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_FIXED_SPACING
|
|
|
|
Positions characters at a constant width. Best mode for fixed-width fonts.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\enum font_direction
|
|
\ingroup interface
|
|
|
|
Determines the direction of the text rendered by the font,
|
|
left-to-right or right-to-left.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_direction B_FONT_LEFT_TO_RIGHT
|
|
|
|
Left to right.
|
|
*/
|
|
|
|
/*!
|
|
\var font_direction B_FONT_RIGHT_TO_LEFT
|
|
|
|
Right to left.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_DISABLE_ANTIALIASING
|
|
|
|
Disable antialiasing. Used by BFont::Flags() and BFont::SetFlags().
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_FORCE_ANTIALIASING
|
|
|
|
Force antialiasing. Used by BFont::Flags() and BFont::SetFlags().
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_TRUNCATE_END
|
|
|
|
Truncate from the end of the string.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_TRUNCATE_BEGINNING
|
|
|
|
Truncate from the beginning of the string.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_TRUNCATE_MIDDLE
|
|
|
|
Truncate from the middle of the string.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_TRUNCATE_SMART
|
|
|
|
Truncate while keeping each string unique.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_UNICODE_UTF8
|
|
|
|
UTF-8 font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_1
|
|
|
|
ISO 8859-1 aka Latin 1 "Western European" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_2
|
|
|
|
ISO 8859-2 aka Latin 2 "Eastern European" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_3
|
|
|
|
ISO 8859-3 aka Latin 3 "South European" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_4
|
|
|
|
ISO 8859-4 aka Latin 4 "Northern European" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_5
|
|
|
|
ISO 8859-5 "Latin/Cyrillic" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_6
|
|
|
|
ISO 8859-6 "Latin/Arabic" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_7
|
|
|
|
ISO 8859-7 "Latin/Greek" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_8
|
|
|
|
ISO 8859-8 "Latin/Hebrew" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_9
|
|
|
|
ISO 8859-9 aka Latin 5 "Latin/Turkish" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ISO_8859_10
|
|
|
|
ISO 8859-10 aka Latin 6 "Nordic" font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_MACINTOSH_ROMAN
|
|
|
|
Macintosh Roman font encoding.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_HAS_TUNED_FONT
|
|
|
|
Flags for get_font_family() and get_font_style()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_IS_FIXED
|
|
|
|
flags for get_font_family() and get_font_style()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_ITALIC_FACE
|
|
|
|
Italic font face flag.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_UNDERSCORE_FACE
|
|
|
|
Underscore font face flag.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_NEGATIVE_FACE
|
|
|
|
Negative font face flag.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_OUTLINED_FACE
|
|
|
|
Outline font face flag.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_STRIKEOUT_FACE
|
|
|
|
Strikeout font face flag.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_BOLD_FACE
|
|
|
|
Bold font face flag.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_REGULAR_FACE
|
|
|
|
Regular font face flag.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_CONDENSED_FACE
|
|
|
|
Condensed font face flag. Not in BeOS 5.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_LIGHT_FACE
|
|
|
|
Light font face flag. Not in BeOS 5.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var B_HEAVY_FACE
|
|
|
|
Heavy font face flag. Not in BeOS 5.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\enum font_metric_mode
|
|
|
|
Font metric mode, screen or printing.
|
|
*/
|
|
|
|
/*!
|
|
\var font_metric_mode B_SCREEN_METRIC
|
|
|
|
Screen font metric mode.
|
|
*/
|
|
|
|
/*!
|
|
\var font_metric_mode B_PRINTING_METRIC
|
|
|
|
Printing font metric mode.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\enum font_file_format
|
|
\ingroup interface
|
|
|
|
Font file format, TrueType™ or PostScript™ Type1.
|
|
|
|
\see BFont::FileFormat()
|
|
*/
|
|
|
|
/*!
|
|
\var font_file_format B_TRUETYPE_WINDOWS
|
|
|
|
TrueType™ font file format.
|
|
*/
|
|
|
|
/*!
|
|
\var font_file_format B_POSTSCRIPT_TYPE1_WINDOWS
|
|
|
|
PostScript™ Type1 font file format.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\class unicode_block
|
|
\ingroup interface
|
|
\ingroup libbe
|
|
\brief Describes the blocks of Unicode characters supported by a font.
|
|
|
|
\see BFont::Blocks()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn unicode_block::unicode_block()
|
|
\brief Construct a \c unicode_block and set block data to 0.
|
|
|
|
You must initialize the block data before before using this object.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn unicode_block::unicode_block(uint64 block2, uint64 block1)
|
|
\brief Construct a \c unicode_block object and initialize it with the
|
|
supplied Unicode block range.
|
|
|
|
\param block2 End block.
|
|
\param block1 Begin block.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool unicode_block::Includes(const unicode_block& block) const
|
|
\brief Determines if \a block is a subset of the \c unicode_block object.
|
|
|
|
\param block The Unicode block to check.
|
|
|
|
\returns Whether or not \a block is a subset of the \c unicode_block
|
|
object.
|
|
\retval true \a block is a subset of the current \c unicode_block.
|
|
\retval false \a block is NOT a subset of the current \c unicode_block.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\name Assignment operators
|
|
*/
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
/*!
|
|
\fn unicode_block unicode_block::operator&(const unicode_block& block) const
|
|
\brief Creates a new \c unicode_block object that is the intersection of
|
|
\a block and the \c unicode_block object.
|
|
|
|
\param block The Unicode block to intersect with.
|
|
|
|
\returns The intersection of \a block and the \c unicode_block object.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn unicode_block unicode_block::operator|(const unicode_block& block) const
|
|
\brief Creates a new \c unicode_block object that is the union of \a block
|
|
and the \c unicode_block object.
|
|
|
|
\param block The Unicode block to form a union with.
|
|
|
|
\returns The union of \a block and the \c unicode_block object.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn unicode_block& unicode_block::operator=(const unicode_block& block)
|
|
\brief Copies \a block data into the left-hand side object.
|
|
|
|
\param block The unicode block to copy from.
|
|
|
|
\returns A copy of \a block.
|
|
*/
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
/*!
|
|
\name Comparison operators
|
|
*/
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
/*!
|
|
\fn bool unicode_block::operator==(const unicode_block& block) const
|
|
\brief Determines if the block object are exactly equal.
|
|
|
|
\param block The unicode block to compare against.
|
|
|
|
\returns \c true if the block object are exactly equal, \c false
|
|
otherwise.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool unicode_block::operator!=(const unicode_block& block) const
|
|
\brief Determines if the block object are not equal.
|
|
|
|
\param block The unicode block to compare against.
|
|
|
|
\returns \c true if the block object are NOT equal, \c false
|
|
if the block objects are exactly equal.
|
|
*/
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
/*!
|
|
\struct edge_info
|
|
\ingroup interface
|
|
\ingroup libbe
|
|
\brief The distance that a character outline is inset from its escapement
|
|
boundaries.
|
|
|
|
Edge values, like escapements, need to be multiplied by the font size to
|
|
get the correct value for the font.
|
|
|
|
\see BFont::GetEdges()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var edge_info::left
|
|
|
|
The distance that the character outline is inset from the left
|
|
escapement boundary.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var edge_info::right
|
|
|
|
The distance that the character outline is inset from the right
|
|
escapement boundary.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\struct font_height
|
|
\ingroup interface
|
|
\ingroup libbe
|
|
\brief The amount of vertical space surrounding a character.
|
|
|
|
\see BFont::GetHeight()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_height::ascent
|
|
|
|
The distance characters can ascend above the baseline.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_height::descent
|
|
|
|
The distance characters can descend below the baseline.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_height::leading
|
|
|
|
The distance between lines, descent above to ascent below.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\struct escapement_delta
|
|
\ingroup interface
|
|
\ingroup libbe
|
|
\brief A struct that allows you to specify extra horizontal space to surround
|
|
each character with.
|
|
|
|
Escapements need to be multiplied by the font size to get the correct
|
|
value for the font.
|
|
|
|
\see BFont::GetEscapements()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var escapement_delta::nonspace
|
|
|
|
The amount of horizontal space to surround a visible glyph character with.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var escapement_delta::space
|
|
|
|
The amount of horizontal space to surround a whitespace character with, for
|
|
example \c B_TAB or \c B_SPACE.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\struct font_cache_info
|
|
\ingroup interface
|
|
\ingroup libbe
|
|
\brief Font cache parameters.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_cache_info::sheared_font_penalty
|
|
|
|
Sheared font penalty.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_cache_info::rotated_font_penalty
|
|
|
|
Rotated font penalty.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_cache_info::oversize_threshold
|
|
|
|
Oversize threshold.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_cache_info::oversize_penalty
|
|
|
|
Oversize penalty.
|
|
*/
|
|
|
|
/*!
|
|
\var font_cache_info::cache_size
|
|
|
|
Cache size.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var font_cache_info::spacing_size_threshold
|
|
|
|
Spacing size threshold.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\struct tuned_font_info
|
|
\ingroup interface
|
|
\ingroup libbe
|
|
\brief Tuning information of fonts used to make it look better when
|
|
displayed on-screen.
|
|
|
|
\see BFont::GetTunedInfo()
|
|
\see BFont::CountTuned()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var tuned_font_info::size
|
|
|
|
Font size.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var tuned_font_info::shear
|
|
|
|
Font shear.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var tuned_font_info::rotation
|
|
|
|
Font rotation.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\var tuned_font_info::flags
|
|
|
|
Font flags.
|
|
*/
|
|
|
|
/*!
|
|
\var tuned_font_info::face
|
|
|
|
Font face.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn int32 count_font_families()
|
|
\brief Gets the number of installed font families
|
|
|
|
\return The number of installed font families
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn int32 count_font_styles(font_family family)
|
|
\brief Gets the number of styles available for a font family.
|
|
|
|
\return The number of styles available for a font family.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn status_t get_font_family(int32 index, font_family *_name,
|
|
uint32 *_flags)
|
|
\brief Retrieves the family name at the specified index.
|
|
|
|
\param index Unique font identifier code.
|
|
\param _name font_family String to receive the name of the family.
|
|
\param _flags if non-<tt>NULL</tt>, the values of the flags \c IS_FIXED
|
|
and \c B_HAS_TUNED_FONT are returned.
|
|
|
|
\return A status code, \c B_OK on success or an error code.
|
|
\retval B_BAD_VALUE \a _name is \c NULL.
|
|
\retval B_ERROR \a index does not correspond to a font family.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn status_t get_font_style(font_family family, int32 index,
|
|
font_style *_name, uint32 *_flags)
|
|
\brief Retrieves the family name at the specified index.
|
|
|
|
\param family The font family.
|
|
\param index Unique font identifier code.
|
|
\param _name string to receive the name of the family.
|
|
\param _flags if non-<tt>NULL</tt>, the values of the flags \c IS_FIXED
|
|
and \c B_HAS_TUNED_FONT are returned
|
|
|
|
\return A status code, \c B_OK on success or an error code.
|
|
\retval B_ERROR \a index does not correspond to a font style.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn status_t get_font_style(font_family family, int32 index,
|
|
font_style *_name, uint16 *_face, uint32 *_flags)
|
|
\brief Retrieves the family name at the specified index.
|
|
|
|
The face value returned by this function is not very reliable. At the same
|
|
time, the value returned should be fairly reliable, returning the proper
|
|
flag for 90%-99% of font names.
|
|
|
|
\param family The font family.
|
|
\param index Unique font identifier code.
|
|
\param _name String to receive the name of the family.
|
|
\param _face recipient of font face value, such as \c B_REGULAR_FACE.
|
|
\param _flags if non-<tt>NULL</tt>, the values of the flags \c IS_FIXED
|
|
and \c B_HAS_TUNED_FONT are returned.
|
|
|
|
\return A status code, \c B_OK on success or an error code.
|
|
\retval B_ERROR \a index does not correspond to a font style.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool update_font_families(bool checkOnly)
|
|
\brief Updates the font families list.
|
|
|
|
\param checkOnly Parameter is ignored.
|
|
|
|
\return \c true if the font list has changed, \c false if not.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\class BFont
|
|
\ingroup interface
|
|
\ingroup libbe
|
|
\brief Represents a typeface including it's family, style and size.
|
|
|
|
The Interface Kit provides three prebuilt BFont objects which can be used
|
|
but not modified.
|
|
- \c const BFont* \c be_plain_font A plain font used by many controls.
|
|
- \c const BFont* \c be_bold_font A bold font used by titles.
|
|
- \c const BFont* \c be_fixed_font A fixed-width font.
|
|
|
|
A BFont object does nothing on it's own but is used in combination with
|
|
a view or control. Here is an example of creating a BFont object from a
|
|
system font and assigning it to a view:
|
|
|
|
\code
|
|
BFont font(be_plain_font);
|
|
font.SetSize(12.0);
|
|
font.SetEncoding(B_ISO_8859_1);
|
|
view->SetFont(&font);
|
|
\endcode
|
|
|
|
You may also create a BFont object from a view, modify it and reassign it
|
|
back to the view like this:
|
|
|
|
\code
|
|
BFont font;
|
|
view->GetFont(&font);
|
|
font.SetFace(B_ITALIC_FACE);
|
|
font.SetSpacing(B_CHAR_SPACING);
|
|
myView->SetFont(&font);
|
|
\endcode
|
|
|
|
You can change the way a font renders with the SetFamilyAndStyle(),
|
|
SetFamilyAndFace(), SetSize(), SetShear(), SetRotation(),
|
|
SetFalseBoldWidth(), SetSpacing(), SetEncoding(), SetFace(), and
|
|
SetFlags() methods.
|
|
|
|
More information about the space taken up by a font can be determined
|
|
by querying a BFont object using the following methods:
|
|
StringWidth(), GetStringWidths() GetEscapements(), GetEdges(),
|
|
GetHeight(), BoundingBox() GetBoundingBoxesAsGlyphs(),
|
|
GetBoundingBoxesAsString(), and GetBoundingBoxesForStrings().
|
|
|
|
You can also perform intelligent string truncation with the
|
|
TruncateString() and GetTruncatedStrings() methods.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn BFont::BFont()
|
|
\brief Creates a BFont object initialized to \c be_plain_font.
|
|
|
|
\see BView::GetFont()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn BFont::BFont(const BFont &font)
|
|
\brief Creates and initializes a BFont object from another BFont object.
|
|
|
|
\param font The BFont object to initialize from.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn BFont::BFont(const BFont *font)
|
|
\brief Creates and initializes a BFont object from a pointer to a BFont
|
|
object.
|
|
|
|
\param font The pointer to a BFont object to initialize from.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn BFont::BFont(const BFont *font)
|
|
\brief Creates and initializes a BFont object from a pointer to a BFont
|
|
object.
|
|
|
|
\param font The pointer to a BFont object to initialize from.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn status_t BFont::SetFamilyAndStyle(const font_family family,
|
|
const font_style style)
|
|
\brief Sets the font's family and style all at once.
|
|
|
|
\param family Font family to set.
|
|
\param style Font style to set.
|
|
|
|
\returns A status code, \c B_OK on success or an error code.
|
|
\retval B_BAD_VALUE \a family is \c NULL and \a style is \c NULL.
|
|
\retval B_NAME_NOT_FOUND Family or style do not exist.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetFamilyAndStyle(uint32 code)
|
|
\brief Sets the font's family and style from a font identifier.
|
|
|
|
\param code Unique font identifier obtained from the server.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn status_t BFont::SetFamilyAndFace(const font_family family, uint16 face)
|
|
\brief Sets the font's family and face all at once.
|
|
|
|
\param family Font family to set.
|
|
\param face Font face to set.
|
|
|
|
\note To comply with the BeBook, this function will only set valid values,
|
|
i.e. passing a nonexistent family will cause only the face to be set.
|
|
Additionally, if a particular face does not exist in a family, the
|
|
closest match will be chosen.
|
|
|
|
\returns A status code, \c B_OK on success or an error code.
|
|
\retval B_ERROR Family does not exists or face has an invalid value.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetSize(float size)
|
|
\brief Sets the font size.
|
|
|
|
\param size The point size to set the font to.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetShear(float shear)
|
|
\brief Sets the angle in degrees relative to the baseline.
|
|
|
|
The default shear is 90.0° measured counterclockwise. The shear
|
|
range is from 45.0° to 135.0°.
|
|
|
|
\param shear The shear in degrees to set the font to.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetRotation(float rotation)
|
|
\brief Sets the font rotation from the baseline in degrees.
|
|
|
|
The default baseline is 0° and rotates counterclockwise. Rotation is not
|
|
supported by BTextView.
|
|
|
|
\param rotation The rotation in degrees to set the font to.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetFalseBoldWidth(float width)
|
|
\brief Sets the false bold width.
|
|
|
|
\param width The false bold width to set.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetSpacing(uint8 spacing)
|
|
\brief Sets how characters are horizontally spaced relative to each other.
|
|
|
|
- \c B_CHAR_SPACING Position each character without adjustment. Best mode
|
|
for printing. Characters may collide or overlap at small font sizes.
|
|
- \c B_STRING_SPACING Optimizes the position of each character within it's
|
|
space. Collisions are unlikely but characters may touch each other.
|
|
Best mode to use when the screen needs to match what appears on the
|
|
printed page. Adding new characters requires the entire string to
|
|
be redrawn.
|
|
- \c B_BITMAP_SPACING The widths of the characters are chosen so that they
|
|
never collide and rarely touch. Best mode for drawing small amounts
|
|
of text. Character widths are integral values. Spacing on screen will
|
|
not match spacing used by \c B_CHAR_SPACING mode for printing.
|
|
- \c B_FIXED_SPACING Positions characters at a constant width. Must be
|
|
used with fixed-width fonts otherwise \c B_CHAR_SPACING mode is used.
|
|
All characters have an identical integral escapement.
|
|
|
|
\c B_STRING_SPACING and \c B_BITMAP_SPACING modes are relevant only for
|
|
font sizes from 7.0pt to 18.0pt, above and below that range
|
|
\c B_CHAR_SPACING produces nicer results. \c B_CHAR_SPACING is also always
|
|
used for rotated or sheared text and when antialiasing is disabled.
|
|
|
|
\param spacing The spacing mode to set.
|
|
|
|
\see BView::DrawString()
|
|
\see GetEscapements()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetEncoding(uint8 encoding)
|
|
\brief Sets the character encoding of the font for example
|
|
\c B_UNICODE_UTF8 or \c B_ISO_8859_1.
|
|
|
|
The following character encodings are supported:
|
|
- \c B_UNICODE_UTF8
|
|
- \c B_ISO_8859_1 aka Latin 1 aka "Western European".
|
|
- \c B_ISO_8859_2 aka Latin 2 aka "Eastern European".
|
|
- \c B_ISO_8859_3 aka Latin 3 aka "South European".
|
|
- \c B_ISO_8859_4 aka Latin 4 aka "Northern European".
|
|
- \c B_ISO_8859_5 aka "Latin/Cyrillic".
|
|
- \c B_ISO_8859_6 aka "Latin/Arabic".
|
|
- \c B_ISO_8859_7 aka "Latin/Greek".
|
|
- \c B_ISO_8859_8 aka "Latin/Hebrew".
|
|
- \c B_ISO_8859_9 aka Latin 5 aka "Latin/Turkish".
|
|
- \c B_ISO_8859_10 aka Latin 6 aka "Nordic".
|
|
- \c B_MACINTOSH_ROMAN
|
|
|
|
\param encoding The character encoding to set the font to.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetFace(uint16 face)
|
|
\brief Sets the font face according to the flags set by \a face.
|
|
|
|
The following font face flags are supported:
|
|
- \c B_ITALIC_FACE Characters are slanted to the right.
|
|
- \c B_UNDERSCORE_FACE Characters are underlined.
|
|
- \c B_NEGATIVE_FACE High and low colors are reversed when drawing
|
|
characters.
|
|
- \c B_OUTLINED_FACE Characters are drawn hollowed out.
|
|
- \c B_STRIKEOUT_FACE A horizontal line is drawn through their middle.
|
|
- \c B_BOLD_FACE Characters are bold.
|
|
- \c B_REGULAR_FACE Characters are drawn normally.
|
|
- \c B_CONDENSED_FACE Characters are drawn condensed. Not in BeOS 5.
|
|
- \c B_LIGHT_FACE Characters are drawn thiner than normal. Not in BeOS 5.
|
|
- \c B_HEAVY_FACE Characters are drawn heavier than normal. Not in BeOS 5.
|
|
|
|
\param face The bitmap of font face flags to set.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::SetFlags(uint32 flags)
|
|
\brief Sets font flags controlling antialiasing.
|
|
|
|
The following flags are supported:
|
|
- \c B_DISABLE_ANTIALIASING Disable antialiasing.
|
|
- \c B_FORCE_ANTIALIASING Force antialiasing.
|
|
|
|
\param flags The bitmap of flags to set.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetFamilyAndStyle(font_family *family,
|
|
font_style *style) const
|
|
\brief Writes out the name of the font family and/or font style.
|
|
|
|
This method may be called with either \a family or \a style set to
|
|
\c NULL in order to get one or the other.
|
|
|
|
\param family A font_family pointer to be filled out.
|
|
\param style A font_style pointer to be filled out.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn uint32 BFont::FamilyAndStyle() const
|
|
\brief Gets the code of the font family and style combination.
|
|
|
|
\returns The family and style combination encoded as a unique integer.
|
|
|
|
\see SetFamilyAndStyle(uint32 code)
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BFont::Size() const
|
|
\brief Gets the font size.
|
|
|
|
\returns The font size in points.
|
|
|
|
\see SetSize()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BFont::Shear() const
|
|
\brief Gets the font shear.
|
|
|
|
\returns The font shear as an angle from 45.0° to 135.0°.
|
|
|
|
\see SetShear()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BFont::Rotation() const
|
|
\brief Gets the font rotation.
|
|
|
|
\returns The font rotation as an angle in degrees.
|
|
|
|
\see SetRotation()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BFont::FalseBoldWidth() const
|
|
\brief Gets the width of the font as if it were bold.
|
|
|
|
\returns The font width of the bold font variety.
|
|
|
|
\see SetFalseBoldWidth()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn uint8 BFont::Spacing() const
|
|
\brief Gets the spacing constant.
|
|
|
|
\returns The spacing constant.
|
|
|
|
\see SetSpacing()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn uint8 BFont::Encoding() const
|
|
\brief Gets the character encoding constant.
|
|
|
|
\returns The character encoding constant.
|
|
|
|
\see SetEncoding()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn uint16 BFont::Face() const
|
|
\brief Gets the font face flags bitmap.
|
|
|
|
\returns The font face flags bitmap.
|
|
|
|
\see SetFace()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn uint32 BFont::Flags() const
|
|
\brief Gets the antialiasing flags.
|
|
|
|
\returns The antialiasing flags.
|
|
|
|
\see SetFlags()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn font_direction BFont::Direction() const
|
|
\brief Gets the font direction, left-to-right or right-to left.
|
|
|
|
\returns The font direction.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BFont::IsFixed() const
|
|
\brief Gets whether or not the font is fixed width.
|
|
|
|
\returns \c true if the font is fixed width, \c false otherwise.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BFont::IsFullAndHalfFixed() const
|
|
\brief Returns whether or not the font is fixed-width and contains both
|
|
full and half-width characters.
|
|
|
|
\note This was left unimplemented as of R5. It is a way to work with both
|
|
Kanji and Roman characters in the same fixed-width font.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn BRect BFont::BoundingBox() const
|
|
\brief Gets a BRect that encloses the font text.
|
|
|
|
\returns A BRect that encloses the font text.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn unicode_block BFont::Blocks() const
|
|
\brief Gets a \c unicode_block object that identifies the Unicode blocks
|
|
supported by this font face and family.
|
|
|
|
\attention Currently unimplemented, returns an empty \a unicode_block
|
|
object.
|
|
|
|
\returns A \c unicode_block object containing supported Unicode blocks.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn font_file_format BFont::FileFormat() const
|
|
\brief Gets whether the font is a TrueType™ or PostScript™ Type1 font.
|
|
|
|
\returns A \c font_file_format struct containing the font file format.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn int32 BFont::CountTuned() const
|
|
\brief Gets the number of tuned fonts for the font family and style.
|
|
|
|
\returns The number of tuned fonts.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetTunedInfo(int32 index, tuned_font_info *info) const
|
|
\brief Writes information about the tuned font at \a index into \a info.
|
|
|
|
The index begins at 0 and counts tuned fonts for current font family and
|
|
style only.
|
|
|
|
\param index The index of desired tuned font.
|
|
\param info The \a turned_font_info struct to be filled out.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::TruncateString(BString *inOut, uint32 mode,
|
|
float width) const
|
|
\brief Truncates \a inOut to be no longer than \a width using the
|
|
supplied truncation \a mode.
|
|
|
|
The following truncation modes are supported:
|
|
- \c B_TRUNCATE_BEGINNING Truncate from the beginning of the string.
|
|
- \c B_TRUNCATE_MIDDLE Truncate from the middle of the string.
|
|
- \c B_TRUNCATE_END Truncate from the end of the string.
|
|
- \c B_TRUNCATE_SMART Truncate from anywhere, but do so so that each
|
|
string is made unique after being truncated.
|
|
|
|
\param inOut The BString to truncate.
|
|
\param mode Truncation mode to use.
|
|
\param width The maximum width to truncate to.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetTruncatedStrings(const char *stringArray[],
|
|
int32 numStrings, uint32 mode, float width,
|
|
BString resultArray[]) const
|
|
\brief Write truncated BString objects to \a resultArray given source
|
|
BString objects in \a stringArray.
|
|
|
|
The following truncation modes are supported:
|
|
- \c B_TRUNCATE_BEGINNING Truncate from the beginning of the string.
|
|
- \c B_TRUNCATE_MIDDLE Truncate from the middle of the string.
|
|
- \c B_TRUNCATE_END Truncate from the end of the string.
|
|
- \c B_TRUNCATE_SMART Truncate from anywhere, but do so so that each
|
|
string is made unique after being truncated.
|
|
|
|
\param stringArray The source string array.
|
|
\param numStrings The number of strings in \a stringArray.
|
|
\param mode Truncation mode to use.
|
|
\param width The maximum width to truncate to.
|
|
\param resultArray The destination string array.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetTruncatedStrings(const char *stringArray[],
|
|
int32 numStrings, uint32 mode, float width, char *resultArray[]) const
|
|
\brief Write truncated strings to \a resultArray given source
|
|
BString objects in \a stringArray.
|
|
|
|
\a resultArray is an array of pointers to string buffers which should be
|
|
allocated ahead of time and should be at least 3 bytes longer than the
|
|
matching input string. The 3 extra bytes provide enough room for the
|
|
truncated output given that GetTruncatedStrings() truncates only a
|
|
single-byte character from the input string and replaces it with an
|
|
ellipsis character (which takes three bytes for the UTF-8 encoding),
|
|
and adds a \c NUL-terminator.
|
|
|
|
The following truncation modes are supported:
|
|
- \c B_TRUNCATE_BEGINNING Truncate from the beginning of the string.
|
|
- \c B_TRUNCATE_MIDDLE Truncate from the middle of the string.
|
|
- \c B_TRUNCATE_END Truncate from the end of the string.
|
|
- \c B_TRUNCATE_SMART Truncate from anywhere, but do so so that each
|
|
string is made unique after being truncated.
|
|
|
|
\param stringArray The source string array.
|
|
\param numStrings The number of strings in \a stringArray.
|
|
\param mode Truncation mode to use.
|
|
\param width The maximum width to truncate to.
|
|
\param resultArray The destination string array.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BFont::StringWidth(const char *string) const
|
|
\brief Determines the amount of space required to draw \a string in the
|
|
current font.
|
|
|
|
\param string The source string.
|
|
|
|
\returns The width required to draw the string.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BFont::StringWidth(const char *string, int32 length) const
|
|
\brief Determines the amount of space required to draw \a string in the
|
|
current font up to \a length characters.
|
|
|
|
\param string The source string.
|
|
\param length The number of characters in \a string to consider.
|
|
|
|
\returns The width required to draw the string.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetStringWidths(const char *stringArray[],
|
|
const int32 lengthArray[], int32 numStrings, float widthArray[]) const
|
|
\brief Determines the amount of space required to draw each string in
|
|
\a stringArray and writes the result in \a widthArray.
|
|
|
|
\param stringArray The source string array.
|
|
\param lengthArray The number of characters to consider for each string in
|
|
\a stringArray
|
|
\param numStrings The number of strings in \a stringArray.
|
|
\param widthArray The destination array to put the widths required to draw
|
|
each string.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetEscapements(const char charArray[], int32 numChars,
|
|
float escapementArray[]) const
|
|
\brief Determines the escapements for each char in \a charArray and writes
|
|
the result in \a escapementArray.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param escapementArray The destination array to put the escapements.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetEscapements(const char charArray[], int32 numChars,
|
|
escapement_delta *delta, float escapementArray[]) const
|
|
\brief Determines the escapements for each char in \a charArray and writes
|
|
the result in \a escapementArray with consideration to the horizontal
|
|
space provided by the escapement \a delta.
|
|
|
|
The escapement_delta structure contains the following values:
|
|
- \c nonspace The amount of horizontal space to surround a visible glyph
|
|
character with.
|
|
- \c space The amount of horizontal space to surround a whitespace character
|
|
with, for example \c B_TAB or \c B_SPACE.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param delta The escapement_delta structure to use.
|
|
\param escapementArray The destination array to put the escapements.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetEscapements(const char charArray[], int32 numChars,
|
|
escapement_delta *delta, BPoint escapementArray[]) const
|
|
\brief Determines the escapements for each char in \a charArray and writes
|
|
the result in \a escapementArray as an array of BPoint objects
|
|
with consideration to the horizontal space provided by the escapement
|
|
\a delta.
|
|
|
|
The escapement_delta structure contains the following values:
|
|
- \c nonspace The amount of horizontal space to surround a visible glyph
|
|
character with.
|
|
- \c space The amount of horizontal space to surround a whitespace character
|
|
with, for example \c B_TAB or \c B_SPACE.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param delta The escapement_delta structure to use.
|
|
\param escapementArray The destination array of escapements as BPoint
|
|
objects.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetEscapements(const char charArray[], int32 numChars,
|
|
escapement_delta *delta, BPoint escapementArray[],
|
|
BPoint offsetArray[]) const
|
|
\brief Determines the escapements for each char in \a charArray and writes
|
|
the result in \a escapementArray as an array of BPoint objects
|
|
with consideration to the horizontal space provided by the escapement
|
|
\a delta and writes the offsets to \a offsetArray.
|
|
|
|
The escapement_delta structure contains the following values:
|
|
- \c nonspace The amount of horizontal space to surround a visible glyph
|
|
character with.
|
|
- \c space The amount of horizontal space to surround a whitespace character
|
|
with, for example \c B_TAB or \c B_SPACE.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param delta The escapement_delta structure to use.
|
|
\param escapementArray The destination array of escapements as BPoint
|
|
objects.
|
|
\param offsetArray The destination array of offsets as BPoint objects.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetEdges(const char charArray[], int32 numChars,
|
|
edge_info edgeArray[]) const
|
|
\brief Determines the edge information for each character in \a charArray
|
|
and writes the result in \a edgeArray.
|
|
|
|
The \c edge_info struct contains the following values:
|
|
- \c left The distance that the character outline is inset from the left
|
|
escapement boundary.
|
|
- \c right The distance that the character outline is inset from the
|
|
right escapement boundary.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param edgeArray The destination array of \c edge_info structs.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetHeight(font_height *_height) const
|
|
\brief Fills out the \c font_height struct with the amount of vertical
|
|
space surrounding a character.
|
|
|
|
The \c font_height struct contains the following values:
|
|
- \c ascent The distance characters can ascend above the baseline.
|
|
- \c descent The distance characters can descend below the baseline.
|
|
- \c leading The distance between lines, descent above to ascent below.
|
|
|
|
\param _height The \c font_height struct to fill out.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetBoundingBoxesAsGlyphs(const char charArray[],
|
|
int32 numChars, font_metric_mode mode, BRect boundingBoxArray[]) const
|
|
\brief Writes an array of BRect objects to \a boundingBoxArray
|
|
representing the bounding rectangles of each character in
|
|
\a charArray.
|
|
|
|
Each BRect object corresponds to the glyph of one character.
|
|
|
|
The \c font_metric_mode should contain one of the following values:
|
|
- \c B_SCREEN_METRIC The bounding boxes should use the screen metric.
|
|
- \c B_PRINTING_METRIC The bounding boxes should use the print metric.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param mode The \c font_metric_mode to use, screen or printing.
|
|
\param boundingBoxArray The destination array of BRect bounding boxes.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetBoundingBoxesAsString(const char charArray[],
|
|
int32 numChars, font_metric_mode mode, escapement_delta *delta,
|
|
BRect boundingBoxArray[]) const
|
|
\brief Writes an array of BRect objects to \a boundingBoxArray representing
|
|
the bounding rectangles of each character in \a charArray with
|
|
consideration to the horizontal space provided by the escapement
|
|
\a delta.
|
|
|
|
Each BRect object corresponds to the glyph of one character.
|
|
|
|
The \c font_metric_mode should contain one of the following values:
|
|
- \c B_SCREEN_METRIC The bounding boxes should use the screen metric.
|
|
- \c B_PRINTING_METRIC The bounding boxes should use the print metric.
|
|
|
|
The provided escapement \a delta is applied as part of the bounding box
|
|
calculations. This lets you specify a character spacing is looser or
|
|
tighter than normal.
|
|
|
|
The escapement_delta structure contains the following values:
|
|
- \c nonspace The amount of horizontal space to surround a visible glyph
|
|
character with.
|
|
- \c space The amount of horizontal space to surround a whitespace character
|
|
with, for example \c B_TAB or \c B_SPACE.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param mode The \c font_metric_mode to use, screen or printing.
|
|
\param delta The escapement_delta structure to use.
|
|
\param boundingBoxArray The destination array of BRect bounding boxes.
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BFont::GetBoundingBoxesForStrings(const char *stringArray[],
|
|
int32 numStrings, font_metric_mode mode, escapement_delta deltas[],
|
|
BRect boundingBoxArray[]) const
|
|
\brief Writes an array of BRect objects to \a boundingBoxArray representing
|
|
the bounding rectangles of each string in \a stringArray with
|
|
consideration to the horizontal space provided by the escapement
|
|
\a deltas.
|
|
|
|
Each BRect object corresponds to the bounding box of the entire string.
|
|
|
|
The \c font_metric_mode should contain one of the following values:
|
|
- \c B_SCREEN_METRIC The bounding boxes should use the screen metric.
|
|
- \c B_PRINTING_METRIC The bounding boxes should use the print metric.
|
|
|
|
The provided escapement \a deltas are applied as part of the bounding box
|
|
calculations. This lets you specify a character spacing is looser or tighter
|
|
than normal.
|
|
|
|
The escapement_delta structure contains the following values:
|
|
- \c nonspace The amount of horizontal space to surround a visible glyph
|
|
character with.
|
|
- \c space The amount of horizontal space to surround a whitespace character
|
|
with, for example \c B_TAB or \c B_SPACE.
|
|
|
|
\param stringArray The source string array.
|
|
\param numStrings The number of strings to consider in \a stringArray.
|
|
\param mode The \c font_metric_mode to use, screen or printing.
|
|
\param deltas The array of escapement_delta structures to use.
|
|
\param boundingBoxArray The destination array of BRect bounding boxes.
|
|
*/
|
|
|
|
|
|
/*!
|
|
void BFont::GetGlyphShapes(const char charArray[], int32 numChars,
|
|
BShape *glyphShapeArray[]) const
|
|
\brief Writes an array of BShape objects to \a glyphShapeArray
|
|
representing the glyph shapes of each character in
|
|
\a charArray.
|
|
|
|
Each BShape object corresponds to the glyph of one character.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param glyphShapeArray The destination array of BShape glyphs.
|
|
*/
|
|
|
|
|
|
/*!
|
|
void BFont::GetHasGlyphs(const char charArray[], int32 numChars,
|
|
bool hasArray[]) const
|
|
\brief Fills out \a hasArray with whether or not each characters in
|
|
\a charArray has a glyph for the font.
|
|
|
|
\c true is written in \a hasArray if the character has a glyph in the
|
|
current font and \c false is written in \a hasArray if the character
|
|
does NOT have a glyph in the current font.
|
|
|
|
\param charArray The source character array.
|
|
\param numChars The number of characters to consider in \a charArray.
|
|
\param hasArray The destination array of booleans.
|
|
*/
|
|
|
|
|
|
/*!
|
|
BFont& BFont::operator=(const BFont &font)
|
|
\brief Assignment overload method.
|
|
|
|
\param font The BFont object to assign from.
|
|
*/
|
|
|
|
|
|
/*!
|
|
bool BFont::operator==(const BFont &font) const
|
|
\brief Equality comparison overload method.
|
|
|
|
\param font The BFont object to compare the current font to.
|
|
|
|
\returns \c true if the fonts objects are identical, \c false otherwise.
|
|
*/
|
|
|
|
|
|
/*!
|
|
bool BFont::operator!=(const BFont &font) const
|
|
\brief Inequality comparison overload method.
|
|
|
|
\param font The BFont object to compare the current font to.
|
|
|
|
\returns \c true if the fonts objects are NOT identical, \c true
|
|
otherwise.
|
|
*/
|
|
|
|
|
|
/*!
|
|
void BFont::PrintToStream() const
|
|
\brief Writes information about the font to \c stdout.
|
|
|
|
printf("BFont { %s (%d), %s (%d) 0x%x %f/%f %fpt (%f %f %f), %d }\n",
|
|
family, fFamilyID, style, fStyleID, fFace, fShear, fRotation, fSize,
|
|
fHeight.ascent, fHeight.descent, fHeight.leading, fEncoding);
|
|
*/
|