Carregar apresentação
A apresentação está carregando. Por favor, espere
PublicouAlícia Jose Alterado mais de 9 anos atrás
1
Jornada de Cursos - J2ME Aula 6 – MIDP 2.0
2
Pausa para reflexão "Sem esforço não há progresso, mas com esforço também não há progresso” Ryotan TokudaRyotan Tokuda, Mestre Zen
3
Agenda MIDP 2.0 Technical Overview MIDP Desenvolvimento e Deployment API´s Wireless Messaging API Práticas de programação
4
Technical Overview
5
APIs de MIDP 1.0 Modelo de aplicação: Javax.microedition.midlet Persistência Javax.microedition.rms Rede Javax.microedition.io.HTTPConnection Interface gráfica Javax.microedition.lcdui IO e pacotes util de CLDC Java.lang Java.io Java.util
6
MIDP 2.0 Objetivos de MIDP 2.0 Compatibilidade com MIDP 1.0 Foco contínuo em telefones com poucos recursos Usar informação dos deployments MIDP 1.0 para criar um modelo mais aprimorado Foco em aplicações core necessárias a todos os dispositivos e aplicações
7
MIDP 2.0 - Novas características Novos protocolos de rede HTTPS, Comm, Datagram, SSL, Socket, ServerSocket Nota: Somente HTTP e HTTPS são requeridos pela especificação Funcionalidade Push Possibilidade de iniciar um MIDlet em resposta a uma mensagem OTA Game API UI melhorada platformRequest
8
Requisitos mínimos Display: Tamanho de tela: 96x54 Profundidade de display: 1 bit Pixel aspect ratio: 1:1 Input One or two handed keyboard, touch screen Memória: 256 kb de memória não-volátil 8 kb para dados persistentes 128 kb de memória volátil
9
Requisitos (cont.) Rede: Two-way Wireless Possibilidade de intermitência, com uma banda limitada Som Pode tocar tons, via HW ou SW
10
Desenvolvimento e Deployment
11
Verificação de classfiles em CLDC
12
Passos 1.Escreva sua aplicação 2.Compile-a 3.Use o preverifier 4.Empacote-a 1.Assine o JAR (só em MIDP 2.0) 5.Crie o descritor 6.Publique a suite MIDlet 7.Instale via OTA
13
Prática recomendada: OTA MIDP 1.0 deixou não especificado OTA MIDP expert group lançou OTA para clarificar detalhes Requisito core em MIDP 2.0
14
OTA
18
Versões Agora que temos MIDP 1.0 e 2.0, é preciso saber a versão que estamos trabalhando System.getProperty(“MicroEdition-Profile”) Por default, o JAM não instalará MIDP 2.0 em aparelhos MIDP 1.0
19
MIDP 2.0 APIs
20
Segurança e segurança em rede Push API Media APIs APIs de interface gráfica Game API
21
Segurança
22
Riscos de segurança inclusos Aplicações usando o dinheiro do usuário sem permissão Mensagens SMS podem custar 10 centavas por mensagem, e com 7 mensagens: 1k de dados Informações privadas sendo expostas Contatos DOS potenciais, códigos maliciosos, etc
23
Modelo de segurança do MIDP 2.0 MIDlet suites requerem segurança Cada MIDlet suite está atrelada a um único domínio de proteção contendo as permissões Restrições da API a funções fundamentais Extensível a APIs desenvolvidas independentemente (WMA, MMAPI, etc)
24
Tipos de permissão Permissões Allowed Sem prompt para verificar se é válido Permissões de usuário Garantidas com aprovação do usuário Usuário escolhe a frequência de prompt: Blanket – válido até o usuário configurar o contrário Session – válido para uma invocação Oneshot – válido para uma chamada da API Um datagrama sendo enviado
25
Dois tipos de domínio de proteção Untrusted domains Sandbox, como MIDP 1.0 Tipicamente, dispositivo pergunta ao usuário por acesso Trusted domains Dispositivo tem mecanismo para validar a suite Pode permitir acesso sem prompt Geralmente implementado usando criptografia de chave pública para assinar o JAR
26
Modelo de segurança
27
Modelo de segurança – Cont.
28
Trusted signed applications Descritor de aplicação inclui: Assinatura do JAR Certificados necessários para verificar assinatura Permissões requeridas pela aplicação Dispositivo autentica assinatura Usando chave pública raiz do dispositivos Cercado pelo domínio de proteção
29
Permissões no WTK Atributos MIDlet-Permissions e MIDlet-Permissions-opt do painel Projetc | Settings
30
Assinando MIDlets Assinar com keytool, JADtool e MEKeytool pode ser complexo WTK oferece assinar MIDlets via GUI Cria um par de chaves e um alias Crie o certificado Adicione um certificado de par de chaves ao JAD Assine o JAR e adicione a assinatura ao JAD
31
Segurança em rede HTTP e HTTPS necessários para MIDP 2.0 Datagrama – pouco overhead, mas inseguro Socket – streams confiáveis Socket seguro – stream confiável sobre SSL/TLS Conexão a porta serial Wireless Messaging – WMAPI
32
Segurança em MIDP 2.0 HTTPConnection e HTTPSConnection Possibilidade de utilizar sockets puros (SecureConnection) MIDP 2.0 define a interface SecurityInfo para informações detalhadas
33
SecureConnection Define uma conexão com sockets seguros Uma conexão segura é estabelecida com Connector.open() quando “SSL” é especificado Na URI, por exemplo: Connector.open(“ssl://host.com:70”); A implementação escolhe entre: Protocolo TLS versão 1.0 Protocolo SSL versão 3.0
34
SecurityInfo Define os métodos para acessar informação numa conexão segura Oferece o certificado, protocolo, versão, suite de cifragem, etc. Uso: SecureConnection sc = (SecureConnection) Connector.open(“ssl://host.com:70”); SecurityInfo info = sc.getSecurityInfo(); System.out.print(“Protocol ” + info.getProtocolName);...
35
Push (ou AutoLaunch)
36
Aplicação de rede Não é possível criar MIDlets do tipo servidor Limitações de plataforma: Sem multi-threading Sem processos daemon Limitações de recursos computacionais Segurança Solução – conexão offline ao servidor Confia num proxy para cuidar da primeira invocação Conexão inbound
37
PushRegistry MIDP 2.0 define um mecanismo de push MIDlets podem ser acordados por eventos externos Push Registry é manuseado pelo AMS Duas maneiras de se registrar: Estática: MIDlet-Push- no JAD Dinâmica: PushRegistry.registerConnection()
38
Esquema geral
39
MMAPI
40
MMAPI em MIDP 2.0 MIDP 2.0 Media API é um subconjunto da Mobile Media API (JSR 135) Somente Sons Pacotes: javax.microedition.media java.microedition.media.control
41
Áudio em MIDP 2.0 Implementações têm que suportar geração de tons e WAV Tipos adicionais são opcionais Para geração de tons: Manager.playTone(); Para playback de algum som em formato WAV, crie um objeto Player O objeto Player tem os métodos start/stop/pause
42
Exemplos de código Geração de tons: try{ Manager.playTone( ToneControl.C4, // nota 5000, //ms 100); //volume } catch(MediaException mee) {} Playback com looping try{ Player p = Manager.createPlayer(http://myMusicServer/music.wav);http://myMusicServer/music.wav p.setLoopCount(5); p.start(); }...
43
Exercício Crie um MIDlet que toca associa um som a cada tecla. Pode ser wav, midi, etc.
44
Interface Gráfica
45
Interface com o usuário Popup ChoiceGroup Novo tipo: POPUP Alerts podem ter comandos Comandos podem ser associados a Item Layout para Item Custom Items Classe Spacer
46
Items É possível setar tamanhos esperados Comandos agora podem ser associados a Items ItemCommandListener Default command SetDefaultCommand Custom Items A coqueluche de MIDP 2.0 Sobrecarrega o método paint Layout Várias opções de layout
47
Exercício Crie um custom item que cada vez que é selecionado, realiza um tipo de pintura diferente. Ex.: uma seta que pisca de vermelho e azul
48
Game API
49
Conjunto com 5 classes que simplificam o desenvolvimento de jogos 2D GameCanvas Layer Sprite TiledLayer LayerManager Provêem 2 importantes funcionalidades GameCanvas Estruturação do jogo em camadas
50
GameCanvas Subclasse de Canvas Fornece offscreen buffer Somente 1 classe extende de GameCanvas Armazena o estado de pressionamento das teclas, podendo serem consultados a qualquer momento int keyState = getKeyStates(); if ((keyState & LEFT_PRESSED) != 0) { sprite.move(-1, 0); }
51
Loop de jogo com Canvas public class MicroTankCanvas extends Canvas implements Runnable { public void run() { while (true) { // Update the game state. repaint(); // Delay one time step. } public void paint(Graphics g) { // Painting code goes here. } protected void keyPressed(int keyCode) { // Respond to key presses here. }
52
Loop de jogo com GameCanvas public class MicroTankCanvas extends GameCanvas implements Runnable { public void run() { Graphics g = getGraphics(); while (true) { // Update the game state. int keyState = getKeyStates(); // Respond to key presses here. // Painting code goes here. flushGraphics(); // Delay one time step. }
53
Exercício Crie uma aplicacao que consiste de um cursor e é possível movimentá-lo.
54
Layer Representa um elemento visual do jogo Possui posição relativa à tela (x,y) além de dimensões (largura, altura) Método paint a ser implementado Em um dado momento pode estar visível ou não
55
Layer - Métodos int getHeight() int getWidth() int getX() int getY() paint(Graphics g) setVisible(boolean visible)
56
TiledLayer
57
TiledLayer – cont.
58
TiledLayer - métodos TiledLayer (int columns, int rows, Image image, int tileWidth, int tileHeight) int getCell (int col, int row) paint (Graphics g) setCell (int col, int row, int tileIndex)
59
LayerManager Gerencia uma série de layers Define a ordem na qual os layers são renderizados e em qual região da tela Simplifica o processo de renderização Define regiões em relação ao eixo-z
60
LayerManager – cont.
61
LayerManager - métodos void append (Layer l) Layer getLayerAt (int index) void insert (Layer l, int index) paint (Graphics g, int x, int y) setViewWindow (int x, int y, int width, int height)
62
Sprite Elemento visual do jogo que pode ser renderizado a partir de um ou mais frames Possui métodos para rotação, colisão e animação Pixel de referência
63
Pixel de Referência
64
Exercício Utilize as classes TiledLayer e Sprite para criar o efeito de um jogo de tanque. Lembre-se que já vimos como é o loop de um jogo simples Os sprites e as figuras do tiled layer vão ser fornecidos.
65
PlatformRequest javax.microedition.midlet.MIDlet.platformRequest() Facilidade para acessar serviços externos: Numeros Suites MIDlet em enderecos http Método não-bloqueante Não enfileira chamadas Ex.: platformRequest(“http://www.cin.ufpe.br/~ela/jorn ada/myGame.jad”);http://www.cin.ufpe.br/~ela/jorn ada/myGame.jad platformRequest(“+358-555-1234567”);
66
Suporte no WTK Adiciona ao system.config com.sun.midp.midlet.platformRequestCommand: “ENDERECO DO BROWSER”
67
Wireless Messaging API
68
Wireless Messaging API – JSR 120 Acesso padrão a mensages WMA foi desenhada para rodar em qualquer configuração Endereça as seguintes tecnologias: Short Message Service – SMS Cell Broadcast Service – CBS Suporta mensagens multimidia, incluindo sons, imagens e texto
69
Wireless Messaging API – JSR 120 Baseada no Generic Connection Framework Design da funcionalidade é parecida com UDPDatagramConnection Já que existem diferenças entre mensagens e datagramas, WMA interfaces definidas em javax.wireless.messaging Dois modos de receber mensagens Usando o metodo receive Bloqueia a Thread atual Definindo um MessageListener
70
MessageListener Implementa o ouvinte para receber objetos mensagem Define um único método notifyIncomingMessage(), que é invocado cada vez que uma mensagem chega Para se registrar para mensagens, use o método MessageConnection.setListener()
71
Boas práticas
72
Cuidado com exceções de segurança Design para rede de um modo assíncrono Use uma thread para ler Use uma thread para escrever Registro para autolaunch
73
Exceções de segurança Não use getMessage(), o usuário não quer ver isso Ofereça uma sugestão Use imagens Espere pela confirmação do usuário
74
Desenhe para threads I/O blocks numa thread Separada Exceções de I/O Feche as conexões
75
Usando uma thread para ler Mantenha thread ativa Até ser mandado um stop Ou ocorrer uma exceção
76
Use threads para enfileirar escritas Use o open connection Enfileire os dados a serem escritos Use uma thread separada para escrever
77
Usando uma thread para escrita No método run, enfileire as chamadas Desenfileire os dados a serem escritos Crie um datagrama para e mande-o
78
Checando autolaunch Pegue uma lista das conexões ativas Abra as conexões ativas Manuseie I/O normalmente
79
Referências Core J2ME Site da Sun Wireless Programming with J2ME: Cracking the code, ISBN: 0-7645-4885-9
80
Agora que acabou "Sem esforço não há progresso, mas com esforço também não há progresso” Ryotan TokudaRyotan Tokuda, Mestre Zen Alguém finalmente entendeu o que danado é isso????
Apresentações semelhantes
© 2024 SlidePlayer.com.br Inc.
All rights reserved.