14.6  Campos de texto e uma introdução ao tratamento de eventos com classes aninhadas Um usuário interage com uma GUI para indicar as tarefas que o aplicativo.

Slides:



Advertisements
Apresentações semelhantes
«Forte do Bom Sucesso (Lisboa) – Lápides 1, 2, 3» «nomes gravados, 21 de Agosto de 2008» «Ultramar.TerraWeb»
Advertisements

IFTO ESTRUTURA DE DADOS AULA 05 Prof. Manoel Campos da Silva Filho
APLICAÇÕES DE LINGUAGEM DE PROGRAMAÇÃO ORIENTADA A OBJETOS COMPONENTES GUI – PARTE I Prof. Thiago Pereira Rique
INFORMAÇÕES COMPLEMENTARES
A busca das mulheres para alcançar seu espaço dentro das organizações
Eventos Marco Antonio, Arquiteto de Software – TJDF Novembro/2005
Vamos contar D U De 10 até 69 Professor Vaz Nunes 1999 (Ovar-Portugal). Nenhuns direitos reservados, excepto para fins comerciais. Por favor, não coloque.
Exercício do Tangram Tangram é um quebra-cabeças chinês no qual, usando 7 peças deve-se construir formas geométricas.
Pesquisa Bibliográfica Disciplina de Metodologia da Pesquisa Profª Tereza Yoshiko Kakehashi 1.
Nome : Resolve estas operações começando no centro de cada espiral. Nos rectângulos põe o resultado de cada operação. Comprova se no final.
APLICAÇÕES DE LINGUAGEM DE PROGRAMAÇÃO ORIENTADA A OBJETOS COMPONENTES GUI – PARTE III Prof. Thiago Pereira Rique
APLICAÇÕES DE LINGUAGEM DE PROGRAMAÇÃO ORIENTADA A OBJETOS COMPONENTES GUI – PARTE II Prof. Thiago Pereira Rique
Interação entre objetos
Copyright (c) 2003 by Valery Sklyarov and Iouliia Skliarova: DETUA, IEETA, Aveiro University, Portugal.
Excel Profa. Cristina M. Nunes.
14.17 Tratamento de Eventos de Teclado
VBA – Módulos, Procedimentos e Funções
Campus Curitiba Departamento Acadêmico de Matemática Angela Olandoski Barboza UTFPR – Damat.
Curso de ADMINISTRAÇÃO
1 MODELAGEM COM A UML (UNIFIED MODELING LANGUAGE) BREVE HISTÓRICO CARACTERÍSTICAS CONCEITOS DE PROGRAMAÇÃO ORIENTADA A OBJETOS MODELAGEM DE ANÁLISE E DE.
EXPRESSÕES ARITMÉTICAS
EXPRESSÕES ARITMÉTICAS
Estatística Básica Utilizando o Excel
Graphical User Interface (GUI) Prof(o): Alexandre Parra.
FUNÇÃO MODULAR.
Linguagem de Programação II
Aula 4 Nomes, Vinculações, Tipos e Escopos
Tutorial II: Tratando eventos em Java
EXEMPLOS DE ESTRUTURAS PROTENDIDAS
Aula de reposição Prof. Grace e Ângela
Classes e objetos Arrays e Sobrecarga
Classes e objetos P. O. O. Prof. Grace.
Provas de Concursos Anteriores
Plataforma brasil.
Renda até 2 SM.
Financeiro - Cadastro de Conta Contábil
Módulo Financeiro Centro de Custo.
Impressão de etiquetas
MECÂNICA - ESTÁTICA Cabos Cap. 7.
Diagnósticos Educativos = Diagnósticos Preenchidos 100% = 1.539
PESQUISA SOBRE PRAZO MÉDIO DA ASSISTÊNCIA NA SAÚDE SUPLEMENTAR
(CESPE/ Técnico Judiciário do TRT 17ª Região/ES) O Superior Tribunal de Justiça entende que o candidato aprovado em concurso público dentro do limite.
MECÂNICA - DINÂMICA Exercícios Cap. 13, 14 e 17. TC027 - Mecânica Geral III - Dinâmica © 2013 Curotto, C.L. - UFPR 2 Problema
Conteúdos do tutorial O que é um Slide Mestre?
CATÁLOGO GÉIA PÁG. 1 GÉIA PÁG. 2 HESTIA PÁG. 3.
Estruturas de Dados com Jogos
Estruturas de Dados com Jogos
Lemas (Sudkamp)  .
Coordenação Geral de Ensino da Faculdade
Múltiplos de um número Sonia Regina de Souza Guedes.
Plataforma Brasil – Submissão de pesquisa
Extranet GRD – Guia de Remessa de Documentos
Projeto Marcas que Eu Gosto 1 PROJETO MARCAS QUE EU GOSTO Estudos Quantitativo de Consumidores Janeiro / 2005.
Entrada de Produtos Posto de Combustível.
Projeto Medindo minha escola.
Compras - Pedido de Compra
1 Aplicações do Fecho Regular. 2 A interseção de uma linguagem livre de contexto e uma linguagem regular é uma linguagem livre de contexto livre de contexto.
POO.
Olhe fixamente para a Bruxa Nariguda
Máquina de Turing Universal
ÁREA DE TRABALHO DO WINDOWS
INTRODUÇÃO À ORIENTAÇÃO A OBJETOS EM JAVA
Equipe Bárbara Régis Lissa Lourenço Lucas Hakim Ricardo Spada Coordenador: Gabriel Pascutti.
Módulo Compras Relatórios e Relações 1. Objetivo 2 Conhecer os relatórios e as relações do sistema disponibilizadas no módulo Compras.
Planilha Eletrônica - Excel
Compras – Planejamento de Estoque
Contagem Sequencial do Estoque
Contagem Sequencial do Estoque
Programação Prof.: Bruno Rafael de Oliveira Rodrigues.
UNIVERSIDADE FEDERAL DE SANTA CATARINA CTC - CENTRO TECNOLÓGICO INE - DEPARTAMENTO DE INFORMÁTICA E ESTATÍSTICA DISCIPLINA DE COMPUTAÇÃO COM OBJETOS DISTRIBUÍDOS.
Transcrição da apresentação:

