前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >1小时学会通过Java Swing Design设计java图形化

1小时学会通过Java Swing Design设计java图形化

作者头像
红目香薰
发布2022-11-30 17:15:43
1.1K0
发布2022-11-30 17:15:43
举报
文章被收录于专栏:CSDNToQQCode

环境与工具:

系统环境:win10 开发工具:Eclipse IDE for Java Developers - 2020-09 数据库:MySQL5.6

学习目标:

一般大一结束的时候需要做一个类似一下内容的javaswing项目,故而咱们的学习目标如下:

其中设计到的控件:文本框、输入框、按钮、表格,数据库是JDBC绑定数据集<List>类型就行。


1、项目创建

使用eclipse直接创建一个java的空项目即可,唯一要注意的就是创建【java】的时候不是点击【class】而是创建【JFrame】,通过【JFrame】才能使用设计工具【Design】。

这里点【other】因为【JFrame】在这个选项栏中。

2、绝对位置布局Absolute layout

使用这个方式方便拖拽,很方便:

3、工具栏简述:

4、常用控件简述

1、顶层容器:JFrame(窗体),JDialog(对话窗)

2、中间容器:JPanel(面板),(滚动面板)JScrollPane,(分割面板)JSplitPane,(工具栏)JToolBar

3、菜单栏:JMenuBar

4、基本组件:

英文名

对照中文

JLabel

标签

JButton

按钮

JTextArea

文本区

JTextField

文本框

JRadioButton

单选按钮

JCheckBox

复选框

JPasswordField

密码框

JComboBox

下拉列表框

JList

列表

JTable

表格

画的有些乱,但是基本上一眼就能看出来是啥: 

表格JTable:

JPanel设置上下布局,JScrollPane设置,这样才能显示table的标题列

添加一些测试数据:

效果:

5、JDBC

需要数据库jar包

mysql-connector-java-5.1.7bin.jar

下载链接:https://download.csdn.net/download/feng8403000/85610502

MySQL

