Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
Actualización: noviembre 2007
Comprueba si un paquete está listo para su lectura.
HRESULT IsPacketAvailable([retval][out] VARIANT_BOOL *pVal)
Parámetros
- pVal
true si los datos están listos para su lectura; de lo contrario, false.
Valor devuelto
Un valor HRESULT que indica el resultado de la llamada al método.
E_INVALIDARG | Los argumentos no son válidos (pbDataAvailable es NULO).
E_FAIL | para cualquier otro error.
Ejemplo
En este ejemplo, la secuencia de paquetes lee datos del objeto RemoteAgent en el escritorio durante la conexión. Para obtener el ejemplo completo, consulte 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 administrado
IDevicePacketStream.IsPacketAvailable
Requisitos
DeviceAgentTransport.h