14.6  Campos de texto e uma introdução ao tratamento de eventos com classes aninhadas Um usuário interage com uma GUI para indicar as tarefas que o aplicativo deve realizar; GUIs são baseadas em evento. Uma interação com o usuário cria um evento, que guia o programa para realizar uma tarefa; Eventos comuns: clicar em um botão, digitar em um campo de texto, selecionar um item de menu, fechar uma janela, mover o mouse; O evento causa uma chamada a um método (o handler de evento). Handler de evento = código que realiza uma tarefa em resposta a um evento; O processo total de responder a eventos é conhecido como Tratamento de Eventos.

JTextFields e JPasswordFields (pacote javax.swing). JTextField estende a classe JTextComponent (pacote javax.swing.text), que fornece muitos recursos comuns aos componentes baseados em texto do Swing; A classe JPasswordField estende JTextField e adiciona métodos que são específicos ao processamento de senhas; JPasswordField mostra que os caracteres estão sendo digitados à medida que o usuário os insere, mas oculta os caracteres reais com caracteres eco.

O método event.getActionCommand() acima poderia ser substituído por textFieldn.getText(), com o mesmo efeito.

O método event.getActionCommand() acima poderia ser substituído por new String(passwordfield.getPassword()) com o mesmo efeito. Deve ser considerado o fato de que o método getPassword() retorna um char[] ao invés de uma String.

Quando o usuário digita dados em um JTextField ou JPasswordField e, então, pressiona Enter, um evento ocorre; Você pode digitar somente no campo de texto que estiver “em foco”. Um componente recebe o foco quando o usuário clica no componente.

Passos para configurar o tratamento de evento de um componente GUI Antes que um aplicativo possa responder a um evento de um componente GUI, deve-se realizar vários passos de codificação: Criar uma classe que represente o handler de evento; Implementar uma interface apropriada, conhecida como Interface Ouvinte de Eventos, na classe do Passo 1; Indicar que um objeto da classe dos Passos 1 e 2 deve ser notificado quando o evento ocorrer. Isso é conhecido como Registrar o Handler de Evento.

Utilizando uma classe aninhada para implementar um handler de evento Todas as classes discutidas até agora foram Classes de Primeiro Nível (não foram declaradas dentro de outra classe); O Java permite declarar classes dentro de outras classes — são chamadas Classes Aninhadas. Podem ser static ou não static; As classes não static aninhadas são chamadas Classes Internas e são frequentemente utilizadas para implementar handlers de evento.

