Carregar apresentação
A apresentação está carregando. Por favor, espere
PublicouIsadora Dionisio Alterado mais de 9 anos atrás
1
Programa Expresso de Capacitação Módulo J2ME Aula 7 – 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
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 AMS 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
Interface Gráfica
44
Interface com o usuário Popup ChoiceGroup Alerts podem ter comandos Comandos podem ser associados a Item Layout para Form e Item Custom Itens
45
Game API
46
Conjunto com 5 classes que simplificam o desenvolvimento de jogos 2D Provêem 2 importantes funcionalidades GameCanvas Estruturação do jogo em camadas
47
GameCanvas Subclasse de Canvas Fornece offscreen buffer 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); }
48
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. }
49
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. }
50
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
51
Layer - Métodos int getHeight() int getWidth() int getX() int getY() paint(Graphics g) setVisible(boolean visible)
52
TiledLayer
53
TiledLayer – cont.
54
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)
55
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
56
LayerManager – cont.
57
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)
58
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
59
Wireless Messaging API
60
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
61
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
62
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()
63
Boas práticas
64
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
65
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
66
Desenhe para threads I/O blocks numa thread Separada Exceções de I/O Feche as conexões
67
Usando uma thread para ler Mantenha thread ativa Até ser mandado um stop Ou ocorrer uma exceção
68
Use threads para enfileirar escritas Use o open connection Enfileire os dados a serem escritos Use uma thread separada para escrever
69
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
70
Checando autolaunch Pegue uma lista das conexões ativas Abra as conexões ativas Manuseie I/O normalmente
71
Referências Core J2ME Site da Sun Wireless Programming with J2ME: Cracking the code, ISBN: 0-7645-4885-9
72
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.