Ich entwickle eine Vision-Anwendung, die die folgende Farbkarte und die Kamera verwendet, um die Farbe jedes Patches in der Tabelle zu extrahieren. Dazu muss ich zuerst den Diagrammbereich in einem Bild erkennen und den Bereich mit der vorhandenen Vorlage abgleichen, die Positionen von Patches enthält.
Meine Frage: Ich muss den Farbfeldbereich erkennen, indem ich vier Ecken des Diagramms erkenne. Sie können die Ecken sehen, die die kleinen Rechtecke im Bild unten anzeigen. Ich weiß, dass eine Möglichkeit darin besteht, den Benutzer diese Ecken auswählen zu lassen, indem er darauf klickt. Gibt es jedoch eine Möglichkeit, vier Ecken des Bildes automatisch zu erkennen?
image-processing
Tae-Sung Shin
quelle
quelle
Antworten:
Sie können Hough-Linien unterbringen, um den Farbbereich zu erkennen
quelle
Jedes 2D-Array einer Farbkomponente (RGB usw.) ist ziemlich kontrastreich und unterscheidungskräftig. Daher könnte ich versuchen, eine komplexe 2D-FFT jeder Farbkomponente zu verwenden, um den Maßstab und den Versatz des Fotobilds gegenüber dem eines Referenzbilds zu bestimmen. Verwenden Sie diese dann, um die gemessenen / bekannten Koordinaten der Ecken und / oder Flecken im Referenzbild anzupassen und Koordinaten im Foto zu erzeugen.
Möglicherweise müssen Sie einige Koordinaten auf einem Referenzbild mit einem Bitmap-Editor aus erster Hand messen.
quelle
Als ersten Schritt würde ich alle Unordnung mit Grau und Text entfernen. Ausgehend von allen vier Seiten werde ich anhalten, bis die meisten Pixel eine eindeutig bekannte "graue" Farbe haben.
Dadurch bleibt nur das Schachbrett übrig, das aus verschiedenen Farben besteht. Sie erwarten ungefähr 22x12 - ungefähr 264 Farben.
Eine einfachste Methode wäre die Anwendung eines einfacheren Palatalisierungsalgorithmus. Wenn Sie dies in ein GIF-Bild übersetzen müssten, wird die Farbquantisierung angewendet, wobei jeder Farbcluster als Schwerpunktfarbe dargestellt wird.
Dies wäre in Ihrem Fall besonders einfach, da die Quelle bereits eine Art Gaumen ist und Sie eine gute, anständige Vermutung anstellen können, um zu beginnen.
Überprüfen Sie dies heraus:
NeuQuant: http://members.ozemail.com.au/~dekker/NEUQUANT.HTML
Octree-Farbquantisierung: http://www.cubic.org/docs/octree.htm . Siehe auch dies .
Dies sind nur einige Referenzen; In den meisten Bibliotheken, die solche Bildformate verwenden, finden Sie jedoch gebrauchsfertigen Code. (BMP, PNG und GIF unterstützen solche Darstellungen). Schauen Sie sich auch libpng und libjpeg für einige schnelle Implementierungen an.
quelle
Warum nicht nach den Grenzen des Diagramms suchen, anstatt nach Ecken? Sie können versuchen, einen Kantendetektor zu verwenden und dann mit der Hough-Transformation gerade Linien zu finden.
quelle