IDevicePacketStream::IsConnected
Aktualisiert: November 2007
Überprüft, ob der Stream verbunden ist.
HRESULT IsConnected([retval][out] VARIANT_BOOL *pbConnected)
Parameter
- pbConnected
True, wenn der Stream verbunden wird; andernfalls false.
Rückgabewert
Ein HRESULT-Wert, der das Ergebnis des Methodenaufrufs angibt.
E_INVALIDARG | Argumente sind nicht gültig (pbConnected ist NULL).
E_FAIL | für einen beliebigen anderen Fehler.
Beispiel
In diesem Beispiel liest der Paketstream Daten aus dem RemoteAgent-Objekt auf dem Desktop, während eine Verbindung besteht. Das vollständige Beispiel finden Sie unter IDeviceAgentTransport.
// Check for a packet while communication stream is connected.
f2(&pPacket);
VARIANT_BOOL connected;
pStream->IsConnected(&connected);
while(connected)
{
pStream->IsConnected(&connected);
VARIANT_BOOL available;
// If a packet is found, display the string.
pStream->IsPacketAvailable(&available);
if(available)
{
pStream->Read(&pPacket);
VARIANT_BOOL endofpacket;
pPacket->IsEndOfPacket(&endofpacket);
while (!endofpacket)
{
pPacket->IsEndOfPacket(&endofpacket);
DataTypeEnum datatype;
pPacket->ReadDataType(&datatype);
switch (datatype)
{
case DT_BYTE:
BYTE byteValue;
pPacket->ReadByte(&byteValue);
break;
case DT_INT32:
INT32 intValue;
pPacket->ReadInt32(&intValue);
break;
case DT_WIDECHAR:
wchar_t charValue;
pPacket->ReadChar(&charValue);
break;
case DT_BOOL:
VARIANT_BOOL boolValue;
pPacket->ReadBool(&boolValue);
break;
case DT_BYTEARRAY:
BYTE * buffer[100];
ULONG length;
pPacket->ReadBytes(buffer,&length);
break;
case DT_STRING:
LPWSTR string;
pPacket->ReadString(&string);
MessageBox(NULL, string,string,0);
break;
default:
break;
}
};
}
};
Verwaltete Entsprechung
IDevicePacketStream.IsConnected
Anforderungen
DeviceAgentTransport.h