Qt QImage пиксельная манипуляция
Я создаю приложение Qt GUI и использую QImage для открытия изображений. Моя проблема в том, что я не могу понять, как использовать бит QImage() и scanline() методы получения доступа на пиксельном уровне.
Я видел этот пост Qt QImage пиксельные проблемы манипуляции но это только для первого пикселя каждой строки. Это правильно или я все неправильно понял?
спасибо заранее
3 ответов
на scanlines
соответствуют высоте изображения, столбцы соответствуют ширине изображения.
согласно документам, прототип выглядит как uchar* QImage::scanline(int i)
, или же const
версия.
но, как указал комментатор, поскольку данные зависят от архитектуры и образа машины, вы должны не использовать uchar *
напрямую. Вместо этого используйте что-то вроде следующего:
QRgb *rowData = (QRgb*)img.scanLine(row);
QRgb pixelData = rowData[col];
int red = qRed(pixelData);
это может быть не сразу очевидно из сообщения Калеба, но следующее работает для установки пикселя на изображении Format_RGB32.
// Get the line we want
QRgb *line = (QRgb *)image->scanLine(row_index);
// Go to the pixel we want
line += col_index;
// Actually set the pixel
*line = qRgb(qRed(color), qGreen(color), qBlue(color));
ответ не работа для меня. Похоже, данные не выровнены по 32bit в моей системе. Чтобы получить правильные данные, о моей системе я должен был сделать это:
for(uint32_t Y = 0; Y < mHeight; ++Y)
{
uint8_t* pPixel = Image.scanLine(Y);
for(uint32_t X = 0; X < mWidth; ++X)
{
const int Blue = *pPixel++;
const int Green = *pPixel++;
const int Red = *pPixel++;
uint8_t GrayscalePixel = (0.21f * Red) + (0.72f * Green) + (0.07 * Blue);
}
}