Folgendes Skript dient zur Suche eines HID-Gerätes mit gegebener Vendor- und Product-ID und anschließendem Verbinden. Das ist z.B. bei Benutzung von USB-LAN-Bridges oder anderen Gründen von USB-Neuverbindungen nützlich.
<?php
$hid_id = 12345; // ID der HID-Instanz in IP-Symcon
$vendor_id = 6789; // Vendor-ID des zu suchenden HID-Geräts
$product_id = 98765; // Product-ID des zu suchenden HID-Geräts
$interval = 5; // Kontrollintervall in Minuten
$instance = IPS_GetInstance($hid_id);
if ($instance['InstanceStatus'] >= 200)
{
$found_device = false;
if (((int)HID_GetDeviceVendorID($hid_id) != $vendor_id) && ((int)HID_GetDeviceProductID($hid_id) != $product_id))
{
echo "looking for hid device... ";
$devices = HID_GetDevices($hid_id);
foreach ($devices as $data)
{
if (((int)$data['VendorID'] == $vendor_id) && ((int)$data['ProductID'] == $product_id))
{
echo "found device... ";
$found_device = true;
HID_SetDeviceSerial($hid_id, (String)$data['DeviceSerial']);
HID_SetDeviceVendorID($hid_id, $vendor_id);
HID_SetDeviceProductID($hid_id, $product_id);
IPS_ApplyChanges($hid_id);
break;
}
}
if (!$found_device) echo "no device found! ";
}
else
{
$found_device = true;
echo "found device... ";
}
if ($found_device)
{
HID_SetOpen($hid_id, true);
IPS_ApplyChanges($hid_id);
echo "device opened... ";
}
}
IPS_SetScriptTimer($IPS_SELF, $interval * 60);
?>
Vendor- und Product-ID aller am PC angeschlossenen HID-Devices lassen sich mit folgendem Skript auflisten:
Ja, lieber Horst, probiere ich gerne aus,
was ich gerne hätte, ist, dass ich ich in die Sendebuffer schreiben kann.
Beispiel, ich habe iM ein HID-Gerät (kann PWM, 433MHz-Baumarkt-Steckdosen, Ports,- analog und digital beschalten) gebastelt, welche mir 12 Sende und 12 Empfangsbuffer (je ein Daten-Byte) liefert.
Lesen ist kein Problem, aber wie schreibe ich in die 12 Sendebuffer?
Beispiel: Byte 2 und 3 ist für HAUSCODE und STECKDOSENCODE der Baumarktsteckdosen, Byte 4 und 5 ist für 2 PWM(0-10Volt), wie schreibe ich gezielt da hinein??
Im neuen Script entweder rechte Mautaste --> Funktionsliste anzeigen
oder aber:
CTRL + SPACE drücken,
dann Anfangsbuchstaben zum vorselektieren
DA sind Sie ALLE die einem i.d.R. entfallen sind,
die Gefahr, sich zu vertippen umgeht man:
einfach beim selektierten ENTER reinhauen,
ist IPS nicht schön.
gefunden.
mfg
BerndJ
PS: Frag mich bitte nicht, was die ReportID ist, ich hab keine Ahnung und träume auch noch von der Möglichkeit in dieser Funktionsliste direkt eine entsprechende Hilfe „quasi per Tastendruck“, zu erhalten.
Die ReportID unterscheidet verschiedene Typen von Reports. Die sind für jedes HID-Gerät implementationsabhängig. Da musst Du in der Protokollbeschreibung nachsehen oder selbst das Protokoll analysieren. Die offizielle HID-Spezifikation findet sich unter USB.org - HID Tools. Mehr als mit der WMRS200 zu reden hab ich mit HID bisher nicht gemacht. Der Begriff HID-Buffer ist mir auch nicht geläufig.
Ich sehe da leider nirgendwo das Wörtchen HID. Das sieht mir da eher nach einem USB-Gerät mit eigenem Treiber aus. Die ReportID beim HID beschreibt von welchem Datensatztyp die gesendeten Daten sind (siehe HID Reports).
Da da Delphi-Beispielcode bei ist könntest Du Dir ein IP-Symcon-Modul schreiben. Ist eigentlich recht unkompliziert. Meine Delphi-Kenntnisse haben nach vier Jahren Inaktivität immernoch dafür gereicht.
Keine Treiber ist auch nicht richtig. Eher: Der Treiber ist beim OS dabei. Als was das USB-Gerät anzusehen ist steht dann schon in den Deskriptoren. Ich vermute, dass die Befehle in IP-Symcon nur für richtige HID-Devices funktionieren und nicht für jedes USB-Gerät.
Meinen Link würde ich so interpretieren, dass für identisch große Datensätze anhand der ReportID eine Unterscheidung möglich ist, wie diese zu interpretieren sind. Nimmt man z.B. einen Block von 3 Byte Länge könnte ReportID 0 bedeuten, dass Byte 1 Luftfeuchtigkeit, Byte 2 und 3 Temperatur darstellen; ReportID 1 sagt, dass Byte 1 bis 3 zusammen einen 24bit Zählerwert darstellen.
Bei der WMRS200 hat das keinen interessiert, da gibt es nur ReportID 0. Empfange Pakete sagen dann in Byte 1, wie viele Bytes des Datenblocks zu verwerten sind. Diese muss man dann bis zum Auftauchen einer Trennfolge zusammensetzen und die Datensätze interpretieren. Welcher Sensor was gesagt hat ist dann im jeweiligen Datenblock zu finden.
Wofür die ReportID gut ist, kann ich dir auch nicht sagen. In Protokollen wird nur definiert, wohin man senden soll. Ich kenne bis jetzt auch nur Geräte, wo an an die #0 gesendet werden muss. Der Rest wird dann über die folgenden Bytes geregelt, da dort meistens ein RS232 ähnliches Protokoll aufgesetzt ist.
Das würde gehen, wenn die Implementation auf Deinem PIC das zuläßt.
Man könnte das so implementieren, das man die übergebenen Daten als Addresse, Value -Paare versteht.
Also um Register 1 mit Wert 255 zu versorgen, kann man chr(1).chr(255) senden.
Zum Auslesen könnte man es so machen, das auf alle Addressen 128 addiert wird. Alle übergebenen Werte sind dann halt Adressen (oder man macht noch ein Befehlsbyte statt dem Adressbit dazu)
BTW: da ich das Projekt ja kenne: Der PIC sollte auch eine Quittung liefern, ob er einen Befehl angenommen und ausgeführt hat.
Ich bin der Meinung das Horsts Script noch einen Fehler hat.
if (((int)HID_GetDeviceVendorID($hid_id) != $vendor_id) && ((int)HID_GetDeviceProductID($hid_id) != $product_id))
An dieser Stelle wird davon ausgegangen das die HID noch eine Verbindung hat. Welche aber schon nicht mehr vorhanden sein kann. Hier müßte meines Erachtens noch eine Prüfung über HID_GetDevices erfolgen ob z.B. die Product ID überhaupt noch existiert.
Mein Velleman Board verliert auch manchmal die Verbindung. Ich muss dann den HID schließen und wieder öffnen - dann klappts wieder.
Deswegen habe ich mal das Skript ausprobiert. Ich habe die 3 IDs korrekt eingetragen - leider setzt das Skript nur den Timer und scheint sonst nichts zu machen? Es kommt keine Meldung (echo) und ein geschlossenes HID wird auch nicht geöffnet…
Wenn der HID das Gerät ansich nicht verliert, dann reicht ja, wenn du per Timer eine IPS_ApplySettings im Skript ausführst. Du kannst dir das Gesuche dann quasi sparen
Wenn der HID das Gerät ansich nicht verliert, dann reicht ja, wenn du per Timer eine IPS_ApplySettings im Skript ausführst. Du kannst dir das Gesuche dann quasi sparen