Java GUL实战——“老八帮你选饭系统“——Swing实现

一.前言

学习加恶搞倾向,并无恶意

二.实现效果

1.主界面:

实现效果:点击嗨嗨嗨,发出"嗨嗨嗨!"语音,并且将姓名添加到数据库,与eat数据库表中的内容进行随机匹配,将结果刷新到下面的表中,点击大选发出语音“奥里给,干就完了” ,并且将所有姓名信息写入数据库,进行随机匹配刷新结果》》

2.更改菜单:

这部分不用多说了吧:

可以修改user信息自然就可以修改菜谱啦!

三.实现过程与关键类 

先来看一下项目结构:

注意这一部分的image已经转到了用javafx写的新版里所以这边显示为空

Eat.dao包中是数据库操作

Eat.domain包是数据库传入与传出对象

Eat.view包是两个视图

Test包,程序从这里开始

其实还是挺简单的

来看一些关键代码:

ReadDateBase.java

package Eat.dao;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.Random;

import Eat.domain.Eat;
import Eat.domain.Used;
import Eat.util.JDBC_Clean;
import Eat.util.JDBC_con;

public class ReadDatabase {
	public static String[][] readDataBaseEat(){
		String sql = "SELECT * FROM eat";
		Connection con = JDBC_con.setConnection();
		Statement sta = null;
		ResultSet re = null;
		ArrayList<Eat> e = new ArrayList<Eat>();
		try {
			sta = con.createStatement();
			re = sta.executeQuery(sql);
			while(re.next()) {
				e.add(new Eat(re.getInt("id"),re.getString("name")));
			}
		} catch (SQLException e1) {
			e1.printStackTrace();
		}finally {
			JDBC_Clean.clean(con, sta, re);
		}
		String[][] r = new String[e.size()][2];
		for(int i=0;i<e.size();i++) {
			r[i][0] = e.get(i).getId()+"";
			r[i][1] = e.get(i).getName();
		}
		return r;
	}
	
	public static String[][] readDateBaseUsed(){
		String sql = "SELECT * FROM used";
		Connection con = JDBC_con.setConnection();
		Statement sta = null;
		ResultSet re = null;
		ArrayList<Used> u = new ArrayList<Used>();
		try {
			sta = con.createStatement();
			re = sta.executeQuery(sql);
			while(re.next()) {
				u.add(new Used(re.getInt("id"),re.getString("name")));
			}
		} catch (SQLException e1) {
			e1.printStackTrace();
		}finally {
			JDBC_Clean.clean(con, sta, re);
		}
		String[][] r = new String[u.size()][2];
		for(int i=0;i<u.size();i++) {
			r[i][0] = u.get(i).getId()+"";
			r[i][1] = u.get(i).getName();
		}
		return r;
	}
	
	public static String[][] tableAll(){                       //将数据库中的名字与食物表中食物进行随机组合
		String[][] human = ReadDatabase.readDateBaseUsed();
		String[][] eats = ReadDatabase.readDataBaseEat();
		String[][] newlist = new String[human.length][2];
		Random random = new Random();
		for(int i=0;i < human.length;i++) {
			newlist[i][0] = human[i][1];        
			int r = random.nextInt(eats.length);   //随机函数对应食物
			newlist[i][1] = eats[r][1];             
		}
		return newlist;
	}
}

这部分是读取数据库内容,将信息写入二维字符串数组,还有就是随机进行匹配(tableAll)

如何发出声音?

这是按钮的Action

public void actionPerformed(ActionEvent e) {
				String roulettespin = "D:\\eclipse-workspace\\WhatYouWantEat\\music\\嗨嗨嗨-老八.wav";
			        try {
						AudioInputStream audioInputStream = AudioSystem.getAudioInputStream(new File(roulettespin).getAbsoluteFile());
						Clip clip = AudioSystem.getClip();
						clip.open(audioInputStream);
						clip.start();
					} catch (UnsupportedAudioFileException | IOException | LineUnavailableException e1) {
						e1.printStackTrace();
					}
			        Used u = new Used();
			        u.setId(2);
			        u.setName(textField_1.getText());
			        AlterDatabase.add(u);
			        table.setModel(
			    		   	new DefaultTableModel(
			    		             ReadDatabase.tableAll(),new String[] {"\u59D3\u540D", "\u5403\u4EC0\u4E48"})
			    		{
			    		boolean[] columnEditables = new boolean[] {
			    			false, false
			    		};
			    		public boolean isCellEditable(int row, int column) {
			    			return columnEditables[column];
			    		}
			    		});
			}

 四.下载

老八选餐系统v1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

RIDDLE!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值