битмап загружается зеркально и инвертировано - PullRequest
0 голосов
/ 23 июня 2019

Я получаю CF_DIB из буфера обмена и затем вызываю:

GdkPixbuf* pixbuf = gdk_pixbuf_new_from_data(info->bmiColors, GDK_COLORSPACE_RGB, TRUE, 8, info->bmiHeader.biWidth, info->bmiHeader.biHeight, rowstride, NULL, NULL);

, чтобы создать GdkPixbuf из данных пикселей.Однако изображение выглядит перевернутым и зеркально инвертированным (я думаю, что это BGR).

Как правильно создать pixbuf?

1 Ответ

0 голосов
/ 24 июня 2019

Я решил свою проблему с помощью этой функции, которую я написал:

GdkPixbuf* soft_drm_dib_to_pixbuf (BITMAPINFO* info)
{
    gint    rowstride   = 4 * ((info->bmiHeader.biBitCount * info->bmiHeader.biWidth + 31) / 32);
    gsize   size        = rowstride * info->bmiHeader.biHeight;
    gchar*  copy        = (gchar *)info->bmiColors;
    gchar*  newp        = g_malloc0(size);
    gint    x           = 0;
    gint    y           = 0;

    for(y = 0; y < info->bmiHeader.biHeight; y++)
    {
        for(x = 0; x < info->bmiHeader.biWidth; x++)
        {
            gint    col     = x;
            gint    row     = info->bmiHeader.biHeight - y - 1;
            gint    index   = (row * info->bmiHeader.biWidth + col) * 4;
            gint    index2  = (row * info->bmiHeader.biWidth + (info->bmiHeader.biWidth - col)) * 4;

            newp[(size - index2) + 0] = copy[index + 2];
            newp[(size - index2) + 1] = copy[index + 1];
            newp[(size - index2) + 2] = copy[index + 0];
        }
    }

    return gdk_pixbuf_new_from_data(newp, GDK_COLORSPACE_RGB, TRUE, 8, info->bmiHeader.biWidth, info->bmiHeader.biHeight, rowstride, (GdkPixbufDestroyNotify)g_free, NULL);
}

это определенно может выглядеть намного лучше, хотя.

...