แก้ไข

แชร์ผ่าน


FormattedText.SetFontStyle Method

Definition

Sets the font style for the FormattedText object.

Overloads

SetFontStyle(FontStyle)

Sets the font style for the entire set of characters in the FormattedText object.

SetFontStyle(FontStyle, Int32, Int32)

Sets the font style for a specified subset of characters in the FormattedText object.

SetFontStyle(FontStyle)

Sets the font style for the entire set of characters in the FormattedText object.

public:
 void SetFontStyle(System::Windows::FontStyle style);
public void SetFontStyle (System.Windows.FontStyle style);
member this.SetFontStyle : System.Windows.FontStyle -> unit
Public Sub SetFontStyle (style As FontStyle)

Parameters

style
FontStyle

The FontStyle value to use for text formatting.

Remarks

FontStyle supports type conversion behavior such that static values of the FontStyles class can be used to initialize FontStyle and fill parameters that are type FontStyle.

This method sets the font style for the entire text string. To set the font style for a subset of the text string, use the SetFontStyle(FontStyle, Int32, Int32) method.

Applies to

SetFontStyle(FontStyle, Int32, Int32)

Sets the font style for a specified subset of characters in the FormattedText object.

public:
 void SetFontStyle(System::Windows::FontStyle style, int startIndex, int count);
public void SetFontStyle (System.Windows.FontStyle style, int startIndex, int count);
member this.SetFontStyle : System.Windows.FontStyle * int * int -> unit
Public Sub SetFontStyle (style As FontStyle, startIndex As Integer, count As Integer)

Parameters

style
FontStyle

The FontStyle value to use for text formatting.

startIndex
Int32

The start index of the initial character to apply the font style to.

count
Int32

The number of characters to apply the font style to.

Examples

The following example creates a FormattedText object and then applies several formatting styles to the text, including SetFontStyle.

protected override void OnRender(DrawingContext drawingContext)
{
    string testString = "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor";

    // Create the initial formatted text string.
    FormattedText formattedText = new FormattedText(
        testString,
        CultureInfo.GetCultureInfo("en-us"),
        FlowDirection.LeftToRight,
        new Typeface("Verdana"),
        32,
        Brushes.Black);

    // Set a maximum width and height. If the text overflows these values, an ellipsis "..." appears.
    formattedText.MaxTextWidth = 300;
    formattedText.MaxTextHeight = 240;

    // Use a larger font size beginning at the first (zero-based) character and continuing for 5 characters.
    // The font size is calculated in terms of points -- not as device-independent pixels.
    formattedText.SetFontSize(36 * (96.0 / 72.0), 0, 5);

    // Use a Bold font weight beginning at the 6th character and continuing for 11 characters.
    formattedText.SetFontWeight(FontWeights.Bold, 6, 11);

    // Use a linear gradient brush beginning at the 6th character and continuing for 11 characters.
    formattedText.SetForegroundBrush(
                            new LinearGradientBrush(
                            Colors.Orange,
                            Colors.Teal,
                            90.0),
                            6, 11);

    // Use an Italic font style beginning at the 28th character and continuing for 28 characters.
    formattedText.SetFontStyle(FontStyles.Italic, 28, 28);

    // Draw the formatted text string to the DrawingContext of the control.
    drawingContext.DrawText(formattedText, new Point(10, 0));
}
Protected Overrides Sub OnRender(ByVal drawingContext As DrawingContext)
    Dim testString As String = "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor"

    ' Create the initial formatted text string.
    Dim formattedText As New FormattedText(testString, CultureInfo.GetCultureInfo("en-us"), FlowDirection.LeftToRight, New Typeface("Verdana"), 32, Brushes.Black)

    ' Set a maximum width and height. If the text overflows these values, an ellipsis "..." appears.
    formattedText.MaxTextWidth = 300
    formattedText.MaxTextHeight = 240

    ' Use a larger font size beginning at the first (zero-based) character and continuing for 5 characters.
    ' The font size is calculated in terms of points -- not as device-independent pixels.
    formattedText.SetFontSize(36 * (96.0 / 72.0), 0, 5)

    ' Use a Bold font weight beginning at the 6th character and continuing for 11 characters.
    formattedText.SetFontWeight(FontWeights.Bold, 6, 11)

    ' Use a linear gradient brush beginning at the 6th character and continuing for 11 characters.
    formattedText.SetForegroundBrush(New LinearGradientBrush(Colors.Orange, Colors.Teal, 90.0), 6, 11)

    ' Use an Italic font style beginning at the 28th character and continuing for 28 characters.
    formattedText.SetFontStyle(FontStyles.Italic, 28, 28)

    ' Draw the formatted text string to the DrawingContext of the control.
    drawingContext.DrawText(formattedText, New Point(10, 0))
End Sub

Remarks

FontStyle supports type conversion behavior such that static values of the FontStyles class can be used to initialize FontStyle and fill parameters that are type FontStyle.

To set the font style for the entire text string, use the SetFontStyle(FontStyle) method.

Applies to