Compartilhar via


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

IPacket::get_Count

Obtém o número total de objetos de dados no pacote.

IPacket::IsEndOfPacket

Verifica se o iterador interno atingiu o participante do pacote.

IPacket::ReadBool

Lê um valor booliano a partir do objeto e aponta o iterador interno para o próximo objeto de dados no pacote.

IPacket::ReadByte

Lê um byte do objeto e aponta o iterador interno para o próximo objeto de dados no pacote.

IPacket::ReadBytes

Lê uma matriz de bytes do objeto e aponta o iterador interno para o próximo objeto de dados no pacote.

IPacket::ReadInt32

Lê um número inteiro do objeto e aponta o iterador interno para o próximo objeto de dados no pacote.

IPacket::ReadChar

Lê um caractere do objeto e aponta o iterador interno para o próximo objeto de dados no pacote.

IPacket::ReadDataType

Retorna o tipo de dados do objeto corrente no pacote sistema autônomo um valor de enumeração.

IPacket::ReadString

Lê uma seqüência de caracteres do objeto e aponta o iterador interno para o próximo objeto de dados no pacote.

IPacket::reiniciar

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.

IPacket::WriteBool

Grava um valor booliano para o objeto.

IPacket::WriteByte

Grava um byte para o objeto.

IPacket::WriteBytes

Grava uma matriz de bytes para o objeto.

IPacket::WriteChar

Grava um caractere para o objeto.

IPacket::WriteInt32

Grava um inteiro para o objeto.

IPacket::WriteString

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