123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- #region MIT License
- /*Copyright (c) 2012 Robert Rouhani <robert.rouhani@gmail.com>
- SharpFont based on Tao.FreeType, Copyright (c) 2003-2007 Tao Framework Team
- Permission is hereby granted, free of charge, to any person obtaining a copy of
- this software and associated documentation files (the "Software"), to deal in
- the Software without restriction, including without limitation the rights to
- use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
- of the Software, and to permit persons to whom the Software is furnished to do
- so, subject to the following conditions:
- The above copyright notice and this permission notice shall be included in all
- copies or substantial portions of the Software.
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- SOFTWARE.*/
- #endregion
- using System;
- using System.Runtime.InteropServices;
- using SharpFont.Internal;
- namespace SharpFont
- {
- /// <summary>
- /// A structure used to model the metrics of a single glyph. The values are expressed in 26.6 fractional pixel
- /// format; if the flag <see cref="LoadFlags.NoScale"/> has been used while loading the glyph, values are expressed
- /// in font units instead.
- /// </summary>
- /// <remarks>
- /// If not disabled with <see cref="LoadFlags.NoHinting"/>, the values represent dimensions of the hinted glyph (in
- /// case hinting is applicable).
- /// </remarks>
- public sealed class GlyphMetrics
- {
- #region Fields
- private IntPtr reference;
- private GlyphMetricsRec rec;
- #endregion
- #region Constructors
- internal GlyphMetrics(IntPtr reference)
- {
- Reference = reference;
- }
- internal GlyphMetrics(GlyphMetricsRec glyphMetInt)
- {
- this.rec = glyphMetInt;
- }
- #endregion
- #region Properties
- /// <summary>
- /// Gets the glyph's width.
- /// </summary>
- public int Width
- {
- get
- {
- return (int)rec.width;
- }
- }
- /// <summary>
- /// Gets the glyph's height.
- /// </summary>
- public int Height
- {
- get
- {
- return (int)rec.height;
- }
- }
- /// <summary>
- /// Gets the left side bearing for horizontal layout.
- /// </summary>
- public int HorizontalBearingX
- {
- get
- {
- return (int)rec.horiBearingX;
- }
- }
- /// <summary>
- /// Gets the top side bearing for horizontal layout.
- /// </summary>
- public int HorizontalBearingY
- {
- get
- {
- return (int)rec.horiBearingY;
- }
- }
- /// <summary>
- /// Gets the advance width for horizontal layout.
- /// </summary>
- public int HorizontalAdvance
- {
- get
- {
- return (int)rec.horiAdvance;
- }
- }
- /// <summary>
- /// Gets the left side bearing for vertical layout.
- /// </summary>
- public int VerticalBearingX
- {
- get
- {
- return (int)rec.vertBearingX;
- }
- }
- /// <summary>
- /// Gets the top side bearing for vertical layout. Larger positive values mean further below the vertical glyph
- /// origin.
- /// </summary>
- public int VerticalBearingY
- {
- get
- {
- return (int)rec.vertBearingY;
- }
- }
- /// <summary>
- /// Gets the advance height for vertical layout. Positive values mean the glyph has a positive advance
- /// downward.
- /// </summary>
- public int VerticalAdvance
- {
- get
- {
- return (int)rec.vertAdvance;
- }
- }
- internal IntPtr Reference
- {
- get
- {
- return reference;
- }
- set
- {
- reference = value;
- rec = PInvokeHelper.PtrToStructure<GlyphMetricsRec>(reference);
- }
- }
- #endregion
- }
- }
|