Antes que um objeto de uma classe interna possa ser criado, deve haver um objeto da classe de primeiro nível que contém a classe interna. Isso é necessário porque um objeto de classe interna tem implicitamente uma referência a um objeto de sua classe de primeiro nível; Há um relacionamento especial entre esses objetos — o objeto da classe interna tem permissão de acessar diretamente todas as variáveis e métodos da classe externa; Uma classe aninhada que é static não exige um objeto de sua classe de primeiro nível e não tem implicitamente uma referência a um objeto da classe de primeiro nível.

Classes internas podem ser declaradas public, protected ou private; Visto que as rotinas de tratamento de evento tendem a ser específicas do aplicativo em que são definidas, muitas vezes elas são implementadas como classes internas private.

Os componentes GUI podem gerar muitos eventos em resposta a interações de usuário; Cada evento é representado por uma classe e pode ser processado apenas pelo tipo de handler de evento apropriado; Normalmente, os eventos suportados de um componente são descritos na documentação da Java API para a classe desse componente e suas superclasses.

Quando o usuário pressiona Enter em um JTextField ou JPasswordField, um ActionEvent (pacote java.awt.event) ocorre; É processado por um objeto que implementa a interface ActionListener (pacote java.awt.event); Para tratar ActionEvents, uma classe deve implementar a interface ActionListener e declarar o método actionPerformed(); Esse método especifica as tarefas a serem realizadas quando ocorrer um ActionEvent; É disparado automativamente quando um evento de ação ocorrer.

Registrando o handler de evento de ação para cada componente GUI Deve-se registrar um objeto como o handler de evento para cada campo de texto – no caso do exemplo – ou cada componente GUI que sofrer evento de ação; O método addActionListener() registra um objeto ActionListener para tratar ActionEvents; Assim, o handler de eventos passa a ouvir o campo de texto (ou outro objeto registrado).

O componente GUI com o qual o usuário interage é a Origem de Evento; O método ActionEvent getSource() (herdado da classe EventObject) retorna uma referência para a origem de evento; O método ActionEvent getActionCommand() obtém o texto que o usuário digitou no campo de texto que gerou o evento; O método JPasswordField getPassword() retorna os caracteres da senha como um array de tipo char; No caso do componente ser não editável, mesmo assim o evento pode ser disparado, caso o componente em questão venha a receber foco durante a execução do aplicativo.

14.7 Tipos comuns de eventos GUI e interfaces ouvintes Há muitos tipos de eventos que podem ocorrer quando um usuário interage com uma GUI; As informações sobre qualquer evento GUI são armazenadas em um objeto de uma classe que estende AWTEvent; A Figura 14.11 ilustra uma hierarquia que contém muitas classes de evento do pacote java.awt.event; Utilizados em componentes AWT e Swing; Tipos adicionais de evento que são específicos dos componentes GUI Swing são declarados no pacote javax.swing.event.

Tipos como esses são declarados no pacote java. awt Tipos como esses são declarados no pacote java.awt.event e alguns deles são mostrados na Figura 14.12; O mecanismo de tratamento de eventos (ou Modelo de Delegação de Evento) se divide em partes: ORIGEM DO EVENTO – componente com o qual o usuário interage; OBJETO DO EVENTO – contém as informações sobre o evento que ocorreu, como uma referência à sua origem; OUVINTE DO EVENTO – notificado pela origem do evento quando um evento ocorre e um de seus métodos executa uma resposta ao evento, recebendo como argumento o objeto do evento.

Para cada tipo de objeto de evento, há, em geral, uma interface ouvinte de eventos apropriada. Um ouvinte de eventos é um objeto que implementa a(s) interface(s) ouvinte(s) de evento do pacote event. Cada uma dessas interfaces especifica um ou mais métodos de tratamento de evento que devem ser declarados na classe que implementa a interface; Quando um evento ocorre o componente GUI notifica seus ouvintes registrados, chamando o método de tratamento apropriado de cada ouvinte.

14.8 Como o tratamento de evento funciona Todo JComponent tem uma variável listenerList que referencia um EventListenerList (pacote javax.swing.event); São mantidas referências a ouvintes registrados na listenerList (um array de ouvintes); Quando um ouvinte é registrado, uma nova entrada é colocada na listenerList do componente. Toda entrada também inclui um tipo de ouvinte.

