ControlPaint.DrawReversibleLine(Point, Point, Color) Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Desenha uma linha reversível na tela dentro dos pontos inicial e final especificados e com a cor da tela de fundo especificada.
public:
static void DrawReversibleLine(System::Drawing::Point start, System::Drawing::Point end, System::Drawing::Color backColor);
public static void DrawReversibleLine (System.Drawing.Point start, System.Drawing.Point end, System.Drawing.Color backColor);
static member DrawReversibleLine : System.Drawing.Point * System.Drawing.Point * System.Drawing.Color -> unit
Public Shared Sub DrawReversibleLine (start As Point, end As Point, backColor As Color)
Parâmetros
Exemplos
O exemplo de código a seguir demonstra o uso dos métodos e Control.PointToScreen do ControlPaint.DrawReversibleLine uso. Para executar o exemplo, cole o código a seguir em um formulário. Adicione um botão nomeado Button3
ao formulário e verifique se todos os eventos estão conectados aos manipuladores de eventos.
// When the mouse hovers over Button3, two reversible lines are
// drawn using the corner coordinates of Button3, which are first
// converted to screen coordinates.
void Button3_MouseHover( Object^ /*sender*/, System::EventArgs^ /*e*/ )
{
ControlPaint::DrawReversibleLine( Button3->PointToScreen( Point(0,0) ), Button3->PointToScreen( Point(Button3->ClientRectangle.Right,Button3->ClientRectangle.Bottom) ), SystemColors::Control );
ControlPaint::DrawReversibleLine( Button3->PointToScreen( Point(Button3->ClientRectangle.Right,Button3->ClientRectangle.Top) ), Button3->PointToScreen( Point(Button1->ClientRectangle.Left,Button3->ClientRectangle.Bottom) ), SystemColors::Control );
}
// When the mouse moves from Button3, the reversible lines are erased by
// using the same coordinates as are used in the Button3_MouseHover method.
void Button3_MouseLeave( Object^ /*sender*/, System::EventArgs^ /*e*/ )
{
ControlPaint::DrawReversibleLine( Button3->PointToScreen( Point(0,0) ), Button3->PointToScreen( Point(Button3->ClientRectangle.Right,Button3->ClientRectangle.Bottom) ), SystemColors::Control );
ControlPaint::DrawReversibleLine( Button3->PointToScreen( Point(Button3->ClientRectangle.Right,Button3->ClientRectangle.Top) ), Button3->PointToScreen( Point(Button3->ClientRectangle.Left,Button3->ClientRectangle.Bottom) ), SystemColors::Control );
}
// When the mouse hovers over Button3, two reversible lines are
// drawn using the corner coordinates of Button3, which are first
// converted to screen coordinates.
private void Button3_MouseHover(object sender, System.EventArgs e)
{
ControlPaint.DrawReversibleLine(Button3.PointToScreen(
new Point(0, 0)), Button3.PointToScreen(
new Point(Button3.ClientRectangle.Right,
Button3.ClientRectangle.Bottom)), SystemColors.Control);
ControlPaint.DrawReversibleLine(Button3.PointToScreen(
new Point(Button3.ClientRectangle.Right,
Button3.ClientRectangle.Top)),
Button3.PointToScreen(new Point(Button1.ClientRectangle.Left,
Button3.ClientRectangle.Bottom)), SystemColors.Control);
}
// When the mouse moves from Button3, the reversible lines are erased by
// using the same coordinates as are used in the Button3_MouseHover method.
private void Button3_MouseLeave(object sender, System.EventArgs e)
{
ControlPaint.DrawReversibleLine(Button3.PointToScreen(
new Point(0, 0)), Button3.PointToScreen(
new Point(Button3.ClientRectangle.Right,
Button3.ClientRectangle.Bottom)), SystemColors.Control);
ControlPaint.DrawReversibleLine(Button3.PointToScreen(
new Point(Button3.ClientRectangle.Right,
Button3.ClientRectangle.Top)),
Button3.PointToScreen(new Point(Button3.ClientRectangle.Left,
Button3.ClientRectangle.Bottom)), SystemColors.Control);
}
' When the mouse hovers over Button3, two reversible lines are drawn
' using the corner coordinates of Button3, which are first
' converted to screen coordinates.
Private Sub Button3_MouseHover(ByVal sender As Object, _
ByVal e As System.EventArgs) Handles Button3.MouseHover
ControlPaint.DrawReversibleLine(Button3.PointToScreen(New Point(0, 0)), _
Button3.PointToScreen(New Point(Button3.ClientRectangle.Right, _
Button3.ClientRectangle.Bottom)), SystemColors.Control)
ControlPaint.DrawReversibleLine(Button3.PointToScreen( _
New Point(Button3.ClientRectangle.Right, Button3.ClientRectangle.Top)), _
Button3.PointToScreen(New Point _
(Button1.ClientRectangle.Left, Button3.ClientRectangle.Bottom)), _
SystemColors.Control)
End Sub
' When the mouse moves from Button3, the reversible lines are
' erased by using the same coordinates as are used in the
' Button3_MouseHover method.
Private Sub Button3_MouseLeave(ByVal sender As Object, _
ByVal e As System.EventArgs) Handles Button3.MouseLeave
ControlPaint.DrawReversibleLine(Button3.PointToScreen(New Point(0, 0)), _
Button3.PointToScreen(New Point(Button3.ClientRectangle.Right, _
Button3.ClientRectangle.Bottom)), SystemColors.Control)
ControlPaint.DrawReversibleLine(Button3.PointToScreen( _
New Point(Button3.ClientRectangle.Right, Button3.ClientRectangle.Top)), _
Button3.PointToScreen(New Point(Button3.ClientRectangle.Left, _
Button3.ClientRectangle.Bottom)), SystemColors.Control)
End Sub
Comentários
O backColor
parâmetro é usado para calcular a cor de preenchimento da linha para que ela fique sempre visível em relação ao plano de fundo.
Os resultados desse método podem ser revertidos desenhando a mesma linha novamente. Desenhar uma linha usando esse método é semelhante a inverter uma região da tela, exceto que ele fornece melhor desempenho para uma variedade mais ampla de cores.