Прочитать на английском

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


ImageLockMode Перечисление

Определение

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

C#
public enum ImageLockMode
Наследование
ImageLockMode

Поля

Имя Значение Описание
ReadOnly 1

Указывает, что часть изображения заблокирована для чтения.

ReadWrite 3

Указывает, что часть изображения заблокирована для чтения и записи.

UserInputBuffer 4

Указывает, что буфер для чтения или записи данных о пикселях определяется пользователем. Если данный флаг установлен, то параметр flags метода LockBits выступает в роли входного параметра (и, возможно, в качестве выходного параметра). Если данный флаг снят, параметр flags является только выходным параметром.

WriteOnly 2

Указывает, что часть изображения заблокирована для записи.

Примеры

В следующем примере кода показано, как использовать PixelFormatсвойства , Height, Widthи Scan0 , LockBits методы и UnlockBits и перечисление ImageLockMode . Этот пример предназначен для использования с Windows Forms. Чтобы выполнить этот пример, вставьте его в форму и обработайте событие формы Paint путем вызова LockUnlockBitsExample метода , передавая e как PaintEventArgs.

C#
private void LockUnlockBitsExample(PaintEventArgs e)
    {

        // Create a new bitmap.
        Bitmap bmp = new Bitmap("c:\\fakePhoto.jpg");

        // Lock the bitmap's bits.  
        Rectangle rect = new Rectangle(0, 0, bmp.Width, bmp.Height);
        System.Drawing.Imaging.BitmapData bmpData =
            bmp.LockBits(rect, System.Drawing.Imaging.ImageLockMode.ReadWrite,
            bmp.PixelFormat);

        // Get the address of the first line.
        IntPtr ptr = bmpData.Scan0;

        // Declare an array to hold the bytes of the bitmap.
        int bytes  = Math.Abs(bmpData.Stride) * bmp.Height;
        byte[] rgbValues = new byte[bytes];

        // Copy the RGB values into the array.
        System.Runtime.InteropServices.Marshal.Copy(ptr, rgbValues, 0, bytes);

        // Set every third value to 255. A 24bpp bitmap will look red.  
        for (int counter = 2; counter < rgbValues.Length; counter += 3)
            rgbValues[counter] = 255;

        // Copy the RGB values back to the bitmap
        System.Runtime.InteropServices.Marshal.Copy(rgbValues, 0, ptr, bytes);

        // Unlock the bits.
        bmp.UnlockBits(bmpData);

        // Draw the modified image.
        e.Graphics.DrawImage(bmp, 0, 150);
    }

Применяется к

Продукт Версии
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9