Нуждаюсь в помощи устанавливая изображение с прозрачным фоном к буферу обмена

Я нуждаюсь в помощи, устанавливая прозрачное изображение на буфер обмена. Я продолжаю получать "дескриптор, недопустимо". В основном мне нужна "вторая пара глаз" для просмотра следующего кода. (Полный рабочий проект по ftp://missico.net/ImageVisualizer.zip.)

Это - Отладка изображения библиотека классов Visualizer, но я сделал включенный проект работать как исполняемый файл за тестированием. (Обратите внимание, что окно является окном панели инструментов, и шоу в панели задач имеет значение false.) Я устал от необходимости выполнить снимок экрана на окне панели инструментов, открыть снимок экрана с редактором изображений и затем удаление фона, добавленного, потому что это был снимок экрана. Таким образом, я думал, что быстро помещу прозрачное изображение на буфер обмена. Ну, проблемой не является... никакая поддержка прозрачности для Буфера обмена. SetImage. Google к спасению... не совсем.

Это - то, что я имею до сих пор. Я вытянул из многих источников. См. код для основной ссылки. Моей проблемой является "недопустимый дескриптор" при использовании CF_DIBV5. Я должен использовать BITMAPV5HEADER и CreateDIBitmap?

Любая справка от Вас GDI/GDI + Мастера значительно ценилась бы.

    public static void SetClipboardData(Bitmap bitmap, IntPtr hDC) {

        const uint SRCCOPY = 0x00CC0020;
        const int CF_DIBV5 = 17;
        const int CF_BITMAP = 2;

        //'reference
        //'http://social.msdn.microsoft.com/Forums/en-US/winforms/thread/816a35f6-9530-442b-9647-e856602cc0e2

        IntPtr memDC = CreateCompatibleDC(hDC);
        IntPtr memBM = CreateCompatibleBitmap(hDC, bitmap.Width, bitmap.Height);

        SelectObject(memDC, memBM);

        using (Graphics g = Graphics.FromImage(bitmap)) {

            IntPtr hBitmapDC = g.GetHdc();
            IntPtr hBitmap = bitmap.GetHbitmap();

            SelectObject(hBitmapDC, hBitmap);

            BitBlt(memDC, 0, 0, bitmap.Width, bitmap.Height, hBitmapDC, 0, 0, SRCCOPY);

            if (!OpenClipboard(IntPtr.Zero)) {
                throw new System.Runtime.InteropServices.ExternalException("Could not open Clipboard", new Win32Exception());
            }

            if (!EmptyClipboard()) {
                throw new System.Runtime.InteropServices.ExternalException("Unable to empty Clipboard", new Win32Exception());
            }

            //IntPtr hClipboard = SetClipboardData(CF_BITMAP, memBM); //works but image is not transparent

            //all my attempts result in SetClipboardData returning hClipboard = IntPtr.Zero
            IntPtr hClipboard = SetClipboardData(CF_DIBV5, memBM);


            //because 
            if (hClipboard == IntPtr.Zero) {

                //    InnerException: System.ComponentModel.Win32Exception
                //         Message="The handle is invalid"
                //         ErrorCode=-2147467259
                //         NativeErrorCode=6
                //         InnerException: 

                throw new System.Runtime.InteropServices.ExternalException("Could not put data on Clipboard", new Win32Exception());
            }

            if (!CloseClipboard()) {
                throw new System.Runtime.InteropServices.ExternalException("Could not close Clipboard", new Win32Exception());
            }

            g.ReleaseHdc(hBitmapDC);

        }

    }

    private void __copyMenuItem_Click(object sender, EventArgs e) {

        using (Graphics g = __pictureBox.CreateGraphics()) {

            IntPtr hDC = g.GetHdc();

            MemoryStream ms = new MemoryStream();

            __pictureBox.Image.Save(ms, ImageFormat.Png);

            ms.Seek(0, SeekOrigin.Begin);

            Image imag = Image.FromStream(ms);

            // Derive BitMap object using Image instance, so that you can avoid the issue 
            //"a graphics object cannot be created from an image that has an indexed pixel format"

            Bitmap img = new Bitmap(new Bitmap(imag));

            SetClipboardData(img, hDC);

            g.ReleaseHdc();

        }

    }

6
задан AMissico 10 May 2010 в 16:49
поделиться

1 ответ

Bitmap.GetHbitmap () фактически объединит растровое изображение в непрозрачный фон, потеряв альфа-канал. Этот вопрос касается того, как получить HBITMAP с неповрежденным альфа-каналом.

0
ответ дан 17 December 2019 в 04:43
поделиться
Другие вопросы по тегам:

Похожие вопросы: