IDevicePacketStream::IsPacketAvailable
Обновлен: Ноябрь 2007
Проверяет, готов ли пакет для чтения.
HRESULT IsPacketAvailable([retval][out] VARIANT_BOOL *pVal)
Параметры
- pVal
Возвращает значение true, если данные можно считывать; в противном случае — false.
Возвращаемое значение
Значение HRESULT, указывающее, каков результат вызова метода.
E_INVALIDARG | недопустимые аргументы (pbDataAvailable имеет значение NULL).
E_FAIL | для любой другой ошибки.
Пример
В этом примере поток пакета считывает данные из объекта RemoteAgent на настольном компьютере при подключении. Полный пример см. в описании интерфейса 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;
}
};
}
};
Управляемый эквивалент
IDevicePacketStream.IsPacketAvailable
Требования
DeviceAgentTransport.h