LabVIEWForum.de - SNAPI DLL zur Bildaufnahme nutzen. Motorola DS3508

LabVIEWForum.de

Normale Version: SNAPI DLL zur Bildaufnahme nutzen. Motorola DS3508
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Hallo zusammen,

mithilfe eines Motorola Scanners DS3508 möchte ich ein Bild aufnehmen (jpeg) und dieses für eine Bildverarbeitungssoftware nutzen. Dies soll mithilfe von LABVIEW realisiert werden. Bereits in Achimedes Thema (Achimedes Thema SNAPI DLL einbinden) wurden einige ähnliche Fragestellungen diskutiert.
Die Ansteuerung des Scanners funktioniert mit SNAPI, dazu gibt es bereits eine DLL.
[attachment=50061][attachment=50064]

Ich habe auch bereits die vorhandenen Beispiel VI's getestet um mich in das Thema einzuarbeiten.

Die Bildaufnahme ist mir scheinbar gelungen (wenn ich den Piepton des Scanners richtig interpretiere).
Allerdings stellt sich mir jetzt die Frage wie handhabe ich die Übergabe der Bilddaten. Bei SNAPI_SetImageBuffer erhalte ich einen Pointer auf eine Adresse. Doch wie lese ich diese Adresse aus bzw. wie erhalte ich die Datenmatrix des Bildes.

Ein Rätsel ist mir auch wie das Funktioniert mit den Windows Messages. Diese benötige ich um die Signale des Sensors zu interpretieren, wo kann ich aber genaueres dazu lesen?
[attachment=50062]

Ich habe hier mal ein kleines Testprogramm welches ein Bild macht, aber leider kann ich nicht darauf zugreifen. Ich habe ein paar Dinge geändert von Achimedes Programm aber die Windows Messages und die auswertung des Zeigers weiß ich nicht wie das funktioniert. [attachment=50063]

Ich hoffe ihr könnt mir weiterhelfen!

Viele Grüße

Rizek
(18.06.2014 15:07 )Rizek schrieb: [ -> ]Hallo zusammen,

mithilfe eines Motorola Scanners DS3508 möchte ich ein Bild aufnehmen (jpeg) und dieses für eine Bildverarbeitungssoftware nutzen. Dies soll mithilfe von LABVIEW realisiert werden. Bereits in Achimedes Thema (Achimedes Thema SNAPI DLL einbinden) wurden einige ähnliche Fragestellungen diskutiert.
Die Ansteuerung des Scanners funktioniert mit SNAPI, dazu gibt es bereits eine DLL.


Ich habe auch bereits die vorhandenen Beispiel VI's getestet um mich in das Thema einzuarbeiten.

Die Bildaufnahme ist mir scheinbar gelungen (wenn ich den Piepton des Scanners richtig interpretiere).
Allerdings stellt sich mir jetzt die Frage wie handhabe ich die Übergabe der Bilddaten. Bei SNAPI_SetImageBuffer erhalte ich einen Pointer auf eine Adresse. Doch wie lese ich diese Adresse aus bzw. wie erhalte ich die Datenmatrix des Bildes.

Ein Rätsel ist mir auch wie das Funktioniert mit den Windows Messages. Diese benötige ich um die Signale des Sensors zu interpretieren, wo kann ich aber genaueres dazu lesen?


Ich habe hier mal ein kleines Testprogramm welches ein Bild macht, aber leider kann ich nicht darauf zugreifen. Ich habe ein paar Dinge geändert von Achimedes Programm aber die Windows Messages und die auswertung des Zeigers weiß ich nicht wie das funktioniert.

Ich hoffe ihr könnt mir weiterhelfen!

Viele Grüße

Rizek

Erster Crashgrund: Bei DSNewPtr() allozierst Du einen Pointer mit 50 Byte aber erzählst SNAPI_SetImageBuffer() heiter fröhlich, dass der Buffer 5000 Byte gross ist!!!! Gute Nacht LabVIEW!!!!

Ebenfalls sinnvoll wäre es dann um die Initialize Array Node mit der selben Nummer anzurufen um ein entsprechen grosses Array anzulegen und auch bei MoveBlock() diese Nummer beim 3. Parameter zu verwenden, aber diese Nummer darf sicher nie mehr sein dann was Du in DSNewPtr() an Bytes alloziert hast. Danach sollte man am Ende auch DSDisposePtr() aufrufen, ansonsten produzierst Du ein Speicherleck.

Der Pointer den Du in DSNewPtr() alloziert hast sollte durchgehend in allen Call Library Nodes als Pointer sized Integer definiert sein. Im Momen liefert DSNewPtr() zwar einen Pointer sized Integer zurück aber alle anderen Funktionen verwenden I64. Das geht dann aber in LabVIEW 32 Bit nicht korrekt.

Die Windwos Message Queue Library verwendet momentan Pseudo Refnums für die window Handle (und auch die Message Queue Reference). Aber eine LabVIEW Refnum ist immer 32 Bit gross, ein Windows Handle aber 32 bit unter LabVIEW 32 Bit und 64 Bit unter LabVIEW 64 Bit. Mit der heutigen Windows Message Queue kannst Du also nur unter LabVIEW 32 Bit arbeiten, auch da ich nicht glaube dass die dazugehörende DLL bereits für 64 Bit kompiliert wurde. Aber selbst wenn Du eine 64 Bit DLL hättest ginge es wegen der Verwendung einer LabVIEW Refnum für diese Datentypen ohnehin falsch. Um diese für LabVIEW 64 ko,mpatibel zu machen muss man sowohl die DLL als 64 Bit DLL kompilieren als auch die Queue Reference und die window Handle im Frontpanel als 64 Bit Integer definieren, aber in allen Call Library Nodes überall als Pointer sized Integer definieren.

