blob: 7329fbe528b048fdff5253c33d80b1bd7936c51e [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!--
Copyright (c) 2009, 2014, Oracle and/or its affiliates. All rights reserved.
-->
<html>
<head>
<title>构建 GUI 应用程序简介 - NetBeans IDE 教程</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" >
<meta name="KEYWORDS" content="NETBEANS, TUTORIAL, GUIDE, USER, DOCUMENTATION">
<meta name="description" content="Adding Functionality to Buttons with the NetBeans GUI Builder: This tutorial teaches you how to build a simple GUI with back-end functionality. This tutorial is geared to the beginner and introduces the basic construction of a GUI with functionality. We will work through the layout and design of a GUI and add a few Buttons and Text Boxes. The Text Boxes will be used for receiving user input and also for displaying the program output. The Button will initiate the functionality built into the front end.">
<link rel="stylesheet" href="../../../netbeans.css">
<meta name="author" content="Saleem Gul, Tomas Pavek">
</head>
<body>
<h1>构建 GUI 应用程序简介</h1>
<div class="articledate" style="margin-left: 0px;">撰稿人:Saleem Gul 和 Tomas Pavek</div>
<p>本入门教程讲述如何创建简单图形用户界面以及如何添加简单后端功能。尤其介绍了如何为 Swing 窗体中的按钮和字段行为编写代码。
</p>
<p>我们将完成 GUI 布局和设计工作并添加几个按钮和文本字段。这些文本字段用于接收用户输入和显示程序输出。这些按钮用于启动前端的内置功能。我们创建的应用程序是一个非常简单但功能完善的计算器。
</p>
<p>有关更全面的 GUI 构建器设计功能指南(包括各种设计功能的视频演示),请参见<a href="quickstart-gui.html">在 NetBeans IDE 中设计 Swing GUI</a></p>
<p align="center"><b>预计时间:20 分钟</b></p>
<div class="indent">
<h3>目录</h3>
<img alt="此页上的内容适用于 NetBeans IDE 6.9 及更高版本" class="stamp" src="../../../images_www/articles/73/netbeans-stamp-80-74-73.png" title="此页上的内容适用于 NetBeans IDE 6.9 及更高版本">
<ul class="toc">
<li><a HREF="#Exercise_1">练习 1:创建项目</a></li>
<li><a HREF="#Exercise_2">练习 2:构建前端</a></li>
<li><a HREF="#Exercise_3">练习 3:添加功能</a></li>
<li><a HREF="#Exercise_4">练习 4:运行程序</a></li>
<li><a HREF="#how">事件处理的工作方式</a></li>
<li><a HREF="#seealso">另请参见</a></li>
</ul>
<p><b>要学完本教程,您需要具备以下软件和资源。</b></p>
<table>
<tbody>
<tr>
<th class="tblheader" scope="col">软件或资源</th>
<th class="tblheader" scope="col">要求的版本</th>
</tr>
<tr>
<td class="tbltd1"><a href="http://netbeans.org/downloads/">带有 Java SE 的 NetBeans IDE</a></td>
<td class="tbltd1">版本 6.9 或更高版本</td>
</tr>
<tr>
<td class="tbltd1"><a href="http://www.oracle.com/technetwork/java/javase/downloads/index.html">Java 开发工具包 (JDK)</a></td>
<td class="tbltd1">版本 6、7 或 8 </td>
</tr>
</tbody>
</table>
</div>
<h2><a name="Exercise_1"></a>练习 1:创建项目</h2>
<p>第一步是为要开发的应用程序创建 IDE 项目。我们将项目命名为 <tt>NumberAddition</tt></p>
<ol>
<li>选择<tt>文件</tt> > <tt>新建项目</tt>。或者,也可以单击 IDE 工具栏中的“新建项目”图标。</li>
<li>在“类别”窗格中,选择 "Java" 节点。在“项目”窗格中,选择“Java 应用程序”。单击“下一步”。 </li>
<li>在“项目名称”字段中键入 <code>NumberAddition</code>,然后指定路径(例如,在主目录中)作为项目位置。 </li>
<li>(可选)选中“使用专用文件夹存储库”复选框,并指定库文件夹的位置。有关详细信息,请参见<i>使用 NetBeans IDE 开发应用程序</i>中的<a href="http://www.oracle.com/pls/topic/lookup?ctx=nb8000&id=NBDAG455">与其他用户共享库</a></li>
<li>如果已选中“创建主类”复选框,请取消选中该复选框。 </li>
<li>单击“完成”。</li>
</ol>
<!-- ===================================================================================== -->
<h2><a name="Exercise_2"></a>练习 2:构建前端</h2>
<p>要继续构建界面,我们需要创建一个 Java 容器,以便放置所需的其他 GUI 组件。在此步骤中,我们将使用 <code>JFrame</code> 组件创建一个容器。我们将该容器放在新包中,该包将显示在“源包”节点中。</p>
<div class="indent">
<h3 class="tutorial">创建 JFrame 容器</h3>
<ol>
<li>在“项目”窗口中,右键单击 <tt>NumberAddition</tt> 节点,然后选择<tt>新建</tt> > <tt>其他</tt></li>
<li>在“新建文件”对话框中,选择 <tt>Swing GUI 窗体</tt>类别和 <tt>JFrame 窗体</tt>文件类型。单击“下一步”。</li>
<li>输入 <tt>NumberAdditionUI</tt> 作为类名。</li>
<li>在“包”中输入 <code>my.numberaddition</code></li>
<li>单击“完成”。</li>
</ol>
<p>IDE 将在 <code>NumberAddition</code> 应用程序中创建 <code>NumberAdditionUI</code> 窗体和 <code>NumberAdditionUI</code> 类,然后在 GUI 构建器中打开 <code>NumberAdditionUI</code> 窗体。<code>my.NumberAddition</code> 包将替代默认包。</p>
<h3 class="tutorial">添加组件:生成前端</h3>
<p>接下来,我们将通过组件面板使用 JPanel 填充应用程序前端。然后,添加三个 JLabel、三个 JTextField 和三个 JButton。如果以前没有用过 GUI 构建器,您可能会发现<a href="quickstart-gui.html">在 NetBeans IDE 中设计 Swing GUI</a> 教程中有关组件放置的信息非常有用。</p>
<p>在拖动并放置完上述组件后,JFrame 应类似于以下屏幕快照。 </p>
<p class="align-center"><img alt="JFrame,带有 3 个 JLabel,3 个 JButton 和 3 个 JTextField" class="margin-around" src="../../../images_www/articles/72/java/gui-functionality/Figure1.png"></p>
<p>如果 IDE 右上角未显示“组件面板”窗口,则选择“窗口”>“组件面板”。</p>
<ol>
<li>先从“组件面板”的“Swing 容器”类别中选择一个面板,然后将其拖放到 JFrame 上。</li>
<li>在突出显示该 JPanel 时,转至“属性”窗口,然后单击 "Border" 旁边的省略号 (...) 按钮以选择边框样式。</li>
<li>在 "Border" 对话框中,从列表中选择“带标题的边框”,然后在“标题”字段中键入 <code>Number Addition</code>。单击“确定”。保存更改并退出该对话框。</li>
<li>现在,将会看到一个标题为 Number Addition 的空 JFrame,它与屏幕快照类似。按照上面的屏幕快照所示,添加三个 JLabel、三个 JTextField 和三个 JButton。</li>
</ol>
<h3 class="tutorial">重命名组件</h3>
<p>在该步骤中,我们将重命名刚添加到 JFrame 中的这些组件的显示文本。</p>
<ol>
<li>双击 <code>jLabel1</code> 并将文本属性更改为 <code>First Number</code></li>
<li>双击 <code>jLabel2</code> 并将文本更改为 <code>Second Number</code></li>
<li>双击 <code>jLabel3</code> 并将文本更改为 <code>Result</code></li>
<li>删除 <code>jTextField1</code> 中的样例文本。要使显示文本可编辑,可以右键单击文本字段,然后从弹出式菜单中选择“编辑文本”。可能需要将 <code>jTextField1</code> 调整为原始大小。对于 <code>jTextField2</code><code>jTextField3</code>,重复此步骤。 </li>
<li><code>jButton1</code> 显示文本重命名为 <code>Clear</code>。(可以通过右键单击按钮并选择“编辑文本”来编辑按钮的文本。或者,也可以单击按钮,稍等片刻,然后再次单击按钮。) </li>
<li><code>jButton2</code> 显示文本重命名为 <code>Add</code></li>
<li><code>jButton3</code> 显示文本重命名为 <code>Exit</code></li>
</ol>
<p>现在,完成的 GUI 应类似于以下屏幕快照:</p>
<p class="align-center"><img alt="完成的应用程序" class="margin-around" src="../../../images_www/articles/72/java/gui-functionality/Figure2.png"></p>
</div>
<!-- ======================================================================================= -->
<h2><a name="Exercise_3"></a>练习 3:添加功能</h2>
<p>在本练习中,我们将为 "Add"、"Clear" 和 "Exit" 按钮添加功能。<code>jTextField1</code><code>jTextField2</code> 框用于用户输入,<code>jTextField3</code> 用于程序输出;我们要创建的应用程序是一个非常简单的计算器。我们现在就开始吧。</p>
<div class="indent">
<h3 class="tutorial">使 "Exit" 按钮正常工作</h3>
<p>要为这些按钮添加功能,必须为每个按钮指定事件处理程序以响应事件。在本示例中,我们需要了解何时通过鼠标单击或键盘按下了按钮。因此,我们使用 ActionListener 来响应 ActionEvent。 <!--TODO clarify here--></p>
<ol>
<li>右键单击 "Exit" 按钮。从弹出式菜单中选择“事件”>“操作”> "actionPerformed"。请注意,该菜单中还包含很多其他可响应的事件!在选择 <tt>actionPerformed</tt> 事件时,IDE 自动在 "Exit" 按钮中添加 ActionListener,并生成一种处理程序方法,以处理监听程序的 actionPerformed 方法。 </li>
<li>IDE 将打开源代码窗口并滚动至某一位置,在此将实现按下按钮(通过鼠标单击或键盘)时希望其执行的操作。源代码窗口应包含以下行:
<pre class="examplecode">private void jButton3ActionPerformed(java.awt.event.ActionEvent evt) {
//TODO add your handling code here:
}</pre></li>
<li>现在,我们将为希望 "Exit" 按钮执行的操作添加代码。将 TODO 行替换为 <code>System.exit(0);</code>。完成的 "Exit" 按钮代码应如下所示:
<pre class="examplecode">private void jButton3ActionPerformed(java.awt.event.ActionEvent evt) {
System.exit(0);
} </pre>
</li>
</ol>
<h3 class="tutorial">使 "Clear" 按钮正常工作</h3>
<ol>
<li>单击工作区域顶部的“设计”标签以返回到窗体设计区域。</li>
<li>右键单击 "Clear" 按钮 (<code>jButton1</code>)。从弹出式菜单中选择“事件”>“操作”> "actionPerformed"。</li>
<li>"Clear" 按钮用于删除 jTextField 中的所有文本。为此,将添加一些与以上代码类似的代码。完成的源代码应如下所示:
<pre class="examplecode">private void jButton1ActionPerformed(java.awt.event.ActionEvent evt){
jTextField1.setText(&quot;&quot;);
jTextField2.setText(&quot;&quot;);
jTextField3.setText(&quot;&quot;);
}</pre>
</li>
</ol>
<p>上面的代码将所有三个 JTextField 中的文本更改为空,实际就是使用空白覆盖现有文本。</p>
<h3 class="tutorial">使 "Add" 按钮正常工作</h3>
<p>"Add" 按钮用于执行三个操作。 </p>
<ol><li>它接受 <code>jTextField1</code><code>jTextField2</code> 中的用户输入,并将输入类型由字符串转换为浮点。 </li>
<li>然后,它将两个数相加。</li>
<li>最后,将相加之和的类型转换为字符串,并将其放在 <code>jTextField3</code> 中。</li>
</ol>
我们现在就开始吧!
<ol>
<li>单击工作区域顶部的“设计”标签以返回到窗体设计区域。</li>
<li>右键单击 "Add" 按钮 (<code>jButton2</code>)。从弹出式菜单中选择“事件”>“操作”> "actionPerformed"。</li>
<li>我们将添加一些代码以使 "Add" 按钮正常工作。完成的源代码应如下所示:
<pre class="examplecode">private void jButton2ActionPerformed(java.awt.event.ActionEvent evt){
// First we define float variables.
float num1, num2, result;
// We have to parse the text to a type float.
num1 = Float.parseFloat(jTextField1.getText());
num2 = Float.parseFloat(jTextField2.getText());
// Now we can perform the addition.
result = num1+num2;
// We will now pass the value of result to jTextField3.
// At the same time, we are going to
// change the value of result from a float to a string.
jTextField3.setText(String.valueOf(result));
}</pre>
</li>
</ol>
<p>程序已创建完毕,我们现在可以构建并运行该程序以查看其运行情况。 </p>
</div>
<h2><a name="Exercise_4"></a>练习 4:运行程序</h2>
<p><b>在 IDE 中运行程序:</b></p>
<ol>
<li>选择“运行”>“运行主项目”(或按 F6 键)。
<p class="notes"><b>注:</b>如果显示的窗口通知您项目 NumberAddition 没有设置主类,则应在同一窗口中选择 <tt>my.NumberAddition.NumberAdditionUI</tt> 作为主类,然后单击“确定”按钮。</p></li>
</ol>
<p><b>在 IDE 外部运行程序:</b></p>
<ol>
<li>选择“运行”>“清理并构建主项目”(Shift-F11 组合键)以构建应用程序 JAR 文件。</li>
<li>通过使用系统的文件资源管理器或文件管理器,导航至 <code>NumberAddition/dist</code> 目录。
<p class="notes"><b>注:</b><tt>NumberAddition</tt> 项目目录的位置取决于在<a href="#Exercise_1">练习 1:创建项目</a>部分中的第 3 步创建项目时指定的路径。</p>
</li>
<li>双击 <code>NumberAddition.jar</code> 文件。</li>
</ol>
<p>几秒钟后,将会启动应用程序。</p>
<p class="notes"><b>注:</b>如果在双击 JAR 文件时没有启动应用程序,请参见<a href="../../articles/javase-deploy.html#troubleshooting">本文</a>以了解在操作系统中设置 JAR 文件关联的相关信息。</p>
<p>也可以通过命令行启动应用程序。</p>
<p><b>通过命令行启动应用程序:</b></p>
<ol>
<li>在系统上,打开命令提示符或终端窗口。</li>
<li>在命令提示符中,转至 <code>NumberAddition/dist</code> 目录。</li>
<li>在命令行中,键入以下语句:
<pre class="examplecode">java -jar NumberAddition.jar</pre>
<p class="notes"><b>注:</b>请确保 <tt>my.NumberAddition.NumberAdditionUI</tt> 设置为主类,然后再运行应用程序。检查方式如下:在“项目”窗格中右键单击 NumberAddition 项目节点,在弹出菜单中选择“属性”,然后在“项目属性”对话框中选择“运行”类别。“主类”字段将显示 <tt>my.numberaddition.NumberAdditionUI</tt></p>
</li>
</ol>
<h2><a name="how"></a>事件处理的工作方式</h2>
<p>本教程已介绍了如何响应简单的按钮事件。还可以让应用程序响应很多其他事件。IDE 可以帮助您查找 GUI 组件可处理的可用事件列表:</p>
<ol>
<li>返回至编辑器中的 <code>NumberAdditionUI.java</code> 文件。单击“设计”标签以在 GUI 构建器中查看 GUI 布局。</li>
<li>右键单击任何 GUI 组件,然后从弹出式菜单中选择“事件”。目前,仅浏览菜单以查看其中的内容,而无需选择任何内容。</li>
<li>或者,也可以从“窗口”菜单中选择“属性”。在“属性”窗口中,单击“事件”标签。在“事件”标签中,可以查看和编辑与当前活动 GUI 组件关联的事件处理程序。</li>
<li>可以让应用程序响应按键、鼠标单击、双击和三击、鼠标移动、窗口大小以及焦点变化。可以从“事件”菜单中为所有这些内容生成事件处理程序。最常用的事件是 Action 事件。(要了解<a href="http://java.sun.com/docs/books/tutorial/uiswing/events/generalrules.html#twokinds">事件处理的最佳做法</a>,请参见 Sun 的 <a href="http://java.sun.com/docs/books/tutorial/uiswing/events/index.html">Java 事件教程</a>。)</li>
</ol>
<p>事件处理是如何工作的呢?每次从“事件”菜单中选择事件时,IDE 都会自动创建一个所谓的事件监听程序,并将其与组件关联。请完成以下步骤以查看事件处理的工作方式。</p>
<ol>
<li>返回至编辑器中的 <code>NumberAdditionUI.java</code> 文件。单击“源”标签以查看 GUI 源代码。</li>
<li>向下滚动并注意刚实现的方法 <code>jButton1ActionPerformed()</code><code>jButton2ActionPerformed()</code><code>jButton3ActionPerformed()</code>。这些方法称为事件处理程序。</li>
<li>现在,滚动至名为 <code>initComponents()</code> 的方法。如果未看到该方法,请查找显示 <code>Generated Code</code> 的行;单击该行旁边的 + 号以展开折叠的 <code>initComponents()</code> 方法。</li>
<li>首先,请注意 <code>initComponents()</code> 方法周围的蓝色块。此代码是由 IDE 自动生成的,无法对其进行编辑。</li>
<li>现在,浏览 <code>initComponents()</code> 方法。此外,该方法还包含用于初始化 GUI 组件并将其放置在窗体上的代码。在“设计”视图中放置和编辑组件时,将会自动生成和更新该代码。</li>
<li><code>initComponents()</code> 中,向下滚动至显示以下内容的位置:
<pre class="examplecode">jButton3.setText(&quot;Exit&quot;);
jButton3.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton3ActionPerformed(evt);
}
});</pre>
<p>这是在 GUI 组件中添加事件监听程序对象的位置;在本示例中,将在 <code>jButton3</code> 中注册 ActionListener。ActionListener 接口具有一个 actionPerformed 方法,该方法采用 ActionEvent 对象(只需调用 <code>jButton3ActionPerformed</code> 事件处理程序即可实现)作为其参数。现在,该按钮将监听 action 事件。每次按下该按钮时,都会生成 ActionEvent 并将其传递给监听程序的 actionPerformed 方法,而该方法又会执行在该事件的事件处理程序中提供的代码。</p></li>
</ol>
<p>
一般来说,要能够进行响应,每个交互式 GUI 组件需要在事件监听程序中进行注册,并且需要实现事件处理程序。正如您所看到的一样,NetBeans IDE 可处理关联事件监听程序的工作,因此,您可以集中精力实现应由事件触发的实际业务逻辑。
</p>
<!--TODO: Add Swing App framework info, links-->
<div class="feedback-box">
<a href="/about/contact_form.html?to=3&amp;subject=Feedback:%20Introduction%20to%20GUI%20Building">发送有关此教程的反馈意见</a>
</div>
<br style="clear:both;">
<h2><a name="seealso"></a>另请参见</h2>
<ul>
<li><i>使用 NetBeans IDE 开发应用程序</i>中的<a href="http://www.oracle.com/pls/topic/lookup?ctx=nb8000&id=NBDAG920">实现 Java GUI</a></li>
<li><a href="quickstart-gui.html">在 NetBeans IDE 中设计 Swing GUI</a></li>
<li><a href="gui-image-display.html">在 GUI 应用程序中处理图像</a></li>
<li><a href="hibernate-java-se.html">在 Java Swing 应用程序中使用 Hibernate</a></li>
<li><a href="../../trails/matisse.html">Java GUI 应用程序学习资源</a></li>
<li><a href="../../trails/java-se.html">常规 Java 开发学习资源</a></li>
<li><a href="http://wiki.netbeans.org/wiki/view/NetBeansUserFAQ#section-NetBeansUserFAQ-GUIEditorMatisse" target="_blank">GUI 构建器 - 常见问题解答</a></li>
<li><a href="http://download.oracle.com/javase/tutorial/index.html" target="_blank">Java(tm) 教程</a>中的<a href="http://download.oracle.com/javase/tutorial/uiswing/events/index.html" target="_blank">课程:编写事件监听程序</a></li>
</ul>
</body>
</html>