Mega Code Archive

 
Categories / VB.Net Tutorial / 2D Graphics
 

Draw Font Metrics

Imports System.Drawing Imports System.Drawing.Drawing2D Imports System.Windows.Forms Imports System.Math public class DrawStringMetrics    public Shared Sub Main         Application.Run(New Form1)    End Sub End class public class Form1   Inherits System.Windows.Forms.Form   Protected Overrides Sub OnPaint(ByVal e As PaintEventArgs)         Dim txt As String = "www.rntsoft.com"         Dim layout_rect As New RectangleF(0, 0, Me.ClientSize.Width , Me.ClientSize.Height)         Dim string_format As New StringFormat         string_format.LineAlignment = StringAlignment.Center         string_format.Alignment = StringAlignment.Center         Dim the_font As Font         e.Graphics.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAliasGridFit         the_font = New Font("Times New Roman", 80, FontStyle.Bold, GraphicsUnit.Pixel)         MeasureCharacters(e.Graphics, the_font, txt, layout_rect, string_format)     End Sub     Public Sub MeasureCharacters(ByVal gr As Graphics, ByVal the_font As Font, ByVal txt As String, ByVal layout_rect As RectangleF, ByVal string_format As StringFormat)         Dim character_ranges(txt.Length - 1) As CharacterRange         For i As Integer = 0 To txt.Length - 1             character_ranges(i) = New CharacterRange(i, 1)         Next i         string_format.SetMeasurableCharacterRanges(character_ranges)         Dim character_regions() As Region = gr.MeasureCharacterRanges(txt, the_font, layout_rect, string_format)         Dim em_height As Integer = the_font.FontFamily.GetEmHeight(FontStyle.Bold)         Dim em_height_pix As Single = the_font.Size         Dim design_to_pixels As Single = the_font.Size / em_height         Dim ascent As Integer = the_font.FontFamily.GetCellAscent(FontStyle.Bold)         Dim ascent_pix As Single = ascent * design_to_pixels         Dim descent As Integer = the_font.FontFamily.GetCellDescent(FontStyle.Bold)         Dim descent_pix As Single = descent * design_to_pixels         Dim cell_height_pix As Single = ascent_pix + descent_pix         Dim internal_leading_pix As Single = cell_height_pix - em_height_pix         Dim line_spacing As Integer = the_font.FontFamily.GetLineSpacing(FontStyle.Bold)         Dim line_spacing_pix As Single = line_spacing * design_to_pixels         Dim external_leading_pix As Single = line_spacing_pix - cell_height_pix         For Each rgn As Region In character_regions             Dim character_bounds As RectangleF = rgn.GetBounds(gr)             Dim character_rect As Rectangle = Rectangle.Round(character_bounds)             gr.DrawRectangle(Pens.Black, character_rect)             gr.DrawLine(Pens.White, character_rect.X, character_rect.Y + internal_leading_pix, character_rect.Right, character_rect.Y + internal_leading_pix)             gr.DrawLine(Pens.Yellow, character_rect.X, character_rect.Y + ascent_pix, character_rect.Right, character_rect.Y + ascent_pix)             gr.DrawLine(Pens.Orange, character_rect.X, character_rect.Y + ascent_pix + descent_pix, character_rect.Right, character_rect.Y + ascent_pix + descent_pix)             gr.FillRectangle(Brushes.Red, character_rect.X, character_rect.Y + ascent_pix + descent_pix, character_rect.Width, external_leading_pix)         Next rgn         gr.DrawString(txt, the_font, Brushes.Black, layout_rect, string_format)   End Sub   Public Sub New()         MyBase.New()     Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)     Me.ClientSize = New System.Drawing.Size(292, 273)     Me.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen   End Sub End Class