Zu guter letzt. Die SNAPI ist so gebaut dass sie Dir ein Windows Event schickt wenn ein Scan verfügbar ist. Erst bei Empfang dieser Message macht es Sinn um mit MoveBlock() die Daten aus dem Buffer im Pointer herauszukopieren. Davor ist durch die DLL nichts im Buffer abgelegt, liest Du also die ursrprünglichen Zufallswerte zurück die im Speicher nach Aufruf von DSNewPtr() bereits lagen.
Habe mal eine "etwas" überarbeitete Version hier angehängt.

Die Windows Message Library wurde etwas angepasst ist aber noch immer nur 32 Bit.
Bei der SNAPI Library habe ich alle VIs die in diesem Beispiel nicht verwendet werden rausgeschmissen. Die die drin sind sind soweit angepasst dass Sie auch mit einer 64 Bit DLL in 64 Bit LabVIEW funktionieren würden.

Dein Spielerei.vi ist aufgeräumt und soweit verbessert.

ABER: ich habe keine Hardware und kann es nicht testen. Dieses VI is ohne Gewähr, auf eigenes Risiko und blabla... Es können noch Bugs drin sein, und Dein Computer kann sich in Flammen auflösen bei Benützung davon. Big Grin

Es ist aber garantiert wesentlich besser und korrekter als das was Du hattest! Cool

[attachment=50067]
(18.06.2014 22:58 )rolfk schrieb: [ -> ]Habe mal eine "etwas" überarbeitete Version hier angehängt.

Die Windows Message Library wurde etwas angepasst ist aber noch immer nur 32 Bit.
Bei der SNAPI Library habe ich alle VIs die in diesem Beispiel nicht verwendet werden rausgeschmissen. Die die drin sind sind soweit angepasst dass Sie auch mit einer 64 Bit DLL in 64 Bit LabVIEW funktionieren würden.

Dein Spielerei.vi ist aufgeräumt und soweit verbessert.

ABER: ich habe keine Hardware und kann es nicht testen. Dieses VI is ohne Gewähr, auf eigenes Risiko und blabla... Es können noch Bugs drin sein, und Dein Computer kann sich in Flammen auflösen bei Benützung davon. Big Grin

Es ist aber garantiert wesentlich besser und korrekter als das was Du hattest! Cool

Hallo Rolf,

vielen vielen Dank für deine Tipps und natürlich auch für die Verbesserungen!! Ich werde es morgen durcharbeiten, versuchen alles nachzuvollziehen und natürlich testen. Ich hoffe ich kann mich weiterhin mit Fragen an dich wenden, falls ich manches nicht so ganz verstehe.


Mit größtem Dank!!!!,

Beste Grüße

Rizek
Beim Ausführen der überarbeiteten Fassung der spielerei tritt folgender Fehler in meiner 32 bit LabView 2013 Version auf

[attachment=50076]

Woran könnte dieser Fehler liegen? Ich hab mal als Test die alte Wait Windows Message eingefügt. Allerdings mit dem selben Ergebnis/Fehler.
(20.06.2014 11:08 )Rizek schrieb: [ -> ]Beim Ausführen der überarbeiteten Fassung der spielerei tritt folgender Fehler in meiner 32 bit LabView 2013 Version auf

Woran könnte dieser Fehler liegen? Ich hab mal als Test die alte Wait Windows Message eingefügt. Allerdings mit dem selben Ergebnis/Fehler.

Also ganz sicher bin ich nicht, aber da war noch ein kleiner Fehler in Create Windows Message Queue.vi so dass das window handle nicht richtig übergeben wurde. Ich gehe da mal schauen. Habe die Windows Message Queue DLL neu kompiliert und angepasst dass es sowohl mit 32 bit als auch 64 laufen sollte, hatte aber noch keinerlei Zeit um das zu testen. Das möchte ich noch tun um zumindest sicher zu sein, dass die Windows Message Queue sicher läuft. Die SNAPI Interface kann ich nicht testen, aber da ich die Windows Message Queue DLL angepasst habe, will ich erst sicher sein, dass die zumindest noch läuft, ansonsten kommst Du eh keinen Millimeter weiter.

Du kannst die neue Version der Message Library (vom vorigen Post von mir) insoweit anpassen, dass Du in Create Windows Message Queue.vi bei der Call Library Node den zweiten Parameter (hWnd) für das window handle dahingehend konfigurierst, dass dieser Parameter nicht by Value sondern by Reference übergeben wird (Pass: Value => Pass: Pointer to Value). Später folgt noch eine überarbeitete Version von mir.
Hier ist eine Version mit angepasster Windows Message Queue library. Diese funktioniert sowohl für 32 Bit und 64 Bit. Aber die SNAPI DLL habe ich nicht in 64 Bit.

[attachment=50096]
Referenz-URLs