百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

初学者的第一个Java GUI入门程序(第一个java程序代码)

ccwgpt 2024-10-24 09:05 45 浏览 0 评论

本例子学习如下内容:

? JavaGUI开发模式

? JFrame框架类

1.1创建一个项目

在eclipse中创建java Project项目,项目名称为guiDemo,从File->New->Project->Java Project,界面如下图所示。

点Next,输入项目名称:guiDemo。

然后点击finish按钮完成项目创建。结果如下图所示:

1.2 项目的开发过程

1.2.1 需求分析

通过开发一个GUI程序,在窗口中添加一张图片,并且通过键盘中的方向键控制图片在窗口中移动。

要完成此功能必须完成以下以下工作:

? 创建一个界面窗口;

? 在窗口中加载一张图片;

? 添加键盘事件;

? 为键盘事件添加控制代码;

1.2.2 项目开发过程

在上面创建的项目中有一个文件夹src,此文件夹是存放编写源代码的地方,另外一个JRE System Library是此项目运行需要加载的jar包。

下面详细说明开发过程:

1) 创建包

在src文件夹下创建一个包:com.sosee,过程如下:

用鼠标选中src文件夹,点右键弹出菜单:

? 在弹出窗口中的Name文本框中输入:com.sosee,如下图

? 点finish按钮完成包的创建;

2) 创建主窗口

创建系统主界面,我们通过继承JFrame框架类创建窗口界面。下面说明创建主窗口类的过程,此类名我们定义为PictMain。过程如下:

? 用鼠标选中上面创建的包com.sosee,点右键弹出菜单,选择new->Class,打开如下界面:

? 输入内容后的界面如下:

? 点Finish按钮完成类的创建。自动打开创建的类文件内容窗口,内容如下:

package com.sosee;


import javax.swing.JFrame;


public class PictMain extends JFrame {

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

}


}

? 定义窗口显示宽度和高度,这里我们定义两个常量,为此类创建一个构造方法,在此方法中设置窗口的大小,代码如下:

package com.sosee;


import javax.swing.JFrame;


public class PictMain extends JFrame {


private static final int WIDTH=500;//定义的宽度

private static final int HEIGHT=400;//定义的高度


/**

* 创建一个构造方法,参数为此窗口的标题

* @param title

*/

public PictMain(String title) {

super(title);

this.setSize(WIDTH, HEIGHT);//设置窗口大小

}

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub


}


}

3) 创建显示板:

下面我们通过继承Jpanel板创建我们加载图片的面板,并且为此板添加键盘事件,此处是通过实现键盘监听事件接口(KeyListener)来完成,创建过程参见主窗口类的创建过程,只是在创建类的实现接口时注意是通过点add按钮来添加的如下图所示:

选择KeyListener接口,点OK。

点Finish按钮完成面板类的创建。

4) 为显示板类添加加载图片文件和实现键盘控制的代码如下:

package com.sosee;


import java.awt.Graphics;

import java.awt.Image;

import java.awt.event.KeyEvent;

import java.awt.event.KeyListener;

import java.io.File;

import java.io.IOException;


import javax.imageio.ImageIO;

import javax.swing.JPanel;


public class PictPanel extends JPanel implements KeyListener {

private final short UP=38;

private final short DOWN=40;

private final short LEFT=37;

private final short RIGHT=39;

private int x;

private int y;

private Image image=null;


/**

* 读取图片文件

* @param mapname

* @return

*/

private Image initmap(String fileName){

try {

image=ImageIO.read(new File(fileName));

} catch (IOException e) {

e.printStackTrace();

}

return image;

}


/**

* 构造方法,调用图形文件读取方法

*/

public PictPanel() {

image=initmap("c:/map.jpg");//这里可以随意指定一个图片文件

this.addKeyListener(this);

}


/**

* 通过重载此方法,实现在面板上绘制加载的图

*/

@Override

protected void paintComponent(Graphics g) {

// TODO Auto-generated method stub

super.paintComponent(g);

g.drawImage(image,x,y,null);

}


@Override

public void keyPressed(KeyEvent e) {

//38up,40down,37left,39right

switch(e.getKeyCode()){

case UP:

y=y-8;

break;

case DOWN:

y=y+8;

break;

case LEFT:

x=x+8;

break;

case RIGHT:

x=x-8;

break;

}

this.paint(this.getGraphics());

}


@Override

public void keyReleased(KeyEvent e) {

// TODO Auto-generated method stub


}


@Override

public void keyTyped(KeyEvent e) {

// TODO Auto-generated method stub


}


}

5) 在主窗口类是调用显示板类,实现主界面的显示,代码如下:

package com.sosee;


import javax.swing.JFrame;


public class PictMain extends JFrame {


private static final int WIDTH=500;//定义的宽度

private static final int HEIGHT=400;//定义的高度


/**

* 创建一个构造方法,参数为此窗口的标题

* @param title

*/

public PictMain(String title) {

super(title);

this.setSize(WIDTH, HEIGHT);//设置窗口大小

PictPanel pic=new PictPanel();

this.add(pic);

pic.setFocusable(true);

}

/**

* @param args

*/

public static void main(String[] args) {

PictMain frame=new PictMain("移动图片");

frame.setVisible(true);

}


}

1.2.3 程序运行

项目创建完成后,可以运行此项目,运行方式可以从两个地方:

