Apostila Programação 3º Período.
Transcrição
Apostila Programação 3º Período.
Programação 3° Período Alex Coelho ... import javax.swing.*; ... public class AppCadastro extends Frame{ ... TextField nome = new TextField(71); TextField descricao = new TextField(68); Button salvar = new Button("Salvar"); Button limpar = new Button("Limpar"); Button report = new Button("Relatório"); Button sair = new Button("Sair"); Label result = new Label(); //método construtor public AppCadastro(){ rio"); ... painelCadastro.setLayout(new FlowLayout()); painelCadastro.add(new Label("Nome:")); painelCadastro.add(nome); painelCadastro.add(new Label("Descrição:")); painelCadastro.add(descricao); Caro estudante, Na aula 1, iniciaremos conhecendo os componentes básicos para a programação visual, utilizando a biblioteca AWT, além de relembrarmos conceitos básicos já vistos na disciplina de Programação anterior. Na aula 2, continuaremos com a apresentação dos componentes da biblioteca AWT e aprenderemos a desenvolver programas e explorar a interação. Em nossa 3ª aula, serão apresentados os tratadores de eventos para a interação dos usuários com o sistema que são aceitos pela biblioteca AWT e serão explorados os conceitos vinculados ao gerenciamento de layouts e disposição dos componentes em uma interface gráfica. Na 4ª aula, conheceremos os conceitos para construção de aplicações que serão interligadas a banco de dados para o armazenamento e recuperação de dados. Em nossa aula 5, o foco será o trabalho com a Applets, que possibilita a criação de programas com interfaces para WEB. Na aula 6, iremos falar sobre o desenvolvimento de programas em Java com relatórios, possibilitando a criação de aplicações comerciais, mais completas. Finalizando, na aula 7 será apresentado um estudo de caso, de uma aplicação completa para o cadastro e consultas de cursos, por meio da utilização de todos os conceitos apresentados em nosso módulo. Então vamos ao que interessa, tente aproveitar ao máximo tudo o que será exposto na disciplina. Apresentação Seja bem-vindo à disciplina Programação. O objetivo deste material é apresentar os principais conceitos que a tecnologia Java disponibiliza para a construção de aplicações visuais, aprofundar e conhecer novos componentes da programação visual, além dos conceitos relacionados à conexão e consulta a banco de dados, para que, ao final desta disciplina, você consiga desenvolver programas em Java, aplicando todo o conhecimento adquirido. A tecnologia Java, nos últimos anos, tornou-se muito popular no mercado, estando presente nas mais diversas aplicações, como, em eletrodomésticos, aparelhos celulares e web. Assim, a linguagem Java tem características que a tornam diferenciada, sendo de grande importância na criação de software. Fundação Universidade do Tocantins Reitor Humberto Luiz Falcão Coelho Vice-Reitor Lívio William Reis de Carvalho Pró-Reitor de Graduação Galileu Marcos Guarenghi Pró-Reitor de Pós-Graduação e Extensão Claudemir Andreaci Pró-Reitora de Pesquisa Antônia Custódia Pedreira Pró-Reitora de Administração e Finanças Maria Valdênia Rodrigues Noleto Diretor de EaD e Tecnologias Educacionais Marcelo Liberato Coordenador Pedagógico Geraldo da Silva Gomes Coordenador do Curso Igor Yepes Organização de Conteúdos Acadêmicos Alex Coelho Material Didático – Equipe Unitins Coordenação Editorial Maria Lourdes F. G. Aires Assessoria Editorial Marinalva do Rêgo Barros Silva Assessoria Produção Gráfica Katia Gomes da Silva Revisão Lingüístico-Textual Kyldes Batista Vicente Revisão Digital Katia Gomes da Silva Projeto Gráfico Douglas Donizeti Soares Irenides Teixeira Katia Gomes da Silva Programação Visual Douglas Donizeti Soares Katia Gomes da Silva Material Didático – Equipe Univali Coordenação Geral - Gerência de EaD Margarete Lazzaris Kleis Reitor José Roberto Provesi Vice-Reitor Mário César dos Santos Procurador Geral Vilson Sandrini Filho Coordenação Técnica e Logística Jeane Cristina de Oliveira Cardoso Coordenação de Curso Luis Carlos Martins Editoração Gráfica Delinea Design Soluções Gráficas e Digitais LTDA Secretário Executivo Nilson Scheidt Coordenação Editorial Charlie Anderson Olsen Larissa Kleis Pereira Pró-Reitora de Ensino Amândia Maria de Borba Logística Editorial Michael Bernardini Pró-Reitor de Pesquisa, Pós-Graduação, Extensão e Cultura Valdir Cechinel Filho Diagramação Michael Bernardini EADCON – Empresa de Educação Continuada Ltda Diretor Presidente Luiz Carlos Borges da Silveira Diretor Executivo Luiz Carlos Borges da Silveira Filho Diretor de Desenvolvimento de Produto Márcio Yamawaki Diretor Administrativo e Financeiro Júlio César Algeri Ilustração Alexandre Beck Ementa Programação visual utilizando a tecnologia Java. Biblioteca AWT (Abstract Window Toolkit). Componentes básicos: Frame, Label, Button, TextField, Panel, TextArea, List, Choice, CheckBox, CheckBoxGroup, Menus. Gerenciadores de Layout. Eventos AWT. Conexão com Banco de dados: JDBC, Tipos JDBC, Connection, Statement, PreparedStatament. Applets. JasperReports e iReport. Objetivos • Apresentar conceitos básicos da linguagem de programação Java para programação visual. • Apresentar os principais componentes utilizados para a construção de • Proporcionar a compreensão aos alunos sobre a utilização de banco de dados em aplicações visuais utilizando componentes e conceitos de conexão. • Demonstrar aos alunos o potencial do desenvolvimento de aplicações visuais e sua possibilidade de interação com os usuários. • Demonstrar aos alunos a confecção de relatórios utilizando a tecnologia Java. Conteúdo programático • Componentes visuais básicos • Label • Button • TextField • Pane • TextArea • Choice • List • Checkbox • CheckboxGroup • Menu • Tratamento de eventos • Gerenciamento de layouts • Conexão com banco de dados • Inserção e consultas a banco de dados • Applets • Relatórios com jasperReport Plano de Ensino interfaces gráficas. BIBLIOGRafia básica BOENTE, Alfredo. Aprendendo a programar em Java 2: orientado a objetos. Rio de Janeiro: Brasport, 2003. ANSELMO, Fernando. Aplicando lógica orientada a objetos em Java. 2. ed. Florianópolis: Visual Books, 2005. CARDOSO, Caíque. Orientação a objetos na prática: aprendendo orientação a objetos com Java. Rio de Janeiro: Ciência Moderna, 2006. DEITEL, Harvey M. Java: como programar. 6 ed. São Paulo: Pearson Prentice Hall, 2005. SANTOS, Rafael. Introdução à programação orientada a objetos usando Java. Rio de Janeiro: Campus, 2003. HEFFELFINGER, David. JasperReports for Java Developers. Agosto, 2006. Bibliografia complementar SUN, MicroSystem. Java Technology. Disponivel em http://java.sun.com. Acessado em 12 out. 2007. Aula 1 – Programação Visual em Java....................................................... 9 Aula 2 – Componentes visuais................................................................ 23 Aula 3 – Gerenciadores de layout e Tratadores de evento.......................... 37 Aula 4 – Trabalhando com Banco de Dados............................................. 49 Aula 5 – Applets Java............................................................................ 61 Aula 6 – Relatórios................................................................................ 71 Sumário Aula 7 – Estudo de Caso........................................................................ 83 Aula 1 Programação Visual em Java Objetivo Esperamos que, ao final desta aula, você seja capaz de: • c onhecer os principais componentes visuais utilizados na tecnologia Java para a programação visual. Pré-requisitos Para iniciarmos os estudos sobre a programação visual Java, é importante conhecermos os conceitos básicos da programação orientada a objetos, vistos na disciplina Programação do segundo período. Esse conhecimento é importante para uma melhor compreensão desta aula, uma vez que são conceitos básicos para prosseguimento na construção de programas visuais em Java. Introdução Nos últimos anos, com o avanço tecnológico e dos microcomputadores em empresas e residências, as aplicações gráficas ganharam considerável espaço, aumentando, com isso, as possibilidades que, além de fornecerem uma interface mais simples, rica e intuítiva com os usuários, passaram a agilizar os processos antes desempenhados de maneira pouco interativa. Essas interfaces que mudaram todo o conceito da programação são mais conhecidas como GUI (Graphical User Interface) e obedecem a um padrão que consiste em dar ao usuário o que ele está vendo e precisando, o famoso “what you see is what you get” das pesquisas oriundas da interação homem-máquina. Assim, a linguagem de programação Java oferece diversas capacidades, únicas no desenvolvimento de aplicações gráficas que, conforme apresentado no módulo anterior, devido à capacidade de liberdade de plataforma não Univali/UNITINS • superior de tecnologia • 3º PERÍODO 9 Aula 1 • programação são necessárias modificações ou mesmo recompilação da aplicação, sendo que estas podem ser executadas em diferentes ambientes gráficos, sendo uma vantagem comercial diante das demais linguagens. 1.1 Programação Visual “ A linguagem Java disponibiliza duas bibliotecas para a construção de interfaces gráficas, utilizando componentes GUI.” Nesta aula, veremos mais a fundo os conceitos relacionados à programação com interfaces visuais, apresentados na aula 5 da disciplina de programação anterior. Assim, iniciaremos esta aula apresentando um conceito geral da programação visual com Java. Podemos dizer que a utilização de componentes padronizados, como botões, campos de texto e menus, fez das interfaces gráficas um sucesso. Pela utilização de componentes visuais, é possível que usuários interajam por meio de operações realizadas pelo teclado ou mouse, tornando possível com isso, entradas de dados, seleção de caixas, botões além de, acionar outras operações que tornem as aplicações interessantes ao usuário conforme demonstrado nas aulas finais do módulo anterior. Estes componentes também conhecidos como GUI componentes, são elementos que compõem uma interface GUI. Segundo Deitel (2005), um componete GUI é: um objeto pelo qual o usuário interage através do mouse, do teclado ou outra forma de entrada, como reconhecimento de voz. A linguagem Java disponibiliza duas bibliotecas para a construção de interfaces gráficas, utilizando componentes GUI. A primeira consiste na utilização da biblioteca Swing, vista anteriormente, com a implementação de aplicações simples. A outra biblioteca e que será tema de nossos estudos nesta aula, consiste na biblioteca AWT (Abstract Window Toolkit) que é disponibilizada por meio da importação do pacote java.awt. No caso, a biblioteca AWT fornece diversas classes, comuns e abstratas que realizam com a utilização da JVM (Java Virtual Machine) a apresentação dos componentes visuais pertencentes a essa biblioteca. A classe abstrata Component consiste na base para construção de qualquer componente visual oferecido pela linguagem Java, por meio da utilização da AWT (DEITEL, 2005). Em discussão sobre os conceitos vinculados aos componentes, pode se afirmar que a AWT faz com que seja criada uma generalização dos componentes utilizados na construção de aplicações visuais, sendo independentes da plataforma que esteja sendo utilizada, fazendo com que estas sejam sempre equivalentes, e desempenhando as mesmas funções 10 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 1 • programação para as quais foram destinadas e se propõem a resolver garantindo a portabilidade do sistema. A Sun define a Java como (SUN, 2007): simples, distribuída, interpretada, robusta, segura, de arquitetura neutra, portátil, multi-funções e dinâmica. Certo, porém o que isto significa para a construção de minhas aplicações? Isto significa que, independentemente do sistema operacional escolhido, uma mesma aplicação pode ser executada sem que o resultado final seja alterado, por exemplo, um botão sempre será compreendido como um botão pela JVM rodando seja no Linux, Windows ou mesmo Solaris, mesmo que a aparência do componente seja distinta, os princípios básicos de funcionamento e operação sempre serão os mesmos (DEITEL, 2005). 1.2 Construindo uma Aplicação Gráfica O processo inicial de uma aplicação gráfica sempre é realizado com a seleção e projeto de uma interface para o sistema, selecionando todos os componentes que irão compor a tal interface, distribuindo-os da forma desejada no ambiente visual e, no caso, é mais importante definir qual a real função de cada componente e sua utilização na aplicação. O mercado fornece diversas IDEs para a construção de interfaces gráficas Java, utilizando o padrão Drag and Drop, porém como nosso intuito nesta aula consiste em fixar todos os conceitos ligados à programação visual, fica a seu critério a utilização ou não dessas ferramentas, não nos apegaremos a nenhuma IDE. Saiba mais Existem diversas IDEs e plugins para ferramentas de desenvolvimento para aplicações gráficas em Java. Dentre estas, as mais utilizadas consistem no Eclipse, Netbeans, Sun One e JBuilder. Estas colaboram com a aceleração do processo de desenvolvimento e, conseqüentemente, com a redução de custos. Com isso, podemos dividir a implementação de um sistema visual utilizando a linguagem Java em três etapas, como visto anteriormente: a primeira consiste na criação e instanciação dos componentes da biblioteca AWT no projeto (FLANAGAN, 2006). Sempre é válido mencionar que em Java todos os componentes são classes. Sendo assim, um componente é instanciado da mesma forma como uma variável, ou mesmo atributo, como melhor você estiver familiarizado. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 11 Aula 1 • programação Outra etapa a ser desempenhada na criação de uma aplicação visual consiste na adição dos componentes à interface, para que eles estejam visíveis no momento da execução do sistema. Existem componentes que incorporam outros componentes, para que estes estejam visíveis sendo denominados como containers. Estes são criados e associados à interface, sendo que podem ser especificados o seu posicionamento com a utilização de gerenciadores de layout que serão estudados nesta aula. A terceira e última etapa de um desenvolvimento voltado para criação de aplicações gráficas, consiste no que irá ser realizado quando um determinado evento ocorrer sobre um dos componentes gráficos de uma aplicação, assim que ocorrer uma interação do usuário com a aplicação, seja por meio do teclado ou mesmo pela utilização do mouse. Após essa interação, é enviada uma mensagem da plataforma em que a aplicação esta sendo executada, informando o tipo e a forma de interação que ocorreram sobre o componente. Aí entram em ação os listeners, que são métodos que ficam em estado de alerta escutando o que é enviado pelo sistema operacional. Estes métodos especiais são implementados nas aplicações e são associados aos componentes, sendo responsáveis por escutar uma interação e reagir a tais interações, conforme desejado (DEITEL, 2005). Depois da apresentação desta visão inicial sobre as aplicações gráficas, vamos pôr a mão na massa e criar nosso primeiro exemplo, utilizando as bibliotecas gráficas AWT. Então transcreva o código a seguir e execute-o. // Classe PrimeiroExemplo.java import java.awt.*; public class PrimeiroExemplo extends Frame{ public static void main (String args[]) { Frame f = new Frame (); Button botao = new Button (“SAIR”); //botao. addActionListener(Evento); f.add(botao); f.setSize(50, 100); f.setLocation(50, 50); f.show(); } } 12 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 1 • programação Como podemos perceber, são utilizados diversos conceitos apresentados no módulo anterior, como o processo de instanciação e referência dos objetos ou mesmo a idéia de herança. Porém, conforme mencionado anteriormente neste módulo, iremos trabalhar com a biblioteca AWT, que difere do que já foi apresentado na aula anterior. Por exemplo: com a utilização da biblioteca Swing, para criarmos um botão convencional, deveríamos instanciar um objeto da classe JButton. Conforme apresentado no exemplo anterior, a AWT utiliza apenas a classe Button, para que o mesmo processo seja realizado, sendo uma biblioteca nativa do Java. Mas não se preocupe, todos os conceitos e componentes conhecidos serão úteis para construções de aplicações, uma vez que a idéia geral do processo é muito semelhante. Com isso, torna-se possível criar aplicações gráficas que utilizem os componentes GUI da biblioteca AWT. Então, para que possamos criar efetivamente uma aplicação, é interessante que sejam conhecidos quais são os componentes básicos da AWT, bem como instanciar, obviamente adicioná-los estes a interfaces, além de propor funcionalidades por meio dos eventos e interações desempenhadas pelos usuários sobre os componentes (SUN, 2007). 1.3 Componentes Básicos Como já mencionado nesta aula, a classe abstrata Component é a base para construção de qualquer componente visual, sendo que este é fornecido pela linguagem Java, por meio do pacote java.awt. Esse pacote oferece classes com toda infra-estrutura necessária para criação de objetos que possuam uma representação gráfica que podem ser exibidos em uma interface que pode reagir a interações de um usuário (DEITEL, 2005). Assim como no conceito de interfaces apresentado no módulo anterior, as classes abstratas não podem ser instanciadas diretamente, mas podem ser utilizadas como um modelo para a criação de novos componentes, sendo estas novas classes derivadas desta, permitindo um tratamento generalizado dos componentes que são oriundos do conceito de polimorfismo. Todos os componentes gráficos que serão aqui apresentados são baseados no pacote java.awt, não se esqueça. A classe Component também é base para construção da classe abstrata Container, que consiste em uma área na qual outros componentes podem ser Univali/UNITINS • superior de tecnologia • 3º PERÍODO 13 Aula 1 • programação adicionados e posicionados a interface. No caso, qualquer classe que herda da classe Container pode agregar a seu escopo outros componentes. Alguns exemplos de containers de componentes são as classes Frame e Window, que consistem em janelas, além da classe Panel que é um painel (DEITEL, 2005). Pensando sobre o assunto Assim como qualquer outra classe, são fornecidos diversos métodos pela classe Component, fornecendo formas de acesso às funcionalidades desta. Sugerimos uma verificação prévia deste, uma vez que todos são herdados pelos demais componentes. Então vamos ao que interessa, vamos apresentar os principais componentes da AWT, conhecendo suas principais aplicações e utilizando, para isso, a construção de pequenos exemplos. Nosso primeiro componente a ser explorado consiste no Frame. 1.3.1 Componente Frame O componente Frame consiste em uma classe responsável pela construção de janelas para aplicações gráficas que disponibiliza uma barra de título e bordas. Como esta é uma subclasse da classe Container, conforme mencionado, esta pode conter em seu escopo outros componentes, sendo que esta consiste em sua finalidade principal. Outro detalhe que deve ser levado em consideração é o alinhamento dos componentes dentro do Frame instanciado, sendo por definição o alinhamento default BorderLayout para os componentes que são adicionados (FILHO, 2005). Ademais, o componente Frame, também implementa a interface MenuContainer, possibilitando que possam ser associados a estes componentes de menu associados à janela . Todos estes componentes serão explorados mais profundamente no decorrer desta aula. Geralmente, o componente Frame consiste na base para a criação de aplicações gráficas, sendo que são feitas especificações da classe Frame, criando, assim, além da janela a ser utilizada, um container para os componentes desta janela, através da utilização de seu método construtor (DEITEL, 2005). Vamos criar nosso exemplo utilizando tais conceitos; então, transcreva o exemplo a seguir e execute-o. 14 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 1 • programação // FrameExemplo.java import java.awt.*; public class FrameExemplo extends Frame{ // metodo construtor public FrameExemplo(){ super(“Janela Exemplo”); setSize(50, 100); setLocation(100, 100); } // metodo executável public static void main (String args[]) { FrameExemplo janela = new FrameExemplo(); janela.setVisible(true); } } Note que no nosso segundo exemplo, conforme mencionado anteriormente, são construídas geralmente classes que estendem da classe Frame, sendo que esta se torna, além de uma janela, um repositório para componentes. Na classe FrameExemplo explicitamos outro detalhe interessante e muito importante, que consiste na invocação do método setVisible(true) para a apresentação da janela, dentro do método executável da classe, porém poderia ser utilizado o método show(), mas este está sendo depreciado pela nova versão da JVM. Porém, apesar de conseguirmos apresentar nossa janela, conforme desejado, com capacidade de conter diversos componentes, além de diversas características, a janela ainda não responde a nenhum evento, por exemplo, quando o botão “fechar”, é acionado nada ocorre. Isso se dá devido ao fato de não existirem métodos que tratem os eventos, no caso que recebam a mensagem do sistema operacional e seja capaz de tratá-la. Por exemplo, como não possuímos um método que escute tais mensagens da plataforma, necessitamos então encerrar a execução da Java Virtual Machine, para conseguirmos finalizar nossa janela. Então vamos tornar nosso segundo exemplo mais interessante: é necessário que sejam construídos métodos que processem os eventos que irão reagir à interação com a janela. Iremos, para tanto, utilizar a interface WindowListener para se incumbir de tal tarefa. A utilização da interface exige de maneira semelhante a um contrato que os métodos definidos nestes sejam implementados, pelas classes que se propõem a implementá-la, pode ser facilmente utilizada devido à possibilidade da utilização de diversas interfaces, para a mesma classe, conforme foi apresentado no módulo anterior (DEITEL, 2005). O ponto negativo da utilização da interface WindowListener é que esta exige a implementação de 7 (sete) métodos, sendo que utilizaremos apenas um. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 15 Aula 1 • programação Vamos verificar como ficará nossa classe FrameExemplo, após a definição de que esta passará a implementar a interface WindowListener. É interessante observar os métodos que devem ser ao menos declarados, devido à utilização da interface, bem como a importação do pacote java.event, sendo que este será detalhado na 3ª aula. Assim, faça as alterações na classe conforme é apresentado no quadro abaixo e execute seu programa. // FrameExemplo.java import java.awt.*; import java.awt.event.*; public class FrameExemplo extends Frame implements WindowListener{ // metodo construtor public FrameExemplo (){ super(“Titulo: Janela Exemplo”); setSize(50, 100); setLocation(100, 100); addWindowListener(this); } // metodo executavel static public void main(String args[]){ FrameExemplo janela = new FrameExemplo(); janela.setVisible(true); } // metodos listeners public void windowClosing(WindowEvent e){ System.exit(0); } public void windowClosed(WindowEvent e){} public void windowIconified(WindowEvent e){} public void windowOpened(WindowEvent e){} public void windowDeiconified(WindowEvent e){} public void windowActivated(WindowEvent e){} public void windowDeactivated(WindowEvent e){} } Assim, conseguimos fazer com que a nossa janela passe a escutar as mensagens vindas do sistema operacional, fazendo com que a interação do usuário junto a nossa janela possa gerar uma reação desta. Todos os componentes da AWT possuem métodos especiais que tratam essas interações entre os usuários e o componente. Certo, pessoal? Então vamos agora a nosso segundo componente que pode ser agregado à nossa janela, enriquecendo nossos programas. 16 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 1 • programação 1.3.2 Componente Label Nesta subseção, iremos apresentar o componente Label, que, conforme mencionado, pode ser agregado ao componente Frame, apresentado, assim, rótulos de texto, ou simplesmente legendas. Este, por sua vez, pode ser utilizado em qualquer componente que seja do tipo container, exibindo apenas uma linha, sendo que esta não permite alteração. Diversos métodos podem ser acessados para uma instância da classe Label, porém, com certeza, os mais utilizados são os métodos construtores, nos quais já podem ser definidos textos que serão apresentados dentro das interfaces gráficas criadas com a classe Frame. Outra característica que é muito utilizada na instanciação de objetos do tipo Label consiste na utilização das constantes para a definição de seu alinhamento. São disponibilizadas três constantes: Label.LEFT, Label.CENTER e Label.RIGHT. Então vamos a outro exemplo para uma pequena demonstração deste componente, no qual alteramos nosso o exemplo anterior (MANZANO, 2006). // FrameExemplo.java import java.awt.*; import java.awt.event.*; public class FrameExemplo extends Frame implements WindowListener{ // metodo construtor public FrameExemplo (){ super(“Titulo: Segundo Exemplo”); setSize(50, 100); setLocation(100, 100); addWindowListener(this); } // metodo executavel static public void main(String args[]){ FrameExemplo janela = new FrameExemplo(); Label texto = new Label(“Novo Texto!”); janela.add(texto); janela.setVisible(true); } ... } Note que no exemplo apenas criamos uma instância da classe Label, denominada texto e, com a utilização de seu construtor, definimos o texto a ser apresentado na janela. Note que foi utilizado o método add() do objeto janela, para que o label fosse acrescentado à janela, para sua apresentação. Desta forma, qualquer objeto que deva ser apresentado deve estar adicionado à janela por meio desse método. Assim, vamos a mais um componente, sendo que este tem importância significativa para o desenvolvimento de aplicações gráficas, no caso os botões. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 17 Aula 1 • programação 1.3.3 Componente Button Agora vamos a um componente importantíssimo para a criação de aplicações gráficas, a classe Button, responsável pela criação de componentes do tipo botão. Os botões são interessantes para as aplicações gráficas por possibilitar a interação entre o sistema e os usuários e, assim, determinar seqüências de comandos para reagirem a tais interações. Os botões agregam valor visual, uma vez que apresentam efeitos e modificações no estado deste, que denotam uma resposta do sistema às ações desempenhadas pelos usuários (DEITEL, 2005). Porém, assim como apresentado na construção das janelas através da utilização da classe Frame, os botões necessitam de implementações, para que as mensagens das interações entre o usuário e o sistema sejam interpretadas e sejam atendidas, ou seja, dependem de tratadores ou escutadores de eventos, realizado pelos famosos listeners. Para que essa interação seja percebida pelo sistema, a classe Button deve implementar a interface ActionListener, no qual exige que seja definido apenas um método, o actionPerformed(), conforme é apresentado em nosso exemplo a seguir, onde alteramos novamente nosso exemplo em que criamos a janela e definimos uma legenda de texto. Assim, altere as linhas no método construtor, bem como crie o novo método conforme é apresentado. // FrameExemplo.java import java.awt.*; import java.awt.event.*; public class FrameExemplo extends Frame implements WindowListener, ActionListener{ // metodo construtor public FrameExemplo (){ super(“Titulo: Botão Exemplo”); Label texto = new Label(“Para sair aperte o botão!”); Button botao = new Button(“Sair”); setSize(150, 100); setLocation(100, 100); addWindowListener(this); setLayout(new FlowLayout()); botao.addActionListener(this); add(texto); add(botao); } //metodo listener public void actionPerformed(ActionEvent e) { System.exit(0); } ... } 18 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 1 • programação Neste exemplo, podemos notar que, assim como na janela, na qual definimos qual é o seu listener, que será o responsável por receber e tratar as mensagens, agindo sobre estas, no botão ocorre o mesmo, porém o método que realiza tal tarefa consiste no actionPerformed(), que recebe um evento de ação que é produzido pelos botões. Outro detalhe a ser percebido é a transferência do código para o construtor da classe, trazendo maior clareza do que a interface deve conter no momento de sua instanciação, facilitando a modularidade do sistema. Além disso, foi acrescentado o método setLayout() no qual foi atribuído o valor de uma nova instância da classe FlowLayout para centralizar os componentes na janela. Retornaremos a este assunto na nossa 3ª aula. Pensando sobre o assunto Uma vez que existem os listeners para escutar e receber as mensagens do sistema de que ocorreu alguma interação sobre os componentes, é possível identificar sobre qual componente a ação foi disparada; para tanto, existe o método getSource() que nos fornece tal informação. Podem ser criados diversos botões em uma aplicação e, uma boa prática de programação que, quando o método actionPerformed() se tornar grande e complexo é a realização de uma explosão do código em outros métodos que tratem isto de maneira mais clara. 1.3.4 Componente TextField Vamos ao nosso último componente desta aula. Assim como o Button, este é exaustivamente utilizado em programas que fazem uso de interfaces visuais: é o componente TextField. Através da classe TextField, obtemos uma caixa de texto, que possibilita a entrada de texto pelos usuários. Todo o conteúdo digitado dentro das caixas de texto é tratado como Strings dentro da aplicação, sendo que devem ser tratados após sua inserção conforme necessário. Assim como a Classe Button, a TextField também utiliza a interface ActionPerformed e, conseqüentemente, o método de mesmo nome para tratar entradas de dados. Porém, este só é acionado através da tecla “enter”. Para ações que devam ser executadas, ao digitar algum texto, deve ser utilizado o método listener addTextListener(TextListener) (DEITEL, 2005). Altere o método construtor de nossa classe FrameExemplo, conforme o quadro abaixo e execute-o. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 19 Aula 1 • programação // FrameExemplo.java import java.awt.*; import java.awt.event.*; public class FrameExemplo extends Frame implements WindowListener, ActionListener{ // metodo construtor public FrameExemplo (){ super(“Titulo: Botão Exemplo”); Label texto = new Label(“Para sair aperte o botão!”); Button botao = new Button(“Sair”); TextField caixaDeTexto = new TextField(“”, 30); setSize(250, 120); setLocation(300, 300); addWindowListener(this); setLayout(new FlowLayout()); botao.addActionListener(this); add(texto); add(caixaDeTexto); add(botao); } ... } Tanto o componente Label quanto o TextField podem ter seu conteúdo alterado, bem como recuperado pelos métodos setText() e getText(), respectivamente. Dessa maneira, finalizamos nossa 1ª aula. Façam as atividades para uma melhor fixação dos conceitos e componentes apresentados até aqui. Nos vemos na próxima aula. Saiba mais É mais que interessante, é de vital importância para que suas aplicações sejam bem sucedidas e que se tenha domínio sobre os métodos disponibilizados pela classe TextField. Para tanto, sugerimos a leitura do javadoc deste importante componente da programação visual Java. Síntese da aula Nesta aula, apresentamos os conceitos básicos relacionados à programação visual com a utilização da tecnologia Java, bem como alguns componentes e tratadores de eventos para uma maior interação entre usuários e sistema. Aprendemos como criar janelas utilizando a classe Frame, além de criar textos estáticos que não podem ser alterados diretamente pelos usuários, no caso as legendas através da classe Label. Ademais, foram apresentados os componentes Button e TextField para a criação de botões e a caixa de texto respectivamente. 20 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 1 • programação Atividades 1. A classe Frame possibilita que criemos janelas para aplicações visuais. Estas podem ter eventos vinculados a sua estrutura. Assim, qual é a interface responsável por fornecer os métodos de uma janela? 2. Devido ao conceito de portabilidade da linguagem Java e a JVM as aplicações visuais com a biblioteca AWT e Swing tem ganho espaço considerável no mercado. Assim, qual a principal vantagem conseguida com a construção de aplicações Java, levando em consideração o conceito de portabilidade? Comentário das atividades Na atividade 1, a principal vantagem apresentada pelas aplicações visuais em Java consiste em sua independência de plataforma graças aos conceito de portabilidade, fazendo com que, independente do sistema operacional, o mesmo botão será apresentado da mesma maneira em todas as plataformas. Já na questão 2, a interface responsável por definir os métodos de uma janela é a WindowListener, que fornece os métodos: windowClosing(), windowClosed(), windowIconified(), windowOpened(), windowDeiconified(), windowActivated(), windowDeactivated(). Referências DEITEL, Harvey M. Java: como programar. 6 ed. São Paulo: Pearson Prentice Hall, 2005. FILHO, Renato Rodrigues. Desenvolva aplicativos com Java 2. São Paulo: Érica, 2005. MANZANO, José Augusto Navarro Garcia; COSTA JR., Roberto Affonso da. Java 2: programação de computadores. São Paulo: Érica, 2006. THOMPSON, Marco Aurélio. Java 2 & banco de dados. São Paulo: Érica, 2002. Na próxima aula Veremos outros componentes para a construção de aplicações visuais utilizando a biblioteca AWT, que enriquecerão a interação com o usuário. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 21 Aula 1 • programação Anotações 22 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 2 Componentes visuais Objetivo Esperamos que, ao final desta aula, você seja capaz de: • c onhecer os componentes visuais básicos da biblioteca AWT relacionados a programação visual. Pré-requisitos É de fundamental importância que os conceitos apresentados na aula 1 tenham sido assimilados por você. Esse conhecimento é necessário, pois agora iremos nos aprofundar na utilização da tecnologia Java, para a crição de programas com outros componentes visuais que interagem com os apresentados em nossa 1a aula. Introdução Com a utilização das interfaces gráficas, conseguimos incorporar valor aos sistemas. Assim, quanto mais componentes forem disponibilizados, mais possibilidades existirão para criarmos aplicações que contribuam com a interação entre usuários e programas. A biblioteca AWT, assim como a Swing, disponibilizam diversos componentes. A programação visual Java é uma metodologia com um enfoque muito diferente aos usuais sustentados e encontrados no mercado, uma vez que estes não disponibilizam controle total sobre os eventos. Estes recursos fornecidos por essa metodologia dão suporte à construção de aplicações que aumentam o poder dos sistemas, além de fornecer subsídio para a solução de problemas pelo computador como uma atividade mais humanizada. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 23 Aula 2 • programação Assim como a própria linguagem de programação Java, a construção de aplicações com a utilização de aplicações visuais em Java é relativamente nova na concepção e implementação de sistemas de software. Os maiores objetivos desta nova metodologia consistem em aumentar a produtividade do programador, além de acelerar todo o processo de desenvolvimento com componentes prontos. Assim, iremos, nesta aula, continuar o trabalhalho com os componentes básicos mais importantes. 2.1 Componentes visuais Então vamos ao que interessa, pessoal! Agora, conheceremos outros componentes visuais, que colaboram com a construção de interfaces e aplicações mais ricas e que apresentam características para uma melhor interação entre usuário e sistemas. 2.1.1 Componente Panel Então, pessoal, empolgados com a programação visual? É claro que sim. É através da utilização de componentes visuais que conseguimos observar toda uma nova era dos computadores que buscam uma maior proximidade com o usuário. Para tanto, iremos, agora, conhecer o componente Panel, que consiste em um painel que, como os demais componentes apresentados até aqui, é um tipo de classe (DEITEL, 2005). Esta consiste em um tipo de container, ou seja, pode agregar a seu escopo outros componentes, inclusive outros painéis, assim como a classe Frame, uma vez que ambas são derivadas da classe Container. Com a utilização do componente Panel, é possível se obter uma maior versatilidade para a disposição de outros componentes gráficos nas interfaces criadas na aplicação (DEITEL, 2005). Sua utilização, juntamente com os gerenciadores de layouts, amplia as possibilidades de uso desta classe. Pessoal, é hora de colocarmos a mão na massa. Vamos criar uma nova janela para observar a combinação de todos os componentes vistos até o momento. 24 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 2 • programação //NovaJanela.java import java.awt.*; public class NovaJanela{ public static void main(String[] args) { Panel painelTopo = new Panel(); Panel painelDireita = new Panel(); Panel painelBaixo = new Panel(new FlowLayout(FlowLayout.LEFT)); Panel painelCentro = new Panel(new FlowLayout(FlowLayout.CENTER)); Panel painelEsquerda = new Panel(); Frame janela = new Frame(“Painel”); janela.setSize(100, 100); janela.setLocation(300, 300); painelTopo.setBackground(Color.RED); painelDireita.setBackground(Color.GREEN); painelBaixo.setBackground(Color.BLUE); painelCentro.setBackground(Color.CYAN); painelEsquerda.setBackground(Color.ORANGE); janela.add(painelTopo, BorderLayout.NORTH); janela.add(painelDireita, BorderLayout.EAST); janela.add(painelBaixo, BorderLayout.SOUTH); janela.add(painelCentro, BorderLayout.CENTER); janela.add(painelEsquerda, BorderLayout.WEST); janela.setVisible(true); } } Executando o exemplo anterior, ficam claras as possibilidades de disposição dos painéis em uma janela, bem como dos componentes que podem estar contidos dentro destes, notando a distinção dos painéis por meio das diferentes cores. Deve ser observado que os painéis são agregados ao container de componentes, no caso a janela, por meio do método add(). Porém, um maior detalhamento será realizado quanto à utilização do gerenciamento de layout, na 3ª aula. Nossos exemplos de agora em diante sempre farão uso dos painéis, sendo utilizados como container para os nossos componentes. Assim, vamos ao próximo componente da biblioteca AWT. Pensando sobre o assunto Assim como já mencionado para a classe Frame, uma vez não definido o layout para os componentes instanciados do tipo Panel, estes automaticamente assumirão um layout default, definido pela própria maquina virtual. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 25 Aula 2 • programação 2.1.2 Componente TextArea Na aula anterior, foi apresentado o componente TextField que apresenta uma caixa de texto de linha única. Agora, iremos conhecer outro de caixa de texto, porém este componente que muito contribui para as diversas aplicações que podem ser desenvolvidas, permite a criação de uma área que aceite a entrada e edição de textos de múltiplas linhas. O componente TextArea assim como o TextField possuí os mesmos métodos, uma vez que são derivados da mesma classe pai a TextComponent, porém esta ainda disponibiliza alguns métodos para o manuseio de suas particularidades, como linhas, colunas ou mesmo a barra de rolagem (FLANAGAN, 2006). Assim, vejamos o exemplo abaixo com a utilização deste componente visual. // NovaJanela.java import java.awt.*; import java.awt.event.*; public class NovaJanela extends Frame implements ActionListener { private TextArea multTexto; private Button botao; private TextField texto; public static void main(String args[]) { NovaJanela f = new NovaJanela(); f.addWindowListener(new WindowAction()); f.setVisible(true); } public NovaJanela() { super(“TextArea”); setSize(300, 300); texto = new TextField(20); texto.addActionListener(this); botao = new Button(“Inserir”); botao.addActionListener(this); multTexto = new TextArea(); Panel p = new Panel(); p.setBackground(SystemColor.control); p.setLayout(new FlowLayout()); p.add(texto); p.add(botao); add(p, BorderLayout.NORTH); add(multTexto, BorderLayout.CENTER); } public void actionPerformed(ActionEvent e) { if (e.getSource()==botao) { multTexto.append(texto.getText()); } texto.setText(“”); } } 26 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 2 • programação Neste exemplo, criamos um janela com três componentes, um TextField, um Button e um TextArea. Porém, agora, como apresentado anteriormente para o componente Panel, começamos a dispor nossos elementos utilizando os gerenciadores de layout. Um detalhe que deve ser observado neste exemplo consiste na alteração de nosso método actionPerfomed(), para realização de operações sobre o componente TextArea. A classe TextArea disponibiliza operações sobre textos como copiar e colar, sendo que tais operações podem ser ativadas e desativadas. Outro detalhe consiste na utilização dos métodos append() e insert() para a inserção de texto no componente. Assim, finalizamos esta seção e vamos conhecer agora outro objeto para programação visual. 2.1.3 Componente List Nesta seção, será apresentado o componente List que permite a exibição de uma lista de itens. Este possui diversas características e comportamentos, sendo que os itens desta lista não podem ser editados diretamente pelos usuários, além de ser sensível à seleção, ou seja, podem ser acrescentadas ações ao evento de seleção sobre os itens da lista através da utilização das interfaces ItemListener e ActionListener, que são acionados quando um objeto é selecionado e quando ocorre um duplo clique sobre algum item respectivamente (DEITEL, 2005). Para criarmos nosso próximo exemplo de utilização do componente List, substitua apenas as linhas referentes a instanciação do objeto TextArea do exemplo da seção anterior pelo código apresentado a seguir. // NovaJanela.java import java.awt.*; import java.awt.event.*; public class NovaJanela extends Frame implements ActionListener { private List lista; private Button botao; private TextField texto; ... public NovaJanela() { ... lista = new List(); ... add(lista, BorderLayout.CENTER); } public void actionPerformed(ActionEvent e) { if (e.getSource()==botao) { lista.add(texto.getText()); } texto.setText(“”); } } Univali/UNITINS • superior de tecnologia • 3º PERÍODO 27 Aula 2 • programação Como resultado, teremos uma janela muito semelhante à apresentada no exemplo da seção anterior, mas, observando seu funcionamento, pode ser verificado que, ao invés de um texto contínuo que pode ser digitado ou mesmo alterado, temos uma lista de itens. Assim como realizado na classe Frame e na Panel, para adicionarmos texto a um objeto List é utilizado o método add(), conforme demonstrado no exemplo anterior. Assim como nos demais componentes, sugerimos a leitura do javadoc para enriquecer suas interfaces. Saiba mais Javadoc consiste na documentação disponibilizada juntamente com cada classe, detalhando o funcionamento e as funcionalidades de atributos e métodos. Desta forma, consiste em uma boa prática de programação, a disponibilização dos javadoc para todas as classes desenvolvidas. A própria máquina virtual disponibiliza um recurso para a geração automática do javadoc. Para tanto, sugerimos a leitura de material relacionado a este assunto. 2.1.4 Componente Choice Outro componente muito utilizado em aplicações gráficas com a utilização do pacote AWT, consiste na Choice, este por sua vez implementa uma lista de itens onde somente um item pode ser exibido. Este consiste no famoso combobox das demais linguagens de programação gráficas. A seleção dos itens que compõem um objeto Choice é disponibilizada para que apenas um destes seja selecionado, não havendo seleção múltipla. Para qualquer ação que queira ser desempenhada sobre os eventos deste componente, devem ser implementados os métodos referentes à interface ItemListener, assim como no objeto List apresentado na seção anterior. Então, utilizando os conhecimentos adquiridos até aqui, construa uma janela por meio da utilização da classe Frame, e crie um painel para receber seus componentes (DEITEL, 2005). Acrescente o código abaixo nos locais indicados nos comentários e execute o programa para visualização do componente Choice. 28 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 2 • programação //Crie sua janela e seu painel conforme demonstrado nos exemplos anteriores import java.awt.*; import java.awt.event.*; public class Janela extends Frame implements ItemListener { private Choice combobox; ... //Transcreva o código abaixo no metodo construtor combobox = new Choice(); combobox.add(“Java”); combobox.add(“Delphi”); combobox.add(“C++ Builder”); combobox.addItemListener(this); ... //Crie o método que reage ao evento public void itemStateChanged(ItemEvent e) { if (e.getSource()==combobox) { texto.setText(“Selecionado:”+combobox.getSelectedItem()); } ... } Assim como nos demais casos apresentados até o momento, é utilizado o método add(), para que sejam acrescentados itens ao componente Choice. O método que trata os eventos que ocorrem sobre um objeto Choice, consiste no itemStateChanged(), conforme pode ser observado no exemplo anterior. Sugerimos que sejam realizadas alterações, bem como a criação de novas interfaces para a fixação dos conhecimentos vinculados a este componente. 2.1.5 Componentes Checkbox Vamos ao próximo componente da biblioteca AWT: uma instância da classe Checkbox cria graficamente, nos programas visuais, caixas de opção. Este componente é geralmente utilizado para representar que uma opção deve ser escolhida, sendo verdadeira, quando o componente está marcado, ou falsa quando estiver desmarcado. Todos os objetos criados por meio da utilização da classe Checkbox, da mesma forma como as classes List e Choice, fazem uso da interface ItemListener para tratar eventos. Um detalhe interessante deste componente consiste no fato de mesclar, além de uma caixa de seleção, um componente Label para descrição textual deste, conforme é apresentado a seguir. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 29 Aula 2 • programação //Classe JanelaCheck import java.awt.*; public class JanelaCheck extends Frame implements ItemListener { private Checkbox checkEmail; private Checkbox checkCorreio; private Label texto; public JanelaCheck() { super(“Checkbox”); setSize(800, 200); texto = new Label(“Indique os meios de envio:”); Panel p = new Panel(); checkCorreio = new Checkbox(“Correios”); checkEmail = new Checkbox(“Email”); checkCorreio.addItemListener(this); checkEmail.addItemListener(this); p.setLayout(new FlowLayout()); p.add(texto); p.add(checkCorreio); p.add(checkEmail); add(p, BorderLayout.NORTH); } public void itemStateChanged(ItemEvent e) { if (checkCorreio.getState()) { texto.setText(“Selecionado:”+checkCorreio.getLabel()); } if (checkEmail.getState()&& checkCorreio.getState()) { texto.setText(“Selecionado:”+checkEmail.getLabel()+” e “ +checkCorreio.getLabel()); } if (checkEmail.getState()) { texto.setText(“Selecionado:”+checkEmail.getLabel()); } } public static void main(String args[]) { JanelaCheck janela = new JanelaCheck(); janela.addWindowListener(new WindowAction()); janela.setVisible(true); } } Diversos Checkboxs podem ser criados, sem que exista referência entre estes componentes; para tanto, quando isto é necessário, utilizamos uma instância da classe CheckboxGroup para que seja realizado um agrupamento de componentes Checkbox. 30 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 2 • programação 2.1.6 Componente CheckboxGroup Conforme mencionado, o componente Checkboxgroup realiza o agrupamento de diversos objetos da classe Checkbox, tornando-se um único componente visual no qual seja capaz de selecionar apenas um item dentro deste componente. Porém, vale ressaltar que o componente Checkboxgroup não apresenta nenhuma interface, apenas faz vinculação entre os itens criados com o Checkbox, e com isto fazendo com que uma única opção seja escolhida. No caso, este tipo de componente visual é mais conhecido como radiobuttons em outras linguagens de programação, sendo que associados estes, disponibilizam que apenas um item seja selecionado, garantindo uma escolha única (DEITEL, 2005). Igualmente aos outros componentes da biblioteca AWT que trabalham com itens, além do fato deste ser composto por um ou mais Checkbox para que os eventos sejam tratados neste, deve ser implementada a interface para tais. Alterando o exemplo anterior, para que este só permita apenas uma opção, apenas crie uma instância do componente Checkboxgroup e nos construtores de cada objeto Checkbox criado, associe ao grupo, conforme é apresentado abaixo. //Classe JanelaCheck import java.awt.*; public class JanelaCheck extends Frame implements ItemListener { private Checkbox checkEmail; private Checkbox checkCorreio; private CheckboxGroup grupo; private Label texto; public JanelaCheck() { ... grupo = new CheckboxGroup(); checkCorreio = new Checkbox(“Correios”,grupo,true); checkEmail = new Checkbox(“Email”,grupo,false); ... } ... } O último parâmetro passado nos construtores dos objetos Checkbox consiste na definição de qual será apresentado como verdadeiro. Certo, pessoal? Conforme pode ser observado no exemplo anterior, isso torna esse componente uma forma de disponibilizar diversas opções, porém garante que apenas uma seja a escolhida. Agora iremos finalizar nossa 2ª aula com a apresentação de um importantíssimo componente, senão o mais importante de todos, devido à sua estrutura e recurso. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 31 Aula 2 • programação 2.1.7 Componentes para criação de Menus Vamos conhecer, agora, diversos componentes que são necessários para a criação de menus nas aplicações gráficas, fazendo com que as aplicações fiquem mais profissionais. A AWT disponibiliza suporte para a criação das famosas barras de menu ou, como também são conhecidos, menus suspensos. Para a criação de menus suspensos utilizando esta biblioteca é necessária a utilização de três classes: MenuBar, Menu e MenuItem (FILHO, 2005). Este três componentes são hierarquicamente organizados, sendo que um deve conter o outro. Inicialmente, o componente MenuBar cria uma barra de menu, para que seja acrescentado o menu, e esta barra deve sempre ser associada ao objeto Frame, no caso a janela. O componente Menu conforme mencionado, deve ser atribuído à barra de menu. E, finalizando nossa organização, as instâncias da classe MenuItem devem ser agregados ao menu. Desta forma, conseguiremos construir menus, aumentando o poder de interação em nossos sistemas, além de uma melhor disposição das funcionalidades. Vamos a um exemplo no qual criamos um menu, então transcreva o código abaixo e o execute. //JanelaMenu.java import java.awt.*; import java.awt.event.*; public class JanelaMenu extends Frame implements ActionListener, WindowListener{ //metodo construtor public JanelaMenu(){ super(“Menus”); MenuBar barra = new MenuBar(); Menu menuArquivo = new Menu(“Arquivo”); Menu menuSobre = new Menu(“Sobre”); MenuItem itemNovo = new MenuItem(“Novo”); MenuItem itemSair; itemSair = new MenuItem(“Sair”, new MenuShortcut(KeyEvent.VK_R)); MenuItem itemAjuda = new MenuItem(“Ajuda”); //Adicionando eventos aos componentes itemSair.addActionListener(this); itemNovo.addActionListener(this); addWindowListener(this); //Agregando os itens ao menu e a barra menuArquivo.add(itemNovo); menuArquivo.add(itemSair); menuSobre.add(itemAjuda); barra.add(menuArquivo); barra.add(menuSobre); setMenuBar(barra); setSize(400, 400); } 32 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 2 • programação //metodo executável public static void main(String[] args) { JanelaMenu janela = new JanelaMenu(); janela.setVisible(true); } //métodos listeners public void windowClosing(WindowEvent e){ System.exit(0); } ... public void actionPerformed(ActionEvent e) { if (e.getSource() instanceof MenuItem) { MenuItem item = (MenuItem) e.getSource(); if(item.getLabel().equals(“Sair”)){ System.exit(0); } if(item.getLabel().equals(“Novo”)){ Frame novaJanela = new Frame(); novaJanela.setVisible(true); } } } } Certo, pessoal? Vamos, agora, entender o que foi realizado no exemplo anterior. Inicialmente, da mesma maneira como nos outros exemplos, criamos nossa classe, sendo que esta deriva da classe Frame, com isto explicitando que estamos criando uma nova janela. Continuando, temos o método construtor que é o responsável por inicializar todos os componentes que farão parte de nossa interface visual. Até aqui, nenhum segredo, pessoal. Tudo acontece da mesma maneira como nos exemplos das outras seções, ou mesmo aula. O único detalhe a ser mencionado, quanto ao conteúdo do método construtor, consiste na instanciação dos objetos que compõem um menu, ou seja, componentes do tipo MenuBar, Menu e MenuItem. Note o agrupamento hierárquico que é realizado, no qual um menu contém vários itens, e uma barra de menu contém diversos menus, sendo que esta barra é associada a nossa janela, conforme é destacado no quadro abaixo. ... //Agregando os itens ao menu e a barra menuArquivo.add(itemNovo); menuArquivo.add(itemSair); menuSobre.add(itemAjuda); barra.add(menuArquivo); barra.add(menuSobre); setMenuBar(barra); ... Univali/UNITINS • superior de tecnologia • 3º PERÍODO 33 Aula 2 • programação Após isto, temos nosso método executável main, no qual é instanciado um objeto de nossa classe JanelaMenu. Este por derivar da classe Frame, conforme mencionado, é uma janela. Com isto, finalizando, são criados os métodos exigidos pelas interfaces que nossa classe implementa a ActionListener e WindowListener. Porém, note que no método actionPerformed() estamos tratando o evento de maneira diferente ao que vínhamos trabalhando. Desta vez, mencionamos que a fonte de nosso evento consiste em um componente do tipo MenuItem. Com tal tratamento por meio do comando instaceof conseguimos lidar com todos os atributos e métodos que venham a ser necessários. A partir deste ponto somente verificamos qual dos itens foi invocado para reagir a interação. ... public void actionPerformed(ActionEvent e) { if (e.getSource() instanceof MenuItem) { MenuItem item = (MenuItem) e.getSource(); if(item.getLabel().equals(“Sair”)){ System.exit(0); } if(item.getLabel().equals(“Novo”)){ Frame novaJanela = new Frame(); novaJanela.setVisible(true); } } } ... Outra característica que enriquecerá as aplicações com menu consiste na utilização de teclas de atalhos para acelerar o processo de acesso às funcionalidades do sistema definidas nos itens. Um exemplo desta possibilidade está disponível em nosso exemplo completo, apresentado no início desta seção, com a utilização do método construtor para a definição deste, conforme é apresentado no quadro logo a seguir, por meio da classe MenuShortcut(). ... new MenuItem(“Sair”, new MenuShortcut(KeyEvent.VK_R)); ... Muito bem, pessoal, assim finalizamos nossa 2ª aula e também a apresentação dos componentes gráficos para a criação de programas com interfaces visuais, utilizando a biblioteca AWT. Esperamos que vocês tenham tirado o máximo de proveito, desta forma façam todos os exercícios. 34 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 2 • programação Síntese da aula Nesta aula, foram apresentados os principais componentes da programação visual Java como, TextArea, Choice, List e Menu, utilizando a biblioteca AWT. Além disto, foram vistos conceitos e classes necessárias para um melhor entendimento de tais componentes, uma vez que, para utilização desses componentes, foi necessário que detalhes como layout e tratadores de eventos fossem incorporados a estes. Atividades 1. Qual o gerenciador default do compenente Panel? 2. Os menus auxiliam na organização e acionamento das funcionalidades do sistema. Para tanto, usuários mais avançados podem fazer uso de técnicas que acelerem o processo de acesso às fucionalidades. Dentre estas técnicas, podemos destacar as teclas de atalho. Assim como são definidas as teclas de atalhos em um menu? Comentário das atividades Na atividade 1, como mencionado em nossa aula, o gerencidor de layout default consiste no BorderLayout, que define as regiões: Norte, Sul, Leste, Oeste e Centro em uma janela para que sejam adicionados outros compoentes. Já na atividade 2, as teclas de atalho podem ser definidas a um menu com a utilização do componente MenuShortcut(), que deve ser definido no momento da instanciação dos itens do menu, além de definidas quais serão as teclas utilizadas para acionar cada item. Referências DEITEL, Harvey M. Java: como programar. 6 ed. São Paulo: Pearson Prentice Hall, 2005. FILHO, Renato Rodrigues. Desenvolva aplicativos com Java 2. São Paulo: Érica, 2005. FLANAGAN, David. Java: o guia essencial. 5. ed. Porto Alegre. Bookman, 2006. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 35 Aula 2 • programação Na próxima aula Continuaremos a relembrar e explorar mais a fundo conceitos vinculados ao gerenciamento de layout, bem como o tratamento de eventos para os componentes. Anotações 36 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 3 Gerenciadores de layout e Tratadores de evento Objetivos Esperamos que, ao final desta aula, você seja capaz de: • relembrar e compreender conceitos relacionados aos gerenciadores de layout para aplicações visuais e os tratadores de eventos. Pré-requisitos É de fundamental importância, para um melhor desenvolvimento e entendimento desta aula, que você já tenha fixado os conceitos expostos nas aulas 1 e 2. É importante também conhecer os componentes da biblioteca AWT, para a definição de uma interface mais amigável através da disposição dos componentes, bem como as interfaces necessárias para a implementação dos tratadores de evento. Introdução No desenvolvimento de aplicações gráficas, interfaces mais amigáveis proporcionam uma melhor aceitação por parte dos usuários, uma vez que, além dos aspectos estéticos, uma melhor organização dos componentes visuais de maneira mais eficiente auxilia a reduzir dificuldades de entendimento, localização de componentes ou mesmo agilizam os trabalhos para os usuários mais avançados, com a utilização de teclas de atalho definidas junto ao sistema. Além disso, uma interface amigável não garantirá o sucesso do sistema se este não desempenhar suas funções da maneira correta, reagindo a ações dos usuários. Desta forma, nesta aula, iremos rever conceitos relacionados aos tratadores de eventos, porém desta vez de maneira isolada, sendo o ponto central de nosso estudo, onde nos atentaremos a conhecer as interfaces que podem ser utilizadas para o tratamento dos principais eventos. Então, pessoal, uma boa aula e tentem aproveitar ao máximo. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 37 Aula 3 • programação 3.1 Gerenciamento de Layouts Como visto nas aulas anteriores, quando criamos uma interface em Java podemos utilizar componentes no qual devem ser incorporados a outros componentes, conforme visto, containers Frame e o Panel. Porém, estes funcionam de maneira diferente nas demais linguagens de programação quanto à definição de posições na janela, no qual podem ser especificadas ecoordenadas para sua definição. A linguagem Java fornece os gerenciadores de layout, responsáveis por, de forma simples, dispor os componentes na interface gráfica. Devido ao fato de tentar se obter o máximo do conceito de portabilidade, criou-se o conceito de gerenciadores de layout, para que, qualquer que seja o sistema operacional que esteja executando, essa aplicação seja interpretada da mesma forma, evitando surpresas quanto a disposição dos elementos na janela (DEITEL, 2005). Como visto na disciplina anterior, e até mesmo com exemplos práticos nas aulas desta aula, os objetos podem ser dispostos dentro de janelas e painéis, sendo que estes podem assumir posições relativas em uma janela, tudo definido pelos gerenciadores de layout. Os gerenciadores de layout são classes especiais que realizam a implementação de interfaces, determinando como os componentes presentes em um container são ordenados e posicionados. Desta forma, podem ser definidos gerenciadores para os painéis que irão compor uma determinada janela, bem como definidos os gerenciadores para os componentes que serão agregados aos painéis. A biblioteca AWT disponibiliza alguns gerenciadores de layout, sendo eles: FlowLayout, GridLayout, BorderLayout, CardLayout e GridBagLayout (DEITEL, 2005). A seguir iniciaremos uma maior explanação dessas classes. 3.1.1 Gerenciador FlowLayout Vamos iniciar esta seção, relembrando os exercícios feitos nas seções e aulas anteriores, então sugerimos uma rápida observação sobre eles para então percebemos a utilização do gerenciador FlowLayout. Segundo Deitel (2005), o gerenciador FlowLayout consiste no mais simples dos gerenciadores, padrão para os applets e painéis. Neste tipo de gerenciador, todos os componentes são dispostos da esquerda para a direita. Ele obedece a ordem como os objetos são adicionados ao contai- 38 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 3 • programação ner, sendo que os componentes são apresentados em uma mesma linha até que não exista mais espaço nela, isto obedecendo ao tamanho do container, criando-se uma nova linha logo abaixo para a disposição dos outros componentes. Certo, pessoal? Vamos a mais um exemplo para que sejam apresentadas a disposição dos componentes por meio da utilização do gerenciador FlowLayout. // GerenciadorLayout.java import java.awt.*; import java.awt.event.*; public class GerenciadorLayout extends Frame { // método construtor public GerenciadorLayout() { super(“Gerenciador Layout”); setSize(200, 115); setLayout(new FlowLayout()); for (int i=1; i<7; i++) add(new TextField(“Texto “+i)); } // método executavel public static void main(String args[]) { GerenciadorLayout gerente = new GerenciadorLayout(); EventosWindows evt = new EventosWindows(); gerente.addWindowListener(evt); gerente.setVisible(true); } } class EventosWindows implements WindowListener{ public void windowClosing(WindowEvent e){ System.exit(0); } public void windowClosed(WindowEvent e){} public void windowIconified(WindowEvent e){} public void windowOpened(WindowEvent e){} public void windowDeiconified(WindowEvent e){} public void windowActivated(WindowEvent e){} public void windowDeactivated(WindowEvent e){} } Como pôde ser observado no exemplo anterior, cria-se uma seqüência de componentes, que, conforme mencionado, é realizada uma quebra de linha a cada momento em que não existe mais espaço para novos objetos na linha. Outro tipo de gerenciador muito utilizado na construção de aplicações gráficas consiste no GridLayout, então vamos a ele. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 39 Aula 3 • programação Pensando sobre o assunto Como mencionado na aula anterior, todos os tipos de containers da linguagem de programação Java derivam da classe Container, sendo que esta disponibiliza o método setLayout() para a definição do gerenciador de um componente do tipo container. Utilize este método sempre que necessário para a redefinição da disposição dos objetos em sua janela. 3.1.2 Gerenciador GridLayout Conforme mencionado, outro gerenciador de layout trata-se da classe GridLayout. Esse gerenciador permite que os componentes sejam arrumados em uma grade formada por células de igual tamanho até que toda a área do container, no caso o Frame ou o Panel, seja ocupada (DEITEL, 2005). Assim como em vetores, podem ser especificadas as quantidades de linhas e colunas, sendo que todos os componentes adicionados aos containers ocupam todo o espaço da celula do qual fazem parte, sendo que alterações quanto à sua dimensão são repassadas, automaticamente, para as células e obviamente para os componentes que as ocupam. Com isto, vamos a um exemplo para que seja observada a disposição dos componentes visuais utilizando este tipo de gerenciador. Para tanto, altere apenas a linha que é responsável pela definição do layout no método construtor do exemplo anterior, substituindo pelo código no quadro a seguir e execute o programa. // GerenciadorLayout.java import java.awt.*; import java.awt.event.*; public class GerenciadorLayout extends Frame{ // método construtor public GerenciadorLayout(){ ... setLayout(new GridLayout(2,3)); ... } // método executavel public static void main(String args[]){ ... } } class EventosWindows implements WindowListener{ ... } 40 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 3 • programação Se tudo ocorreu como o esperado, provavelmente você deve ter percebido a mudança na disposição dos objetos na tela de seu programa. Isto tudo com apenas a redefinição do gerenciador de layout. A linguagem Java ainda dispõe do gerenciador BorderLayout, CardLayout e GridBagLayout. 3.1.3 Gerenciador BorderLayout Assim como em uma bússola, o gerenciador de layout BorderLayout executa a disposição de componentes em um container dividido em cinco regiões, sendo elas: east, west, north, south e center, no caso direita, esquerda, norte, sul e centro, respectivamente. Este, por sua vez, é o gerenciador padrão para o container Frame da API (Application Program Interface) AWT, bem como JFrame do pacote Swing, conforme foi visto na aula anterior (DEITEL, 2005). Um detalhe interessante, e que foge do que foi visto até agora para os demais gerenciadores já apresentados, consiste no fato de que a ordem como os componentes são adicionados não afetará o resultado final da tela: eles devem ser adicionados explicitamente a uma região fixa do gerenciador, sendo que uma vez adicionado um componente, ele ocupará toda a região. Tudo isso foi demonstrado no exemplo utilizado para a apresentação do container criado por meio da utilização da classe Panel, na aula 2 na seção 2.1.1. Desta forma, revisem o exemplo mencionado. Saiba mais Conforme mencionado, cada região definida pelo gerenciador de layout só pode ser ocupada por apenas um componente, sendo que este é redimensionado ocupando-a toda. Assim, uma vez que dois ou mais elementos forem inseridos na mesma região um sobrescreverá o outro, sendo que o primeiro não estará disponível para visualização ou mesmo acesso (DEITEL, 2005). 3.1.4 CardLayout A partir desta seção, trabalharemos com gerenciadores de layout diferenciados frente aos demais apresentados. Embora bem mais flexíveis, estes são muitas vezes ineficientes para resolver alguns problemas. No caso, a classe CardLayoout é responsável por gerenciar um layout mais incrementado, que trata os componentes presentes no container como uma pilha de cartas (FILHO, 2005). Univali/UNITINS • superior de tecnologia • 3º PERÍODO 41 Aula 3 • programação Este gerenciador disponibiliza formas de acesso aos diversos componentes que podem ser “empilhados” no container, sendo que este permite a exibição do primeiro componente ou mesmo o último, ficando livre a navegação entre estes (FILHO, 2005). Desta forma, é possível navegarmos em diversos componentes Panel ou mesmo Frame, sendo que estes podem conter diversos outros tipos de componentes, conforme demonstrado nas aulas anteriores. Assim, conseguimos obter o aspecto de aplicações com diversas janelas, sendo que estas podem ser acessadas a qualquer momento por componentes como os Menus. Isto, porém, é mais trabalhoso, uma vez que exige que mais código seja necessário, mas os resultados compensam todo o trabalho. O exemplo a seguir demonstra a utilização deste gerenciador visual. Alguns pontos do código foram suprimidos, pois não sofrem alteração do último exemplo apresentado, então os reutilize. // GerenciadorLayout.java import java.awt.*; import java.awt.event.*; public class GerenciadorLayout extends Frame implements ActionListener { private Panel windows; private Button anterior, proximo; // método executável, reutilize o código do outro exemplo public static void main(String args[]) { ... } // método construtor public GerenciadorLayout() { super(“Janelas”); setSize(250, 100); // Painel Lateral de Controle Panel lateral = new Panel(); lateral.setBackground(SystemColor.control); Panel p2 = new Panel(); p2.setBackground(SystemColor.control); p2.setLayout(new GridLayout(2, 1)); p2.add(anterior = new Button(“Anterior”)); anterior.addActionListener(this); p2.add(proximo = new Button(“Proximo”)); proximo.addActionListener(this); lateral.add(p2); add(“East”, lateral); Panel painel1 = new Panel(); painel1.add(new Label(“Segundo Painel”)); painel1.add(anterior); 42 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 3 • programação // Painel Múltiplo windows = new Panel(); windows.setLayout(new CardLayout()); windows.add(new Label(“Primeiro Painel”), “Janela2”); windows.add(painel1, “Janela2”); add(“Center”, windows); } public void actionPerformed(ActionEvent e) { CardLayout janelas = (CardLayout) windows.getLayout(); if (e.getSource()==anterior) { janelas.previous(windows); } if (e.getSource()==proximo) { janelas.next(windows); } } } class EventosJanela implements WindowListener{ ... } Note que, neste exemplo, consegue-se criar diversos painéis, construíndo o efeito de que existem diversas janelas que são executadas ao clicar sobre os botões. Isto tudo é possível devido às características da classe CardLayout, sendo que tais funcionalidades o diferenciam dos demais. Nosso último gerenciador consiste no mais complexo, mas também o que mais dispõe de funcionalidades dentre os gerenciadores. 3.1.5 GridBagLayout Finalizando os gerenciadores de layout, apresentaremos o mais flexível dentre todos os apresentados, o GridBagLayout. Assim como o CardLayout, devido a esta flexibilidade, este torna-se o mais complexo de todos os gerenciadores (FILHO, 2005). O GridBagLayout, por sua vez, permite, assim como o GridLayout, definir a posição de componentes em uma tabela com linhas e colunas. Porém, diferentemente do gerenciador GridLayout, este é bem mais tratável, permitindo que os componentes sejam adicionados em qualquer ordem, além de poder variar o tamanho das células, sendo que um componente pode ocupar mais de uma linha ou coluna (FILHO, 2005). Univali/UNITINS • superior de tecnologia • 3º PERÍODO 43 Aula 3 • programação Este gerenciador é mais utilizado por programas que utilizam a API Swing, porém este também pode ser utilizada pelos componentes AWT. A utilização deste gerenciador consiste na definição de um objeto para a caracterização, através da classe GridBagConstraints, na qual podem ser definidas a quantidade de células, a posição, tamanho e, por exemplo, se o componente deve ocupar todo o espaço da celular. Vamos a um pequeno exemplo para fixação. // ExemploGridBag.java import java.awt.*; import javax.swing.*; public class ExemploGridBag extends JFrame { public ExemploGridBag { super(“Exemplo1”); this.setDefaultCloseOperation(EXIT_ON_CLOSE); Container c = this.getContentPane(); GridBagConstraints cons = new GridBagConstraints(); c.setLayout(new GridBagLayout()); c.add(new Button(“Esquerda”), cons); c.add(new Button(“Direita”), cons); this.setSize(600,600); } public static void main(String[] args ) { ExemploGridBag exe = new ExemploGridBag(); exe.setVisible(true); } } Conforme mencionado, criado um objeto da classe GridBagConstraints que será o responsável pela redefinição das características da interface como os componentes devem ser apresentados, estes devem ser associados à janela através do método add(). Assim finalizamos nossa seção de gerenciamento de layout e agora iremos trabalhar mais a fundo com os tratadores de eventos. Saiba mais Para uma melhor utilização da classe GridBagConstraints, sugerimos leituras complementares para que sejam conhecidas todas as características que podem ser manuseadas através de uma instância desta classe, enriquecendo suas interfaces através do gerenciamento de layout flexível com a classe GridBagLayout. 44 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 3 • programação 3.2 Tratadores de eventos Assim como vimos em diversos exemplos até aqui, os eventos ocorrem quando existe uma interação dos usuários por meio de operações com o mouse (pressionar um botão ou arrastar) ou através do teclado (pressionando alguma tecla). O modelo de eventos da AWT é o responsável por este serviço, identificando os objetos em que ocorreram as interações, os sources e os que atuarão como receptores, escutando as mensagens do sistema operacional mais conhecidos como listeners. Neste modelo de eventos, mais especificamente os objetos receptores são os responsáveis por além de receber, processar os eventos reagindo a interação realizada pelos usuários, chamando determinadas tarefas (DEITEL, 2005). Os eventos são objetos de uma classe, enquanto os listeners são interfaces que implementam os métodos que tratam estes eventos. Usualmente, cada tipo de componente pode disparar certos tipos de eventos que podem ser “escutados” por mais de um listener, conforme é apresentado na Tabela 1 (FLANAGAN, 2006). Evento Interface ou Adaptador Métodos ActionEvent ActionListener actionPerformed AdjustmentEvent AdjustmentListener adjustmentValueChanged ComponentEvent ComponentListener ComponentAdapter componentMoved componentHidden componentResized ContainerEvent ContainerListener ContainerAdapter componentAdded componentRemoved FocusEvent FocusListener FocusAdapter focusGained focusLost ItemEvent ItemListener itemStateChanged KeyEvent KeyListener KeyAdapter keyPressed keyReleased keyTyped MouseEvent MouseListener MouseAdapter MouseMotionListener MouseMotionAdapter mousePressed mouseReleased mouseEntered mouseExited mouseClicked mouseDragged mouseMoved Univali/UNITINS • superior de tecnologia • 3º PERÍODO 45 Aula 3 • programação TextEvent WindowEvent TextListener WindowListener WindowAdapter textValueChanged windowClosing windowOpened windowIconified windowDeiconified windowClosed windowActivated windowDeactivated Alguns destes eventos, interfaces e métodos foram implementados nos exemplos desta disciplina. Assim, vamos finalizar nossa 3ª aula falando de uma maneira mais simples de tratar os listeners. Como ficou claro no decorrer desta disciplina, ao implementarmos uma interface todos os métodos nela declarados deverão ser redefinidos na classe que a implementa. Conforme pôde ser observado nos diversos exemplos que fizemos até o momento, ou mesmo na Tabela 1, muitas vezes somente um dos métodos nos interessa. Por exemplo, isto acontece quando uma classe implementa a interface WindowListener, sendo que assim é necessário que se declarem todos os sete métodos que estão definidos na interface. Mas se quisermos tratar somente um determinado evento, quando este ocorre ignorando o restante, sem precisar ficar reescrevendo os métodos que são desnecessários, como podemos agir? Para podermos fazer isso, apenas redefinimos somente o método que se necessita, ignorando os demais, para tanto utilizamos as classes adaptadoras, que também foram apresentadas na Tabela 1, juntamente com as interfaces. As classes adaptadoras são classes que já implementam as interfaces listener para os eventos, redefinindo todos os seus métodos (DEITEL, 2005). Porém, os métodos definidos na classe adaptadora não possuem corpo ou funcionalidade, fazendo com isto que tenhamos que utilizar o processo de herança, criando uma subclasse das classes adaptadoras e nela redefinirmos ou implementarmos somente o método que nos interessa. Desta forma, vamos a um exemplo que demonstra tudo o que mencionamos: para fechar uma das janelas de nossos exemplos, era necessário declarar, nada mais, nada menos, que sete métodos da interface WindowListener. 46 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 3 • programação // GerenciadorLayout.java import java.awt.*; import java.awt.event.*; public class GerenciadorLayout extends Frame{ // método construtor public GerenciadorLayout(){ ... setLayout(new GridLayout(2,3)); ... } // método executavel public static void main(String args[]){ ... } } class EventosWindows extends WindowAdapter{ public void windowClosing(WindowEvent e){ System.exit(0); } } Note que apenas alteramos nossa classe EventosWindows e, considerando o código apresentado e qualquer outro exemplo, fica claro que as classes adaptadoras reduzem, consideravelmente, o trabalho, sendo apenas necessário que sejam implementados os métodos listerner que realmente serão necessários. Isto não é possível quando temos uma classe que já herda de alguma outra classe. Bom, pessoal, assim chega ao fim nossa 3ª aula, espero que todos tenham conseguido sanar qualquer dúvida sobre os conceitos aqui tratados, de suma importância para aplicações visuais. Síntese da aula Nesta aula, foram apresentados os conceitos relacionados aos métodos construtores, responsáveis por inicializar o espaço de memória de uma instância de uma classe, bem como realizar operações e inicializar atributos e variáveis com valores, tornando possível o perfeito funcionamento da funcionalidades da instância da classe. Da mesma maneira que existem os métodos construtores, existem os métodos destrutores, sendo responsáveis por colocar ordem na casa, liberando espaços de memória e finalizando operações da instância. Porém, diferentemente das outras linguagens de programação, em Java não é necessário se preocupar com a liberação do espaço de memória: Java possui um coletor de lixo automático, que se responsabiliza pela liberação de memória para o bom funcionamento do programa. Finalizando, apresentamos os conceitos vinculados ao encapsulamento, que tem por objetivo, além da segurança evitando acesso direto aos atributos, esconder detalhes de implementação do usuário, fornecendo somente a real função da classe, sem que os detalhes de como isto ocorrer fiquem explícitos. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 47 Aula 3 • programação Atividades 1. Quais são os gerenciadores de layout definidos pela biblioteca AWT? 2. A implementação de interfaces listener são responsáveis por interpretar os eventos oriundos da interação do usuário com o sistema. Estas, muitas vezes, se tornam dispendiosas devido a obrigar que todos os métodos da interface sejam declarados na classe que implementa a interface. Dessa forma, qual a outra possibilidade fornecida pela linguagem Java para tratar os eventos? Comentário das atividades Na atividade 1, os gerenciadores de layout definidos pela biblioteca AWT consistem nas classes FlowLayout, BorderLayout, CardLayout, GridLayout, GridBagLayout, sendo que este podem ser definidos a qualquer componente que seja um container. Já na atividade 2, a outra possibilidade fornecida pela linguagem Java para tratar os eventos de um sistema consiste nas classes adaptadoras, que implementam as interfaces, e desta forma fornecem a possibilidade de que outras classes derivem destas classes adaptadoras e assim, deixa de ser obrigatória a definição de todos os métodos das interfaces listener, sendo somente redefinindo os métodos que realmente serão utilizados pelo sistema. Referências DEITEL, Harvey M. Java: como programar. 6 ed. São Paulo: Pearson Prentice Hall, 2005. FILHO, Renato Rodrigues. Desenvolva aplicativos com Java 2. São Paulo: Érica, 2005. FLANAGAN, David. Java: o guia essencial. 5. ed. Porto Alegre. Bookman, 2006. Na próxima aula Serão expostos os conceitos sobre conexão de aplicações Java com banco de dados, possibilitando a construção de programas que realizem as operações básicas com o manuseio de dados, além de, com isto, enriquecê-los. 48 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 4 Trabalhando com Banco de Dados Objetivo Esperamos que, ao final desta aula, você seja capaz de: • c ompreender os conceitos relacionados à conexão de aplicações gráficas com banco de dados. Pré-requisitos Para iniciarmos esta aula, é importante ter concluído a disciplina de banco de dados já apresentada e, além disso, ter assimilado todo conhecimento referente às aulas anteriores. Sendo mais específico: serão necessários, conhecimento básico de SQL (Structured Query Language), além de dominar os conceitos quantos aos componentes da linguagem de programação Java para aplicações visuais. Introdução Uma funcionalidade primordial em qualquer sistema, é a habilidade para comunicar-se com um repositório de dados. A Linguagem Java possui uma Application Programming Interface (API) que possibilita o acesso a repositórios de dados através de um modelo de conexão uniforme, permitindo uma padronização no acesso a distintos bancos de dados. Esta API é a Java DataBase Connectivity (JDBC). Univali/UNITINS • superior de tecnologia • 3º PERÍODO 49 Aula 4 • programação 4.1 JDBC A API JDBC consiste em uma biblioteca, implementada em Java, que disponibiliza classes e interfaces para o acesso ao banco de dados. Para cada banco de dados, deve haver uma implementação (também chamada de driver) dessas interfaces, levando em consideração as suas particularidades (THOMPSON, 2002). 4.1.1 Tipos de drivers JDBC Conforme mencionado, a API JDBC utiliza-se de diversos tipos de drivers que possibilitam a conexão de aplicações com banco de dados. Os principais drivers são apresentados a seguir. 4.1.1.1 JDBC-ODBC Também conhecido como Ponto JDBC-ODBC, é restrito à plataforma Windows, este tipo utiliza ODBC para conectar-se com o banco de dados, convertendo métodos JDBC em chamadas às funções do ODBC. Este tipo de conexão geralmente é usado quando não há um driver “puro-java”, que será descrito na seção 4.1.1.4 logo a seguir, para um determinado banco de dados (THOMPSON, 2002). 4.1.1.2 Driver API-Nativo Este é o responsável por traduzir as chamadas realizadas com o JDBC para realizadas com a API cliente do banco de dados utilizado. Assim como o driver JDBC-ODBC, pode ser que sejam necessários que outras soluções e aplicativos estejam instalados nas máquinas clientes, para que a conexão possa ser estabelecida (THOMPSON, 2002). 4.1.1.3 Driver de Protocolo de Rede A utilização do driver de protocolo de rede funciona, convertendo a chamada por meio do JDBC para um protocolo de rede, que independe do banco de dados que está sendo utilizado, fazendo com que os dados sejam traduzidos para o protocolo do banco de dados. Desta forma, devido ao fato de se utilizar de protocolos que não se prendem a um determinado banco de dados, este consiste no modelo de conexão mais flexível e abrangente (THOMPSON, 2002). 50 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 4 • programação 4.1.1.4 Driver nativo Este drive, por sua vez, converte as chamadas JDBC diretamente no protocolo do banco de dados. Este, que é implementado na linguagem Java, normalmente independe de plataforma, é escrito pelos próprios desenvolvedores, tornando o muito flexível. É o tipo mais recomendado para ser usado e mais utilizado no mercado (THOMPSON, 2002). Saiba mais Conforme mencionado, os drivers são os responsáveis pela maneira como a aplicação realizará a comunicação com o banco de dados. Com isto, é interessante ficar atento aos drivers disponíveis para o banco de dados que estamos utilizando, uma vez que este pode fornercer uma interface que otimize essa comunicação, como por exemplo, com o banco de dados Oracle. 4.1.2 Pacote java.sql O pacote java.sql é o responsável por fornecer a API para acesso e processamento de dados armazenados em uma fonte de dados, geralmente em uma base de dados relacional, utilizando a linguagem de programação Java. As principais classes e interfaces do pacote java.sql são (DEITEL, 2005): • D riverManager, responsável por criar uma conexão com o banco de dados; • C onnection, classe responsável por manter uma conexão aberta com o banco; • Statement, gerencia e executa instruções SQL; • P reparedStatement, gerencia e executa instruções SQL, permitindo também a passagem de parâmetros em uma instrução; • R esultSet, responsável por receber os dados obtidos em uma pesquisa ao banco. Prosseguindo nos tópicos seguintes, serão descritas e exemplificadas cada uma dessas principais classes e interfaces, que tornam possível o armazenamento e recuperação de informação em base de dados. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 51 Aula 4 • programação 4.1.3 DriverManager A Classe DriverManager é a responsável pelo gerenciamento de drivers JDBC. Esta classe também proporciona o estabelecimento de conexões a bancos de dados (THOMPSON, 2002). // Carregando um driver em tempo de execução Class.forName(“org.gjt.mm.mysql.Driver”); // Tentando estabelecer conexão com o Banco de Dados Connection conn = DriverManager.getConnection(“jdbc:mysql://localhost/ aula04?autoReconnect=true”, “conta”, “senha”); No código apresentado, primeiramente um driver é carregado em tempo de execução para que seja possível a tentativa de estabelecer conexão com o banco de dados, por meio do método getConnection() da classe DriverManager. Este método retorna uma implementação para a interface Connection, então vamos a ela? 4.1.4 Connection A interface Connection representa a conexão com o banco de dados. Todas as operações executadas entre a aplicação Java e o banco de dados ocorrem dentro do contexto desta interface (SUN, 2007). No código exibido no tópico anterior, um objeto da interface Connection (conn) recebe a conexão estabelecida com o banco de dados através da classe DriverManager. Tal objeto é capaz de proporcionar informações sobre as tabelas do banco, capacidades de sua conexão, quais gramáticas de SQL são suportadas pelo banco, entre outros. Estes são métodos desta interface freqüentemente utilizados (SUN, 2007): • c ommit(), executa todas as alterações feitas com o banco de dados pela atual transação. • rollback(), desfaz qualquer alteração feita com o banco de dados pela atual transação. • close(), libera o recurso que estava sendo utilizado pelo objeto. 52 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 4 • programação Note, porém que os métodos fornecidos pela interface Connection não trabalham diretamente com os dados, lidando somente com características de como o banco irá se comportar. 4.1.5 Statement O objeto desta interface fornece métodos para executar uma instrução SQL estática, sem passagem de parâmetros. Os principais métodos da Interface Statement são (SUN, 2007): • executeUpdate(), executa instruções SQL do tipo: INSERT, UPDATE e DELETE; • execute(), executa instruções SQL de busca de dados do tipo SELECT; • close(), libera o recurso que estava sendo utilizado pelo objeto. // Instanciando o objeto statement (stmt) Statement stmt = conn.createStatement(); // Executando uma instrução SQL. stmt.executeUpdate(“INSERT INTO ALUNO VALUES (1, ‘Pedro da Silva’)”); O código acima mostra a instância de um objeto do tipo Statement (stmt) através do método createStatement(), do objeto conn da interface Connection. Após a instância do objeto stmt, é executada uma instrução SQL de inserção em uma tabela de um banco de dados, a partir do método executeUpdate(). 4.1.6 PreparedStatement A interface PreparedStatement possui todos os recursos da interface Statement, acrescentando a utilização de parâmetros em uma instrução SQL. Os principais métodos da interface PreparedStatement são (SUN, 2007): • • • • execute(), consolida a instrução SQL informada; setDate(), método utilizado para atribuir um valor do tipo Data; setInt(), utilizado para atribuir valores do tipo inteiro; setString(), método utilizado para atribuir valores do tipo Alfa Numéricos. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 53 Aula 4 • programação // Instanciando o objeto preparedStatement (pstmt) PreparedStatement pstmt = conn.prepareStatement(“UPDATE ALUNO SET NOME = ?”); // Setando o valor ao parâmetro pstmt.setString(1, “MARIA RITA”); O código acima apresenta a instância do objeto pstmt da classe PreparedStatement, através do método prepareStatement(), do objeto conn da classe Connection. Após a instância, o objeto pstmt utiliza o método setString() para passar o valor do parâmetro criado na instrução SQL anteriormente. 4.1.7 ResultSet Esta interface permite o recebimento e gerenciamento do conjunto de dados resultante de uma consulta SQL, realizada ao banco de dados. Ela proporciona métodos capazes de acessar os dados provenientes da consulta SQL. Alguns dos métodos desta interface frequentemente utilizados (SUN, 2007): • n ext(), move o cursor para a próxima linha de dados, já que o conjunto de dados retornados pela consulta SQL é armazenado como em uma lista. • close(), libera o recurso que estava sendo utilizado pelo objeto. • g etString(String columnName), recupera o valor da coluna informada como parâmetro, da linha atual do conjunto de dados recebidos pelo objeto ResultSet. //Recebendo o conjunto de dados da consulta SQL ResultSet rs = stmt.executeQuery(“SELECT id, nome FROM ALUNO”); // Se while } houver resultados, posiciona-se o cursor na próxima linha de dados (rs.next()) { // Recuperando os dados retornados pela consulta SQL int id = rs.getInt(“id”); String nome = rs.getString(“nome”); Este código exibe uma instância da interface ResultSet (rs), recebendo um conjunto de dados retornados pela consulta SQL, caso esta retorne algo. Esta consulta contém a seleção de dois campos: id e nome. Com o método next(), caso haja resultados, o cursor que indica qual linha de dados do conjunto está em evidência, é apontado para a próxima linha. Assim, é possível recuperar os valores dos campos selecionados com métodos como o getInt(), getString(), entre outros. 54 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 4 • programação 4.2 Exemplo de uma aplicação O exemplo contido nesta seção apresenta uma aplicação com uma base de dados MySQL. Essa aplicação contém tudo o que foi mostrado nos tópicos anteriores. O código abaixo mostra o início de uma classe chamada Aula04. java, mostrando as importações necessárias para a aplicação funcionar. Então, mãos à obra, transcreva o código a seguir. import import import import import import import import java.awt.Frame; java.awt.List; java.sql.Connection; java.sql.DriverManager; java.sql.PreparedStatement; java.sql.ResultSet; java.sql.SQLException; java.sql.Statement; public class Aula04 { private Connection conn; private PreparedStatement pstmt; private Statement stmt; private ResultSet rs; Após as importações, foram declarados quatro atributos, os quais serão necessários para a interação com o banco. Além desses atributos, esta aplicação contém sete métodos apresentados logo a seguir. public void open() { try { Class.forName(“org.gjt.mm.mysql.Driver”); conn = DriverManager.getConnection( “jdbc:mysql://localhost/aula04?autoReconnect=true”, “root”, “”); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } } public void close() { try { if (stmt != null) stmt.close(); conn.close(); } catch (SQLException e) { e.printStackTrace(); } } Univali/UNITINS • superior de tecnologia • 3º PERÍODO 55 Aula 4 • programação Para esta aplicação, foi utilizado o Tipo de driver 4 (drive nativo). O método open() atribui a string de conexão do banco em questão (MySQL). Logo a seguir é instanciado um objeto conn da interface Connection, passando como parâmetro o tipo de driver, o local do servidor, o usuário e senha. A intenção deste método é apenas abrir uma conexão com o banco. O próximo método, close(), faz exatamente o contrário do método open(), ou seja, somente fecha a conexão com o banco. public void inserir(){ try { // Abrindo a conexão com o banco open(); // Instanciando o objeto statement (stmt) stmt = conn.createStatement(); // Executando uma instrução SQL. stmt.executeUpdate( “INSERT INTO ALUNO VALUES (1, ‘Pedro da Silva’)”); // Fechando a conexão com o banco close(); } catch (SQLException e) { // Fechando a conexão com o banco close(); e.printStackTrace(); } } O método inserir() utilizou a interface Statement para adicionar um aluno ao banco. Observe que para rodar esta aplicação, teremos que possuir uma tabela Aluno, contendo duas colunas, id e nome. Neste método foi aberta uma conexão com o banco, através do método open(), logo após criou-se uma instância da interface Statement (stmt). Este objeto executou um método chamado executeUpdate(), passando como parâmetro uma instrução SQL de inserção de dados. Ao final foi fechada a conexão com o banco. public void alterar(){ try { // Abrindo a conexão com o banco open(); // Instanciando o objeto preparedStatement (pstmt) pstmt = conn.prepareStatement(“UPDATE ALUNO SET NOME = ? Where id = 1”); // Setando o valor ao parâmetro pstmt.setString(1, “MARIA RITA”); // Fechando a conexão com o banco pstmt.execute(); close(); } catch (SQLException e) { // Fechando a conexão com o banco close(); e.printStackTrace(); } } 56 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 4 • programação O método alterar() é bem parecido com o inserir(). Apenas foi utilizada outra classe para a execução da instrução SQL. Neste caso, utilizamos a interface PreparedStatement, que funciona de forma semelhante à interface Statement, mas possui a grande vantagem de se passar parâmetros a uma instrução SQL. Na instância da interface PreparedStatement (pstmt), é informada a instrução SQL. Nesta instrução, espera-se alterar o nome de um aluno que possui o id igual a “1”, inserido no método anterior. Nesta mesma instrução, logo após o nome, foi utilizado o caractere “?”, que significa a criação de um parâmetro. Na próxima linha, o objeto pstmt utiliza o método setString() para atribuir o valor ao parâmetro em questão. Repare que são informados dois valores: qual o parâmetro e o seu devido valor. Neste caso, como só existe um parâmetro, foi informado o número “1”. Se houvesse mais parâmetros, seriam informados na seqüência: “2”, “3” etc. Logo após informar o valor do parâmetro, é executado o método execute() do objeto pstmt, consolidando a alteração no banco. public ResultSet buscarAlunos(){ try { open(); stmt = conn.createStatement(); rs = stmt.executeQuery(“SELECT id, nome FROM ALUNO”); return rs; } catch (SQLException e) { close(); e.printStackTrace(); } return null; } O método seguinte, buscarAlunos(), utiliza o Statement, para fazer uma pesquisa ao banco, através do método executeQuery(). Este retorna um objeto do tipo ResultSet ao objeto rs, contendo os dados selecionados da tabela Aluno. Este método será utilizado logo a seguir para imprimir os dados na tela. public void imprimirAlunos() throws SQLException{ List listAlunos = new List(); Aula04 aula = new Aula04(); aula.rs = aula.buscarAlunos(); while (aula.rs.next()) listAlunos.add(“Id: “ + aula.rs.getInt(“id”) + “ - “ + “Nome: “ + aula.rs.getString(“nome”)); Frame janela = new Frame(“Janela”); janela.setLocation(300, 300); janela.setSize(300, 300); janela.add(listAlunos); janela.setVisible(true); } Univali/UNITINS • superior de tecnologia • 3º PERÍODO 57 Aula 4 • programação O método imprimirAlunos() utilizou componentes do pacote AWT para a impressão dos alunos na tela. Foram feitas instâncias das classes List e Aula04. O objeto aula faz uma pesquisa no banco, através de seu método buscarAlunos(), explicado anteriormente, e logo a seguir é feito um laço de repetição para adicionar os valores ao objeto listAlunos. Logo após, é criado o objeto janela do tipo Frame, atribuindo valores de posição e tamanho. Depois disso, é adicionada a lista de alunos à janela, a qual é exibida na tela. Pensando sobre o assunto Assim como foi utilizado um objeto do tipo List para a exibição dos valores obtidos junto ao banco de dados, diversos outros componentes poderiam ter sido utilizados. Dentre esses podemos citar o componete Jtable da biblioteca Swing. Com isto, sugerimos testes e uma leitura mais detalhada sobre quais componentes podem receber valores de uma consulta a um banco de dados. public static void main(String[] args ){ Aula04 aula = new Aula04(); aula.inserir(); aula.alterar(); aula.rs = aula.buscarAlunos(); try { aula.imprimirAlunos(); } catch (SQLException e) { e.printStackTrace(); } } Finalmente, o código acima apresenta o método main(), de execução padrão de uma classe Java. Nele, apenas se instância o objeto da classe Aula04 e executa os métodos explicados anteriormente. Assim finalizamos nossa 4ª aula, refaçam todos os exemplos para um melhor aproveitamento dela. Síntese da aula Nesta aula, foram apresentados os conceitos relacionados à conexão de aplicações Java com banco de dados. Inicialmente foram apresentados os tipos de conexão JDBC possíveis, além de detalhar cada um destes. Depois, foram consideradas as classes que fazem parte de uma conexão nativa do Java, apresentado sua utilização. Finalmente, foi criado um exemplo que fizesse uso de todos os conceitos vistos anteriormente. 58 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 4 • programação Atividades 1. Levando em consideração os tópicos apresentados nesta aula, quais são os métodos implementados pela Interface Connection, para controle da conexão com um banco de dados e qual o objetivo destes? 2. Qual a diferença entre as interfaces Statement e PreparedStatement? Comentário das atividades Na atividade 1, os métodos que são implementados pela interface Connection, constem em: commit(), que executa todas as alterações feitas pela atual transação; rollback(), que desfaz qualquer alteração feita pela atual transação; close(), que libera o recurso que estava sendo utilizado pelo objeto. Já na atividade 2, a primeira consiste em uma interface que disponibiliza métodos para a execução de claúsulas SQL, sem a passagem de parâmetros, no caso estáticos. Já a interface PreparedStatement, além de possuir todos os métodos disponibilizados pela primeira interface, fornece suporte à passagem de parâmetros para as claúsulas que esta executa. Referências DEITEL, Harvey M. Java: como programar. 6 ed. São Paulo: Pearson Prentice Hall, 2005. THOMPSON, Marco Aurélio. Java 2 & banco de dados. São Paulo: Érica, 2002. SUN, MicroSystem. Java Technology. Disponivel em http://java.sun.com. Acessado em 12 out. 2007. Na próxima aula Serão apresentados os conceitos relacionados a construção de aplicações utilizando a classe Applets Java, fornecendo suporte para que possamos disponibilizar aplicações visuais Java para a WEB. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 59 Aula 4 • programação Anotações 60 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 5 Applets Java Objetivo Esperamos que, ao final desta aula, você seja capaz de: • desenvolver programas Java para WEB utilizando Applets. Pré-requisitos Para começar os estudos sobre a tecnologia de programação Applet Java, é importante conhecer os conceitos de programação Java, vistos nas aulas anteriores, bem como conceitos relacionados à orientação ao objeto. Esse conhecimento é importante para uma melhor compreensão dos conceitos desta aula. Introdução Um Applet consiste em um trecho de código Java que pode ser integrados a páginas WEB, sendo que este têm um ciclo de vida diferente dos programas executável. Se destinam a ser utilizado pelos navegadores, significando que será transportado pela Internet tal como documentos HTML, imagens entre outros conteúdos típicos da rede. Assim, esta aula irá apresentá-lo e prepará-lo para compreender e aplicar os conceitos da tecnologia Applets Java. Bons estudos! Univali/UNITINS • superior de tecnologia • 3º PERÍODO 61 Aula 5 • programação 5.1 Funcionamento das Applets As classes Applets são muito úteis para escrever aplicativos para a Internet, pois podem ser incorporadas a documentos HTML e executadas usandose navegadores que sejam compatíveis com Java, no caso, que suportem os plugins disponibilizados para a execução do código pela JVM. Os programas construídos com Applets são construídos de forma idêntica aos programas gráficos Java, o entendimento da forma do seu ciclo de vida auxilia bastante na compreensão de sua estrutura. O seu funcionamento se baseia em um modo particular de programação, que consiste em (DEITEL, 2005): 1.Instanciação – (create); 2.Inicialização – (init); 3.Início – (start); 4.Execução e renderização – (paint e outros métodos); 5.Parada – (stop); 6.Finalização ou destruição – (destroy). Figura 1 - Ciclo de vida das Applets Todos as classes Applets devem, necessariamente, seguir este ciclo de vida. Dessa forma, é interessante conhecermos qual a função de cada um destes métodos que determinam a vida de um Applet. 62 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 5 • programação 5.1.1 Método Init É executado uma única vez, assim que a página que executa o Applet está sendo carregada pela primeira vez, sendo invocado pelo navegador, através das JVM encarregada pela execução das Applets, conforme mencionado. Através desse método é possível adicionar componentes, receber parâmetros de execução e realizar outras atividades de preparo, antes que o Applet seja apresentado (DEITEL, 2005). 5.1.2 Método start Seguindo o ciclo de vida apresentado anteriormente, é executado logo após o método init() o start(), no caso, este é invocado pelo browser toda vez que o Applet se torna visível. Este pode ser utilizado para iniciar outros métodos e executar animações gráficas ou mesmo arquivos de som (DEITEL, 2005). 5.1.3 Método paint O paint é um método executado toda vez que a área de exibição da Applet precisa ser novamente renderizada, ou seja, toda vez em que houver a necessidade de uma nova apresentação do conteúdo do Applet, este deverá ser invocado. Após o Applet ser carregado pela primeira vez, este método deverá ser chamado explicitamente para que seu código seja executado e, assim, apresentado o resultado ao usuário (DEITEL, 2005). 5.1.4 Método stop Outro método que sempre deve ser considerado na implementação de um Applet consiste no stop(). Ele é executado sempre que houver uma mudança da página atual que contém o Applet, ou minimização da janela ou qualquer outra operação em que a janela não for mais a principal, ou seja, quando o Applet deixar de ser visível (DEITEL, 2005). 5.1.5 Método destroy Finalizando os métodos de ciclo de vida de um Applet, chegamos ao método destroy. Muito parecido com o método stop, no entanto este é executado Univali/UNITINS • superior de tecnologia • 3º PERÍODO 63 Aula 5 • programação após todos os recursos da página serem utilizados, assim liberando todos os recursos alocados durante a sua execução. Não há a necessidade de explicitá-lo, ou seja, de invocá-lo, havendo uma comunicação com outras classes Applets ou conexões de rede que serão finalizadas (DEITEL, 2005). Bom, pessoal, depois de tantos conceitos, iremos, a seguir, entender como esses métodos são utilizados em uma classe Java e depois utilizados pelos navegadores. O trecho de código logo abaixo exemplifica, dando uma noção de como uma classe Applet Java é implementada. // MetodosApplet.java import java.applet.Applet; import java.awt.Graphics; public class MetodosApplet extends Applet{ private int init = 0; private int start = 0; private int paint = 0; private int stop = 0; public void init(){ init++; } public void start(){ start++; } public void paint( Graphics g){ paint++; g.drawString(“O método Init: “+init, 5, 15); g.drawString(“O método Start: “+start, 5, 30); g.drawString(“O método Paint: “+paint, 5, 45); g.drawString(“O método Stop: “+stop, 5, 60); } public void stop(){ stop++; } } Este exemplo é interessante, devido ao fato de demonstrar a quantidade de vezes que os métodos essenciais do ciclo de vida de um applet são invocados no momento de sua execução, explicitando todas as características mencionadas. Outro detalhe que deve ser mencionado consiste no fato de que as classes que se propõem a implementar um Applet devem derivar, no caso, herdar da classe Applet, conforme é apresentado no exemplo anterior na assinatura da classe MetodosApplet. 64 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 5 • programação Saiba mais As classes Applets passaram a ser um diferencial da linguagem Java, abrindo um grande leque de possibilidades para as aplicações Java. O conceito de Applets foi o responsável pelo crescimento exponencial vivido pela tecnologia Java, que, em conjunto com o navegador Netscape, revolucionou o conteúdo e a forma de apresentação na WEB em meados dos anos 90. 5.2 Rodando Applets Java em uma Página WEB É isso, pessoal, depois de alguns conceitos básicos na seção anterior, iremos nos aprofundar neste conceito, porém, agora, realizaremos a chamada de um Applet por meio de um arquivo html, ou seja, uma página WEB que serão apresentados por navegadores. Para carregar um Applet Java em uma página HTML (HyperText Markup Language), devemos especificar sua utilização através da tag Applet. Abaixo segue um trecho de código que exemplifica essa afirmação. Um detalhe que temos de nos atentar consiste na necessidade da compilação do código Applet como as demais classes Java apresentadas até aqui, uma vez que é utilizado o arquivo .class. <HTML> <HEAD> <TITLE>Primeiro Programa Applet</TITLE> </HEAD> <BODY> <applet code= MetodosApplet.class width=”220” height=”100”> </applet> </BODY> </HTML> Pronto, agora que já sabemos como apresentar nosso Applet em um navegador, iremos apresentar um programa simples que escreverá na página HTML a mensagem “Olá Mundo !!!”. O código a seguir ilustra a classe responsável por isto. import java.awt.Graphics; public class PrimeiroApplet extends Applet{ public void paint(Graphics g){ g.drawString(“Oi Mundo!!!”, 50, 25); } } Univali/UNITINS • superior de tecnologia • 3º PERÍODO 65 Aula 5 • programação Conforme já mencionado, após a criação de nossa classe Applet, é necessário que o código de nossa classe seja compilado, para que o Applet inserido no navegador possa funcionar corretamente. Para compilar nossa classe é necessário digitar o comando javac, conforme é realizado com qualquer classe. javac PrimeiroApplet.java A partir disso, será gerado um arquivo PrimeiroApplet.class que é um bytecode da Applet. Para a apresentação de nossa nova classe em um navegador, o byte-code deve ser adicionado a um código HTML como demonstrado no exemplo de código inicial desta seção. Alguns navegadores não suportam Java e obviamente não conseguem disponibilizar a visualização do Applet inserido no código HTML de uma página. Porém, existe um programa denominado appletviewer, que é disponibilizado pela JDK, fazendo com que apenas a área onde o Applet é executado, seja apresentada. O trecho de código a seguir exemplifica a utilização desta ferramenta, que deve indicar qual arquivo html deve ser apresentado. appletviewer index.html Este aplicativo é, na maioria das vezes, utilizado para verificar a consistência dos Applets, antes que a página seja disponibilizada, uma vez que a maioria dos navegadores atuais já possui plugins para suporte a tecnologia Applet. 5.3 Restrições das Applets Vimos que as Applets podem ser incorporadas às páginas WEB, mas, como qualquer código, deve-se ficar atento para que nenhuma classe Applet desconhecida possa prejudicar o sistema onde está sendo executada, ou seja, apagando ou acessando informações indevidas armazenadas dentro do sistema (DEITEL, 2005). Para isso, há um sistema de monitoramento de segurança denominado applet security manager, que causa uma interrupção no applet, caso este tente violar as regras de segurança determinadas. Sendo assim, é comum dizer que as Applets são como crianças que estão sempre sob a vigilância de um adulto. Algumas restrições impostas aos applets que são (DEITEL, 2005): 66 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 5 • programação 1.Programas localmente instalados não podem ser executados; 2.Exceto no host de origem não há comunicação com outros hosts; 3.Não há permissão de leitura e escrita no sistema de arquivo local; 4.Só podem obter informações do sistema sobre a JVM a qual operam. Pensando sobre o assunto Na maioria das vezes, não é necessário se preocupar com estes detalhes, visto que as classes Applets são utilizadas apenas para a disponibilização e apresentação de conteúdo de outra classe, sendo que essa então realiza os acessos necessários, evitando que a classe Applet desempenhe diretamente estas funções. 5.4 Parametrizando Applets Assim como programas podem receber argumentos vindos das linhas de comando, fazendo alterações que os ajustem com esses parâmetros, as Applets podem ser parametrizadas, para que possam ter uma maior versatilidade de sua utilização, possibilitando a criação de um código mais genérico (DEITEL, 2005). Como vimos anteriormente, as applets não são executadas através de uma linha de comando e sim através de um arquivo HTML, que é lido pelo navegador ou pelo appletviewer. A passagem de parâmetros, neste caso, pode ser realizada com o uso da tag especial <APPLET> em conjunto com a tag denominada <PARAM>. Essa tag possui alguns parâmetros dos quais dois são aplicáveis unindo-os a tag <APPLET> que são o NAME e o VALUE. Assim sendo, um determinado parâmetro especificado, cujo nome está definido no campo NAME e cujo valor está definido no campo VALUE, se encontra disponível para ser utilizado. A quantidade de parâmetros não é predefinida em uma Applet, podendo ser utilizados quantos forem necessários desde que uma ou mais tags <PARAM> sejam incluídas dentro das tags <APPLET> e </APPLET>. Estes são então lidos pela Applet Java. O exemplo a seguir demonstra esse tipo de código. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 67 Aula 5 • programação ... <applet code=”param.class” height=115 width=115> <param name=”cor” value=”FFF000”> <param name=”valor” value=”10”> </applet> ... A idéia principal dos parâmetros consiste na troca de informação com as classes applets. Para tanto, com a utilização do método getParameter(), é possível se passar valores para a tag HTML <PARAM>. Com isso, é possível recuperar valores de parâmetros especificados como argumentos. O código a seguir exemplifica a afirmação sendo utilizado o método em uma classe Applet. // processamento dos parâmetros ... String aux = getParameter(“corFundo”); if (aux!=null){ setBackground(new Color(Integer.parseInt(aux, 16))); } aux = getParameter(“valorInicial”); if (aux!=null){ tfEntrada.setText(aux) } ... Se o método getParameter() retornar um valor null, significa que o nome especificado não contém valor definido ou o parâmetro especificado é nulo. No exemplo acima, os valores recuperados têm como retorno objetos do tipo String, sendo que, logo após, o valor é convertido para o tipo desejado, é exigido pelo método setBackground(), no caso, o parâmetro corFundo teve seu valor de String recuperado, é logo após convertido para um valor inteiro com base hexadecimal, ao passo que o parâmetro valorInicial é utilizado diretamente para apresentação por um componente. 5.5 Applets que são Aplicações Dependendo de como os programas Java forem carregados, eles podem se portar como aplicativos ou como Applets. Portanto, quando adicionamos o método executável (main) a uma aplicação Applet, este está realizando o tratamento para criar uma aplicação (DEITEL, 2005). As aplicações feitas através de applets são úteis em situações em que devem ser utilizadas tanto localmente quanto em conexões de rede. Agora no sentido inverso é de certa forma possível, embora algumas restrições impostas a este funcionamento sejam feitas. 68 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 5 • programação 5.6 O Contexto das Applets Uma das principais e mais importantes características de um Applet é a forma como ele interage com o navegador no qual está sendo executado, obtendo informações sobre o ambiente em que são executados utilizando-se da interface AppletContext, cujos métodos são relacionados na tabela a seguir (DEITEL, 2005). Método Descrição getApplets() Lista as applets contidas na exibição do documento. getAudioClip(URL) Um clip de áudio da URL solicitada é retornado. getApplet(String) Retorna uma referência para a tag <APPLET> no documento atual. getImage(URL) A URL retorna uma imagem. showDocument(URL) Requisita ao navegador que substitua a página atual pela contida na URL dada. showStatus(String) A string será fornecida na linha de status ou na janela. showDocument(URL, String) Requisita ao navegador que substitua a página atual pela contida na URL dada na janela especificada como alvo. Tabela 1 - Métodos da Interface AppletContext Nos métodos citados acima, pode-se verificar que suas funcionalidades apresentadas auxiliam no trabalho com Applets, conseguindo executar até mesmo referências a outras classes Applet, além possibilitar o trabalho com imagens, áudio e vídeos dentre outros. Um dos métodos mais importantes em uma classe Applet é o showDocument(), no qual pode-se gerenciar um navegador, para criar novas janelas ou mesmo exibir um novo documento em uma janela já existente. Assim finalizamos nossa 5ª aula, com este importante conceito da tecnologia Java. Síntese da aula Nesta aula, foram apresentados os conceitos de Applets, bem como o seu funcionamento para criação de programas, através de páginas WEB, a forma como é feita a programação do código para que esses Applets possam funcionar nos documentos HTML e alguns métodos para auxiliar na criação de Applets mais sofisticadas. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 69 Aula 5 • programação Atividades 1. Um Applet consiste em uma classe com características e comportamentos que a diferem das demais classes conhecidas. Dentre os comportamentos de um Applet, existe o ciclo de vida. No que consiste o clico de vida de um Applet? 2. Uma classe Applet, conforme pôde ser observado em nossa aula, pode ser executado dentro de uma página HTML que pode conter parâmetros. Quais são os métodos que possibilitam a interação entre a claase Applet e a página HTML? Comentário das atividades Na atividade 1, uma classe Applet possui um ciclo de vida pré-determinado, que deve ser obedecido e definido pelos métodos init(), start(), paint(), stop() e destroy(). No caso, um Applet tem um processo que é iniciado com os métodos init() e start(), processado com paint() e stop() e logo após este tem um fim com o método destroy(), sendo que este não necessita ser explicitamente invocado. Já na atividade 2, os métodos que disponibilizam uma interface entre a Applet e a página HTML consistem nos métodos getParameter() e setParameter(), sendo que o primeiro é o responsável por obter o conteúdo de um parâmetro definido em uma tag HTML e o segundo por estabelecer valores que podem ser utilizados pela página. Referências DEITEL, Harvey M. Java: como programar. 6. ed. São Paulo: Pearson Prentice Hall, 2005. Na próxima aula Apresentaremos os conceitos relacionados à criação de relatórios em aplicações Java com a utilização do framework jasperReport, bem como a apresentação de ferramentas que auxiliem neste processo. 70 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 6 Relatórios Objetivo Esperamos que, ao final desta aula, você seja capaz de: • criar relatórios de aplicações Java utilizando ferramentas livres. Pré-requisitos Para começarmos os estudos sobre a geração de relatórios, é importante conhecer os conceitos de programação Java, vistos nas aulas anteriores, bem como conceitos relacionados à XML (eXtensible Markup Language). Esse conhecimento é importante para uma melhor compreensão das aulas desta aula. Introdução Todo sistema é criado com a finalidade de organizar, guardar e recuperar dados. Um de seus objetivos é a geração de relatórios, contendo parte desses dados armazenados no sistema para um determinado fim específico, seja ele de gerência, auditoria ou apenas de conferência. Apesar de sua importância e sua presença em, basicamente, todos os sistemas computacionais, muitas vezes este módulo do sistema não tem seu devido reconhecimento. Em resumo, podemos dizer que o processo de geração de relatórios consiste na criação de um layout e na seleção dos dados que irão compor o corpo do relatório. Essa necessidade de criação de relatórios fez com que surgissem diversas ferramentas especializadas neste assunto, como a ferramenta proprietária Crystal Reports e as ferramentas de código aberto JasperReports e iReport que serão tratadas nesta aula. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 71 Aula 6 • programação Agora que já tivemos a idéia da finalidade dos relatórios, vamos ao que interessa! Começaremos a nossa aula falando sobre o JasperReports. 6.1 JasperReports Como dissemos anteriormente, JasperReports é uma das ferramentas (framework) de código aberto (open-source) que nos auxilia na criação de relatórios. Como não podia deixar de ser, essa ferramenta é escrita em Java e alguns de seus pontos fortes são a organização e apresentação de conteúdo, gerando de forma dinâmica seus relatórios em vários formatos: XML, PDF, XLS, HTML e CSV (HEFFELFINGER, 2006). E como todos nós já sabemos, podemos utilizá-la em qualquer aplicativo feito em Java, indo de desktop, WEB ou mesmo distribuído. Saiba mais Um framework consiste em uma estrutura de software muito utilizada na linguagem Java. Ele consiste em um arcabouço de soluções, disponibilizando bibliotecas ou mesmo softwares que acelerem o processo de desenvolvimento de aplicações. Estes se diferenciam das bibliotecas de classes convencionais fornecidas, pois, diferentemente destas, os frameworks fornecem uma solução para uma família de problemas em comum, com pouco esforço, aumentando o poder de reutilização de código. 6.1.1 XML a chave do funcionamento Aqui, pessoal, é onde começamos o processo de criação dos nossos relatórios. Logo, temos que compreender como o processo funciona, e a Figura 1 tem como objetivo nos mostrar como se dá este processo. Figura 1 - JasperReports - Processo para gerar um relatório 72 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 6 • programação Você deve estar se perguntando: “Qual o objetivo do arquivo XML?”. Calma, iremos falar sobre isso agora. Na introdução da aula falamos que o processo de criação de relatórios consistia basicamente em definir um layout e filtrar (selecionar) os dados que irão fazer parte de seu conteúdo. Pois bem! O arquivo XML é quem vai definir tanto o layout quanto a localização e os nomes dos campos dos dados a serem preenchidos. Este processo se dá por meio das tags, não as tags de Java, mas as tags do XML, que, por sua vez, obedecem a um padrão de estrutura e vocabulário com suas restrições, cujos valores são declarados em um arquivo chamado jasperreports.dtd (HEFFELFINGER, 2006). Pensando sobre o assunto A XML é uma metalinguagem utilizada para intercâmbio de informações e criação de estruturas de arquivos. Dessa forma, sugerimos a leitura de obras relacionadas ao assunto e que colaborem com o seu aprendizado. Segue uma boa referência: http://www.w3.org/XML/. Com o uso do XML, o layout poderá ser definido com formas geométricas, imagens e textos padronizados estaticamente e/ou principalmente dinamicamente, através dos campos definidos para tal fim, tendo o seu conteúdo buscado em uma base de dados. Todos esses elementos contêm uma localização específica dentro do relatório. Após a fase de definição dos elementos que compõem o layout do arquivo XML, ele precisa passar por uma compilação que gerará um arquivo de formato .jasper, ou seja, o código Java ali contido será verificado e compilado neste processo. As etapas de geração de relatório são representadas utilizando diferentes objetos do JasperReports, que serão apresentadas na Tabela 5.1. OBJETO DESCRIÇÃO JasperDesign Objeto de definição do relatório é criado a partir do template XML. JasperReport Objeto de compilação do JasperDesign, é criado após o processo de compilação e verificação do layout do relatório. JasperPrint Objeto final, é criado a partir de um JasperReport e contém o relatório preenchido. Tabela 5.1 – Objetos do JasperReports para criação de relatórios Univali/UNITINS • superior de tecnologia • 3º PERÍODO 73 Aula 6 • programação 6.1.2 Dados, a alma do conteúdo Nesta parte, pessoal, trataremos do preenchimento com os dados necessários para a criação do conteúdo do relatório. Na maioria esmagadora das vezes, esses dados são recuperados de algum SGBD (Sistema Gerenciador de Banco de Dados), mas, também, podem ser recuperados de arquivos XML. Quando queremos recuperar os dados de um SGBD relacional, utilizamos como padrão a linguagem SQL, conforme apresentado na 3ª aula, para realizar e retornar os dados da consulta, conforme foi visto na aula 4. Podemos inserir o código de consulta SQL ao código do XML ou utilizar uma classe Java já definida para esse fim, cujo resultado irá gerar um objeto ResultSet, que será lido pelas classes do Jasper, fazendo com que o relatório seja preenchido. Outro ponto forte do JasperReports é o suporte a muitos tipos de fonte de dados (datasources). O responsável por isso é a interface JRDataSource. JRResultSetDataSource é uma implementação padrão para objetos ResultSet para a interface JRDataSource (HEFFELFINGER, 2006). O ResultSet deve conter todas as colunas que serão mapeadas para seus campos correspondentes no relatório, quando este for à fonte de dados. 6.1.3 Campos, Variáveis, Parâmetros e Expressões Dando seqüência ao conteúdo, falaremos sobre o que são os campos, variáveis, parâmetros e expressões, para a geração de relatórios. Os campos (field) servem para entrada direta de dados no relatório, a coluna referenciada deve conter o mesmo nome do campo do relatório (HEFFELFINGER, 2006). Como exemplo, pegaremos os dados da coluna ‘Matricula’ com o tipo ‘Integer’ de uma tabela ‘aluno’. Para mapearmos esse dado, devemos definir, no arquivo XML, um campo com o nome ‘matricula’, como segue abaixo: ... <field name=“Matricula” class=“java.lang.Integer”/> ... Para a simplificação do projeto do relatório, utilizamos as variáveis (variable) e através delas podemos definir apenas uma expressão que será repetida freqüentemente e, quando se fizer necessário, no decorrer do design do relatório. As variáveis podem referenciar, internamente, tipos de cálculos como 74 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 6 • programação count (realiza uma contagem de itens), sum (realiza a soma de itens), average (realiza a média aritmética de itens) entre outros. Seguindo o exemplo anterior, poderíamos utilizar as variáveis para realizar o cálculo da média das notas dos alunos como é demonstrado abaixo. ... <variable name=“ValorMedia” class=“java.lang.Double” calculation= “Average”> <variable expression> ${Nota} </variable expression> </variable> ... A ordem de declaração de variáveis no relatório tem muita importância, pois, em uma expressão, uma variável pode referenciar outras variáveis, desde que elas tenham sido pré-definidas. Quando usamos variáveis para a realização de cálculos, podemos definir quando elas devem ser reinicializadas. Para isso, existem vários níveis de reinicialização, que são apresentadas na Tabela 5.2. NÍVEIS DESCRIÇÃO None Este nível indica que a variável nunca é inicializada com o valor inicial da expressão, ela apenas guarda o valor obtido pela expressão principal; Report Este nível indica que a variável somente será inicializada no inicio do relatório e terá seu valor acumulado até o término do mesmo; Page Este nível indica que a variável será inicializada no início de cada página do relatório; Column Este nível indica que a variável será inicializada no início de cada coluna; Group Este nível indica que a variável será inicializada quando o grupo especificado pelo atributo de resetGroup for modificado; Default O valor padrão do nível é Report; Tabela 5.2 – Níveis de reinicialização de variáveis (FURUTANI, 2007) A ferramenta também oferece variáveis pré-definidas para uso nas expressões regulares, sendo elas: PAGE_NUMBER, COLUMN_NUMBER, REPORT_ COUNT, PAGE_COUNT, COLUMN_COUNT, GroupName_COUNT. Quando não podemos encontrar os dados na fonte de dados que estamos usando para o preenchimento do relatório, usamos os parâmetros (parameter) para nos auxiliar nesse objetivo, assim temos. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 75 Aula 6 • programação ... <parameter name=“Titulo” class= “java.lang.String”/> ... Então passados, através da classe HashMap, via código Java, conforme é demonstrado a seguir. ... Map param = new HashMap( ); param.put( “Aluno”, “Vinny Coelho Frota” ); ... Outra forma muito importante de utilização de parâmetros é no uso do SQL do relatório, para obtermos dados em bases de dados, tendo como exemplo. ... SELECT * FROM aluno WHERE matricula=$P{Matricula} ... Assim, como resultado desta consulta, os dados contidos no relatório serão apenas aluno cuja matrícula foi passada por parâmetro. Para podermos especificar o conteúdo de campos de texto, que freqüentemente são usados, utilizamos as expressões (expression) e essas expressões são feitas em código Java e, normalmente, contêm em sua sintaxe campos, variáveis e parâmetros de relatório, veja este exemplo. 6.1.4 Layout ... <textFieldExpression> “Sr.(a) ” + $F{Aluno} + “ seu pagamento está em atraso no valor de: R$ “ + $V{ValorTotalDevedor} + “ referente à data de vencimento: “ + (new SimpleDateFormat(“dd/MM/yyyy”)).format($F{DataVencimento}) + “. Favor passar na secretaria.” </textFieldExpression> ... O layout do JasperReports, por motivos de melhor organização e definição de seu design, está dividido em algumas áreas pré-definidas que chamamos de seções, são elas: title, pageHeader, columnHeader, groupHeader, detail, groupFooter, columnFoter, pageFooter, summary (FURUTANI, 2007). A definição da posição do conteúdo do relatório é essencial para a criação do mesmo, pois é ela quem representa a estrutura visual do documento gerado. Porém, a criação de relatórios diretamente em XML não é uma tarefa simples e fácil, daí a necessidade de ferramentas que auxiliem na criação de layout dos relatórios. 76 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 6 • programação 6.2 iReport O iReport, uma ferramenta que automatiza e torna mais intuitiva a criação dos layouts dos relatórios. Constituído de ambiemte gráfico, reune todos os recursos da biblioteca Jasper para a criação de relatórios apresentados até aqui, auxiliando na construção de layouts mais elaborados e de maneira rápida, pois evita que o usuário perca tempo escrevendo linhas de código em XML. O iReport está disponível para download gratuitamente na internet. Este é disponibilizado de duas formas: a primeira consiste em um arquivo para descompactação, e a segunda um executável. Para tanto, baixe o arquivo que mais lhe convier no endereço: http://www.jasperforge.org/sf/projects/ireport. Pensando sobre o assunto Existem diversas publicações que auxiliam o processo de instalação do iReport disponíveis na WEB, mas não nos apegaremos aos detalhes de instalação dessa ferramenta. Um detalhe que dever ser citado é que, assim como para o funcionamento de nossos exemplos em Java, é necessário que estejam definas as variáveis de ambiente, uma vez que o iReport consiste em um programa Java. Uma vez que todo o processo de instalação tenha acontecido da maneira desejada, teremos como resultado da execução do iReport a tela apresentada na Figura 2. Figura 2 - Tela inicial do iReport Univali/UNITINS • superior de tecnologia • 3º PERÍODO 77 Aula 6 • programação Familiarize-se com todos os componentes desta ferramenta e, assim, construa seu layout conforme a necessidade. Todo código XML é gerado automaticamente pela ferramenta, ela ainda traz diversos atalhos para testes, como compilação e visualização de como está ficando o relatório a ser gerado. Saiba mais Existem outras ferramentas com o mesmo objetivo do iReport, mas estas não fazem parte do escopo desta aula. Fica aqui a sugestão para que sejam realizados estudos correlatos, a fim de se ter uma visão geral destas e, com isto, definir qual mais satisfaz as necessidades de seu projeto. Segue uma lista delas: iText, JFreeReports, OracleReports, JFreeStudio e FOP. Com isso, a ferramenta acelera, significativamente, o processo de desenvolvimento do relatório. 6.2.1 Fonte de Dados Suportadas O iReport suporta diversos tipos de conexões para a recuperação de dados para a construção de relatórios: conexões ODBC, JDBC, XML DataSource, JavaBeans Set DataSource, Custom DataSource e Empty DataSource. Sugerimos leituras complementares para conhecer essas fontes de dados (HEFFELFINGER, 2006). 6.3 Um estudo de caso Agora, iremos colocar a mão na massa, pessoal: vamos criar um relatório que nossa aplicação irá executar. Para tanto, execute ou crie uma tabela com a estrutura: ‘nome’ e ‘descricao’, e preencha sua tabela com dados, se necessário, adapte ao banco de dados que melhor lhe convier, porém note que, no exemplo, essas mudanças devem ser refletidas. Apenas certifique-se de que não ocorreram erros na criação. Certo. Agora, crie, com a utilização do iReport, seu relatório com o layout, conforme é demonstrado na Figura 3. Para tanto, familiarize-se com a ferramenta, acrescente novos elementos como Fields e Texts, para obter mais conhecimento dos elementos que a compõe. 78 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 6 • programação Figura 3 - Criação do layout do relatório Conforme já mencionado, um arquivo do iReport, quando salvo, consiste em uma arquivo XML, com a extensão .jrxml. Este deve ser nomeado como curso.jrxml. Porém, nosso programa Java utiliza o arquivo .jasper. Certo. Então, para isso, no próprio iReport compile o programa .jrxml e verifique que na pasta onde foi salvo o arquivo jrxml foi criado também um arquivo jasper. Agora, iremos criar nosso programa Java que irá realizar a chamada a nosso relatório. Porém, como o iReport consiste em um framework externo devemos ter acrescentado as bilbiotecas ao repositório java. Isto já deve ter sido realizado no processo de instalação do iReport. Então transcreva o código abaixo e execute-o. //Report.java import java.awt.*; import java.awt.event.*; import java.sql.*; import java.util.*; import com.mysql.jdbc.*; import net.sf.jasperreports.engine.*; import net.sf.jasperreports.view.*; public class Report extends Frame implements ActionListener{ public Report(){ super(“Relatórios”); Button botao = new Button(“Relatório”); botao.addActionListener(this); add(botao); setLayout(new FlowLayout()); setSize(200, 60); setLocation(300, 300); addWindowListener(new Eventos()); } Univali/UNITINS • superior de tecnologia • 3º PERÍODO 79 Aula 6 • programação // Cria método de conexão com o banco de dados // da mesma forma como apresentado na aula 4 private static Connection getConnection() throws ClassNotFoundException, SQLException { ... return con; } // método que cria o relatório public void geraRelatorio() throws JRException, Exception { Connection con = getConnection(); Statement stm = (Statement) con.createStatement(); String query = “select * from Curso”; ResultSet rs = (ResultSet) stm.executeQuery(query); // implementação da interface JRDataSource para DataSource ResultSet JRResultSetDataSource jrRS = new JRResultSetDataSource(rs); // HashMap de parametros utilizados no relatório. Sempre instanciados Map parameters = new HashMap(); // Preenche o relatório com os dados. Gera o arquivo curso.jrprint JasperFillManager.fillReportToFile( “curso.jasper”, parameters, jrRS ); // Preenche o relatorio e o salva diretamente em arquivo PDF. JasperRunManager.runReportToPdfFile(“curso.jasper”, parameters, jrRS); /* Visualiza o relatório em formato PDF */ JasperViewer.viewReport( “curso.pdf”, false); } // método de execução public static void main(String[] args) { Report programa = new Report(); programa.setVisible(true); } // listener que reage ao evento public void actionPerformed(ActionEvent e) { try { geraRelatorio(); } catch (JRException e1) { e1.printStackTrace(); } catch (Exception e1) { e1.printStackTrace(); } } } // Eventos da Janela class Eventos extends WindowAdapter{ ... } Se tudo correu como esperado, através do botão “Relatório”, realizamos a execução de nosso relatório. Adapte o exemplo para novos exemplos, utilize o iReport e crie seus novos relatórios para seus programas. Assim, finalizamos nossa aula 6, e esperamos que você já saiba criar suas aplicações gráficas com relatórios. 80 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 6 • programação Síntese da aula Nesta aula, foram apresentados os conceitos fundamentais do JasperReports para a elaboração e criação de relatórios práticos de aplicações Java e a interação do JasperReports com o iReport. Foram expostôs as principais características de como criar relatórios usando XML e recuperar dados de SGBDs. Além disso, outro aspecto fundamental do Reports foi a ênfase na criação do layout dos relatórios e seus tipos. Finalizando com os conceitos da ferramenta gráfica open-source iReport e suas fontes de dados suportadas, para geração dos relatórios. Atividades 1. Porque o arquivo XML é tão importante para a criação de relatórios? 2. Quais as principais características do iReport? Explique. Comentário das atividades Na atividade 1, sabemos que o arquivo XML é o responsável por gerenciar os dados que serão exibidos no relatório a ser gerado. Com o uso do XML, o layout poderá ser definido com formas geométricas, imagens e textos, através dos campos mapeados a uma base de dados ou datasource. Todos esses elementos terão uma localização específica dentro do relatório. Na atividade 2, as características do iReport é ser uma ferramenta open-source que automatiza a criação dos arquivos XML e torna mais intuitivo a criação dos layouts dos relatórios. Constituido de ambiemte gráfico, reune todos os recursos da biblioteca Jasper, para a criação de relatórios mais elaborados e de forma rápida, pois evita que o usuário perca tempo escrevendo inúmeras linhas de código em XML. Referências FURUTANI, Roberto J. Como criar relatórios Java para Web com JasperReports e iReport. <http://www.furutani.eti.br/tutoriais/Mini-Tutorial_ Relatorios_Java_JasperReports_e_iReport.pdf> Acessado em 12 out. 2007. HEFFELFINGER, David. JasperReports for Java Developers. Agosto, 2006. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 81 Aula 6 • programação Na próxima aula Continuaremos com a apresentação dos fundamentos do paradigma de Programação Orientada a Objetos, mencionando os conceitos de métodos construtores e encapsulamento. Anotações 82 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 7 Estudo de Caso Objetivo Esperamos que, ao final desta aula, você seja capaz de: • utilizar todos os conceitos aprendidos durante toda a disciplina. Pré-requisitos Para esta aula é necessário que os conceitos apresentados no decorrer desta disciplina tenham sido assimilados, e que estejam muito claro o conceito e orientação a objetos que foi visto na disciplina de Programação anterior: eles serão utilizados na construção do estudo de caso, visando a demonstrar que são de fundamental importância, para construção de aplicações por um programador Java. Introdução Iremos, agora, criar um estudo de caso, no qual utilizaremos todos os conceitos apresentados em nossas aulas, relacionados ao processo de construção de aplicações visuais com a linguagem Java, utilizando um banco de dados, criando, assim, uma pequena aplicação. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 83 Aula 7 • programação 7.1 Definição do problema Como estamos no final de nossa disciplina, iremos agora utilizar todos os conceitos apresentados, bem como relembrar outros que nos foram colocados na aula passada. Para tanto, vamos criar uma aplicação que interage com um banco de dados. Então vamos ao que interessa. Nosso estudo de caso consiste na criação de uma pequena aplicação para cadastro de cursos de uma universidade. Assim, utilizaremos a estrutura de banco de dados criada na aula 6, na construção de relatórios. Para isso, devemos definir uma tela inicial com um menu, no qual deverá ser oferecida a possibilidade de abrir a tela de cadastro ou mesmo sair. A tela de cadastro deve possibilitar que diversos cursos sejam acrescentados, com nome e descrição. Além disso, iremos acionar um relatório através de nossa aplicação. 7.2 Implementação do estudo de caso Iniciaremos nosso estudo de caso criando uma classe que deriva da classe Frame, no caso, será criada uma janela na qual iremos definir através de seu método construtor o tamanho e a localização da tela. Além disso, também definiremos o método executável, então, transcreva o código a seguir, salve-o e execute. //AppCadastro.java import java.awt.Frame; public class AppCadastro extends Frame{ //método construtor public AppCadastro(){ super(“Aplicação de cadastro”); setSize(600, 600); setLocation(200, 100); } //método executável public static void main(String[] args) { AppCadastro exec = new AppCadastro(); exec.setVisible(true); } } Note que, em nosso método executável instanciamos um objeto da classe que estamos construindo. Dessa forma, conseguimos visualizar os resultados de nossa aplicação. Prosseguindo com nosso exemplo, defina, no mesmo arquivo, uma nova classe que será responsável por definir as funcionalidades da janela, que serão acionados com os eventos sobre esta, no caso o listener. 84 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 7 • programação //AppCadastro.java import java.awt.*; import java.awt.event.*; public class AppCadastro extends Frame{ ... } class EvtJanela extends WindowAdapter{ public void windowClosing(WindowEvent e){ System.exit(0); } } Verifique que apenas foram adicionados um import e a nova classe, ao final da apresentada no exemplo anterior. Note que, ao invés de implementarmos a interface WindowListener, fazendo com que obrigatoriamente tivéssemos de declarar sete métodos, derivamos da classe WindowAdapter, sendo que é declarado apenas o método que utilizaremos. Porém, é necessário que este evento seja associado à janela, para tanto, acrescente o próximo código ao método construtor. Neste, instanciamos, um listener, no caso um escutador que é o responsável por reagir à interação dos usuários com a janela. ... public class AppCadastro extends Frame{ //método construtor public AppCadastro(){ ... EvtJanela evt = new EvtJanela(); addWindowListener(evt); } ... } ... Vamos agora definir nosso menu, sendo que neste definiremos dois itens, para que sejam executadas as funcionalidades de acionar a tela de cadastro e sair. Assim, como nos exemplos anteriores, transcreva as linhas de código a seguir no método construtor. ... public class AppCadastro extends Frame{ //método construtor public AppCadastro(){ ... MenuBar barraMenu = new MenuBar(); Menu menuArquivo = new Menu(“Arquivo”); MenuItem itemCadastro = new MenuItem(“Cadastro de Curso”); MenuItem itemSair = new MenuItem(“Sair”); menuArquivo.add(itemCadastro); menuArquivo.add(itemSair); barraMenu.add(menuArquivo); setMenuBar(barraMenu); } ... } ... Univali/UNITINS • superior de tecnologia • 3º PERÍODO 85 Aula 7 • programação Agora, precisamos definir o listener de nosso menu. Para tanto, devemos mencionar que nossa classe AppCadastro implementa a interface ActionListener e, com isso nos obriga a também implementar o método ActionPerformed. Então vamos a eles. ... public class AppCadastro extends Frame implements ActionListener{ //método construtor public AppCadastro(){ ... itemCadastro.addActionListener(this); itemSair.addActionListener(this); } ... public void actionPerformed(ActionEvent e) { if (e.getSource() instanceof MenuItem) { MenuItem item = (MenuItem) e.getSource(); if(item.getLabel().equals(“Sair”)){ System.exit(0); } if(item.getLabel().equals(“Novo de Curso”)){ } } } ... } Continuamos nosso estudo de caso definindo os containers de componentes de nossa aplicação. Então vamos criar três painéis que serão nossas telas, sendo que utilizaremos o gerenciador de layout CardLayout, para assim, termos o efeito de novas janelas que serão trabalhadas. ... public class AppCadastro extends Frame implements ActionListener{ Panel geral; //método construtor public AppCadastro(){ ... Panel painelApp = new Panel(); Panel painelCadastro = new Panel(); painelApp.setBackground(SystemColor.control); painelCadastro.setBackground(SystemColor.control); geral = new Panel(); geral.add(painelApp,”J1”); geral.add(painelCadastro,”J2”); geral.setLayout(new CardLayout()); add(“Center”,geral); } ... public void actionPerformed(ActionEvent e) { ... if(item.getLabel().equals(“Novo de Curso”)){ CardLayout pilha = (CardLayout) geral.getLayout(); pilha.next(geral); } … } } ... 86 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 7 • programação Criamos três painéis sendo que um consiste no mestre, denominado geral, por meio do qual conseguimos acessar os demais, criando como mencionado o aspecto de janelas. O componente painelCadastro consiste em nosso container que possuirá todos os demais campos, no caso outros componentes para nosso cadastro. Então, ao final o método construtor adicione as linhas de código a seguir descritas. Pensando sobre o assunto O efeito de janelas criado pela utilização de painéis é muito útil para a construção de aplicações visuais. Porém, podem ser instanciadas diversas classes que derivam da classe Frame, e realizando assim a chamada, através do método setVisible(). Deve-se, antes de invocar novas janelas, informar que a janela que está realizando a chamada não é mais a janela ativa, isso com a utilização do método setEnable(). ... import ... public javax.swing.*; class AppCadastro extends Frame{ ... TextField nome = new TextField(71); TextField descricao = new TextField(68); Button salvar = new Button(“Salvar”); Button limpar = new Button(“Limpar”); Button report = new Button(“Relatório”); Button sair = new Button(“Sair”); Label result = new Label(); //método construtor public AppCadastro(){ ... painelCadastro.setLayout(new FlowLayout()); painelCadastro.add(new Label(“Nome:”)); painelCadastro.add(nome); painelCadastro.add(new Label(“Descrição:”)); painelCadastro.add(descricao); String[] colunas = {“NOME”, “DESCRIÇÃO”}; Object[][] conteudo = {{“”, “”}}; JTable tabela = new JTable(10,2); tabela.setPreferredScrollableViewportSize(new Dimension(560, 120)); painelCadastro.add(new JScrollPane(tabela)); Panel painelButton = new Panel(); painelButton.add(salvar); painelButton.add(limpar); painelButton.add(sair); painelButton.add(result); painelCadastro.add(“South”, painelButton); } ... } ... Univali/UNITINS • superior de tecnologia • 3º PERÍODO 87 Aula 7 • programação Com isso, temos nosso layout de nossa aplicação concluído, porém, ainda temos de adicionar as funcionalidades aos eventos que nossos botões reagirão. Dessa forma, inicialmente iremos criar nosso método que irá realizar a conexão com o banco de dados, abrindo espaço para que possamos criar outros métodos para inserção de novos elementos. ... import java.sql.*; import com.mysql.jdbc.Connection; ... public class AppCadastro extends Frame implements ActionListener{ ... public void actionPerformed(ActionEvent e) { ... } public Connection connection() { Connection connection = null; String con = “jdbc:mysql://localhost:3306/aula07?user=root&password=root”; try { Class.forName(“com.mysql.jdbc.Driver”).newInstance(); } catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } try { connection = (Connection) DriverManager.getConnection(con); } catch (SQLException e) { e.printStackTrace(); } return connection; } } ... Note que, em nosso método de conexão, utilizamos o driver jdbc para o banco de dados MySql, porém, adapte a string de conexão para que seu banco de dados, de forma que este seja acessado, possibilitando a inserção e consulta a seu seus dados. Pensando sobre o assunto Geralmente é necessário que realizemos o import dos drivers de conexão para um determinado banco de dados. Os SGBDs fornecem estas APIs junto com sua distribuição. Desta forma, consulte o manual de seu banco de dados e verifique o driver para conexão Java. Por exemplo, realizamos o import da classe “com.mysql.jdbc.Connection”. 88 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 7 • programação Levando a tona todo o conceito de orientação a objetos, criaremos nosso “modelo” de um curso, no caso a classe Curso, com seus atributos e métodos. Note que são disponibilizados os métodos get e set garantindo que os atributos não são acessados diretamente. Então, transcreva a classe Curso para dentro do arquivo. //AppCadastro.java ... public class AppCadastro extends Frame{ ... } class EvtJanela extends WindowAdapter{ ... } class Curso { private Integer id = new Integer(0); private String nome = new String(); private String descricao = new String(); private public String getDescricao() { return descricao; } public void setDescricao(String descricao) { this.descricao = descricao; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getNome() { return nome; } public void setNome(String nome) { this.nome = nome; } } Nosso próximo passo consiste na criação dos métodos que serão responsáveis por incluir e consultar dados em nosso banco de dados. Com isso, nos restara apenas fazer com que estes métodos sejam acionados por eventos em nossos botões. Assim, transcreva o código abaixo para sua classe e execute-a. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 89 Aula 7 • programação //AppCadastro.java ... import java.sql.*; import com.mysql.jdbc.Connection; import com.mysql.jdbc.ResultSet; import com.mysql.jdbc.Statement; public class AppCadastro extends Frame{ ... Curso c = new Curso(); ... public void incluir(){ try { Statement statement = connection().createStatement(); String sql = “Insert into Curso VALUES (null, \’”+c.getNome()+ “\’, \’”+c.getDescricao()+”\’)”; statement.executeUpdate(sql); result.setText(“CURSO INSERIDO COM SUCESSO!”); } catch (SQLException e) { e.printStackTrace(); result.setText(“OCORRERAM ERROS NA INSEÇÃO!”); } } public ResultSet consultar(){ ResultSet resultadoBanco = null; String consulta = “Select * from Curso”; try { PreparedStatement comandoBanco = connection().prepareStatement(consulta); resultadoBanco = comandoBanco.executeQuery(); connection().close(); } catch (Exception Erro) { result.setText(“OCORRERAM ERROS NA CONSULTA!”); } return resultadoBanco; } public void limpar(){ nome.setText(“”); descricao.setText(“”); } } Nos resta, ainda, gerar nosso relatório, conforme exemplificado na aula 6. Utilizaremos o arquivo jasper desenvolvido nesta aula, e assim temos somente que criar um método que execute a invocação de nosso relatório. Vamos ao que interessa: copie o código a seguir, conforme exemplificado, na classe AppCadastro. Pensando sobre o assunto Conforme exemplificado na aula 6, é interessante que seja utilizada uma ferramenta para criação dos relatórios, pois, além de acelerar todo o processo de desenvolvimento, evita um processo trabalhoso manual e, com isso, surpresas na construção dos relatórios. 90 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 7 • programação ... import import import import public java.io.*; net.sf.jasperreports.engine.*; net.sf.jasperreports.engine.export.*; net.sf.jasperreports.view.*; class AppCadastro extends Frame implements ActionListener{ Panel geral; //método construtor public AppCadastro(){ ... } ... public void actionPerformed(ActionEvent e) { ... } public void gerarReport() { try { Connection con = connection(); Statement stm = (Statement) con.createStatement(); String query = “Select * from Curso”; ResultSet rs = (ResultSet) stm.executeQuery(query); JRResultSetDataSource jrRS = new JRResultSetDataSource(rs); JRExporter jrpdf = new JRPdfExporter(); JasperPrint print; OutputStream fos = null; print = JasperFillManager.fillReport(“.\\reports\\Curso.jasper”, null, jrRS); fos = new FileOutputStream(“.\\reports\\Curso.pdf”); jrpdf.setParameter(JRExporterParameter.OUTPUT_STREAM, fos); jrpdf.setParameter(JRExporterParameter.JASPER_PRINT, print); jrpdf.exportReport(); fos.close(); JasperViewer.viewReport(print); } catch (IOException e) { e.printStackTrace(); } catch (JRException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } } } ... Para que nosso código funcione, certifique-se que o arquivo Curso. jasper está no “report” dentro do diretório em que nossa classe AppCadastro está. Como mencionado, iremos fazer com que nossos botões, assim que acionados, executem nossos métodos, e apresentem os resultados na tabela. Então, assim como nos exemplos, copie o código e verifique o resultado. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 91 Aula 7 • programação ... public class AppCadastro extends Frame implements ActionListener{ Panel geral; //método construtor public AppCadastro(){ ... salvar.addActionListener(this); limpar.addActionListener(this); report.addActionListener(this); sair.addActionListener(this); } ... public void actionPerformed(ActionEvent e) { ... if(e.getSource()==salvar){ c.setNome(nome.getText()); c.setDescricao(descricao.getText()); incluir(); limpar(); } if(e.getSource()==limpar){ limpar(); } if(e.getSource()==report){ gerarReport(); } if(e.getSource()==sair){ System.exit(0); } } } ... Chegamos ao fim de nosso estudo de caso. No quadro a seguir, é apresentado todo o código de nossa classe, auxiliando numa visão mais macro do exemplo apresentado. AppCadastro.java //AppCadastro.java import java.awt.*; import java.awt.event.*; import javax.swing.*; import java.io.*; import java.sql.*; import net.sf.jasperreports.engine.*; import net.sf.jasperreports.engine.export.*; import net.sf.jasperreports.view.*; import com.mysql.jdbc.Connection; import com.mysql.jdbc.ResultSet; import com.mysql.jdbc.Statement; 92 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 7 • programação public class AppCadastro extends Frame implements ActionListener{ TextField nome = new TextField(71); TextField descricao = new TextField(68); Button salvar = new Button(“Salvar”); Button limpar = new Button(“Limpar”); Button report = new Button(“Relatório”); Button sair = new Button(“Sair”); Panel geral; Curso c = new Curso(); Label result = new Label(); public AppCadastro(){ super(“Aplicação de cadastro”); setSize(600, 285); setLocation(200, 100); EvtJanela evt = new EvtJanela(); addWindowListener(evt); MenuBar barraMenu = new MenuBar(); Menu menuArquivo = new Menu(“Arquivo”); MenuItem itemCadastro = new MenuItem(“Novo de Curso”); MenuItem itemSair = new MenuItem(“Sair”, new MenuShortcut(KeyEvent.VK_R)); menuArquivo.add(itemCadastro); menuArquivo.add(itemSair); barraMenu.add(menuArquivo); setMenuBar(barraMenu); itemCadastro.addActionListener(this); itemSair.addActionListener(this); Panel painelApp = new Panel(); Panel painelCadastro = new Panel(); painelApp.setBackground(SystemColor.control); painelCadastro.setBackground(SystemColor.control); geral = new Panel(); geral.add(painelApp,”J1”); geral.add(painelCadastro,”J2”); geral.setLayout(new CardLayout()); add(“Center”,geral); painelCadastro.setLayout(new FlowLayout()); painelCadastro.add(new Label(“Nome:”)); painelCadastro.add(nome); painelCadastro.add(new Label(“Descrição:”)); painelCadastro.add(descricao); String[] colunas = {“NOME”, “DESCRIÇÃO”}; Object[][] conteudo = {{“”, “”}}; JTable tabela = new JTable(conteudo, colunas); tabela.setPreferredScrollableViewportSize(new Dimension(560,120)); painelCadastro.add(new JScrollPane(tabela)); Panel painelButton = new Panel(); painelButton.add(salvar); painelButton.add(limpar); painelButton.add(report); painelButton.add(sair); painelButton.add(result); painelCadastro.add(“South”, painelButton); salvar.addActionListener(this); limpar.addActionListener(this); report.addActionListener(this); sair.addActionListener(this); } Univali/UNITINS • superior de tecnologia • 3º PERÍODO 93 Aula 7 • programação public static void main(String[] args) { AppCadastro exec = new AppCadastro(); exec.setVisible(true); } public void actionPerformed(ActionEvent e) { if (e.getSource() instanceof MenuItem) { MenuItem item = (MenuItem) e.getSource(); if(item.getLabel().equals(“Sair”)){ System.exit(0); } if(item.getLabel().equals(“Novo de Curso”)){ CardLayout pilha = CardLayout) geral.getLayout(); pilha.next(geral); } } if(e.getSource()==salvar){ c.setNome(nome.getText()); c.setDescricao(descricao.getText()); incluir(); limpar(); } if(e.getSource()==limpar){ limpar(); } if(e.getSource()==report){ gerarReport(); } if(e.getSource()==sair){ System.exit(0); } } public void gerarReport() { try { Connection con = connection(); Statement stm = (Statement) con.createStatement(); String query = “Select * from Curso”; ResultSet rs = (ResultSet) stm.executeQuery(query); JRResultSetDataSource jrRS = new JRResultSetDataSource(rs); JRExporter jrpdf = new JRPdfExporter(); JasperPrint print; OutputStream fos = null; print = JasperFillManager.fillReport (“.\\reports\\Curso.jasper”, null, jrRS); fos = new FileOutputStream(“.\\reports\\Curso.pdf”); jrpdf.setParameter(JRExporterParameter.OUTPUT_STREAM,fos); jrpdf.setParameter(JRExporterParameter.JASPER_PRINT,print); jrpdf.exportReport(); fos.close(); JasperViewer.viewReport(print); } catch (IOException e) { e.printStackTrace(); } catch (JRException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } } 94 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 7 • programação public void incluir(){ try { Statement statement = Statement) connection().createStatement(); String sql = “Insert into Curso VALUES (null, \’”+ c.getNome()+”\’, \’”+ c.getDescricao()+”\’)”; statement.executeUpdate(sql); result.setText(“CURSO INSERIDO COM SUCESSO!”); } catch (SQLException e) { e.printStackTrace(); result.setText(“OCORRERAM ERROS NA INSEÇÃO!”); } } public void consultar(){ ResultSet resultadoBanco = null; String consulta = “Select * from Curso”; try { PreparedStatement comandoBanco = connection().prepareStatement(consulta); resultadoBanco = (ResultSet)comandoBanco.executeQuery(); connection().close(); } catch (Exception Erro) { result.setText(“OCORRERAM ERROS NA CONSULTA!”); } } public void limpar(){ nome.setText(“”); descricao.setText(“”); } public Connection connection() { Connection connection = null; try { Class.forName(“com.mysql.jdbc.Driver”).newInstance(); } catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } try { connection = (Connection) DriverManager.getConnection (“jdbc:mysql://localhost:3306/universidade?user=root&password= root”); } catch (SQLException e) { e.printStackTrace(); } return connection; } } class EvtJanela extends WindowAdapter{ public void windowClosing(WindowEvent e){ System.exit(0); } } Univali/UNITINS • superior de tecnologia • 3º PERÍODO 95 Aula 7 • programação class Curso { Integer id = new Integer(0); String nome = new String(); String descricao = new String(); public String getDescricao() { return descricao; } public void setDescricao(String descricao) { this.descricao = descricao; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getNome() { return nome; } public void setNome(String nome) { this.nome = nome; } } Se tudo ocorreu como o esperado, teremos, como resultado final, nossa aplicação, na qual poderemos realizar um novo cadastro, bem como gerar o relatório destes cadastros. Assim finalizamos nossa 7ª aula e logo nossa disciplina. Esperamos que todos tenham tirado o máximo de proveito e que agora todos sejam capazes de criar programas visuais, utilizando a biblioteca AWT, bem como gerar relatórios. Boa sorte a todos! Síntese da aula Nesta aula, aplicamos todos os conceitos e componentes apresentados durante esta aula, além de utilizar o paradigma de orientação a objetos, criando um estudo de caso, no qual pode ser realizado o cadastro em um banco de dados, geração de relatório e trabalhar com diversas janelas e componentes, fixando todo o conhecimento adquirido e alicerçando a idéia geral, para que novas aplicações possam ser construídas. 96 3º PERÍODO • superior de tecnologia • Univali/UNITINS Aula 7 • programação Atividades 1. Conforme utilizado em nosso estudo de caso, como pode ser realizado o processo de navegação entre painéis em uma aplicação visual Java? 2. Assinale a alternativa incorreta, referente aos componentes gráficos apresentados em nosso estudo de caso. a) A classe Panel consiste em uma classe do tipo container. b) P or meio da classe Frame, é possível criar diversas janelas para aplicações visuais. c) O componente Button é o responsável por executar as funcionalidades do sistema. d) As classes TextField e TextArea permitem o trabalho com textos. Comentário das atividades Na atividade 1, é possível se realizar todo o processo de navegação entre painéis, utilizando o gerenciador de layout CardLayout, e com o auxilio de um listener reagir a eventos e efetuar a mudança entre os painéis com a invocação do método next() ou after(). É válido relembrar que pode se trabalhar com outras janelas, por meio da instanciação de diversas classes derivadas da classe Frame. Na atividade 2, se você respondeu o item (c), parabéns, você acertou. No caso o botão, é apenas utilizado para passar ao sistema operacional uma mensagem de que um evento foi realizado, não executar ou mesmo fazer a chamada a uma funcionalidade do sistema, sendo que todo o comportamento deve ser implementado nos métodos oriundo dos listeners que são implementados. O item (a) está correto, uma vez que a classe Panel deriva da classe Container. O (b) também está correto, uma vez que por meio da classe Frame podemos criar diversas janelas. E, finalmente, o item (d) está correto, já que ambos os componentes trabalham com textos. Referências DEITEL, Harvey M. Java: como programar. 6 ed. São Paulo: Pearson Prentice Hall, 2005. FILHO, Renato Rodrigues. Desenvolva aplicativos com Java 2. São Paulo: Érica, 2005. Univali/UNITINS • superior de tecnologia • 3º PERÍODO 97 Aula 7 • programação FLANAGAN, David. Java: o guia essencial. 5. ed. Porto Alegre. Bookman, 2006. MANZANO, José Augusto Navarro Garcia; COSTA JR., Roberto Affonso da. Java 2: programação de computadores. São Paulo: Érica, 2006. THOMPSON, Marco Aurélio. Java 2 & banco de dados. São Paulo: Érica, 2002. Anotações 98 3º PERÍODO • superior de tecnologia • Univali/UNITINS