IPacket
Mantém os dados e é usado por objetos que implementam IDevicePacketStream transferência dados entre um dispositivo agente de aplicativo e um computador de mesa.
IPacket : public IUnknown
Métodos
Método |
Descrição |
---|---|
Obtém o número total de objetos de dados no pacote. |
|
Verifica se o iterador interno atingiu o participante do pacote. |
|
Lê um valor booliano a partir do objeto e aponta o iterador interno para o próximo objeto de dados no pacote. |
|
Lê um byte do objeto e aponta o iterador interno para o próximo objeto de dados no pacote. |
|
Lê uma matriz de bytes do objeto e aponta o iterador interno para o próximo objeto de dados no pacote. |
|
Lê um número inteiro do objeto e aponta o iterador interno para o próximo objeto de dados no pacote. |
|
Lê um caractere do objeto e aponta o iterador interno para o próximo objeto de dados no pacote. |
|
Retorna o tipo de dados do objeto corrente no pacote sistema autônomo um valor de enumeração. |
|
Lê uma seqüência de caracteres do objeto e aponta o iterador interno para o próximo objeto de dados no pacote. |
|
Redefine o iterador interno do pacote para apontar para o primeiro objeto de dados no pacote.A próxima ler operação lê o primeiro objeto de dados no pacote. |
|
Grava um valor booliano para o objeto. |
|
Grava um byte para o objeto. |
|
Grava uma matriz de bytes para o objeto. |
|
Grava um caractere para o objeto. |
|
Grava um inteiro para o objeto. |
|
Grava uma cadeia de caracteres para o objeto. |
Comentários
Para obter um objeto que implementa essa interface, use GetNewPacket.
Objetos que implementam essa interface somente podem conter objetos do tipo byte, byte[], string, int, e char. Não é extensível para ler e gravar objetos personalizados.No entanto, os usuários podem ainda transferência objetos personalizados entre o fluxo de dividindo o tipo de dados personalizados em tipos de dados básicos ou serialização de tipos de dados personalizados em uma matriz de byte.
Exemplo
O exemplo a seguir é um aplicativo de agente de dispositivo que grava um pacote para a área de trabalho e lê um pacote de área de trabalho.
#include "stdafx.h"
// Custom implementation of IAgentTransportShutdownCallback
class MyShutdownCallback: public IAgentTransportShutdownCallback
{
private:
long ref;
public:
HRESULT STDMETHODCALLTYPE Shutdown(IUnknown *in_pUnknown)
{
// Add your cleanup code here
MessageBox(NULL,_T("conmanclient2 exited"),_T("conmanclient exited"),0);
return 0;
}
// Must implement members from IUnknown
HRESULT STDMETHODCALLTYPE QueryInterface( REFIID riid, void __RPC_FAR *__RPC_FAR *ppvObject)
{
return 0;
}
ULONG STDMETHODCALLTYPE AddRef( void)
{
return InterlockedIncrement(&ref);
}
ULONG STDMETHODCALLTYPE Release( void)
{
if(InterlockedDecrement(&ref) == 0)
{
delete this;
return 0;
}
return ref;
}
};
int _tmain(int argc, _TCHAR* argv[])
{
// Load the Device Agent Transport Library
HINSTANCE hmod;
hmod = LoadLibrary(L"DeviceAgentTransport.dll");
// Get an instance of IDeviceAgentTransport
GetDeviceAgentTransportFunc f1 = (GetDeviceAgentTransportFunc)
::GetProcAddress(hmod, L"GetDeviceAgentTransport");
IDeviceAgentTransport *pTransport = NULL;
f1(&pTransport);
// Register the callback with the Device Agent Transport
MyShutdownCallback *shutdownCallback = new MyShutdownCallback();
pTransport->RegisterShutdownCallback(shutdownCallback,shutdownCallback);
// Let the desktop application know that this remote agent was deployed successfully
// and that this remote agent will handle the supplied list of services.
LPCOLESTR szServiceIds[] = {L"F85E57BA-5AE9-4FF7-8433-6AB7D991D033"};
pTransport->AcknowledgeLaunch(1, szServiceIds);
// Open a communcation stream with desktop application on the service.
IDevicePacketStream *pStream = NULL;
pTransport->AcceptConnectionEx(szServiceIds[0], &pStream);
// Get an instance of IPacket
GetNewPacketFunc f2 = (GetNewPacketFunc) :: GetProcAddress(hmod, L"GetNewPacket");
IPacket *pPacket = NULL;
f2(&pPacket);
// Write a message and sent the packet.
pPacket->WriteBool(true);
pPacket->WriteByte(0xff);
pPacket->WriteChar('c');
pPacket->WriteInt32(1024);
pPacket->WriteString(L"Hello Desktop Computer");
pStream->Write(pPacket);
// 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;
}
};
}
};
return 0;
}
Equivalente gerenciado
Microsoft.SmartDevice.DeviceAgentTransport.IPacket
Requisitos
DeviceAgentTransport.h
Consulte também
Outros recursos
Não gerenciado do lado do dispositivo dispositivo inteligente conectividade API