(1) 从菜单中运行Run->Run。

(2) 可以从工具栏中选择工具栏快速运行,如下图所示:

运行结果如下所示:

说明:图片文件可以在自己的电脑上找一个替代程序中的图片文件。

1.2.4 问题

运行后,点击右上角的关闭窗口后,实际上在Eclipse环境中并没有结束,显示如下:

解决办法:

方法一:为主窗口增加窗口监听事件;

方法二:在主窗口类的构造方法中添加如下代码:


this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

完结。

相关推荐

css布局方案汇总(28个实例图文并茂)

简介布局在我们前端日常开发来说是非常重要的,一个好的布局能简化代码的同时还能提高网页的性能。常见的布局方法有浮动(float)布局、绝对定位(position)布局、表格布局(table)、弹性(fl...

十款免费的CSS框架加速Web开发

Pure这是Yahoo最新推出的一款CSS框架,它只有HTML和CSS,没有使用任何JavaScript语言。总大小只有4.4kb,但功能却非常丰富,支持响应式样式和各种导航、表格、表单、按钮、网格和...

Tailwind CSS 是不是目前世上最好的CSS框架?

转载说明:原创不易,未经授权,谢绝任何形式的转载今天看了一篇国外大佬对TailwindCSS的看法,在这里分享给大家,看看大家是否赞同,以下是其相关内容的整理,由于翻译水平有限,欢迎大家讨论和指...

下一代 CSS 框架:Mojo CSS,为何如此受欢迎?

TailwindCSS推出即受到广大开发者的欢迎,当前Githubstar数已达77.8k。它是一个功能类优先(utility-first)的CSS框架,它提供了一系列功能类,让开发者...

常见的几种摄影构图方式

摄影构图,是一种在摄影画面中表现结构美、形式美的方式。构图能让摄影主体更加突出,画面更加有序。所以说,构图在摄影中是非常重要的一个环节。无论是前期构图还是后期构图,摄影者都要对构图有一个比较深的了解。...

风光摄影10大构图技巧,会用构图,照片更容易好看

风光摄影10大构图技巧,会用构图,照片更容易好看先解释一下,为什么会使用构图之后,照片更容易好看?因为,构图是根据很多好看的照片,总结出来的技巧,使用这些构图技巧,就相当于站在了巨人的肩膀上,也就是用...

掌握框式构图的摄影技巧,会让摄影爱好者的作品更有魅力!

很多摄影爱好者都知道摄影构图中有个框式构图,但大多数人对框式构图的摄影技巧,却一知半解。所以摄影爱好者们有必要更全面、深入的了解,并掌握框式构图,会对你摄影水平的提高更有帮助。【欢迎点击上方关注:金立...

这个构图很简洁,但为什么不耐看?

摄影爱好者最常犯的错就是过于复杂、主体不明确,但当遇到简单的场景往往又会出现单调、不耐看的状况。为什么会这样?说白了还是观察力不够。下面是本周的摄影入围习作,我们一起来看看这些照片中主体、陪体以及背景...

初学者需要记牢的八种常用构图法

作者:冯海军摄影中,构图很关键,决定照片是否成功,所以在构图上要加以重视和推敲,虽然说构图无定法,但是也有很多的规律可循,以下列举几种常用构图,会对初学者有很大的帮助。多彩刘卫洲摄苏州姑苏俱乐部(...

构图这件事不难!掌握14种构图模式就稳了

如果说视觉元素是视觉信息的载体,那么构图就是视觉元素的载体。没有适当形式的构图对视觉元素有机、有序地承载,平面设计将无法传达预定的设计意图和视觉信息。因此,对于平面设计而言,构图是平面设计不可或缺的重...

框架构图如何使用?

1分钟教你用手机拍大片。今天我们利用框架构图,在不同的运镜方法下拍摄。·首先将手机贴近地面,拍摄人物走过的画面。·然后利用3D效果的背景衬托,将手机贴近地面,以低角度仰拍人物。·最后我们用高清画质来呈...

面构图的5种超实用的构图形式 前景构图,框架构图,填充构图

面构图的5种超实用的构图形式。为什么有的人拍摄的照片好看又舒适?仔细观察会发现他们善用构图。大家好,今天带大家了解摄影中5种超实用的面构图形式。·一、前景构图。前景是构图中的神奇要素,可以提升照片的表...

一看就懂!跟着马格南的大师学构图

马格南图片社是迄今为止全球最重要的摄影图片社,其网站包涵了太多经典的名字和照片。细细品味这些经典图片,能够学到很多有用的构图手法。跟着大师走,总不会错吧?前后景的运用这似乎是非常常见的一种手法,仔细看...

这才是框架构图,有想法!能给你启发么?

框架构图大家并不陌生,但并不是有一个框就行了。框架构图用得不好,就很死板生硬,给人感觉很假。如果你理解透了,拍出的作品不会单调。今天就给大家分享一下框架构图,你看看有哪些妙用?1.广角与长焦的应用长焦...

7B小模型写好学术论文,新框架告别AI引用幻觉

ScholarCopilot团队投稿量子位|公众号QbitAI学术写作通常需要花费大量精力查询文献引用,而以ChatGPT、GPT-4等为代表的通用大语言模型(LLM)虽然能够生成流畅文本,但...

取消回复欢迎 发表评论: