Jak na to: Použití třídy pro vykreslování ovládacího prvku
Tento příklad ukazuje, jak pomocí třídy ComboBoxRenderer vykreslit šipku rozevíracího pole ovládacího prvku. Příklad se skládá z metody OnPaint jednoduchého vlastního ovládacího prvku. Vlastnost ComboBoxRenderer.IsSupported slouží k určení, zda jsou styly vizuálů povoleny v klientské oblasti oken aplikací. Pokud jsou vizuální styly aktivní, pak metoda ComboBoxRenderer.DrawDropDownButton vykresluje šipku rozevíracího seznamu se styly vizuálů; jinak metoda ControlPaint.DrawComboButton vykreslí šipku rozevíracího seznamu v klasickém stylu Windows.
Příklad
// Render the drop-down arrow with or without visual styles.
protected:
virtual void OnPaint(PaintEventArgs^ e) override
{
__super::OnPaint(e);
if (!ComboBoxRenderer::IsSupported)
{
ControlPaint::DrawComboButton(e->Graphics,
this->ClientRectangle, ButtonState::Normal);
}
else
{
ComboBoxRenderer::DrawDropDownButton(e->Graphics,
this->ClientRectangle, ComboBoxState::Normal);
}
}
// Render the drop-down arrow with or without visual styles.
protected override void OnPaint(PaintEventArgs e)
{
base.OnPaint(e);
if (!ComboBoxRenderer.IsSupported)
{
ControlPaint.DrawComboButton(e.Graphics,
this.ClientRectangle, ButtonState.Normal);
}
else
{
ComboBoxRenderer.DrawDropDownButton(e.Graphics,
this.ClientRectangle, ComboBoxState.Normal);
}
}
' Render the drop-down arrow with or without visual styles.
Protected Overrides Sub OnPaint(ByVal e As PaintEventArgs)
MyBase.OnPaint(e)
If Not ComboBoxRenderer.IsSupported Then
ControlPaint.DrawComboButton(e.Graphics, _
Me.ClientRectangle, ButtonState.Normal)
Else
ComboBoxRenderer.DrawDropDownButton(e.Graphics, _
Me.ClientRectangle, ComboBoxState.Normal)
End If
End Sub
Kompilace kódu
Tento příklad vyžaduje:
Vlastní ovládací prvek odvozený z Control třídy.
Form, který je hostitelem vlastního ovládacího prvku.
Odkazy na obory názvů System, System.Drawing, System.Windows.Formsa System.Windows.Forms.VisualStyles.
Viz také
.NET Desktop feedback