A apresentação está carregando. Por favor, espere

A apresentação está carregando. Por favor, espere

Paolo Cemim Rogério Vieira

Apresentações semelhantes


Apresentação em tema: "Paolo Cemim Rogério Vieira"— Transcrição da apresentação:

1 Paolo Cemim Rogério Vieira
Framework Marge Paolo Cemim Rogério Vieira

2 Bluetooth – O que é? Especificação para comunicações sem fio
Criado pela Ericsson Mobile Versão atual 2.1

3 Bluetooth – Características
Substituição do uso de cabos Banda ISM (2.4GHz) Curta distância (1-100m) Baixo consumo de energia (>=1 mW) Baixo custo (>$5.00) Velocidade moderada (768K bit/sec) Utilizado em celulares, PDA’s, fones de ouvido, microfones, computadores, teclados, entre outros.

4 Bluetooth - Arquitetura
Pilha de Protocolos Perfil define uma pilha de protocolo. A aplicação só pode se comunicar se estiver no mesmo perfil ou seja mesma pilha de protocolo.

5 Bluetooth – Como funciona a comunicação
Inquiry: busca dos dispositivos na área Service Discovery: descoberta dos serviços providos pelo dispositivo (Transferência e Sincronização de dados, Dial-Up, ...) Connection: estabelecimento da conexão entre os dispositivos Communication: trocas de dados ou voz

6 JSR-82

7 JSR-82 – O que é? Java APIs para Bluetooth (JABWT).
Especificação que padroniza um conjunto de APIs para permitir integração entre aplicações Java e Bluetooth. Liderada pela Motorola Iniciada em Out/00, liberada em Mar/02 (v 1.0) Final Release 2 em 2006 (v 1.1) Atualmente esta na Closed Maintenance Review 3 (v 1.1)

8 JSR-82 – Características
Java ME como plataforma alvo Baseada no GCF (Generic Connection Framework), definido na CLDC 1.0 (Connected Limited Device Configuration) Separado em dois pacotes: javax.bluetooth – SDP, L2CAP, RFCOMM javax.obex – OBEX (opcional)

9 JSR-82 – Desktop Algumas implementações do GCF/JSR-82:
AvetanaBluetooth (Linux) Bluecove (Windows, Mac OS X e Linux)

10 JSR – 82 – Opinião dos Criadores do Framework
Idealizada para Java ME (GCF) Difícil curva de aprendizado Códigos repetitivos Muitas constantes de controle Falta de clareza em alguns pontos

11 Projeto Framework Marge Desenvolvido por: Bruno Ghisi e Lucas Tossi

12 Marge – Dados Gerais do Projeto
Objetivo: Facilitar o desenvolvimento Bluetooth em Java através do Framework e Aplicações de exemplo. Hospedado no portal java.net: LGPL (Lesser General Public License): licença usual em bibliotecas

13 Marge – Dados Gerais do Projeto
O nome Marge vem dos Simpsons. Onde a Marge tem um grande cabelo azul (eles fazem a analogia do cabelo azul(BLUE) com o BLUEtooth) e ela sempre está ajudando a sua família. E outra analogia que eles fazem é com o operando merge(mesclar) que é tem a idéia do projeto : um framework para uma aplicação e criar uma boa ferramenta para resolver problemas.

14 Marge - Framework marge-core Abstração do pacote javax.bluetooth
Java ME e SE Versão 0.6

