学过java的人应该对java的图形化界面很是反感,特别是接触java不久的人。如果想和其他语言那样用鼠标拖拽,可以使用wondosbulider插件。但是用起来也不是那么方便。当然对于不乐意写代码的人来说真是太幸福了。

然而用代码去实现java的图形化界面并非那么麻烦。总结起来就是~

1.定义你需要使用的面板,按钮,文本,标签。

2.对这些实例化。  然后把按钮,文本,标签按照你想要的方法放到面板上。

3.把面板放在界面上。  如果界面简单的话,面板也是可以不使用的,面板可以方便管理一些按钮。

如何去简单的添加一些按钮那?

定义面板按钮~实例化面板按钮~将按钮添加到面板上。

package Swing;
import java.awt.FlowLayout;
import java.awt.Frame; import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel; public class FrameDemo extends JFrame {
private JPanel jp,jp1; //声明面板,面板功能:可添加按钮文本等,方便管理界面。
private JButton b1; //声明 按钮
private JButton b2,b3;
public FrameDemo ()
{
super("测试窗口");
jp = new JPanel();
b1 = new JButton("按钮1");
b2 = new JButton("按钮2");//实例化 jp b1 b2
jp.add(b1);
jp.add(b2); this.add(jp); //按钮添加到面板,面板添加到界面。
this.setSize(300,200); //设定 窗口宽度300,高度200
this.setLocation(100,100); //设定窗口左上角坐标,窗口打开时的位置。以左上定点为0.0
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
public static void main(String[] args) {
FrameDemo frame = new FrameDemo();
frame.setVisible(true); } }

下面介绍几个布局,让你的界面更加美观

流布局~组建从左到右依次安排到面板上。也是默认布局

package Swing;
import java.awt.FlowLayout;
import java.awt.Frame; import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel; public class FrameDemo extends JFrame {
private JPanel jp; //声明面板,面板功能:可添加按钮文本等,方便管理界面。
private JButton b1; //声明 按钮
private JButton b2,b3,b4;
public FrameDemo ()
{
super("测试窗口");
jp = new JPanel(); // 先对面板实例化,再对面板进行布局。 (左对齐,水平间距10,垂直间距15)可更改。
FlowLayout layout = new FlowLayout(FlowLayout.LEFT,10,25);
jp.setLayout(layout); b1 = new JButton("按钮1");
b2 = new JButton("按钮2");
b3 = new JButton("按钮3");
b4 = new JButton("按钮4");
jp.add(b1);
jp.add(b2);
jp.add(b3);
jp.add(b4);
this.add(jp); //按钮添加到面板,面板添加到界面
this.setSize(300,200); //设定 窗口宽度300,高度200
this.setLocation(100,100); //设定窗口左上角坐标,窗口打开时的位置。
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
public static void main(String[] args) {
FrameDemo frame = new FrameDemo();
frame.setVisible(true); } }

执行结果

边界布局~有五个位置,东南西北中~默认为中

package Swing;
import java.awt.BorderLayout;
import java.awt.FlowLayout;
import java.awt.Frame; import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel; public class FrameDemo extends JFrame {
private JPanel jp; //声明面板,面板功能:可添加按钮文本等,方便管理界面。
private JButton b1; //声明 按钮
private JButton b2,b3,b4;
public FrameDemo ()
{
super("测试窗口");
jp = new JPanel(); // 先对面板实例化,再对面板进行布局。 (左对齐,水平间距10,垂直间距15)可更改。
jp.setLayout(new BorderLayout()); b1 = new JButton("按钮1");
b2 = new JButton("按钮2");//实例化 jp b1 b2
b3 = new JButton("按钮3");
b4 = new JButton("按钮4");
jp.add(b1,BorderLayout.WEST);
jp.add(b2,BorderLayout.WEST); //按钮2将按钮1覆盖, 未设置按钮大小,按钮会的长度会是面板的长度。
jp.add(b3,BorderLayout.NORTH);
jp.add(b4,BorderLayout.SOUTH);
this.add(jp); //按钮添加到面板,面板添加到界面
this.setSize(500,500); //设定 窗口宽度500,高度500
this.setLocation(100,100); //设定窗口左上角坐标,窗口打开时的位置。
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
public static void main(String[] args) {
FrameDemo frame = new FrameDemo();
frame.setVisible(true); } }

注意,按钮1被按钮2覆盖

网格布局以及卡片布局都是一样的设置步骤,唯一改变的是布局方式改变。只要依次添加组件,注意个组件的位置就可以做好自己要求的界面。

我最喜欢的布局~null空布局。根据自己的意愿在面板上随意添加,但是容易造成布局混乱。我将文本框,标签,和按钮放在null布局中,标签和文本框的放置方法和按钮相同。

package Swing;
import java.awt.FlowLayout;
import java.awt.Frame; import javax.swing.JButton;
import javax.swing.JFormattedTextField;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JPasswordField;
import javax.swing.JTextField; public class FrameDemo extends JFrame {
private JPanel jp; //声明面板,面板功能:可添加按钮文本等,方便管理界面。
private JButton b1; //声明 按钮
private JButton b2,b3,b4;
private JLabel lname ,lpwd;
private JTextField txtname;
private JPasswordField txtpwd;
public FrameDemo ()
{
super("测试窗口");
jp = new JPanel();
jp.setLayout(null);
b1 = new JButton("登陆"); //对按钮创建添加
b2 = new JButton("取消"); b1.setBounds(60, 90, 60, 25);
b2.setBounds(125, 90, 60, 25);
jp.add(b1);
jp.add(b2); lname = new JLabel("用户名"); // 对标签创建添加
lpwd = new JLabel("密码");
txtname = new JTextField(20);
txtpwd = new JPasswordField(20);
txtpwd.setEchoChar('*'); lname.setBounds(30,30,60,25);
txtname.setBounds(95, 30, 120, 25);
lpwd.setBounds(30,60,60,25);
txtpwd.setBounds(95,60,120,25); jp.add(lname);
jp.add(txtname);
jp.add(lpwd);
jp.add(txtpwd); this.add(jp); //按钮添加到面板,面板添加到界'
this.setSize(250,170);
this.setLocation(300,300); //设定窗口左上角坐标,窗口打开时的位置。
this.setResizable(false);//窗口不可改变大小
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
public static void main(String[] args) {
FrameDemo frame = new FrameDemo();
frame.setVisible(true); } }

是否会自己按装一些组件了那?复选框的添加步骤也是一样的,但是要注意多设置些面板,用以管理各个复选框的标签等。

java Swing图形化界面的更多相关文章

  1. JAVA之旅(三十一)——JAVA的图形化界面,GUI布局,Frame,GUI事件监听机制,Action事件,鼠标事件

    JAVA之旅(三十一)--JAVA的图形化界面,GUI布局,Frame,GUI事件监听机制,Action事件,鼠标事件 有段时间没有更新JAVA了,我们今天来说一下JAVA中的图形化界面,也就是GUI ...

  2. java的图形化界面 文本区JTextArea的程序例子

    package java1;     //使用时这个改成你的包名即可//文本区 JTextArea import javax.swing.*;import java.awt.*;import java ...

  3. Java四则运算——图形化界面

    一.前提 (1)作业来源:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE1/homework/2213 (2)GitHub地址:https://github ...

  4. 黑马程序员:Java基础总结----GUI图形化界面

    黑马程序员:Java基础总结 GUI图形化界面   ASP.Net+Android+IO开发 . .Net培训 .期待与您交流!   GUI(Graphical User Interface)图形化界 ...

  5. Java 图形化界面设计(GUI)实战练习(代码)

    关于Java图形化界面设计,基础知识网上可搜,下面简单介绍一下重点概念,然后就由浅入深代码实例. 程序是为了方便用户使用的,Java引入图形化界面编程. 1.JFrame 是容器类 2.AWT 是抽象 ...

  6. 转:二十七、Java图形化界面设计——容器(JFrame)

    转:http://blog.csdn.net/liujun13579/article/details/7756729 二十七.Java图形化界面设计——容器(JFrame) 程序是为了方便用户使用的, ...

  7. 三十二、Java图形化界面设计——布局管理器之CardLayout(卡片布局)

    摘自 http://blog.csdn.net/liujun13579/article/details/7773945 三十二.Java图形化界面设计--布局管理器之CardLayout(卡片布局) ...

  8. 二十七、Java图形化界面设计——容器(JFrame)

    摘自http://blog.csdn.net/liujun13579/article/details/7756729 二十七.Java图形化界面设计--容器(JFrame) 程序是为了方便用户使用的, ...

  9. 三十三、Java图形化界面设计——布局管理器之null布局(空布局)

    摘自http://blog.csdn.net/liujun13579/article/details/7774267 三十三.Java图形化界面设计--布局管理器之null布局(空布局) 一般容器都有 ...

随机推荐

  1. 24点C++程序实现 编程之美1.16

    解法1,对于任意输入的四个数字,给出一个24点的解法,若无解,则没有输出. 原理参照下图(编程之美原书) 代码如下,仅供参考 // 1.16.cpp : Defines the entry point ...

  2. 在vs2010中mfc,C++的一些小经验

    1 如果你最近才从vc6.0到vs2010,在vs2010中mfc可能遇见一个小问题,如果你添加或改天了窗口中的控件,运行程序缺没有发现其中的变化,这时候需要在debug选项中rebuild all一 ...

  3. python 简单示例说明os.walk和os.path.walk的不同

    import os,os.path def func(arg,dirname,names): for filespath in names: print os.path.join(dirname,fi ...

  4. PHP微信公众平台开发1 配置接口

    1.简介 微信公众平台是腾讯公司在微信的基础上新增的功能模块,通过这一平台,个人和企业都可以打造一个微信的公众号,并实现和特定群体的文字.图片.语音的全方位沟通.互动. 2.通讯机制 3.注册微信公众 ...

  5. ObfuscationAttribute模糊处理

    在Reflection的强大和Reflector的盛行下,.NET产品的内部实现越来越透明,在恶意用户和Cracker面前,基本上已是砧板上的肉,被切到什么程度只能祈祷遇到的都是钝刀子:于是一批批的混 ...

  6. WPF 中如何使用第三方控件 ,可以使用WindowsFormsHost 类

    允许在 WPF 页面上承载 Windows Forms控件的元素. 命名空间:   System.Windows.Forms.Integration 程序集:   WindowsFormsIntegr ...

  7. C#如何使用和开发自定义配置节

    在日常的程序设计中,如何灵活和巧妙地运用配置信息是一个成功的设计师的首要选择.这不仅是为了程序设计得更灵活性和可扩展性,也是为了让你的代码给人以清新的感觉.程序中的配置信息一般放在应用程序的app.c ...

  8. Ubuntu设置中文

    Ubuntu设置中文:需要联网下载中文包,不然无法设置中文系统. 进去系统后再右上角有个齿轮图标点击,找到系统设置(System Settings)点击弹出一个界面,找到Language Suppor ...

  9. 宏page_t

    /** Type of the index page */ typedef byte page_t;

  10. Linux SocketCan client server demo hacking

    /*********************************************************************** * Linux SocketCan client se ...