IDevicePacketStream::IsPacketAvailable
Verifica se há um pacote pronto para ser lido.
HRESULT IsPacketAvailable([retval][out] VARIANT_BOOL *pVal)
Parâmetros
- pVal
true Se os dados estiverem prontos para serem leitura; caso contrário, false.
Valor de retorno
An HRESULT valor que indica o resultado da telefonar do método.
E_INVALIDARG | argumentos inválido são válido (pbDataAvailable é nulo).
E_FAIL | para qualquer Outros falha.
Exemplo
Neste exemplo, o fluxo de pacote lê dados do RemoteAgent objeto da área de trabalho enquanto estiver conectado. For the complete example, see 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;
}
};
}
};
Equivalente gerenciado
IDevicePacketStream.IsPacketAvailable
Requisitos
DeviceAgentTransport.h