Обычно можно выполнять итерации по массиву изображений сверху вниз по строкам и внутри каждой строки слева направо по столбцам.В этом случае вам нужно обратное: мы хотим перебирать каждый столбец, начиная слева, а внутри столбца перебираем все строки и проверяем наличие черного пикселя.
Это даст вамкрайний левый черный пиксель:
size_t maxIndex = height * bytesPerRow;
for (size_t x = 0; x < bytesPerRow; x += bytesPerPixel)
{
for (size_t index = x; index < maxIndex; index += bytesPerRow)
{
if (rawData[index + 3] > 0)
{
goto exitLoop;
}
}
}
exitLoop:
if (x < bytesPerRow)
{
x /= bytesPerPixel;
// left most column is `x`
}
Ну, это равно mattjgalloway, только немного оптимизировано и аккуратнее: O
Хотя goto
обычно разрешается отказаться от двух цикловизнутри внутренней петли все еще безобразно.Заставляет меня действительно скучать по этим изящным операторам управления потоком данных. D имеет ...
Функция, которую вы предоставили в примере кода, делает что-то другое.Он начинается в определенной позиции на изображении (определяемой xx
и yy
) и пересекает count
пикселей, переходя от начальной позиции вправо и переходя к следующим строкам.Я подозреваю, что эти альфа-значения добавляются в какой-то массив.
При пропуске xx = yy = 0
будет найден самый верхний пиксель с определенными условиями, а не самый левый.Это преобразование дается приведенным выше кодом.Напомним, что 2D-изображение - это просто одномерный массив в памяти, начиная с верхнего ряда слева направо и продолжая следующими рядами.Делая простую математику, можно перебирать строки или столбцы.