AchimK Geschrieben February 15, 2022 at 19:15 Geschrieben February 15, 2022 at 19:15 Hallo Forum, ich nutze das RemoteSwitchV2-Bricklet in Kombination mit Masterbrick und Wifi V2 Extension zur zeitgesteuerten Schaltung von 8 Funk-Steckdosen. Die Applikation für die Steuerung habe ich in VB.Net geschrieben, sie läuft auf einem Windows-Tablet. Tablet und Wifi-Extension sind als Client am Haus-Wifi (TP-Link Powerline Extender) angemeldet. Die Schaltung der 8 Steckdosen erfolgt immer quasi gleichzeitig, über die SwitchDoneCallback-Funktion wird mit dem nächsten Schalten gewartet, bis die Rückmeldung vorhanden ist. Für die Software-Struktur habe ich den robusten Ansatz aus dem Tutorial gewählt, es funktioniert auch meistens über mehrere Stunden, aber es kommt vor, dass die Callback-Funktion aussetzt und die Schaltschrittkette nicht ausgeführt wird bzw. hängen bleibt. Zur Diagnose habe ich die Aufrufe der Connected-, Disconnected- und Enumerate-Callbacks in einer Datei protokolliert. Im Fehlerfall wird kurz nacheinander eine Unterbrechung der Verbindung mit Grund 1 gemeldet, dann der Aufbau mit Grund 1 und abschließend der Enumerate-Callback. Wie kann es zu solchen kurzen Unterbrechungen kommen und warum funktioniert der SwitchingDoneCallback dann nicht mehr? Danke und Grüße Hier noch ein Auszug aus der Software '********************************************************** '* Callback-Funktion RemoteSwitch '* Rückmeldung, dass ein Schaltvorgang durchgeführt wurde '********************************************************** Sub SwitchingDoneCallback(ByVal sender As BrickletRemoteSwitchV2) Try SwitchingDoneCallback_Cnt += 1 bSendBusy = False Catch ex As Exception MsgBox("SwitchingDoneCB " + ex.Message) End Try End Sub '********************************************************** '* Callback-Funktion Verbindung '* Meldung, dass die Verbindung unterbrochen wurde '********************************************************** Sub DisconnectedCallback(ByVal sender As IPConnection, ByVal disconnectReason As Short) Try DisconnectedCallback_Cnt += 1 sDisconnected = "Verbindung unterbrochen mit Grund " + disconnectReason.ToString + " " + Now.ToShortDateString + " " + Now.ToShortTimeString bDisconnected = True Catch ex As Exception MsgBox("DisconnectedCB " + ex.Message) End Try End Sub '********************************************************** '* Callback-Funktion Verbindung '* Meldung, dass die Verbindung aufgebaut wurde '********************************************************** Sub ConnectedCallback(ByVal sender As IPConnection, ByVal connectReason As Short) Try ConnectedCallback_Cnt += 1 sConnected = "Verbindung hergestellt mit Grund " + connectReason.ToString + " " + Now.ToShortDateString + " " + Now.ToShortTimeString bConnected = True ipcon.Enumerate() Catch ex As Exception MsgBox("ConnectedtCB " + ex.Message) End Try End Sub '********************************************************** '* Callback-Funktion Verbindung '* Enumerate '********************************************************** Sub EnumerateCB(ByVal sender As IPConnection, ByVal uid As String, ByVal connectedUid As String, ByVal position As Char, ByVal hardwareVersion() As Short, ByVal firmwareVersion() As Short, ByVal deviceIdentifier As Integer, ByVal enumerationType As Short) If enumerationType = IPConnection.ENUMERATION_TYPE_CONNECTED Or enumerationType = IPConnection.ENUMERATION_TYPE_AVAILABLE Then If deviceIdentifier = BrickletRemoteSwitchV2.DEVICE_IDENTIFIER Then rs = New BrickletRemoteSwitchV2(uid, ipcon) AddHandler rs.SwitchingDoneCallback, AddressOf SwitchingDoneCallback bEnumerate = True End If End If End Sub ... ... '***************************************************************************** '* Load: Aufruf bei Programm-Start '***************************************************************************** Private Sub FormMain_Load(sender As Object, e As EventArgs) Handles MyBase.Load ... ... '************************************************************** '* Verbindung zur Tinkerforge-Hardware '* Callback-Funktionen einrichten und Verbindugn starten '************************************************************** ipcon = New IPConnection AddHandler ipcon.DisconnectedCallback, AddressOf DisconnectedCallback AddHandler ipcon.ConnectedCallback, AddressOf ConnectedCallback AddHandler ipcon.EnumerateCallback, AddressOf EnumerateCB ipcon.Connect(sHost, nPort) ' Trigger Enumerate ipcon.Enumerate() End Sub Zitieren
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.