blob: 66f6148f128f63e947797723a48f2e9f2593796a [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Usando o Depurador Visual</title>
<link rel="stylesheet" href="../../../netbeans.css">
<link rel="stylesheet" type="text/css" href="../../../print.css" media="print">
<link rel="stylesheet" type="text/css" href="../../../lytebox.css" media="screen">
<script type="text/javascript" src="../../../images_www/js/lytebox-compressed.js"></script>
<meta name="description" content="A guide to using the visual debugger in NetBeans IDE to locate source code in GUI applications."/>
<meta HTTP-EQUIV="Content-Type" Content="text/html; charset=UTF-8"></head>
<body>
<h1>Usando o Depurador Visual no NetBeans IDE</h1>
<p>Este documento descreve como usar o Depurador Visual para ajudá-lo a localizar e depurar o código de elementos visuais em sua aplicação GUI. Você pode usar o depurador visual nas aplicações GUI Java e JavaFX.
</p>
<p>Neste documento, você irá usar o Depurador Visual para explorar o projeto de amostra Jogo de Anagramas. Este documento irá demonstrar como obter um snapshot da GUI da aplicação, e a seguir trabalhar com o snapshot para localizar os códigos-fonte, adicionar listeners aos eventos e exibir o log de eventos de componentes da GUI.
</p>
<p><b>Conteúdo</b></p>
<img alt="O conteúdo desta página se aplica ao NetBeans IDE 7.2, 7.3, 7.4 e 8.0" class="stamp" src="../../../images_www/articles/73/netbeans-stamp-80-74-73.png" title="O conteúdo desta página se aplica ao NetBeans IDE 7.2, 7.3, 7.4 e 8.0">
<ul>
<li><a href="#Exercise_10">Obtendo um Snapshot da GUI</a></li>
<li><a href="#Exercise_20">Trabalhando com o Depurador Visual</a>
<ul>
<li><a href="#Exercise_21">Localizando os Códigos-fonte</a></li>
<li><a href="#Exercise_22">Explorando Eventos do Componente</a></li>
</ul>
</li>
</ul>
<p><b>Para seguir este tutorial, são necessários os recursos e o software a seguir.</b></p>
<table>
<tr>
<th class="tblheader" scope="col">Software ou Recurso</th>
<th class="tblheader" scope="col">Versão Necessária</th>
</tr>
<tr>
<td class="tbltd1"><a href="https://netbeans.org/downloads/index.html">NetBeans IDE</a></td>
<td class="tbltd1">7.2, 7.3, 7.4, 8.0</td>
</tr>
<tr>
<td class="tbltd1"><a href="http://www.oracle.com/technetwork/java/javase/downloads/index.html">JDK (Java Development Kit)</a></td>
<td class="tbltd1">versão 7 ou 8</td>
</tr>
</table>
<p class="notes"><strong>Observação sobre JUnit.</strong> Se as bibliotecas JUnit não tiverem sido instaladas quando você instalou o IDE, você será solicitado a resolver os recursos ausentes e instalar o JUnit quando tentar depurar a aplicação.</p>
<!-- ===================================================================================== -->
<a name="Exercise_10"></a>
<h2>Obtendo um Snapshot da GUI</h2>
<p>Neste tutorial você irá usar a aplicação de amostra Jogo de Anagramas, uma aplicação desktop Java com uma GUI simples, que está disponível como amostra no assistente Novo Projeto. Após você criar o projeto, irá iniciar uma sessão de depuração e obter um snapshot da GUI da aplicação.
</p>
<ol>
<li>Escolha Arquivo > Novo Projeto no menu principal (Ctrl-Shift-N; ⌘-Shift-N no Mac) para abrir o assistente Novo Projeto.</li>
<li>Selecione Jogo de Anagramas na categoria Amostras > Java. Clique em Próximo.</li>
<li>Selecione uma localização para o projeto. Clique em Finalizar.
<p>Quando você clica em Finalizar, o IDE cria o projeto e o abre na janela Projetos.</p>
</li>
<li>Clique no botão Depurar na barra de ferramentas (Ctrl-F5; -F5 no Mac) para iniciar a sessão de depuração.
<p>Alternativamente, clique com o botão direito do mouse no nó do projeto na janela Projetos e escolha Depurar.</p>
<p>Quando você inicia a sessão, o IDE irá iniciar a aplicação Jogo de Anagramas e abrirá a janela Depuração.</p>
<p>Para obter mais informações sobre a execução do depurador, consulte <a href="http://www.oracle.com/pls/topic/lookup?ctx=nb8000&id=NBDAG798">Sobre Execução e Depuração de Projetos de Aplicação Java</a> em <em>Desenvolvendo Aplicações com o NetBeans IDE</em>.</p>
</li>
<li>Escolha Depurar > Obter Snapshot da GUI no menu principal.
<p>Quando você escolhe Obter um Snapshot da GUI, o IDE irá obter um snapshot da GUI e irá abrir o snapshot na janela principal.</p>
</li>
</ol>
<a href="../../../images_www/articles/74/java/visualdebug/debug-fullscreen.png" rel="lytebox" title="O snapshot da GUI será exibido na janela principal do IDE"> <img alt="Tela de snapshot GUI" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-fullscreen.png" style="width:600px" title="Clique para aumentar"></a>
<p>Neste guia para o depurador visual de erros, você não irá usar a janela Depuração.</p>
<a name="Exercise_20"></a>
<h2>Trabalhando com o Depurador Visual</h2>
<p>O snapshot da GUI é uma ferramenta de depuração visual que pode ajudar a localizar os códigos-fonte para componentes da GUI. Os códigos-fonte para componentes da GUI pode ser às vezes difícil de ser localizado e o snapshot fornece um meio para localizar o código com base na GUI ao invés de procurar por meio do código. Você seleciona os componentes no snapshot e chama tarefas no menu pop-up para exibir os códigos-fonte para o componente, mostrar os listeners e definir pontos de interrupção nos componentes.
</p>
<div class="indent">
<a name="Exercise_21"></a>
<h3>Localizando s Código-fonte para Componentes</h3>
<p>Neste exercício iremos demonstrar como usar o snapshot da GUI para navegar para as linhas nos códigos-fonte onde um componente está declarado e definido. Quando você selecionar um componente no snapshot da GUI, poderá usar o menu pop-up para chamar diversos comandos.
</p>
<p class="tips">Os comandos também podem ser chamados da janela Navegador ao clicar com o botão direito do mouse no componente e ao escolher o comando no menu pop-up.</p>
<ol>
<li>No snapshot da GUI, selecione o botão Adivinhar.
<p>Quando você seleciona o componente no snapshot, o IDE exibe detalhes sobre o componente selecionado na janela Propriedades. Se a janela Propriedades não estiver visível, você poderá escolher Janela > Propriedades no menu principal para abrir a janela.</p>
<img alt="Tela de snapshot GUI" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-snapshot.png" title="Snapshot GUI">
<p>O IDE também exibe o local do componente na forma hierárquica na janela Navegador.</p>
<img alt="Tela de snapshot GUI" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-navigator.png" title="Snapshot GUI">
</li>
<li>Clique com o botão direito do mouse no botão Adivinhar no snapshot e escolha Ir para a Declaração do Componente no menu pop-up.
<p>Quando você escolhe Ir para a Declaração do Componente, o IDE abre o arquivo de códigos-fonte no editor e move o cursor para a linha no código onde <tt>guessButton</tt> está declarado.</p>
<img alt="Tela do código-fonte no editor" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-gotodeclaration.png" title="Linha de código onde o componente é declarado">
</li>
<li>Clique novamente com o botão direito do mouse no botão Adivinhar no snapshot e escolha Ir para o Código-fonte do Componente.
<p>Quando você escolhe Ir para o Código-fonte do Componente, o IDE abre o arquivo de códigos-fonte no editor e move o cursor para a linha no código para o componente JButton.</p>
<img alt="Tela do código-fonte no editor" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-gotosource.png" title="Linha de código-fonte para o componente" />
</li>
</ol>
<p>
Você pode usar o comando Ir Para a Adição de Hierarquia no snapshot GUI para localizar a linha no código-fonte no qual um componente é adicionado ao seu contêiner. O comando Ir Para a Adição de Hierarquia é desativado por default. Você pode ativar o comando na janela Opções.
</p>
<ol>
<li>Abra a janela Opções.</li>
<li>Clique na guia Depurador Java na categoria Java na janela Opções.
<p class="notes"><strong>Observação.</strong> No NetBeans IDE 7.1, a guia Depurador Java está localizada na categoria Diversos na janela Opções.</p></li>
<li>Selecione Depuração Visual na lista de categorias e selecione <strong>Rastrear as localizações das alterações de hierarquia do componente</strong>. Clique em OK.</li>
<li>Interrompa sua sessão de depuração (se uma estiver em execução).
<p class="notes"><strong>Observação.</strong> Após ativar o comando na janela Opções, você precisará reiniciar sua sessão de depuração e obter um novo snapshot GUI antes de usar o comando Ir Para a Adição de Hierarquia.</p>
</li>
<li>Inicie uma sessão de depuração e obtenha um snapshot da GUI.</li>
<li>Clique com o botão direito do mouse em um componente no snapshot da GUI e escolha Ir Para a Adição de Hierarquia.
<p>O IDE irá abrir o código-fonte no editor na linha onde o componente está adicionado.</p>
<img alt="Tela do código-fonte no editor" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-hierarchy.png" title="Linha do código-fonte onde o componente é adicionado ao contêiner" />
</li>
</ol>
<a name="Exercise_22"></a>
<h3>Explorando Eventos do Componente</h3>
<p>Este exercício irá demonstrar como você pode usar o snapshot da GUI e a janela Eventos para explorar eventos do componente permitindo localizar os listeners do componente e os eventos que são acionados pelos componentes.</p>
<ol>
<li>Clique com o botão direito do mouse no botão Adivinhar no snapshot e escolha Mostrar listeners no menu pop-up.
<p>Quando você escolhe Mostrar Listeners, o IDE abre a janela Eventos. Você pode ver que o nó Listeners Personalizados está expandido.</p>
<img alt="Tela do código-fonte no editor" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-customlisteners.png" title="Linha do código-fonte onde o componente é adicionado ao contêiner" />
</li>
<li>Clique com o botão direito do mouse em <strong>com.toy.anagrams.ui.Anagrams$3</strong> abaixo do nó Listeners Personalizados e escolha Ir para o Código-fonte do Componente no menu pop-up.
<p>O código-fonte é aberto no editor na linha onde o listener está definido.</p>
</li>
<li>Selecione o campo de texto vazio no snapshot.
<p>Outra opção é selecionar o campo de texto <tt>guessedWord</tt> na janela Navegador.</p>
<p>Quando você selecionar o campo de texto, os itens na janela Eventos irá mudar automaticamente para exibir os listeners para o componente selecionado.</p></li>
<li>Na janela Eventos, clique duas vezes no nó Log de Eventos para abrir a janela Selecionar Listener.
<p>Se preferir, clique com o botão direito do mouse no nó Log de Eventos e escolha Definir o Log de Eventos do menu pop-up.</p></li>
<li>Selecione o listener<tt>java.awt.event.KeyListener</tt> na caixa de diálogo. Clique em OK.<br /> <img alt="Tela do código-fonte no editor" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-select-listener.png" title="Linha do código-fonte onde o componente é adicionado ao contêiner" />
<p>Este listener está agora fazendo listening para eventos de teclado no campo de texto.</p>
</li>
<li>Na aplicação Jogo de Anagramas, digite alguns caracteres no campo de texto.
<p>Quando você digita um caractere no campo de texto, o evento é registrado no log de eventos. Caso você expanda o nó Log de Eventos, poderá ver que cada tecla pressionada está agora registrada. Novos eventos aparecem todas as vezes que você digita no campo de texto da aplicação Jogo de Anagramas. Se você expandir um evento individual, por exemplo <tt>keyPressed</tt>, poderá ver as propriedades daquele evento no log.</p>
<img alt="Tela do código-fonte no editor" class="margin-around b-all" src="../../../images_www/articles/74/java/visualdebug/debug-eventlog.png" title="Linha do código-fonte onde o componente é adicionado ao contêiner" />
<p>Caso você expanda o nó "Chamado de..." para um evento, poderá ver o traço da pilha para o evento.</p>
</li>
</ol>
</div>
<!-- ===================================================================================== -->
<p>Este tutorial foi uma introdução básica para o depurador visual no IDE. O depurador visual permite localizar com facilidade o código-fonte e eventos do log para componentes da GUI. Isso pode ser extremamente útil quando você estiver depurando aplicações de GUI.
</p>
<!-- End Content Area -->
<br>
<div class="feedback-box"><a href="https://netbeans.org/about/contact_form.html?to=3&amp;subject=Feedback:%20Using%20the%20Visual%20Debugger">Enviar Feedback neste Tutorial</a></div>
<br style="clear:both;" />
<!-- ======================================================================================= -->
<h2><a name="nextsteps"></a>Consulte Também</h2>
<p>Para obter mais informações sobre o desenvolvimento e teste de aplicações Java no NetBeans IDE, veja os recursos a seguir:</p>
<ul>
<li><a href="gui-functionality.html">Introdução à Construção de GUIs do Java</a></li>
<li>Demonstração: <a href="debug-visual-screencast.html">Usando o Depurador Visual</a></li>
<li>Demonstração: <a href="debug-multithreaded-screencast.html">Depurando uma Aplicação Multithread</a></li>
<li>Demonstração: <a href="debug-stepinto-screencast.html">Ação Visual Step Into no Depurador do NetBeans</a></li>
<li>Demonstração: <a href="debug-deadlock-screencast.html">Detecção de Bloqueio usando o Depurador do NetBeans</a></li>
<li>Demonstração: <a href="debug-evaluator-screencast.html">Usando o Avaliador de Snippet do Código no Depurador do NetBeans</a></li>
<li><a href="../../trails/java-se.html">Trilha de Aprendizado da Programação Java e IDE Básica</a></li>
</ul>
</body>
</html>