Invocação de handler de evento. Como o componente GUI sabe que deve chamar actionPerformed() em vez de outro método? Todo componente GUI suporta vários tipos de evento, inclusive eventos de mouse, eventos de teclado e outros; Quando um evento ocorre, o evento é despachado apenas para os ouvintes de evento do tipo apropriado; Despacho (dispatching) é simplesmente o processo pelo qual o componente GUI chama um método de tratamento de evento em cada um de seus ouvintes que são registrados para o tipo de evento que ocorreu.

Cada tipo de evento tem uma ou mais interfaces ouvinte de eventos correspondentes; ActionEvents são tratados por ActionListeners; MouseEvents são tratados por MouseListeners e MouseMotionListeners; KeyEvents são tratados por KeyListeners; Quando ocorre um evento, o componente GUI recebe (do JVM) um único ID de evento para especificar o tipo de evento; O componente GUI utiliza o ID de evento para decidir o tipo de ouvinte para o evento que deve ser despachado e decidir qual método chamar em cada objeto ouvinte.

Para um ActionEvent, o evento é despachado para o método actionPerformed() de todos ActionListeners registrados; Para um MouseEvent, o evento é despachado para cada MouseListener ou MouseMotionListener registrado, dependendo do evento de mouse que ocorre; O ID de evento de MouseEvent determina quais dos vários métodos de tratamento de evento de mouse serão chamados.

14.9  JButton Um botão é um componente em que o usuário clica para acionar uma ação específica; Há vários tipos de botões: Botões de Comando; Caixas de Seleção; Botões de Alternação; Botões de Opção; Os tipos de botão são subclasses de AbstractButton (pacote javax.swing), que declara os recursos comuns de botões Swing.

JToggleButton – é similar a um JButton, só que quando pressionado fica em destaque até que seja pressionado novamente. Dispara itemEvent.

Botão de Comando JButtons, assim como JTextFields, geram ActionEvents que podem ser processados por qualquer objeto ActionListener. São criados a partir da classe JButton; O texto na face de um JButton é chamado Rótulo de Botão; Uma Gui pode ter muitos JButtons, mas, em geral, cada rótulo de botão deve ser único na parte da Gui em que é atualmente exibido.

Notar que a referência this foi associada à classe ButtonFrame dentro do método da classe Buttonhandler. Indicando que é a classe mais externa que está sendo refernciada, e não a mais interna, que deve ser utilizada como Gui-pai da caixa de diálogo.

Um JButton pode exibir um Icon; Um JButton também pode ter um Icon de rollover, exibido quando o usuário posiciona o mouse sobre o Jbutton. Isso faz com que o ícone se altere quando o mouse está dentro/fora do botão, tornando essas situações mais distintas; O ícone do JButton altera-se quando o mouse move-se para dentro e para fora da área do JButton na tela; O método AbstractButton setRolloverIcon() especifica a imagem exibida no JButton quando o usuário posiciona o mouse sobre ele.

14.10 Botões que mantêm o estado Três tipos de botões de estado, que têm valores ativados/desativados ou verdadeiro/falso: JToggleButton; JCheckBox; JRadioButton; As classes JCheckBox e JRadioButton são subclasses de JToggleButton; JRadioButtons são agrupados e mutuamente exclusivos — somente um no grupo pode ser selecionado por vez; JCheckBoxs não precisam ser agrupados e não são mutuamente exclusivos.

14.10.1  JCheckbox Contém um rótulo de caixa de seleção que aparece à direita da caixa de seleção, por padrão. O rótulo é informada através do construtor da classe; Gera um ItemEvent quando é clicado. ItemEvents são tratados por um objeto da interface ItemListener; Passado para o método itemStateChanged() da interface, e que deve ser implementado pelo ouvinte do evento. Esse é o método que será disparado quando ocorrer um clique no checkBox; A associação do ouvinte ao objeto origem do evento ocorre através do método addItemListener(); O método isSelected() retorna se uma caixa de seleção está selecionada (true) ou não (false); Um aplicativo pode ter vários checkBoxs atuando em conjunto.

