Поделиться через


Практическое руководство. Рисование изображений с прозрачностью

Обновлен: Ноябрь 2007

Платформа .NET Compact Framework поддерживает прозрачность, но только с одним прозрачным цветом. В методе SetColorKey(Color, Color) для диапазона слабо насыщенных цветов и диапазона сильно насыщенных цветов должен быть указан один и тот же цвет.

Пример

В данном примере создается экземпляр Bitmap в виде прямоугольника с черными и красными узорами и демонстрируются два способа задания прозрачности:

  • Используйте метод SetColorKey(Color, Color), основанный на точке в изображении. В данном примере прозрачность задается с помощью верхней левой точки на изображении. Поскольку данная точка имеет черный цвет, прозрачными будут все точки, которые изначально были черными.

  • Используйте метод SetColorKey(Color, Color) с явным заданием цвета. В примере устанавливается красный цвет, поэтому прозрачными будут все точки, которые изначально были красными.

Для наглядности сначала запустите приложение, поместив код обоих методов задания прозрачности в комментарии, чтобы просмотреть изображение без прозрачности. Затем удалите значки комментария для одного из способов.

' The .NET Compact Framework supports transparency,
' but with only one transparency color.
' The SetColorKey method must have the same color 
' specified for the low color and high color range.

' Note that you must uncomment lines of code
' as indicated for the desired transparency effect.
Protected Overrides Sub OnPaint(ByVal e As PaintEventArgs)

' Create a red and black bitmap to demonstrate transparency.
    Dim bmp As New Bitmap(75, 75)
    Dim g As Graphics = Graphics.FromImage(bmp)

    g.FillEllipse(New SolidBrush(Color.Red), 0, 0, bmp.Width, bmp.Width)
    g.DrawLine(New Pen(Color.Black), 0, 0, bmp.Width, bmp.Width)
    g.DrawLine(New Pen(Color.Black), bmp.Width, 0, 0, bmp.Width)
    g.Dispose()


Dim attr As New ImageAttributes

' Set the transparency color key based on the upper-left pixel 
' of the image.
' Uncomment the following line to make all black pixels transparent:
' attr.SetColorKey(bmp.GetPixel(0, 0), bmp.GetPixel(0, 0))

' Set the transparency color key based on a specified value.
' Uncomment the following line to make all red pixels transparent:
' attr.SetColorKey(Color.Red, Color.Red)

' Draw the image using the image attributes.
Dim dstRect As New Rectangle(0, 0, bmp.Width, bmp.Height)
e.Graphics.DrawImage(bmp, dstRect, 0, 0, bmp.Width, bmp.Height, _
    GraphicsUnit.Pixel, attr)

End Sub
// The .NET Compact Framework supports transparency,
// but with only one transparency color.
// The SetColorKey method must have the same color 
// specified for the low color and high color range.

// Note that you must uncomment lines of code
// as indicated for the desired transparency effect.

protected override void OnPaint(PaintEventArgs e)
{
    // Create a red and black bitmap to demonstrate transparency.
    Bitmap bmp = new Bitmap(75,75);
    Graphics g = Graphics.FromImage(bmp);

    g.FillEllipse(new SolidBrush(Color.Red), 0, 0, bmp.Width, bmp.Width);
    g.DrawLine(new Pen(Color.Black), 0, 0, bmp.Width, bmp.Width);
    g.DrawLine(new Pen(Color.Black), bmp.Width, 0, 0, bmp.Width);
    g.Dispose();

    ImageAttributes attr = new ImageAttributes();

    // Set the transparency color key based on the upper-left pixel 
    // of the image.
    // Uncomment the following line to make all black pixels transparent:
    // attr.SetColorKey(bmp.GetPixel(0, 0), bmp.GetPixel(0, 0));

    // Set the transparency color key based on a specified value.
    // Uncomment the following line to make all red pixels transparent:
    // attr.SetColorKey(Color.Red, Color.Red);

    // Draw the image using the image attributes.
    Rectangle dstRect = new Rectangle(0, 0, bmp.Width, bmp.Height);
    e.Graphics.DrawImage(bmp, dstRect, 0, 0, bmp.Width, bmp.Height,
        GraphicsUnit.Pixel, attr);
}

Компиляция кода

Для этого примера требуются ссылки на следующие пространства имен:

Отказоустойчивость

Обратите внимание на то, что объект Graphics, используемый для создания растрового изображения, удаляется явным образом. Объект Graphics, возвращаемый свойством Graphics объекта PaintEventArgs, уничтожается сборщиком мусора, и для него не требуется явное удаление.

См. также

Другие ресурсы

Графика и рисование в .NET Compact Framework