15 Marge – Como instalar O que é preciso?
Java Development Kit ( NetBeans 6 IDE os mais novo com Mobility plugins ( *Seleciona a versão completa para nada ser esquecido. Marge Framework ( Para utilizar basta importar os jars do marge para o projeto.

16 Marge - Estrutura 24 classes 5 pacotes net.java.dev.marge.autocon
net.java.dev.marge.communication net.java.dev.marge.communication.layer net.java.dev.marge.entity net.java.dev.marge.entity.config net.java.dev.marge.factory net.java.dev.marge.inquiry

17 Marge – Sem Marge x Com Marge (Busca)
LocalDevice localDevice = LocalDevice.getLocalDevice(); DiscoveryAgent agent = localDevice.getDiscoveryAgent(); agent.startInquiry(DiscoveryAgent.GIAC, new DiscoveryListenerImpl()); DeviceDiscoverer.getInstance(). startInquiryGIAC( new InquiryListenerImpl()); É necessário implementar um DiscoveryListener que contêm trechos de código longos e repetitivos. Cada status de retorno da busca deve ser previamente conhecidos para que possam ser tratados. ● Classe específica para busca de dispositivos ● InquiryListener contém métodos que são notificados conforme o status de retorno, através da sua implementação padrão

18 Marge – Sem Marge x Com Marge (Serviço)
LocalDevice localDevice = LocalDevice.getLocalDevice(); DiscoveryAgent agent = localDevice.getDiscoveryAgent(); int transactionID = agent. searchServices( attrSet, uuidArray, rmtDevice, new DiscoveryListenerImpl()); ServiceDiscoverer.getInstance() .startSearch(remoteDevice, new ServiceSearchListenerImpl()); Classe específica para busca de serviços ServiceSearchListener contém métodos para erros na busca e busca finalizada ServiceDiscoverer permite cancelar a busca diretamente, sem a necessidade de guardar o ID de transação Mesma interface do processo de Inquiry para notificação dos resultados

19 Marge – Sem Marge x Com Marge (Servidor)
CommunicationFactory factory =new RFCOMMCommunicationFactory(); ServerConfiguration sconf =new ServerConfiguration(new CommunicationListenerImpl()); factory.waitClients(sconf, new ConnectionListenerImpl()); StreamConnectionNotifier notifier = (StreamConnectionNotifier) Connector.open( "btspp://localhost:” + ” A1B1C1DE100;” + ”name=Server1;” + ”authenticate=false; authorize=false"); StreamConnection connection = notifier.acceptAndOpen(); ConnectionListener contém métodos para notificar uma conexão estabelecida ou erros Novos clientes são tratados e notificados automaticamente Servidor configurável Utilização de diferentes protocolos através das fábricas disponíveis É necessário saber a URL de serviço e seus parâmetros Controle de número de clientes é feito manualmente

20 Marge – Sem Marge x Com Marge (Cliente)
CommunicationFactory factory = new L2CAPCommunicationFactory(); ClientConfiguration cconfig = new ClientConfiguration(serviceRecordFound, new CommunicationListenerImpl()); ClientDevice clientDevice = factory.connectToServer(cconf); String url = serviceRecord.getConnectionURL( ServiceRecord .NOAUTHENTICATE_NOENCRYPT, true); StreamConnection connection = (StreamConnection) Connector.open(url); Cliente configurável Utilização de diferentes protocolos através das fábricas disponíveis ● É necessário tratar diretamente com a parte de IO

21 Marge – Sem Marge x Com Marge (Comunicação)
DataOutputStream dataout = connection .openDataOutputStream(); dataout.writeUTF(”Hello world”); dataout.flush(); connection.close(); device.startListening(); device.send("Hello world".getBytes()); device.close(); Controle automático do recebimento de mensagens, onde as mensagens recebidas são notificadas através do método receiveMessage do Listener enviado na configuração Facilidade no envio de mensagens Controle de escuta É necessário ter um controle em paralelo para o recebimento de mensagens

22 Marge - AutoConnect Cria servidor:
AutoConnect.createServer("MargeBluechatServer", new CommunicationListenerImpl(),new ConnectionListenerImpl() ); Cria cliente: ClientDevice device = AutoConnect.createClient("MargeBluechatServer",new CommunicationListenerImpl());

23 Marge – Breve Comentário
Se não quizer programar a parte de inquiry e search process, podesse usar o AutoConnect. Mas deve se ter certeza que onde for executado a sua aplicação não tenham muitos aparelhos bluetooth que poderiam se conectar à você, caso contrário pode demorar para ter resposta de retorno ou se conectar ao dispositivo errado.É uma boa função mas não funciona em determinados dispositivos por alguns problemas de implementação. Mas vale a pena testar.

24 Marge - Vantagens Maior abstração da JSR-82 fornecendo um código comum entre aplicações, evitando reescrita. Estruturas separadas para Inquiry e Service Discoverer provêem notificações conforme status de retorno. Rápida criação e configuração de Clientes e Servidores através das fábricas de protocolo. Fácil envio e recebimento de mensagens e extensível para novos protocolos e comportamentos (Layers).

25 Referencias https://marge.dev.java.net


Carregar ppt "Paolo Cemim Rogério Vieira"

Apresentações semelhantes


Anúncios Google