Я создал приложение для iPhone, которое может сканировать изображение страницы миллиметровки и затем сообщать мне, какие квадраты были затемнены, а какие пустыми.
Я делаю это путем сканирования изслева направо и используйте линии миллиметровки в качестве направляющих.Когда я сталкиваюсь с линией миллиметровки, я начинаю искать черный, пока не достигну линии миллиметровки снова.Затем, вместо продолжения вдоль линии сканирования, я продолжаю сканировать квадрат на черный.Затем я перехожу к следующей коробке.В конце строки я пропускаю так много пикселей перед началом сканирования новой строки (так как я уже выяснил, какова высота каждой рамки).
Такого рода работает, но есть проблемы.Иногда я ошибочно принимаю линии графика на «черных».Иногда, если изображение искажено или у меня нет равномерного освещения по всей странице, я не получаю хороших результатов.
Я бы хотел указать несколько «выравниваний»ящики, которые я затем изменяю размер и поворачиваю (и наклоняю) изображение, чтобы выровнять с теми.Затем я подумал, что, как только у меня выровняется изображение, я узнаю, где находятся все ящики, и мне не нужно будет сканировать ящики, просто отсканируй их внутри, чтобы увидеть, черные ли они.Это должно быть быстрее и надежнее.И если бы я работал с изображениями, поступающими с камеры, у меня было бы больше гибкости в том, чтобы попросить пользователя выровнять изображение в соответствии с метками выравнивания, а не самому выравнивать изображение.
Учитывая, чтоэто мой первый проект по обработке изображений, я чувствую, что заново изобретаю колесо.Я хотел бы получить предложения о том, как это сделать и использовать ли библиотеки, такие как OpenCV.
Я прилагаю изображение, похожее на то, что я хотел бы обработать.Я ищу список всех квадратов, которые имеют значительное количество черной маркировки, то есть A8, C4, E7, G4, H1, J9.
Проблемы, о которых следует знать:
- Световой охват изображения может быть не идеальным, но должен быть относительно равномерным по всему изображению (то есть без теней)
- Все квадраты могут быть пустыми или полностью темными, и алгоритм должен быть в состоянии определить, что
- изображение может быть перекошено или повернуто вокруг любой оси.Вращение вокруг оси z может быть легко исправлено.Может быть вращение вокруг оси x или y, что делает одну сторону изображения шире, чем другую.Однако, если я сканирую изображение в режиме реального времени, как оно поступает с камеры, я могу попросить пользователя выровнять метки совмещения с метками на экране.Как лучше всего обеспечить такое выравнивание, чтобы дать пользователю соответствующую обратную связь?Просто проверка, чтобы убедиться, что 4 угла темные, может привести к ложному положительному результату, когда камера указывает на черную поверхность.
- не каждый квадрат будет одинаково или постоянно затемнен, но я думаю, что будет достаточночерный, чтобы сделать его бесспорным для человеческого глаза.
- синяя сетка может быть полезной, но есть случаи, когда черные маркировки могут перекрывать синюю сетку.Я думаю, что виртуальная сетка, вероятно, лучше, чем полагаться на печатную сетку.Я думаю, что использование маркеров выравнивания для выравнивания изображения позволит создать точную виртуальную сетку.И затем содержимое каждой ячейки сетки может быть отобрано, чтобы увидеть, было ли оно преимущественно черным, по сравнению со сканированием слева направо, нет?Вот еще одно изображение с большим количеством отметок на сетке.На этом изображении, в дополнение к предыдущей маркировке в A8, C4, E7, G4, H1, J9, я пометил E2, G8 и G9 и I4 и J4, и вы можете увидеть, как синяя сетка скрыта.
- Это мой первый этап этого проекта.В конце концов я бы хотел масштабировать этот алгоритм, чтобы иметь возможность обрабатывать как минимум несколько сотен слотов и, возможно, разных цветов.