代码语言:javascript
复制
DROP TABLE IF EXISTS `users`;
CREATE TABLE `users`  (
  `id` int(8) NOT NULL AUTO_INCREMENT,
  `createDate` datetime(0) NOT NULL,
  `userName` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `sex` varchar(2) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `introduce` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;

-- ----------------------------
-- Records of users
-- ----------------------------
INSERT INTO `users` VALUES (1, '2022-06-11 12:55:02', '王语嫣', '女', '琅嬛福地,神仙姐姐。');
INSERT INTO `users` VALUES (2, '2022-06-11 12:56:05', '小龙女', '女', '冰山美人');

SET FOREIGN_KEY_CHECKS = 1;

JDCB_Demo

代码语言:javascript
复制
package com.item.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

/**
 * 数据库工厂
 * @author Administrator
 *
 */
public class FactoryDB {
	/**
	 * 驱动位置
	 */
	private static final String driver ="com.mysql.jdbc.Driver";
	/**
	 * 数据库链接路径·必背
	 */
	private static final String url ="jdbc:mysql://127.0.0.1:3306/mytest?characterEncoding=utf-8";
	/**
	 * 数据库账号
	 */
	private static final String user ="root";
	/**
	 * 数据库密码
	 */
	private static final String pwd ="12345678";
	/**
	 * 静态块引入数据库驱动·解决包位置问题
	 */
	static {
		try {
			Class.forName(driver);
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
	/**
	 * 数据库链接
	 * @return
	 */
	public static Connection getConn() {
		Connection conn = null;
		try {
			conn = DriverManager.getConnection(url,user,pwd);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return conn;
	}
	/**
	 * 关闭数据库连接
	 * @param conn
	 * @param pr
	 * @param re
	 */
	public static void close(Connection conn,PreparedStatement pr, ResultSet re) {
		try {
			if (re!=null) {
				re.close();
			} 
			if(pr!=null){
				pr.close();
			}
			if(conn!=null){
				conn.close();
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

封装模型:

代码语言:javascript
复制
package com.item.model;

import java.util.Date;

public class Users {
	@Override
	public String toString() {
		return "Users [id=" + id + ", creaetDate=" + creaetDate + ", userName=" + userName + ", sex=" + sex
				+ ", introduce=" + introduce + "]";
	}
	private int id;
	private Date creaetDate;
	private String userName;
	private String sex;
	private String introduce;
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public Date getCreaetDate() {
		return creaetDate;
	}
	public void setCreaetDate(Date creaetDate) {
		this.creaetDate = creaetDate;
	}
	public String getUserName() {
		return userName;
	}
	public void setUserName(String userName) {
		this.userName = userName;
	}
	public String getSex() {
		return sex;
	}
	public void setSex(String sex) {
		this.sex = sex;
	}
	public String getIntroduce() {
		return introduce;
	}
	public void setIntroduce(String introduce) {
		this.introduce = introduce;
	}
	

}

DAO层数据:

代码语言:javascript
复制
package com.item.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;

import com.item.jdbc.FactoryDB;
import com.item.model.Users;

public class UsersDAO {
	/**
	 * 查询所有
	 * @return
	 */
	public static ArrayList<Users> GetInfo(String userName){
		Connection conn = FactoryDB.getConn();
		String sql=null;
		if(userName==null) {
			sql="select * from users";
		}else {
			sql="select * from users where userName like '%"+userName+"%'";
		}
		ArrayList<Users> list = new ArrayList<Users>();
		try {
			PreparedStatement pr = conn.prepareStatement(sql);
			ResultSet re = pr.executeQuery();
			while (re.next()) {
				Users u = new Users();
				u.setId(re.getInt(1));
				u.setCreaetDate(re.getDate(2));
				u.setUserName(re.getString(3));
				u.setSex(re.getString(4));
				u.setIntroduce(re.getString(5));
				list.add(u);
			}
			FactoryDB.close(conn, pr, re);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return list;
	}
	/**
	 * 添加
	 * @param userName
	 * @param sex
	 * @param introduce
	 * @return
	 */
	public static boolean AddInfo(String userName,String sex,String introduce) {
		Connection conn = FactoryDB.getConn();
		String sql=String.format("insert into users values(0,now(),'%s','%s','%s')", userName,sex,introduce);
		try {
			PreparedStatement pr = conn.prepareStatement(sql);
			int rows = pr.executeUpdate();
			FactoryDB.close(conn, pr, null);
			return rows>0;
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return false;
	}
	/**
	 * 修改
	 * @param id
	 * @param introduce
	 * @return
	 */
	public static boolean UpdateById(int id,String introduce) {
		Connection conn = FactoryDB.getConn();
		String sql=String.format("update users set introduce='%s' where id=%d", introduce,id);
		try {
			PreparedStatement pr = conn.prepareStatement(sql);
			int rows = pr.executeUpdate();
			FactoryDB.close(conn, pr, null);
			return rows>0;
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return false;
	}
	/**
	 * 删除
	 * @param id
	 * @return
	 */
	public static boolean DeleteById(int id) {
		Connection conn = FactoryDB.getConn();
		String sql=String.format("delete from users where id=%d", id);
		try {
			PreparedStatement pr = conn.prepareStatement(sql);
			int rows = pr.executeUpdate();
			FactoryDB.close(conn, pr, null);
			return rows>0;
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return false;
	}
}

UI层添加数据:

JTable需要绑定一下俩数据:

代码语言:javascript
复制
//添加标题
Vector vTitle  = new Vector();
//添加数据
Vector vdate = new Vector();
//绑定到控件
table.setModel(new DefaultTableModel(vdate,vTitle));
代码语言:javascript
复制
package com.item.ui;

import java.awt.BorderLayout;
import java.awt.EventQueue;
import java.util.ArrayList;
import java.util.Vector;

import javax.swing.JFrame;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.border.EmptyBorder;
import javax.swing.JScrollPane;
import javax.swing.JButton;
import javax.swing.JTextField;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;

import com.item.dao.UsersDAO;
import com.item.model.Users;


import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;

public class utest extends JFrame {

	/**
	 * 序列
	 */
	private static final long serialVersionUID = 1L;
	private JPanel contentPane;
	private JTextField userName;
	private JTable table;

	/**
	 * Launch the application.
	 */
	public static void main(String[] args) {
		EventQueue.invokeLater(new Runnable() {
			public void run() {
				try {
					utest frame = new utest();
					frame.setVisible(true);
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
		});
	}

	/**
	 * Create the frame.
	 */
	public utest() {
		setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		setBounds(100, 100, 667, 598);
		contentPane = new JPanel();
		contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
		contentPane.setLayout(new BorderLayout(0, 0));
		setContentPane(contentPane);
		
		JPanel panel = new JPanel();
		contentPane.add(panel, BorderLayout.NORTH);
		//添加按钮
		JButton btnNewButton = new JButton("\u6DFB\u52A0");
		btnNewButton.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				AddUsers users = new AddUsers();
				users.setVisible(true);
			}
		});
		panel.add(btnNewButton);
		
		userName = new JTextField();
		panel.add(userName);
		userName.setColumns(20);
		//查询按钮
		JButton btnNewButton_2 = new JButton("\u67E5\u8BE2");
		btnNewButton_2.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				bind(userName.getText());
			}
		});
		panel.add(btnNewButton_2);
		
		JPanel panel_1 = new JPanel();
		contentPane.add(panel_1, BorderLayout.SOUTH);
		//删除
		JButton btnNewButton_1 = new JButton("\u9009\u4E2D\u884C\u70B9\u8FD9\u91CC\u5220\u9664");
		btnNewButton_1.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				int i = table.getSelectedRow();
				if (i==-1) {
					JOptionPane.showMessageDialog(null,"请选择删除的行");
					return ;
				}
				String id  = table.getValueAt(i, 0).toString();
				boolean isf = UsersDAO.DeleteById(Integer.parseInt(id));
				if (isf) {
					JOptionPane.showMessageDialog(null, "删除成功!!!");
				} else {
					JOptionPane.showMessageDialog(null, "删除失败!!!");
				}
				bind(null);
			}
		});
		panel_1.add(btnNewButton_1);
		//刷新按钮
		JButton btnNewButton_3 = new JButton("\u6570\u636E\u5237\u65B0");
		btnNewButton_3.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				bind(null);
			}
		});
		panel_1.add(btnNewButton_3);
		
		JScrollPane scrollPane = new JScrollPane();
		contentPane.add(scrollPane, BorderLayout.CENTER);
		table = new JTable();
		scrollPane.setViewportView(table);
		bind(null);
	}
	//加载数据
	public void bind(String userName) {
		//添加标题
		Vector<String> vTitle  = new Vector<String>();
		vTitle.add("编号");
		vTitle.add("创建时间");
		vTitle.add("用户名");
		vTitle.add("性别");
		vTitle.add("简介");
		//添加数据
		Vector vdate = new Vector<Users>();
		ArrayList<Users> list = UsersDAO.GetInfo(userName);
		for (Users u : list) {
			Vector v = new Vector();
			v.add(u.getId());
			v.add(u.getCreaetDate());
			v.add(u.getUserName());
			v.add(u.getSex());
			v.add(u.getIntroduce());
			vdate.add(v);
		}
		table.setModel(new DefaultTableModel(vdate,vTitle));
	}

}

效果:

添加:如果有单选按钮得分组

为了方便操作,别忘改一个控件的名称: 

双击添加按钮:

添加编码:

代码语言:javascript
复制
package com.item.ui;

import java.awt.BorderLayout;
import java.awt.EventQueue;

import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.border.EmptyBorder;

import com.item.dao.UsersDAO;

import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JRadioButton;
import javax.swing.SwingConstants;
import javax.swing.JTextField;
import javax.swing.JTextArea;
import javax.swing.JButton;
import javax.swing.ButtonGroup;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;

public class AddUsers extends JFrame {

	private JPanel contentPane;
	private JTextField userName;
	private final ButtonGroup buttonGroup = new ButtonGroup();
	public utest utest;
	/**
	 * Launch the application.
	 */
	public static void main(String[] args) {
		EventQueue.invokeLater(new Runnable() {
			public void run() {
				try {
					AddUsers frame = new AddUsers();
					frame.setVisible(true);
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
		});
	}

	/**
	 * Create the frame.
	 */
	public AddUsers() {
		setBounds(100, 100, 589, 457);
		contentPane = new JPanel();
		contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
		setContentPane(contentPane);
		contentPane.setLayout(null);

		JLabel lblNewLabel = new JLabel("\u7528\u6237\u540D");
		lblNewLabel.setBounds(100, 88, 76, 29);
		contentPane.add(lblNewLabel);

		JLabel lblNewLabel_1 = new JLabel("\u7B80\u4ECB");
		lblNewLabel_1.setBounds(100, 209, 54, 15);
		contentPane.add(lblNewLabel_1);

		JRadioButton sex1 = new JRadioButton("\u7537");
		buttonGroup.add(sex1);
		sex1.setSelected(true);
		sex1.setBounds(200, 141, 121, 23);
		contentPane.add(sex1);

		JLabel lblNewLabel_2 = new JLabel("\u6027\u522B");
		lblNewLabel_2.setBounds(100, 145, 54, 15);
		contentPane.add(lblNewLabel_2);

		JRadioButton sex2 = new JRadioButton("\u5973");
		buttonGroup.add(sex2);
		sex2.setBounds(357, 141, 121, 23);
		contentPane.add(sex2);

		userName = new JTextField();
		userName.setBounds(160, 92, 278, 21);
		contentPane.add(userName);
		userName.setColumns(10);

		JTextArea introduce = new JTextArea();
		introduce.setBounds(164, 204, 291, 117);
		contentPane.add(introduce);

		JButton btnNewButton = new JButton("\u6DFB\u52A0");
		btnNewButton.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				String name = userName.getText();
				boolean isf = sex1.isSelected();
				String sex=isf?"男":"女";
				String intro = introduce.getText();
				boolean addInfo = UsersDAO.AddInfo(name, sex, intro);
				JOptionPane.showMessageDialog(null, addInfo?"添加成功!!!":"添加失败!!!");
			}
		});
		btnNewButton.setBounds(231, 357, 93, 23);
		contentPane.add(btnNewButton);
	}

}

增删查演示完毕。

修改就是删除的获取数据跟添加组合在一起就行了。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-06-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 环境与工具:
  • 学习目标:
  • 1、项目创建
  • 5、JDBC
    • MySQL
      • JDCB_Demo
        • 封装模型:
          • DAO层数据:
            • UI层添加数据:
            相关产品与服务
            数据库
            云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档