Sobre o código da figura 14.17 A String passada para o construtor JCheckBox é o rótulo da caixa de seleção que aparece à direita da JCheckBox; O método JTextField setFont() (herdado por JTextField indiretamente de Component) configura a fonte do JTextField como uma nova Font (pacote java.awt); O construtor da classe Font contém os argumentos: nome da fonte (String), estilo da fonte (constantes de Font. Como: Font.PLAIN, Font.BOLD, Font.ITALIC) e tamanho da fonte. Quando mais de um estilo precisar ser considerado, deve-se passar como argumento a soma de tais estilos (das constantes).

14.10.2  JRadioButton Botões de opção (declarados com a classe JRadioButton) são semelhantes a caixas de seleção no sentido de que têm dois estados — selecionado e não selecionado; Os botões de opção aparecem como um grupo em que apenas um botão pode ser selecionado por vez; Selecionar um botão de opção diferente força a remoção da seleção de todos os outros que estão selecionados; Utilizados para representar opções mutuamente exclusivas; A relação lógica entre os botões de opção é mantida por um objeto ButtonGroup (pacote javax.swing), que organiza um grupo de botões e não é exibido em uma interface com o usuário.

O método ButtonGroup add() associa um JRadioButton com o grupo; Se mais de um objeto JRadioButton selecionado for adicionado ao grupo, aquele que tiver sido adicionado primeiro será selecionado quando a GUI for exibida; JRadioButtons, assim como JCheckBoxes, geram ItemEvents quando são clicados.

Observar que as primeiras chamada a um método add() está adicionando os radioButton à frame. O segundo grupo de chamadas de método add() está adicionando os radioButton ao buttonGroup.

Reparar que o handler de evento no trecho destacado no código acima para tratamento de evento está sendo instanciado sem que haja uma variável que a referencie (é passado para o método diretamente).

14.11 JComboBox e utilização de uma classe interna anônima para tratamento de eventos Uma caixa de combinação (ou lista drop-down) permite ao usuário selecionar um único item de uma lista; Caixas de combinação são implementadas com a classe JComboBox, que estende a classe Jcomponent; JComboBoxs também geram ItemEvents; O construtor de um JComboBox recebe como argumento um array de Strings com os elementos da lista que deve ser exibida. O primeiro item da lista é o item inicialmente exibido no comboBox;

Cada item na lista tem um índice, iniciando com 0 (zero); O primeiro item adicionado a uma JComboBox aparece como o item atualmente selecionado quando a JComboBox é exibida; Outros itens são selecionados clicando na JComboBox e, então, selecionando um item da lista que aparece; O método JComboBox setMaximumRowCount configura o número máximo de elementos que é exibido quando o usuário clica na JComboBox; Se houver itens adicionais, a JComboBox fornece uma barra de rolagem, para que o usuário role por todos os elementos da lista.

O argumento para addItemListener() deve ser um objeto ItemListener O argumento para addItemListener() deve ser um objeto ItemListener. O que está dentro dos parênteses da chamada do método é uma expressão de criação da instância de classe que declara uma classe interna anônima e cria um objeto dessa classe. Uma referência ao objeto criado é passado como argumento para o método. Os parênteses depois de ItemListener() indicam uma chamada ao construtor padrão da classe interna anônima. As chaves de abertura e fechamento após tal construtor delimitam o corpo da classe interna anônima. Para cada item selecionado de um comboBox, a seleção de outro item primeiro é removida. Assim ocorrem dois itemEvents – um para o item removido e outro para o novo item selecionado.

Classe Interna Anônima Uma classe interna anônima é uma classe interna que é declarada sem nome e, em geral, aparece dentro de uma declaração de método; Como outras classes internas, uma classe interna anônima pode acessar os membros de sua classe de primeiro nível; Uma classe interna anônima tem acesso limitado às variáveis locais do método em que ela é declarada; Visto que uma classe interna anônima não tem nomes, deve-se criar um objeto da classe interna anônima no ponto em que a classe é declarada. Costuma ocorrer dentro da chamada do método, sendo um argumento deste método.

O método JComboBox getSelectedIndex() retorna o índice do item selecionado; Para cada item selecionado de uma JComboBox, a seleção de outro item é primeiro removida — então dois ItemEvents ocorrem quando um item é selecionado; O método ItemEvent getStateChange() retorna o tipo de alteração de estado. ItemEvent.SELECTED indica que um item foi selecionado.