Java swing實(shí)現(xiàn)酒店管理系統(tǒng)
今天給大家提供一個(gè)由今天給大家提供一個(gè)由Java swing實(shí)現(xiàn)的酒店管理系統(tǒng),數(shù)據(jù)庫采用sqlserver,我會(huì)貼上部分代碼,完整的代碼請(qǐng)看文章最下方下載,下面看代碼:
1.主框架代碼:
package 主框架窗口; import java.awt.BorderLayout; import java.awt.Color; import java.awt.Dimension; import java.awt.FlowLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.MouseEvent; import java.awt.event.MouseListener; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JMenu; import javax.swing.JMenuBar; import javax.swing.JMenuItem; import javax.swing.JOptionPane; import javax.swing.JPanel; import javax.swing.JSplitPane; import javax.swing.JToolBar; import javax.swing.border.LineBorder; import javax.swing.table.DefaultTableModel; import com.sunshine.sunsdk.system.suntools; import sunsdk.sql.Journal; import sunsdk.sql.sunsql; import sunsdk.swing.TJButton; import 關(guān)于我們.About; import 團(tuán)體開單.Team; import 客戶管理.Customer; import 客房預(yù)定.Engage; import 賓客結(jié)賬.CheckOut; import 散客開單.Individual; import 系統(tǒng)設(shè)置.Setup; import 網(wǎng)絡(luò)設(shè)置.NetSetup; import 菜單事件窗口.ApartBill; import 菜單事件窗口.Change; import 菜單事件窗口.GoOn; import 菜單事件窗口.Record; import 菜單事件窗口.UniteBill; import 營(yíng)業(yè)查詢.Query; //加入公共類庫 //加入模塊類庫 //散客開單 //團(tuán)體開單 //賓客結(jié)帳 //預(yù)訂房間 //營(yíng)業(yè)查詢 //客戶管理 //網(wǎng)絡(luò)設(shè)置 //系統(tǒng)設(shè)置 //關(guān)于我們 //下拉菜單中的功能庫 public class HotelFrame extends JFrame implements ActionListener, MouseListener, Runnable { //用戶名,權(quán)限 public static String userid, puil; public static JLabel lbA, lbB; public static String clue = " 提 示 : "; public static String face = " 當(dāng)前操作界面 : "; //聲名與菜單相關(guān)的類 private JMenuBar mb; private JMenu m1, m2, m3, m4; private JMenuItem mi11, mi12, mi13, mi14, mi15, mi16, mi17, mi18, mi19, mi21, mi22, mi23, mi24, mi25, mi31, mi32, mi33, mi34, mi35, mi36; //工具欄 private JToolBar tb; private JButton bt1, bt2, bt3, bt4, bt5, bt6, bt7, bt8, bt9, btA; //分割面板 private JSplitPane spaneMain, spaneLeft, spaneRight; //模塊接口 private JPanel panelMain, bott, jp2, jp3, jp4; private LeftTopPanel jp1; //主窗口左邊面板 //功能提示 private String toolTip[] = { "零散賓客入住登記 ", "團(tuán)體入住登記 ", "關(guān)于本軟件的支持信息 ", "賓客退房結(jié)算 ", "為賓客預(yù)訂房間 ", "查詢營(yíng)業(yè)情況 ", "為酒店固定客戶設(shè)置參數(shù) ", "設(shè)置系統(tǒng)的網(wǎng)絡(luò)連接方式 ", "設(shè)置系統(tǒng)參數(shù) ", "返回Windows " }; //功能模塊 /*#######################################################################*/ Individual idv = new Individual(this); //散客開單 Team tm = new Team(this); //團(tuán)體開單 CheckOut co = new CheckOut(this); //賓客結(jié)帳 Engage eg = new Engage(this); //客房預(yù)定 Query qr = new Query(this); //營(yíng)業(yè)查詢 Customer ct = new Customer(this); //客戶管理 NetSetup ns = new NetSetup(this); //網(wǎng)絡(luò)設(shè)置 Setup st = new Setup(this); //系統(tǒng)設(shè)置 About ab = new About(this); //關(guān)于我們 GoOn go = new GoOn(this); //賓客續(xù)住 Change cg = new Change(this); //更換房間 // Remind rm = new Remind(this); //電子提醒 UniteBill ub = new UniteBill(this); //合并帳單 ApartBill ap = new ApartBill(this); //拆分帳單 Record rc = new Record(this); //系統(tǒng)日志 /*#######################################################################*/ //構(gòu)造函數(shù) public HotelFrame (String us, String pu) { super ("陽光酒店管理系統(tǒng) - ★★版"); userid = us; //獲得操作員名稱 puil = pu; //獲得操作員權(quán)限 panelMain = new JPanel (new BorderLayout()); //主面板 //制作菜單 buildMenuBar (); //制作工具欄 buildToolBar (); //制作分割面板 buildSpaneMain (); //制作窗口底端信息框 buildBott (); //加入組件到主面板 panelMain.add ("North", tb); //加入工具欄 panelMain.add ("South", bott); //加入窗口底端信息框 panelMain.add ("Center", spaneMain); //加入分割面板 //加入菜單欄 this.setJMenuBar (mb); //加事件監(jiān)聽 addListener (); this.addWindowListener (new WindowAdapter () { public void windowClosing (WindowEvent we) { quit (); }//End windowClosing }); this.setContentPane (panelMain); this.setBounds (2, 2, 1020, 740); this.setDefaultCloseOperation (JFrame.DO_NOTHING_ON_CLOSE); this.setMinimumSize (new Dimension (1020, 740)); //設(shè)置窗口最小尺寸 this.setVisible (true); (new Thread(this)).start(); //啟動(dòng)房間狀態(tài)檢查線程 } //制作菜單 private void buildMenuBar () { //實(shí)例菜單欄 mb = new JMenuBar (); //實(shí)例菜單 m1 = new JMenu ("來賓登記 (B)"); m2 = new JMenu ("收銀結(jié)算 (S)"); m3 = new JMenu ("系統(tǒng)維護(hù) (W)"); //實(shí)例菜單項(xiàng) mi11 = new JMenuItem ("散客開單 (G)"); mi12 = new JMenuItem ("團(tuán)體開單 (M)"); mi13 = new JMenuItem ("賓客續(xù)住 (Z)"); mi14 = new JMenuItem ("更換房間 (A)"); mi15 = new JMenuItem ("修改登記 (J)"); mi16 = new JMenuItem ("房間狀態(tài) (Z)"); mi17 = new JMenuItem ("預(yù)訂管理 (T)"); mi18 = new JMenuItem ("電子提醒 (L)"); mi19 = new JMenuItem ("退出系統(tǒng) (X)"); mi21 = new JMenuItem ("賓客結(jié)帳 (J)"); mi22 = new JMenuItem ("合并帳單 (E)"); mi23 = new JMenuItem ("折分帳單 (F)"); mi24 = new JMenuItem ("賓客消費(fèi)明細(xì)查詢"); mi25 = new JMenuItem ("賓客退單明細(xì)查詢"); mi31 = new JMenuItem ("網(wǎng)絡(luò)設(shè)置 (N)"); mi32 = new JMenuItem ("系統(tǒng)設(shè)置 (X)"); mi33 = new JMenuItem ("系統(tǒng)日志 (Z)"); mi34 = new JMenuItem ("數(shù)據(jù)備份 (R)"); mi35 = new JMenuItem ("軟件幫助 (H)"); mi36 = new JMenuItem ("關(guān)于我們 (A)"); /////////////////////////////////////////// mi16.setEnabled(false);//未開發(fā)完畢的功能 mi18.setEnabled(false); mi34.setEnabled(false); //////////////////////////////////////////// //組織菜單 m1.add (mi11); //來賓登記 m1.add (mi12); m1.add (mi13); m1.add (mi14); m1.add (mi15); m1.add (mi16); m1.addSeparator(); m1.add (mi17); m1.add (mi18); m1.addSeparator(); m1.add (mi19); m2.add (mi21); //收銀結(jié)算 m2.add (mi22); m2.add (mi23); //m2.addSeparator(); //m2.add (mi24); //賓客消費(fèi)明細(xì) //m2.add (mi25); m3.add (mi31); //系統(tǒng)維護(hù) m3.add (mi32); m3.add (mi33); m3.addSeparator(); m3.add (mi34); m3.addSeparator(); m3.add (mi35); m3.add (mi36); mb.add (m1); //加入菜單欄 mb.add (m2); mb.add (m3); } //制作工具欄 private void buildToolBar () { tb = new JToolBar(); //制作按鍵 bt1 = new TJButton ("pic/ToolBar/m01.gif", " 散客開單 ", "零散賓客入住登記", true); bt2 = new TJButton ("pic/ToolBar/m02.gif", " 團(tuán)體開單 ", "團(tuán)體入住登記", true); bt3 = new TJButton ("pic/ToolBar/m03.gif", " 關(guān)于我們 ", "軟件信息", true); bt4 = new TJButton ("pic/ToolBar/m04.gif", " 賓客結(jié)帳 ", "賓客退房結(jié)算", true); bt5 = new TJButton ("pic/ToolBar/m05.gif", " 客房預(yù)訂 ", "為賓客預(yù)定房間", true); bt6 = new TJButton ("pic/ToolBar/m06.gif", " 營(yíng)業(yè)查詢 ", "查詢營(yíng)業(yè)情況", true); bt7 = new TJButton ("pic/ToolBar/m07.gif", " 客戶管理 ", "為酒店固定客戶設(shè)置", true); bt8 = new TJButton ("pic/ToolBar/m08.gif", " 網(wǎng)絡(luò)設(shè)置 ", "設(shè)置連接方式", true); bt9 = new TJButton ("pic/ToolBar/m09.gif", " 系統(tǒng)設(shè)置 ", "設(shè)置系統(tǒng)參數(shù)", true); btA = new TJButton ("pic/ToolBar/m10.gif", " 退出系統(tǒng) ", "返回Windows", true); //把按鍵加入工具欄 tb.addSeparator (); tb.add (bt1); tb.add (bt2); tb.addSeparator (); tb.add (bt4); tb.add (bt5); tb.add (bt6); tb.addSeparator (); tb.add (bt7); tb.add (bt8); tb.add (bt9); tb.addSeparator (); tb.add (bt3); tb.addSeparator (); tb.add (btA); //設(shè)置工具欄不可浮動(dòng) tb.setFloatable(false); } //制作主面板 private void buildSpaneMain () { jp1 = new LeftTopPanel (); //這四個(gè)面板為功能接口////////////// jp2 = new LeftBottPanel(); //左下面板 快速通道 jp3 = new RightTopPanel(); /////////////////////////////// jp4 = new RightBottPanel(); //右下面板 消費(fèi)信息表 //聲名分割面板 spaneLeft = new JSplitPane(JSplitPane.VERTICAL_SPLIT, true, jp1, jp2); spaneRight = new JSplitPane(JSplitPane.VERTICAL_SPLIT, true, jp3, jp4); spaneMain = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, true, spaneLeft, spaneRight); //設(shè)置面板最小尺寸 jp1.setMinimumSize(new Dimension (157, 450)); jp2.setMinimumSize(new Dimension (157, 94)); jp3.setMinimumSize(new Dimension (875, 300)); jp4.setMinimumSize(new Dimension (875, 94)); spaneRight.setMinimumSize(new Dimension (875, 565)); //設(shè)置分割條是否有伸縮鍵 spaneMain.setOneTouchExpandable (true); spaneRight.setOneTouchExpandable(true); //設(shè)置各面板的初起尺寸 spaneMain.setDividerLocation (160); spaneLeft.setDividerLocation (450); spaneRight.setDividerLocation(450); //設(shè)置分隔條寬度 spaneMain.setDividerSize (10); spaneLeft.setDividerSize (23); spaneRight.setDividerSize(23); } //制作bott欄 private void buildBott () { JLabel lb1, lb2; lb1 = new JLabel(" 陽 光 酒 店 管 理 系 統(tǒng) "); lb2 = new JLabel(" 當(dāng)前操作員 : " + userid + " "); lbA = new JLabel(clue + "請(qǐng)選擇功能項(xiàng) ... "); lbB = new JLabel(face + "陽 光 酒 店 管 理 系 統(tǒng) - ★★ 版 "); //加外框線 lbA.setBorder(new LineBorder(new Color(87, 87, 47))); lbB.setBorder(new LineBorder(new Color(87, 87, 47))); lb1.setBorder(new LineBorder(new Color(87, 87, 47))); lb2.setBorder(new LineBorder(new Color(87, 87, 47))); bott = new JPanel(new FlowLayout(FlowLayout.LEFT, 2, 2)); bott.add (lb1); bott.add (lbA); bott.add (lbB); bott.add (lb2); } //加事件監(jiān)聽 private void addListener () { mi11.addActionListener (this); //來賓登記 mi12.addActionListener (this); mi13.addActionListener (this); mi14.addActionListener (this); mi15.addActionListener (this); mi16.addActionListener (this); mi17.addActionListener (this); mi18.addActionListener (this); mi19.addActionListener (this); mi21.addActionListener (this); //收銀結(jié)算 mi22.addActionListener (this); mi23.addActionListener (this); mi24.addActionListener (this); mi25.addActionListener (this); mi31.addActionListener (this); //系統(tǒng)維護(hù) mi32.addActionListener (this); mi33.addActionListener (this); mi34.addActionListener (this); mi35.addActionListener (this); mi36.addActionListener (this); bt1.addActionListener (this); //按鍵加動(dòng)作監(jiān)聽 bt2.addActionListener (this); bt3.addActionListener (this); bt4.addActionListener (this); bt5.addActionListener (this); bt6.addActionListener (this); bt7.addActionListener (this); bt8.addActionListener (this); bt9.addActionListener (this); btA.addActionListener (this); bt1.addMouseListener (this); //按鍵加鼠標(biāo)監(jiān)聽 bt2.addMouseListener (this); bt3.addMouseListener (this); bt4.addMouseListener (this); bt5.addMouseListener (this); bt6.addMouseListener (this); bt7.addMouseListener (this); bt8.addMouseListener (this); bt9.addMouseListener (this); btA.addMouseListener (this); } /**=======================================================================** * [## private void quit () {} ]: 系統(tǒng)退出 * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :關(guān)閉系統(tǒng)函數(shù),僅類內(nèi)使用 **=======================================================================** */ private void quit () { int flag = 0; String msg = "您 現(xiàn) 在 要 關(guān) 閉 系 統(tǒng) 嗎 ?"; flag = JOptionPane.showConfirmDialog (null, msg, "提示", JOptionPane.YES_NO_OPTION); if(flag == JOptionPane.YES_OPTION) { Journal.writeJournalInfo(userid, "退出本系統(tǒng)", Journal.TYPE_LG);//記錄操作日志 this.setVisible (false); System.exit (0); }//End if(flag == JOptionPane.YES_OPTION) return; } //刷新左房間信息欄數(shù)據(jù) private void initLeftData() { jp1.title1.setText(""); //刷房間信息 for (int i = 0; i < 8; i++) { jp1.lt[i].setText(""); }//Endfor jp1.initRoomstate(); //刷新房間總狀態(tài) } //傳數(shù)據(jù)給散客開單窗口 private boolean initIDV() { try { //從房間信息表里獲得當(dāng)前房間的狀態(tài)和房間類型編號(hào) ResultSet rs = sunsql.executeQuery("select state,r_type_id from roominfo " + "where delmark=0 and id='" + LeftTopPanel.title1.getText() + "'"); if(!rs.next()) { //如果無結(jié)果集,提示用戶刷新房間數(shù)據(jù) if(LeftTopPanel.title1.getText().length() == 0) { JOptionPane.showMessageDialog(null,"請(qǐng)選定房間后,再為賓客開設(shè)房間", "提示", JOptionPane.INFORMATION_MESSAGE); }else { JOptionPane.showMessageDialog(null, "[ " + LeftTopPanel.title1.getText() + " ] 房間信息已更改,請(qǐng)刷新房間信息,再為賓客開設(shè)房間", "提示", JOptionPane.INFORMATION_MESSAGE); } return false; }else { if(!rs.getString(1).equals("可供")) { //只有狀態(tài)是可供房間,才能為賓客開設(shè) JOptionPane.showMessageDialog(null, "請(qǐng)選擇空房間,再為賓客開設(shè)房間", "提示", JOptionPane.INFORMATION_MESSAGE); return false; }//Endif //傳房間號(hào)到開單窗口 Individual.lbA.setText(LeftTopPanel.title1.getText()); //傳房間類型到開單窗口 Individual.lbB.setText(LeftTopPanel.title0.getText().substring(0, LeftTopPanel.title0.getText().length()-2)); //傳房間單價(jià)到開單窗口 Individual.lbC.setText(LeftTopPanel.lt[1].getText()); //房間類型編號(hào) String clRoom = rs.getString(2); //獲得此類型房間是否可以開設(shè)鐘點(diǎn)房 rs = sunsql.executeQuery("select cl_room from roomtype where " + "delmark=0 and id='" + clRoom + "'"); rs.next(); if(rs.getString(1).equals("N")) { //不能開設(shè),則開單窗口的鐘點(diǎn)選項(xiàng)不可用 Individual.chk1.setSelected(false); //取消選中狀態(tài) Individual.chk1.setEnabled(false); //設(shè)置不可用 }else { Individual.chk1.setEnabled(true); //可用 }//Endif //傳賓客類型數(shù)據(jù)給開單窗口 rs = sunsql.executeQuery("select distinct c_type from customertype where " + "delmark = 0 and pk!=0"); int ct = sunsql.recCount(rs); String cType[] = new String[ct]; for (int i = 0; i < ct; i++) { rs.next(); cType[i] = rs.getString(1); }//Endfor Individual.cb2.removeAllItems(); for (int i = 0; i < ct; i++) { Individual.cb2.addItem(cType[i]); }//Endfor Individual.cb2.setSelectedItem("普通賓客"); //初始化開單房間表---------臨時(shí)表 sunsql.executeUpdate("delete from roomnum"); //清空臨時(shí)表 sunsql.executeUpdate("insert into roomnum(roomid) values('" + LeftTopPanel.title1.getText() + "')"); //加入當(dāng)前房間信息 //初始化開單窗口的開單房間表 sunsql.initDTM(Individual.dtm2,"select roomid 房間編號(hào) from roomnum"); //初始化追加房間表---------當(dāng)前類型的除當(dāng)前房間的所有可供房間 sunsql.executeUpdate("update roominfo set indimark=0"); //刷新所有房間的開單狀態(tài) sunsql.executeUpdate("update roominfo set indimark=1 where id='" + LeftTopPanel.title1.getText() + "'"); //設(shè)置當(dāng)前房間為開單狀態(tài) //初始化開單窗口的可供房間表 sunsql.initDTM(Individual.dtm1,"select a.id 房間編號(hào)1 from roominfo " + "a,(select id from roomtype where r_type='" + Individual.lbB.getText() + "') b where a.delmark=0 and a.indimark=0 and a.state='可供' and a.r_type_id=b.id"); }//Endif } catch (Exception ex) { System.out.println ("HotelFrame.initIDV(): false"); }//End try return true; } //傳數(shù)據(jù)給團(tuán)體開單窗口 private boolean initTeam() { try { //初始化開單房間表---------臨時(shí)表 sunsql.executeUpdate("delete from roomnums"); //清空臨時(shí)表 //初始化開單窗口的開單房間表 Team.initDTM2(); //初始化追加房間表---------當(dāng)前類型的除當(dāng)前房間的所有可供房間 sunsql.executeUpdate("update roominfo set indimark=0"); //刷新所有房間的開單狀態(tài) //傳房間類型數(shù)據(jù)給團(tuán)體開單窗口 ResultSet rs = sunsql.executeQuery("select r_type from roomtype where delmark=0"); int ct = sunsql.recCount(rs); String type[] = new String[ct]; //傳賓客房型數(shù)據(jù)給團(tuán)體開單窗口 for (int i = 0; i < ct; i++) { rs.next(); type[i] = rs.getString(1); }//Endfor Team.cb.removeAllItems(); for (int i = 0; i < ct; i++) { Team.cb.addItem(type[i]); }//Endfor //傳賓客類型數(shù)據(jù)給團(tuán)體開單窗口 rs = sunsql.executeQuery("select distinct c_type from customertype where " + "delmark = 0 and pk!=0"); ct = sunsql.recCount(rs); for (int i = 0; i < ct; i++) { rs.next(); type[i] = rs.getString(1); }//Endfor Team.cb2.removeAllItems(); for (int i = 0; i < ct; i++) { Team.cb2.addItem(type[i]); }//Endfor Team.cb2.setSelectedItem("普通賓客"); } catch (Exception ex) { System.out.println ("HotelFrame.initTeam(): false"); }//Endtry return true; } //傳數(shù)據(jù)給結(jié)算窗口 private boolean initCKO() { try { ResultSet rs = sunsql.executeQuery("select state,r_type_id from roominfo " + "where delmark=0 and id='" + LeftTopPanel.title1.getText() + "'"); if(!rs.next()) { //如果無結(jié)果集,提示用戶刷新房間數(shù)據(jù) if(LeftTopPanel.title1.getText().length() == 0) { JOptionPane.showMessageDialog(null,"請(qǐng)選定賓客入住的房間后,再為賓客結(jié)算費(fèi)用", "提示", JOptionPane.INFORMATION_MESSAGE); }else { JOptionPane.showMessageDialog(null, "[ " + LeftTopPanel.title1.getText() + " ] 房間信息已更改,請(qǐng)刷新房間信息,再為賓客開設(shè)房間", "提示", JOptionPane.INFORMATION_MESSAGE); }//Endif return false; }else { //只有狀態(tài)是占用或鐘點(diǎn)房間,才能為賓客結(jié)算 if(!rs.getString(1).equals("占用") && !rs.getString(1).equals("鐘點(diǎn)")) { JOptionPane.showMessageDialog(null, "請(qǐng)選擇賓客正在消費(fèi)的房間進(jìn)行結(jié)算費(fèi)用操作", "提示", JOptionPane.INFORMATION_MESSAGE); return false; }//Endif //傳結(jié)算單號(hào)給結(jié)算窗口 co.lbA.setText(suntools.getNumber(suntools.Number_JS)); //傳結(jié)算房間給結(jié)算窗口 co.lbB.setText(jp1.title1.getText()); //傳結(jié)算賓客名稱給結(jié)算窗口 co.lbC.setText(jp1.lt[0].getText()); //傳押金給結(jié)算窗口 co.lbF.setText(jp1.lt[6].getText()); //清空結(jié)算中間表 sunsql.executeUpdate("delete from checkout_temp"); //獲得主房間號(hào) rs = sunsql.executeQuery("select main_room,in_no from livein where " + "delmark=0 and r_no='" + co.lbB.getText() + "' and statemark='正在消費(fèi)'"); if(!rs.next()) { JOptionPane.showMessageDialog(null, "操作失敗,請(qǐng)檢查網(wǎng)絡(luò)情況", "提示", JOptionPane.INFORMATION_MESSAGE); return false; }//Endif String mainRoom = rs.getString(1); //取出主房間號(hào) co.inNo = rs.getString(2); //傳入住單號(hào)為結(jié)算窗口 //獲得主房間狀態(tài),看是普通住宿還是鐘點(diǎn)房 rs = sunsql.executeQuery("select state from roominfo where delmark=0 and id='" + mainRoom + "'"); rs.next(); int mrState = 0; //主房間狀態(tài) 0:普通入住 1:鐘點(diǎn)房 if(rs.getString(1).equals("鐘點(diǎn)")) { mrState = 1; }//Endif DefaultTableModel ckoDTM = new DefaultTableModel(); //主房間下的所有房間信息 sunsql.initDTM(ckoDTM, "select pk,r_no,r_type_id,c_type_id,in_time,foregift from " + "livein where delmark=0 and main_room='" + mainRoom + "'"); double total = 0; //消費(fèi)總金額 double shsh = 0; //實(shí)收金額 double youh = 0; //優(yōu)惠金額 for (int i = 0; i < ckoDTM.getRowCount(); i++) { //取出當(dāng)前房間的標(biāo)準(zhǔn)單價(jià) rs = sunsql.executeQuery("select price,cl_price from roomtype where delmark=0 and id='" + ckoDTM.getValueAt(i, 2) + "'"); rs.next(); double rprice = 0; double days = 0; if(mrState == 0) { rprice = rs.getDouble(1); //普通入住單價(jià) //獲得入住天數(shù) days = suntools.getConsumeFactor(ckoDTM.getValueAt(i, 4) + "", Journal.getNowDTime()); }else { rprice = rs.getDouble(2); //鐘點(diǎn)房單價(jià) days = suntools.getClockFactor(ckoDTM.getValueAt(i, 4) + "", Journal.getNowDTime()); }//Endif double rd = rprice * days; //當(dāng)前房間的消費(fèi)總金額 total = total + rd; //累加總消費(fèi) rs = sunsql.executeQuery("select discount from customertype where delmark=0 and " + "id='" + ckoDTM.getValueAt(i, 3) + "' and dis_attr='" + ckoDTM.getValueAt(i, 2) + "'"); rs.next(); //取出賓客享受的折扣 int dst = rs.getInt(1); double ddr = rd * dst/10; //當(dāng)前房間的打折后價(jià)格 shsh = shsh + ddr; //應(yīng)收金額累加 youh = youh + rd - ddr; //優(yōu)惠金額累加 //向結(jié)算中間表加入數(shù)據(jù) sunsql.executeUpdate("insert into checkout_temp(pk,r_type_id,r_no,price," + "discount,dis_price,account,money,in_time) values(" + ckoDTM.getValueAt(i, 0) + ",'" + ckoDTM.getValueAt(i, 2) + "','" + ckoDTM.getValueAt(i, 1) + "'," + rprice + "," + dst + "," + rprice * dst / 10 + "," + days + "," + ddr + ",'" + ckoDTM.getValueAt(i, 4) + "')"); } //傳消費(fèi)金額給結(jié)算窗口 co.lbD.setText(total + ""); //傳應(yīng)收金額給結(jié)算窗口 co.lbE.setText(shsh + ""); //傳實(shí)收金額 co.tf1.setText(shsh + ""); //傳優(yōu)惠金額給結(jié)算窗口 co.lbG.setText(youh + ""); //傳找零金額給結(jié)算窗口 co.lbH.setText(Double.parseDouble(co.lbF.getText()) - shsh + ""); //刷新結(jié)算中間表數(shù)據(jù) co.initDTM(); co.tf2.requestFocus(true); //給賓客支付焦點(diǎn) }//Endif } catch (Exception ex) { JOptionPane.showMessageDialog(null, "操作失敗,請(qǐng)檢查網(wǎng)絡(luò)情況", "提示", JOptionPane.INFORMATION_MESSAGE); ex.printStackTrace(); System.out.println ("HotelFrame.initCKO(): false"); return false; }//End try return true; } /**=======================================================================** * ActionListener 監(jiān)聽 **=======================================================================** */ public void actionPerformed (ActionEvent ae) { Object o = ae.getSource (); if(o == bt1 || o ==mi11) {//============================================ lbB.setText(face + "散 客 開 單 -"); if(initIDV()) { //傳數(shù)據(jù)給散客開單窗口 idv.show(); //散客開單 initLeftData(); //刷新左房間信息欄數(shù)據(jù) }//Endif }else if(o == bt2 || o == mi12) {//===================================== lbB.setText(face + "團(tuán) 體 開 單 -"); if(initTeam()) { //傳賓客類型數(shù)據(jù)給團(tuán)體開單窗口 tm.show(); //團(tuán)體開單 initLeftData(); //刷新左房間信息欄數(shù)據(jù) }//Endif }else if(o == bt3 || o == mi36) {//===================================== lbB.setText(face + "關(guān) 于 我 們 -"); ab.show(); //關(guān)于我們 }else if(o == bt4 || o == mi21) {//===================================== lbB.setText(face + "賓 客 結(jié) 帳 -"); if(initCKO()) { //傳數(shù)據(jù)給結(jié)算窗口 co.show(); //賓客結(jié)帳 initLeftData(); //刷新左房間信息欄數(shù)據(jù) }//Endif }else if(o == bt5 || o == mi17) {//===================================== lbB.setText(face + "客 房 預(yù) 訂 -"); eg.show(); //客房預(yù)訂 initLeftData(); //刷新左房間信息欄數(shù)據(jù) }else if(o == bt6) {//================================================== lbB.setText(face + "營(yíng) 業(yè) 查 詢 -"); qr.show(); //營(yíng)業(yè)查詢 }else if(o == bt7) {//================================================== if(puil.equals("普通操作員")) { //客戶管理 String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 客戶管理 ] 頁面,請(qǐng)用管理員ID登錄 ..."; JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE); return; } lbB.setText(face + "客 戶 管 理 -"); ct.show(); }else if(o == bt8 || o == mi31) {//===================================== if(puil.equals("普通操作員")) { //網(wǎng)絡(luò)設(shè)置 String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 網(wǎng)絡(luò)設(shè)置 ] 頁面,請(qǐng)用管理員ID登錄 ..."; JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE); return; } lbB.setText(face + "網(wǎng) 絡(luò) 設(shè) 置 -"); ns.show(); }else if(o == bt9 || o == mi32) {//===================================== if(puil.equals("普通操作員")) { //系統(tǒng)設(shè)置 String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 網(wǎng)絡(luò)設(shè)置 ] 頁面,請(qǐng)用管理員ID登錄 ..."; JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE); return; } lbB.setText(face + "系 統(tǒng) 設(shè) 置 -"); st.buildDTM12(""); //刷新房間信息表的房間狀態(tài) st.show(); initLeftData(); //刷新左房間信息欄數(shù)據(jù) }else if(o == btA || o == mi19) {//===================================== quit (); //退出系統(tǒng) }else if(o == mi13) {//================================================= lbB.setText(face + "賓 客 續(xù) 住 -"); go.show(); //賓客續(xù)住 }else if(o == mi14) {//================================================= lbB.setText(face + "更 換 房 間 -"); cg.show(); //更換房間 }else if(o == mi15) {//================================================= lbB.setText(face + "修 改 登 記 -"); idv.show(); //修改登記-------還要修改 }else if(o == mi16) {//================================================= //房間狀態(tài) }else if(o == mi18) {//================================================= //電子提醒 }else if(o == mi22) {//================================================= lbB.setText(face + "合 并 帳 單 -"); ub.show(); //合并帳單 }else if(o == mi23) {//================================================= lbB.setText(face + "折 分 帳 單 -"); ap.show(); //折分帳單 }else if(o == mi33) {//================================================= lbB.setText(face + "系 統(tǒng) 日 志 -"); rc.initDTM(); //刷新日志列表 rc.show(); //系統(tǒng)日志 }else if(o == mi34) {//================================================= //數(shù)據(jù)備份 }else if(o == mi35) {//================================================= //軟件幫助 } lbB.setText(face + "陽 光 酒 店 管 理 系 統(tǒng) - ★★ 版 "); } /**=======================================================================** * MouseListener 監(jiān)聽 **=======================================================================** */ public void mouseClicked (MouseEvent me) { } public void mousePressed (MouseEvent me) { } public void mouseReleased(MouseEvent me) { } public void mouseEntered (MouseEvent me) { //鼠標(biāo)移進(jìn)提示 Object o = me.getSource (); if(o == bt1) { lbA.setText (clue + toolTip[0]); }else if(o == bt2) { lbA.setText (clue + toolTip[1]); }else if(o == bt3) { lbA.setText (clue + toolTip[2]); }else if(o == bt4) { lbA.setText (clue + toolTip[3]); }else if(o == bt5) { lbA.setText (clue + toolTip[4]); }else if(o == bt6) { lbA.setText (clue + toolTip[5]); }else if(o == bt7) { lbA.setText (clue + toolTip[6]); }else if(o == bt8) { lbA.setText (clue + toolTip[7]); }else if(o == bt9) { lbA.setText (clue + toolTip[8]); }else if(o == btA) { lbA.setText (clue + toolTip[9]); } } public void mouseExited (MouseEvent me) { lbA.setText (clue + "請(qǐng)選擇功能項(xiàng) ... "); } /**=======================================================================** * [## public void run() {} ]: * 參數(shù) :無 * 返回值 :無 * 修飾符 :public * 功能 :結(jié)算后檢查房間狀態(tài)線程 **=======================================================================** */ public void run() { try { Statement ste1 = null; Connection conn1 = null; if(sunini.getIniKey ("Default_Link").equals ("1")) { //JDBC連接方式 String user1 = sunini.getIniKey ("UserID"); String pwd1 = sunini.getIniKey ("Password"); String ip1 = sunini.getIniKey ("IP"); String acc1 = sunini.getIniKey ("Access"); String dbf1 = sunini.getIniKey ("DBFname"); String url1 = "jdbc:microsoft:sqlserver://" + ip1 + ":" + acc1 + ";" + "databasename=" + dbf1; //注冊(cè)驅(qū)動(dòng) DriverManager.registerDriver (new com.microsoft.jdbc.sqlserver.SQLServerDriver()); //獲得一個(gè)連接 conn1 = DriverManager.getConnection (url1, user1, pwd1); } else { //注冊(cè)驅(qū)動(dòng) //JDBCODBC連接方式 DriverManager.registerDriver (new sun.jdbc.odbc.JdbcOdbcDriver()); //獲得一個(gè)連接 conn1 = DriverManager.getConnection ("jdbc:odbc:" + sunini.getIniKey("LinkName")); } //建立高級(jí)載體 ste1 = conn1.createStatement (ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); while( true ) { ste1.executeUpdate("update roominfo set statetime=statetime-1 where statetime>0"); ste1.executeUpdate("update roominfo set state='可供' where statetime=0 and state='臟房'"); Thread.sleep(30000); }//End while } catch (Exception ex) { JOptionPane.showMessageDialog (null, "數(shù)據(jù)庫連接失敗...", "錯(cuò)誤", JOptionPane.ERROR_MESSAGE); System.exit(0); //ex.printStackTrace(); }//End try } /* public static void main (String sd[]) { sunswing.setWindowStyle (sunini.getIniKey ("Sys_style").charAt (0)); new HotelFrame ("gujun", "管理員"); }*/ }
2.系統(tǒng)設(shè)置:
/** *############################################################################## * * [ 項(xiàng)目名 ] : 陽光酒店管理系統(tǒng) * [ 公司名 ] : 清華IT * [ 模塊名 ] : 系統(tǒng)設(shè)置模塊 * [ 文件名 ] : Setup.java * [ 相關(guān)文件 ] : * [ 文件實(shí)現(xiàn)功能] : 組織系統(tǒng)設(shè)置窗口 * [ 作者 ] : 董豐 * [ 版本 ] : 1.1 * ---------------------------------------------------------------------------- * [ 備注 ] : * ---------------------------------------------------------------------------- * [ 修改記錄 ] : * * [ 日 期 ] [版本] [修改人] [修改內(nèi)容] * 2006/04/19 1.0 董豐 創(chuàng)建 * 2006/04/22 1.1 顧俊 實(shí)現(xiàn)數(shù)據(jù)保存 * ##-------------------------------------------------------------------------- * 版權(quán)所有(c) 2006-2007, SunshineSOFT Corporation * --------------------------------------------------------------------------## * * [ 函數(shù)說明 ] : 看類內(nèi)各函數(shù)開頭 * * [ 遺留問題 ] : * *############################################################################## */ package com.sunshine.setup; import javax.swing.*; import javax.swing.border.*; import javax.swing.table.*; import java.awt.*; import java.awt.event.*; import java.sql.*; import com.sunshine.sunsdk.sql.*; //公共類庫 import com.sunshine.sunsdk.system.*; import com.sunshine.sunsdk.swing.*; import com.sunshine.mainframe.HotelFrame; //加載主窗口 public class Setup extends JDialog implements ActionListener, MouseListener { private JLabel top,bott; private JTabbedPane tp; private JPanel panelMain; //=========房間項(xiàng)目設(shè)置 private JTable tb11, tb12; private DefaultTableModel dtm11, dtm12; //房間類型列表//房間信息列表 private JScrollPane sp11,sp12; private JComboBox cb11,cb12; //房間類型,可供/清理狀態(tài) private JButton bt11, bt12, bt13, bt14, bt15, bt16, bt17, bt18, bt19, bt20; //添加, 修改,刪除LX,折扣,單個(gè),批量添加,刪除,修改FJ,保存,篩選 private JTextField tf11; //=========客戶類型設(shè)置 private JTable tb21,tb22; private DefaultTableModel dtm21,dtm22; //客戶類型列表,房間費(fèi)打折列表 private JScrollPane sp21,sp22; private JButton bt21, bt22, bt23, bt24; //添加, 修改,刪除LX,房費(fèi)打折 //=========操作員設(shè)置 private JTable tb31; private DefaultTableModel dtm31; //操作員列表 private JScrollPane sp31; private JComboBox cb31;//用戶名 private JPasswordField tf31, tf32, tf33; //原密碼,新密碼,確認(rèn)密碼 private JRadioButton rb31, rb32, rb33, rb34, rb35; //新用戶登記, 修改密碼,刪除用戶,普通用戶,管理員 private JButton bt31, bt32, bt33; // 登記, 修改, 刪除 //=========計(jì)費(fèi)設(shè)置 private JTextField tf41, tf42, tf43, tf44, tf45, tf46, tf47; private JCheckBox ck; private JButton bt41, bt42; //提示信息 String msg0 = "您確定要?jiǎng)h除在表格中選中的資料條目嗎?"; String msg1 = "請(qǐng)?jiān)谙鄳?yīng)的表格中選定條目,再點(diǎn)刪除鍵 ..."; //日志信息 String journal; //INI文件中的鍵名 String ini[] = { "[SOFTINFO]", "UserName", "CompName", "[CONFIG]", "Soft_First", "Default_Link" , "Default_Page", "Sys_style", "[NUMBER]", "LodgName", "LodgNumber", "EngaName", "EngaNumber", "ChouName", "ChouNumber", "[HABITUS]", "Ck_Habitus", "Ck_Minute", "[PARTTIME]", "In_Room", "Out_Room1", "Out_Room2", "InsuDay", "ClockRoom1", "ClockRoom2", "InsuHour1", "InsuHour2", "[JDBC]", "DBFname", "UserID", "Password", "IP", "Access", "[ODBC]", "LinkName" }; //實(shí)例化功能模塊 //========================================================================// AddRoomType art = new AddRoomType (this); //添加房間類型 ModiRoomType mrt = new ModiRoomType(this); //添加房間類型 AddCustomerType act = new AddCustomerType(this); //添加客戶類型 ModiCustomerType mct = new ModiCustomerType(this); //添加客戶類型 Discount dis = new Discount(this); //折扣設(shè)置 AddRoomInfo ari = new AddRoomInfo(this); //單個(gè)添加房間 AddRoomInfos aris = new AddRoomInfos(this); //批量添加房間 ModiRoomInfo mri = new ModiRoomInfo(this); //修改房間信息 //========================================================================// /**=======================================================================** * [## public Setup(JFrame frame) {} ]: 構(gòu)造函數(shù) * 參數(shù) :JDialog對(duì)象表示本對(duì)話框的父窗口 * 返回值 :無 * 修飾符 :public * 功能 :組建系統(tǒng)設(shè)置模塊 **=======================================================================** */ public Setup(JFrame frame) { super (frame, "系統(tǒng)設(shè)置", true); top = new JLabel(); //假空格 panelMain = new JPanel(new BorderLayout(0,10)); tab(); //制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板 addListener(); //加入事件監(jiān)聽 panelMain.add("North",top); panelMain.add("Center",tp); this.setContentPane(panelMain); this.setPreferredSize (new Dimension (718,508)); this.setMinimumSize (new Dimension (718,508)); this.setResizable(false); //不允許改變窗口大小 pack(); sunswing.setWindowCenter(this); //窗口屏幕居中 } /**=======================================================================** * [## private void addListener() {} ]: 加事件監(jiān)聽 * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :加事件監(jiān)聽 **=======================================================================** */ private void addListener() { bt11.addActionListener(this); //加動(dòng)作監(jiān)聽 bt12.addActionListener(this); bt13.addActionListener(this); bt14.addActionListener(this); bt15.addActionListener(this); bt16.addActionListener(this); bt17.addActionListener(this); bt18.addActionListener(this); bt19.addActionListener(this); bt20.addActionListener(this); bt21.addActionListener(this); bt22.addActionListener(this); bt23.addActionListener(this); bt24.addActionListener(this); bt31.addActionListener(this); bt32.addActionListener(this); bt33.addActionListener(this); bt41.addActionListener(this); bt42.addActionListener(this); rb31.addActionListener(this); //操作員作操范圍監(jiān)聽 rb32.addActionListener(this); rb33.addActionListener(this); tf41.addActionListener(this); //計(jì)費(fèi)設(shè)置文本框加監(jiān)聽 tf42.addActionListener(this); tf43.addActionListener(this); tf44.addActionListener(this); tf45.addActionListener(this); tf46.addActionListener(this); bt11.addMouseListener(this); //加鼠標(biāo)監(jiān)聽 bt12.addMouseListener(this); bt13.addMouseListener(this); bt14.addMouseListener(this); bt15.addMouseListener(this); bt16.addMouseListener(this); bt17.addMouseListener(this); bt18.addMouseListener(this); bt19.addMouseListener(this); bt20.addMouseListener(this); bt21.addMouseListener(this); bt22.addMouseListener(this); bt23.addMouseListener(this); bt24.addMouseListener(this); bt31.addMouseListener(this); bt32.addMouseListener(this); bt33.addMouseListener(this); bt41.addMouseListener(this); bt42.addMouseListener(this); } /**=======================================================================** * [## private void tab() {} ]: 制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板 * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板 **=======================================================================** */ private void tab() { JPanel jp1,jp2,jp3,jp4; ///////////////////////////////////////////////-------模塊面板接口 jp1 = fangjian(); //房間項(xiàng)目設(shè)置 jp2 = kehu(); //客戶類型設(shè)置 jp3 = caozuo(); //操作員設(shè)置 jp4 = jiFei(); //計(jì)費(fèi)設(shè)置 ////////////////////////////////////////////////////////////////// tp = new JTabbedPane(); tp.addTab("房間項(xiàng)目設(shè)置", new ImageIcon("pic/u01.gif"), jp1); tp.addTab("客戶類型設(shè)置", new ImageIcon("pic/u02.gif"), jp2); tp.addTab("操作員設(shè)置", new ImageIcon("pic/u03.gif"), jp3); tp.addTab("計(jì)費(fèi)設(shè)置", new ImageIcon("pic/u04.gif"), jp4); } /**=======================================================================** * [## private JPanel fangjian() {} ]: * 參數(shù) :無 * 返回值 :JPanel * 修飾符 :private * 功能 :房間項(xiàng)目設(shè)置 **=======================================================================** */ private JPanel fangjian() { dtm11 = new DefaultTableModel(); tb11 = new JTable(dtm11); sp11 = new JScrollPane(tb11); dtm12 = new DefaultTableModel(); tb12 = new JTable(dtm12); sp12 = new JScrollPane(tb12); JPanel pfangjian,pTop,pBott,pTn,pTc,pBn,pBc,pTcc,pTcs,pBcc,pBcs; pfangjian = new JPanel(new GridLayout(2,1,0,5)); pTop = new JPanel(new BorderLayout()); pBott = new JPanel(new BorderLayout()); pTn = new JPanel(); //放置保存按鈕等... pTc = new JPanel(new BorderLayout()); //放置房間類型列表及四個(gè)按鈕 pBn = new JPanel(new FlowLayout(FlowLayout.LEFT,10,0));//放置下拉列表 pBc = new JPanel(new BorderLayout()); //放置房間信息列表及四個(gè)按鈕 pTcc = new JPanel(new GridLayout(1,1));//放置房間類型列表 pTcs = new JPanel(new FlowLayout(FlowLayout.CENTER,20,5));//放置四個(gè)按鈕 pBcc = new JPanel(new GridLayout(1,1));//放置房間信息列表 pBcs = new JPanel(new FlowLayout(FlowLayout.CENTER,20,5));//放置四個(gè)按鈕 //保存按鈕等 ... JLabel lb1,lb2,lb3; lb1 = new JLabel("結(jié)帳后房間狀態(tài)變?yōu)? "); lb2 = new JLabel(" 結(jié)帳后"); lb3 = new JLabel("分鐘后變?yōu)榭晒顟B(tài) "); tf11 = new TJTextField(sunini.getIniKey(ini[17]),5); //根據(jù)INI文件給初值 tf11.setHorizontalAlignment(JTextField.RIGHT); cb12 = new JComboBox(); cb12.addItem(" 可供狀態(tài) "); cb12.addItem(" 清理狀態(tài) "); //根據(jù)INI文件給初值 cb12.setSelectedIndex(Integer.parseInt(sunini.getIniKey(ini[16]))); bt19 = new TJButton ("pic/save.gif", " 保 存 ", "保存設(shè)置"); pTn.add(lb1); pTn.add(cb12); pTn.add(lb2); pTn.add(tf11); pTn.add(lb3); pTn.add(bt19); pTn.setBorder(BorderFactory.createTitledBorder("")); //房間類型列表及四個(gè)按鈕 bt11 = new TJButton ("pic/new.gif", "添加類型", "添加房間類型"); bt12 = new TJButton ("pic/modi0.gif", "修改類型", "修改房間類型"); bt13 = new TJButton ("pic/del.gif", "刪除類型", "刪除房間類型"); bt14 = new TJButton ("pic/modi3.gif", "房費(fèi)打折", "設(shè)置房間費(fèi)折扣"); pTcc.add(sp11); pTcs.add(bt11); pTcs.add(bt12); pTcs.add(bt13); pTcs.add(bt14); pTc.add(pTcc); pTc.add("South",pTcs); pTc.setBorder(BorderFactory.createTitledBorder("房間類型")); //完成上半部分 pTop.add("North",pTn); pTop.add(pTc); //下拉列表 JLabel lb0 = new JLabel("按包廂類型過濾: "); cb11 = new JComboBox(); bt20 = new TJButton ("pic/choose1.gif", "篩 選", "篩選房間信息"); bt20.setBorderPainted(false); bt20.setFocusPainted(false); pBn.add(lb0); pBn.add(cb11); pBn.add(bt20); buildDTM11(); //初始化房間類型列表和下拉列表的值 buildDTM12(""); //初始化房間號(hào)列表 //房間信息列表及四個(gè)按鈕 bt15 = new TJButton ("pic/new.gif", "單個(gè)添加", "添加單個(gè)房間信息"); bt16 = new TJButton ("pic/book.gif", "批量添加", "批量添加房間信息"); bt17 = new TJButton ("pic/del.gif", "刪除房間", "刪除某個(gè)房間信息"); bt18 = new TJButton ("pic/modi0.gif", "修改房間", "修改某個(gè)房間信息"); pBcc.add(sp12); pBcs.add(bt15); pBcs.add(bt16); pBcs.add(bt17); pBcs.add(bt18); pBc.add(pBcc); pBc.add("South",pBcs); pBc.setBorder ( BorderFactory.createTitledBorder ("房間信息") ); //完成下半部分 pBott.add("North",pBn); pBott.add(pBc); //組合 pfangjian.add(pTop); pfangjian.add(pBott); return pfangjian; } // /**=======================================================================** * [## private void buildDTM11() {} ]: * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :房間類型列表和ComboBox **=======================================================================** */ private void buildDTM11() { String sqlCode2 = "select pk,sysmark,id,foregift,r_type 房間類型," + "price 預(yù)設(shè)單價(jià),cl_price " + "'鐘點(diǎn)價(jià)格/小時(shí)'" + ",bed 床位數(shù)量,cl_room "+ "'能否按鐘點(diǎn)計(jì)費(fèi)(Y/N)' from roomtype where delmark = 0"; sunsql.initDTM(dtm11,sqlCode2); tb11.removeColumn(tb11.getColumn("pk")); tb11.removeColumn(tb11.getColumn("sysmark")); tb11.removeColumn(tb11.getColumn("foregift")); tb11.removeColumn(tb11.getColumn("id")); String sqlCode1 = "select r_type from roomtype where delmark = 0"; sunsql.initJComboBox(cb11,sqlCode1); cb11.addItem("顯示全部房間信息"); cb11.setSelectedIndex(cb11.getItemCount() - 1); //設(shè)置顯示全部 } /**=======================================================================** * [## private void buildDTM12(String rType) {} ]: * 參數(shù) :String rType為刷新參數(shù) * 返回值 :無 * 修飾符 :private * 功能 :房間信息表 **=======================================================================** */ public void buildDTM12(String rType) { String sqlCode = "select a.pk,a.r_type_id,a.id 房間號(hào),b.r_type 房間類型," + "a.state 房間狀態(tài),a.location 所在區(qū)域,a.r_tel 房間電話 from roominfo as a," + "roomtype as b where a.r_type_id = b.id and a.delmark = 0 " + rType; sunsql.initDTM(dtm12,sqlCode); tb12.removeColumn(tb12.getColumn("pk")); tb12.removeColumn(tb12.getColumn("r_type_id")); } /**=======================================================================** * [## private JPanel kehu() {} ]: * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :客戶類型設(shè)置 **=======================================================================** */ private JPanel kehu() { dtm21 = new DefaultTableModel(); tb21 = new JTable(dtm21); sp21 = new JScrollPane(tb21); dtm22 = new DefaultTableModel(); tb22 = new JTable(dtm22); sp22 = new JScrollPane(tb22); JPanel pkehu,p1,p2,p1b,p2b; p1 = new JPanel(new BorderLayout());//客戶類型面板 p2 = new JPanel(new BorderLayout());//房間費(fèi)打折面板 p1b = new JPanel(new FlowLayout(FlowLayout.CENTER,30,5));//客戶類型按鈕面板 p2b = new JPanel(); //房間費(fèi)打折按鈕面板 buildDTM21(); //初始化客戶類型表 bt21 = new TJButton ("pic/new.gif", "添加類型", "添加客戶類型"); bt22 = new TJButton ("pic/modi0.gif", "修改類型", "修改客戶類型"); bt23 = new TJButton ("pic/del.gif", "刪除類型", "刪除客戶類型"); p1b.add(bt21); p1b.add(bt22); p1b.add(bt23); p1.add(sp21); p1.add("South",p1b); p1.setBorder ( BorderFactory.createTitledBorder ("客戶類型") ); buildDTM22(); //初始化房間打折表 bt24 = new TJButton ("pic/modi3.gif", " 房間費(fèi)打折 ", "設(shè)置房間費(fèi)折扣"); p2b.add(bt24); p2.add(sp22); p2.add("South",p2b); p2.setBorder ( BorderFactory.createTitledBorder ("房間費(fèi)打折") ); pkehu = new JPanel(new GridLayout(2,1,0,10)); pkehu.add(p1); pkehu.add(p2); return pkehu; } /**=======================================================================** * [## private JPanel caozuo() {} ]: * 參數(shù) :無 * 返回值 :JPanel * 修飾符 :private * 功能 :操作員設(shè)置 **=======================================================================** */ private JPanel caozuo() { JPanel panelMain,panelMain1,panelTop,panelBott1,panelBott2; dtm31 = new DefaultTableModel(); tb31 = new JTable(dtm31); sp31 = new JScrollPane(tb31); panelMain = new JPanel(new GridLayout(2,1,0,5)); panelMain1 = new JPanel (new BorderLayout (0,3)); //下半面板 panelTop = new JPanel(new GridLayout(1,1)); //操作員列表面板 panelBott1 = new JPanel(new GridLayout (1, 2));//詳細(xì)信息,操作范圍,操作權(quán)限面板 panelBott2 = new JPanel(new FlowLayout (FlowLayout.CENTER,20,5));//按鈕面板 bt31 = new TJButton ("pic/new.gif", " 登 記 ", "保存當(dāng)前用戶信息", false); bt32 = new TJButton ("pic/key.gif", " 修 改 ", "修改密碼", false); bt33 = new TJButton ("pic/del.gif", " 刪 除 ", "刪除當(dāng)前用戶", false); bt32.setEnabled(false); bt33.setEnabled(false); panelBott2.add (bt31); panelBott2.add (bt32); panelBott2.add (bt33); //制作并加入Top_Left面板 panelBott1.add (bottLeft()); //制作并加入Top_Right面板 panelBott1.add (bottRight()); panelMain1.add ("Center", panelBott1); panelMain1.add ("South", panelBott2); buildDTM31(); //初始化操作員信息表 panelTop.add(sp31); panelTop.setBorder(BorderFactory.createTitledBorder("操作員列表")); panelMain.add(panelTop); panelMain.add(panelMain1); return panelMain; } /**=======================================================================** * [## private JPanel topLeft () {} ]: 制作Top_Left面板 * 參數(shù) :無 * 返回值 :JPanel表示組織好的面板 * 修飾符 :private * 功能 :組建對(duì)話框的用戶名和密碼面板 **=======================================================================** */ private JPanel bottLeft () { JLabel lb1, lb2, lb3, lb4; JPanel tl, jp1, jp2; lb1 = new JLabel ("用 戶 名: "); lb2 = new JLabel ("原 密 碼: "); lb3 = new JLabel ("新 密 碼: "); lb4 = new JLabel ("確認(rèn)密碼: "); tf31 = new TJPasswordField (17); tf32 = new TJPasswordField (17); tf33 = new TJPasswordField (17); tl = new JPanel (); jp1 = new JPanel (new GridLayout (4, 1, 0, 18)); jp2 = new JPanel (new GridLayout (4, 1, 0, 9)); //初始化用戶名下拉框 cb31 = new JComboBox (); cb31.setEditable (true); tf31.setEditable (false); //加入組件 jp1.add (lb1); jp1.add (lb2); jp1.add (lb3); jp1.add (lb4); jp2.add (cb31); jp2.add (tf31); jp2.add (tf32); jp2.add (tf33); tl.add (jp1); tl.add (jp2); tl.setBorder (BorderFactory.createTitledBorder (" 詳細(xì)信息 ")); return tl; } /**=======================================================================** * [## private JPanel topRight () {} ]: 制作Top_Right面板 * 參數(shù) :無 * 返回值 :JPanel表示組織好的面板 * 修飾符 :private * 功能 :組建對(duì)話框操作面板 **=======================================================================** */ private JPanel bottRight () { JPanel tr, jp1, jp2; ButtonGroup bg1,bg2; rb31 = new JRadioButton ("新用戶登記", true); rb32 = new JRadioButton ("修改密碼"); rb33 = new JRadioButton ("刪除用戶"); rb34 = new JRadioButton ("普通操作員", true); rb35 = new JRadioButton ("管 理 員"); bg1 = new ButtonGroup (); bg2 = new ButtonGroup (); tr = new JPanel (new GridLayout (2, 1)); jp1 = new JPanel (); jp2 = new JPanel (); //加單選組 操作范圍 bg1.add (rb31); bg1.add (rb32); bg1.add (rb33); //加單選組 操作權(quán)限 bg2.add (rb34); bg2.add (rb35); jp1.add (rb31); jp1.add (rb32); jp1.add (rb33); jp2.add (rb34); jp2.add (rb35); jp1.setBorder (BorderFactory.createTitledBorder (" 操作范圍 ")); jp2.setBorder (BorderFactory.createTitledBorder (" 操作權(quán)限 ")); tr.add (jp1); tr.add (jp2); return tr; } /**=======================================================================** * [## private void buildDTM21() {} ]: * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :初始化客戶類型列表 **=======================================================================** */ private void buildDTM21() { String sqlCode = "select pk,id 客戶類型編號(hào),id,c_type 客戶類型,discount " + "打折比率 from customertype where delmark = 0 and dis_attr = '購(gòu)物折扣' and id!='SYSMARK'"; sunsql.initDTM(dtm21,sqlCode); tb21.removeColumn(tb21.getColumn("pk")); tb21.removeColumn(tb21.getColumn("id")); } /**=======================================================================** * [## private void buildDTM22() {} ]: * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :初始化房間打折費(fèi)列表 **=======================================================================** */ private void buildDTM22() { String sqlCode = "select pk,sysmark,id,foregift,r_type 房間類型,price 預(yù)設(shè)單價(jià) from roomtype where delmark = 0"; sunsql.initDTM(dtm22,sqlCode); tb22.removeColumn(tb22.getColumn("pk")); tb22.removeColumn(tb22.getColumn("id")); tb22.removeColumn(tb22.getColumn("sysmark")); tb22.removeColumn(tb22.getColumn("foregift")); } /**=======================================================================** * [## private void buildDTM31() {} ]: * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :初始化操作員列表 **=======================================================================** */ private void buildDTM31() { String sqlCode = "select pk,userid 用戶登錄ID,puis 用戶權(quán)限 from pwd where delmark = 0"; sunsql.initDTM(dtm31,sqlCode); tb31.removeColumn(tb31.getColumn("pk")); sunsql.initJComboBox (cb31, "select userid from pwd where delmark=0"); } /**=======================================================================** * [## private JPanel jiFei() {} ]: * 參數(shù) :無 * 返回值 :JPanel * 修飾符 :private * 功能 :計(jì)費(fèi)設(shè)置 **=======================================================================** */ private JPanel jiFei() { JLabel lb1, lb2, lb3, lb4, lb5, lb6, lb7, lb8, lb9, lb10, lb11, lb12, lb13, lb14, lb15, lb16; //定義各方位面板 JPanel panelJF, jfTop, jfLeft, jfRight, jfBott; JPanel jp1, jp2, jp3, jp4, jp5, jp6, jp7, jp8, jp9; //定義標(biāo)簽 lb1 = new JLabel(" 客人開房時(shí)間在"); lb2 = new JLabel("點(diǎn)之后按新的一天開始計(jì)費(fèi)"); lb3 = new JLabel(" 客人退房時(shí)間在"); lb4 = new JLabel("點(diǎn)之后計(jì)價(jià)天數(shù)自動(dòng)追加半天"); lb5 = new JLabel(" 客人退房時(shí)間在"); lb6 = new JLabel("點(diǎn)之后計(jì)價(jià)天數(shù)自動(dòng)追加一天"); lb7 = new JLabel(" 開房后"); lb8 = new JLabel("分鐘開始計(jì)費(fèi)"); lb9 = new JLabel(" 最少按"); lb10 = new JLabel("小時(shí)計(jì)費(fèi),小于這個(gè)時(shí)間的按此時(shí)間計(jì)費(fèi)"); lb11 = new JLabel(" 若不足一小時(shí)但超過"); lb12 = new JLabel("分鐘的部分按1小時(shí)計(jì)費(fèi)"); lb13 = new JLabel(" 不足上面分鐘數(shù)但超過"); lb14 = new JLabel("分鐘的部分按半小時(shí)計(jì)費(fèi)"); lb15 = new JLabel("注:此設(shè)置僅限于標(biāo)準(zhǔn)計(jì)費(fèi)的鐘點(diǎn)房! "); lb16 = new JLabel(" "); lb15.setForeground(new Color(255, 138, 0)); //初始化計(jì)時(shí)計(jì)費(fèi)設(shè)置 tf41 = new TJTextField(sunini.getIniKey("In_Room"), 5); tf42 = new TJTextField(sunini.getIniKey("Out_Room1"), 5); tf43 = new TJTextField(sunini.getIniKey("Out_Room2"), 5); tf44 = new TJTextField(sunini.getIniKey("ClockRoom1"), 5); tf45 = new TJTextField(sunini.getIniKey("ClockRoom2"), 5); tf46 = new TJTextField(sunini.getIniKey("InsuHour1"), 5); tf47 = new TJTextField(sunini.getIniKey("InsuHour2"), 5); //設(shè)置文本框右對(duì)齊 tf41.setHorizontalAlignment(JTextField.RIGHT); tf42.setHorizontalAlignment(JTextField.RIGHT); tf43.setHorizontalAlignment(JTextField.RIGHT); tf44.setHorizontalAlignment(JTextField.RIGHT); tf45.setHorizontalAlignment(JTextField.RIGHT); tf46.setHorizontalAlignment(JTextField.RIGHT); tf47.setHorizontalAlignment(JTextField.RIGHT); //不足一天是否按一天計(jì)價(jià) ck = new JCheckBox("入住時(shí)間不足一天的按一天計(jì)費(fèi)"); if(sunini.getIniKey("InsuDay").equals("1")) { ck.setSelected(true); } bt41 = new TJButton ("pic/save.gif", " 保 存 ", "保存當(dāng)前設(shè)置"); bt42 = new TJButton ("pic/exit.gif", " 返 回 ", "返回主窗口"); panelJF = new JPanel(new BorderLayout()); //計(jì)費(fèi)主面板 jfTop = new JPanel(new GridLayout(2, 1)); //放左右面板 jfLeft = new JPanel(new GridLayout(4, 1)); //計(jì)費(fèi)左面板 jfRight = new JPanel(new GridLayout(5, 1)); //計(jì)費(fèi)右面板 jfBott = new JPanel(new FlowLayout(FlowLayout.RIGHT, 40, 4));//按鍵面板 jp1 = new JPanel(new FlowLayout(FlowLayout.LEFT)); //左邊的面板用到的 jp2 = new JPanel(new FlowLayout(FlowLayout.LEFT)); jp3 = new JPanel(new FlowLayout(FlowLayout.LEFT)); jp4 = new JPanel(new FlowLayout(FlowLayout.LEFT)); jp5 = new JPanel(new FlowLayout(FlowLayout.LEFT)); //右邊的面板用到的 jp6 = new JPanel(new FlowLayout(FlowLayout.LEFT)); jp7 = new JPanel(new FlowLayout(FlowLayout.LEFT)); jp8 = new JPanel(new FlowLayout(FlowLayout.LEFT)); jp9 = new JPanel(new FlowLayout(FlowLayout.RIGHT)); //制作左邊面板 jp1.add(lb1); jp1.add(tf41); jp1.add(lb2); jp2.add(lb3); jp2.add(tf42); jp2.add(lb4); jp3.add(lb5); jp3.add(tf43); jp3.add(lb6); jp4.add(lb16); //假空格 jp4.add(ck); jfLeft.add(jp1); jfLeft.add(jp2); jfLeft.add(jp3); jfLeft.add(jp4); //制作右邊面板 jp5.add(lb7); jp5.add(tf44); jp5.add(lb8); jp6.add(lb9); jp6.add(tf45); jp6.add(lb10); jp7.add(lb11); jp7.add(tf46); jp7.add(lb12); jp8.add(lb13); jp8.add(tf47); jp8.add(lb14); jp9.add(lb15); jfRight.add(jp5); jfRight.add(jp6); jfRight.add(jp7); jfRight.add(jp8); jfRight.add(jp9); //組織兩個(gè)表到一起 jfTop.add(jfLeft); jfTop.add(jfRight); //組織按鍵面板 jfBott.add(bt41); jfBott.add(bt42); //加入主面板 panelJF.add("Center", jfTop); panelJF.add("South", jfBott); jfLeft.setBorder(BorderFactory.createTitledBorder("普通房間標(biāo)準(zhǔn)計(jì)費(fèi)")); jfRight.setBorder ( BorderFactory.createTitledBorder ("鐘點(diǎn)房標(biāo)準(zhǔn)計(jì)費(fèi)") ); return panelJF; } /**=======================================================================** * [## private boolean initMrt() {} ]: * 參數(shù) :無 * 返回值 :boolean * 修飾符 :private * 功能 :傳數(shù)據(jù)給修改房間類型窗口 **=======================================================================** */ private boolean initMrt() { int row = tb11.getSelectedRow(); if(row == -1) { JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦骖愋捅碇兄付ǚ块g類型," + "才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE); return false; } ModiRoomType.tf0.setText(dtm11.getValueAt(row,2) + ""); //類型編號(hào) ModiRoomType.tf1.setText(dtm11.getValueAt(row,4) + ""); //類型名稱 ModiRoomType.tf2.setText(dtm11.getValueAt(row,7) + ""); //床位數(shù)量 ModiRoomType.tf3.setText(dtm11.getValueAt(row,5) + ""); //預(yù)設(shè)單價(jià) ModiRoomType.tf4.setText(dtm11.getValueAt(row,3) + ""); //預(yù)設(shè)押金 ModiRoomType.tf5.setText(dtm11.getValueAt(row,6) + ""); //鐘點(diǎn)計(jì)費(fèi) String cl_room = dtm11.getValueAt(row, 8) + ""; if(cl_room.equals("Y")) { ModiRoomType.chk.setSelected(true); //允許提供鐘點(diǎn)服務(wù) } else { ModiRoomType.chk.setSelected(false); //不允許提供鐘點(diǎn)服務(wù) ModiRoomType.tf5.setEnabled(false); //設(shè)置鐘點(diǎn)計(jì)費(fèi)不可用 } return true; } /**=======================================================================** * [## private boolean initMri() {} ]: * 參數(shù) :無 * 返回值 :boolean * 修飾符 :private * 功能 :傳數(shù)據(jù)給修改房間信息窗口 **=======================================================================** */ private boolean initMri() { int row = tb12.getSelectedRow(); if(row == -1) { JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦娣块g信息表中指定房間號(hào)," + "才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE); return false; } ModiRoomInfo.tf1.setText(dtm12.getValueAt(row, 2) + ""); //房間編號(hào) ModiRoomInfo.tf2.setText(dtm12.getValueAt(row, 5) + ""); //所在區(qū)域 ModiRoomInfo.tf3.setText(dtm12.getValueAt(row, 6) + ""); //房間電話 ModiRoomInfo.pk = dtm12.getValueAt(row, 0) + ""; //獲得當(dāng)前行的PK try { ResultSet rs = sunsql.executeQuery("select r_type from roomtype " + "where delmark=0 and id='" + dtm12.getValueAt(row,1) + "'"); rs.next(); ModiRoomInfo.cb1.setSelectedItem(rs.getString(1)); //房間類型 } catch (Exception ex) { System.out.println ("ModiRoomInfo.initMri(): Modi false"); }//End try return true; } /**=======================================================================** * [## private boolean initMct() {} ]: * 參數(shù) :無 * 返回值 :boolean * 修飾符 :private * 功能 :傳數(shù)據(jù)給修改客戶類型窗口 **=======================================================================** */ private boolean initMct() { int row = tb21.getSelectedRow(); if(row == -1) { JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦骖愋捅碇兄付蛻纛愋停? + "才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE); return false; } ModiCustomerType.tf1.setText(dtm21.getValueAt(row,1) + ""); //客戶類型編號(hào) ModiCustomerType.tf2.setText(dtm21.getValueAt(row,3) + ""); //客戶類型名稱 ModiCustomerType.tf3.setText(dtm21.getValueAt(row,4) + ""); //客戶類型折扣 ModiCustomerType.pk = dtm21.getValueAt(row, 0) + ""; //獲得當(dāng)前行的PK return true; } /**=======================================================================** * [## private boolean initDis(JTable dtb, DefaultTableModel ddtm) {} ]: * 參數(shù) :JTable 與 DefaultTableModel 為項(xiàng)目與折扣中的表 * 返回值 :boolean * 修飾符 :private * 功能 :傳數(shù)據(jù)給打折設(shè)置窗口 **=======================================================================** */ private boolean initDis(JTable dtb, DefaultTableModel ddtm) { int row = dtb.getSelectedRow(); if(row == -1) { JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谙鄳?yīng)列表中指定房間類型," + "才能進(jìn)行打折設(shè)置操作", "提示", JOptionPane.INFORMATION_MESSAGE); return false; } try { Discount.rt = ddtm.getValueAt(row, 2) + ""; //獲得房間編號(hào) ResultSet rs = sunsql.executeQuery("select discount from customertype " + "where id='SYSMARK' and dis_attr='" + ddtm.getValueAt(row, 2) + "'"); rs.next(); int temp = rs.getInt(1); if(temp == 10){ Discount.cb1.setSelectedIndex(1); //普通賓客不打折選項(xiàng) Discount.tf1.setEnabled(false); }else { Discount.cb1.setSelectedIndex(0); //普通賓客打折選項(xiàng) Discount.tf1.setEnabled(true); }//Endif Discount.tf1.setText(temp + ""); //普通賓客的折扣 } catch (Exception ex) { } Discount.lb1.setText(ddtm.getValueAt(row, 4) + ""); //房間類型名稱 Discount.lb2.setText(ddtm.getValueAt(row, 5) + ""); //房間價(jià)格 //初始化表格的DTM sunsql.initDTM(Discount.dtm, "select c_type 客戶等級(jí),discount 享受折扣, " + "dis_price 折扣價(jià)格 from customertype where delmark=0 and dis_attr='" + ddtm.getValueAt(row, 2) + "' and id!='SYSMARK'"); //初始化會(huì)員等級(jí)ComboBox sunsql.initJComboBox(Discount.cb2, "select c_type from customertype where " + "delmark=0 and id!='SYSMARK' and dis_attr='" + ddtm.getValueAt(row, 2) + "'"); return true; } /**=======================================================================** * [## private boolean delInfo (String tName, DefaultTableModel delDtm, int dr[], String m) {} ]: * 參數(shù) :Sring tName 表示要執(zhí)行刪除的表名 * DTM delDtm 表示相關(guān)聯(lián)的DTM * int dr[] 要被執(zhí)行刪除的行數(shù) * String m 提示信息 * 返回值 :boolean * 修飾符 :private * 功能 :房間類型、房間信息和客戶類型的刪操作 **=======================================================================** */ private boolean delInfo (String tName, DefaultTableModel delDtm, int dr[], String m) { int rowCount = dr.length; int r =0; //DTM行指針 if(tName.equals ("roomtype")) { //如果刪除房間類型,則刪除與房間類型相關(guān)的房間信息與客戶折扣設(shè)置 rowCount = rowCount * 3; }//Endif if(rowCount > 0) { //判斷選擇記錄數(shù) int isDel = JOptionPane.showConfirmDialog (null, m, "提示", JOptionPane.YES_NO_OPTION); if(isDel == JOptionPane.YES_OPTION) { String sqlCode[] = new String[rowCount]; //生成SQL語句 for (int i = 0; i < rowCount; i++) { sqlCode[i] = "update " + tName +" set delmark=1 where pk=" + delDtm.getValueAt(dr[r], 0) + " and id='" + delDtm.getValueAt(dr[r],2) + "'"; if(tName.equals ("roomtype")) { //如果刪除房間類型,則同時(shí)刪除相關(guān)房間信息 i++; sqlCode[i] = "update roominfo set delmark=1 where id='sunhotel' or r_type_id='" + delDtm.getValueAt(dr[r],2) + "'"; i++; sqlCode[i] = "update customertype set delmark=1 where id='sunhotel' or dis_attr='" + delDtm.getValueAt(dr[r],2) + "'"; } r++; //DTM行指針加1 }//Endfor //以事務(wù)模式執(zhí)行SQL語句組, 確保操作正確, 返回值為成功執(zhí)行SQL語句的條數(shù) isDel = sunsql.runTransaction(sqlCode); if(isDel != rowCount) { //如果成功執(zhí)行的條數(shù) = 數(shù)組長(zhǎng)度,則表示更新成功 String mm = "在執(zhí)行第 [ " + (isDel + 1) + " ] 條記錄的刪除操作時(shí)出錯(cuò),數(shù)據(jù)有可能被其它終端修改\n或者是網(wǎng)絡(luò)不通暢 ..."; JOptionPane.showMessageDialog(null, mm, "錯(cuò)誤",JOptionPane.ERROR_MESSAGE); //更新失敗,返回false return false; }//Endif return true; //更新成功,返回true }//Endif } else //如果沒有選中記錄,則提示一下 JOptionPane.showMessageDialog(null, msg1, "提示",JOptionPane.INFORMATION_MESSAGE); return false; } /**=======================================================================** * [## private void umAdd () {} ]: 添加操作 * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :添加新的用戶ID **=======================================================================** */ private void umAdd () { String pwd1 = String.valueOf(tf32.getPassword()); String pwd2 = String.valueOf(tf33.getPassword()); String pu = "普通操作員"; //用戶權(quán)限 if(!pwd1.equals (pwd2)) { //兩次密碼不相等 JOptionPane.showMessageDialog (null, "輸入錯(cuò)誤,[ 新密碼 ] 與 [ 確認(rèn)密碼 ] " + "不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE); return; }//Endif String umName = cb31.getEditor ().getItem () + "";//獲得用戶名 try { ResultSet rs = sunsql.executeQuery ("select userid from pwd where delmark=0 " + "and userid='" + umName + "'"); int isID = sunsql.recCount(rs); if(isID > 0){ //當(dāng)前要加入的用戶名是否存在 JOptionPane.showMessageDialog (null, "管理員ID [ " + umName + " ] 已存在," + "請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE); return; }//Endif if(rb35.isSelected()) //獲得是否是管理員權(quán)限 pu = "管理員"; long pk = sunsql.getPrimaryKey();//從服務(wù)獲得主鍵 //記入數(shù)據(jù)庫 isID = sunsql.executeUpdate("insert into pwd(pk,userid,pwd,puis) values(" + pk + ",'" + umName + "','" + pwd1 + "','" + pu + "')"); if(isID == 0) { JOptionPane.showMessageDialog (null, "添加操作失敗,請(qǐng)檢查網(wǎng)絡(luò)連接是否正常 " + "...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE); return; } tf32.setText(""); //清空密碼 tf33.setText(""); } catch (Exception ex) { System.out.println ("UserID.umAdd(): Add new ID error."); }//End try } /**=======================================================================** * [## private void umUpdate (int type) {} ]: 更新刪除操作 * 參數(shù) :int 變量表示操作類型 0:表示修改密碼 1:表示刪除記錄 * 返回值 :無 * 修飾符 :private * 功能 :修改密碼和刪除用戶ID **=======================================================================** */ private void umUpdate (int type) { String umName = cb31.getSelectedItem() + ""; //獲得用戶名 String pwd0; String pwd1 = String.valueOf (tf32.getPassword ()); String pwd2 = String.valueOf (tf33.getPassword ()); int isID = 0; //用戶是否存在 if(!pwd1.equals (pwd2)) { //兩次密碼不相等 JOptionPane.showMessageDialog (null, "輸入錯(cuò)誤,[ 新密碼 ] 與 [ 確認(rèn)密碼 ] " + "不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE); return; }//Endif if(type == 0) pwd0 = String.valueOf (tf31.getPassword ());//取修改操作的密碼 else pwd0 = String.valueOf (tf32.getPassword ());//取刪除操作的密碼 try { ResultSet rs = sunsql.executeQuery ("select pwd from pwd where delmark=0 and " + "userid='" + umName + "'"); rs.next(); if(!pwd0.equals(rs.getString(1))){ //判斷原密碼是否正確 JOptionPane.showMessageDialog (null, "管理員ID [ " + umName + " ] 的 [ 原" + "密碼 ] 不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE); return; }//Endif if(type == 0) { //執(zhí)行修改密碼操作 isID = sunsql.executeUpdate("update pwd set pwd='" + pwd1 + "' where " + "delmark=0 and userid='" + umName + "'"); }else { //執(zhí)行刪除操作 isID = sunsql.executeUpdate("update pwd set delmark=1 where userid='" + umName + "'"); }//Endif } catch (Exception ex) { }//End try if(isID == 0) { //判斷操作是否成功 JOptionPane.showMessageDialog (null, "執(zhí)行操作失敗,請(qǐng)檢查網(wǎng)絡(luò)連接是否正常 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE); } tf31.setText(""); //清空密碼 tf32.setText(""); tf33.setText(""); return; } //檢查計(jì)費(fèi)設(shè)置是否合法 private boolean isValidity() { if(!suntools.isNum(tf41.getText(), 1, 6, 9)) { JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 1 ] 只能是數(shù)字,且范圍在 6-9 之間", "提示", JOptionPane.INFORMATION_MESSAGE); tf41.requestFocus(true); return false; }else if(!suntools.isNum(tf42.getText(), 2, 11, 13)) { JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 2 ] 只能是數(shù)字,且范圍在 11-13 之間", "提示", JOptionPane.INFORMATION_MESSAGE); tf42.requestFocus(true); return false; }else if(!suntools.isNum(tf43.getText(), 2, 17, 19)) { JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 3 ] 只能是數(shù)字,且范圍在 17-19 之間", "提示", JOptionPane.INFORMATION_MESSAGE); tf43.requestFocus(true); return false; }else if(!suntools.isNum(tf44.getText(), 1, 0, 5)) { JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 1 ] 只能是數(shù)字,且范圍在 0-5 之間", "提示", JOptionPane.INFORMATION_MESSAGE); tf44.requestFocus(true); return false; }else if(!suntools.isNum(tf45.getText(), 1, 1, 5)) { JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 2 ] 只能是數(shù)字,且范圍在 1-5 之間", "提示", JOptionPane.INFORMATION_MESSAGE); tf45.requestFocus(true); return false; }else if(!suntools.isNum(tf46.getText(), 2, 20, 40)) { JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 3 ] 只能是數(shù)字,且范圍在 20-40 之間", "提示", JOptionPane.INFORMATION_MESSAGE); tf46.requestFocus(true); return false; }else if(!suntools.isNum(tf47.getText(), 2, 5, 15)) { JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 4 ] 只能是數(shù)字,且范圍在 5-15 之間", "提示", JOptionPane.INFORMATION_MESSAGE); tf47.requestFocus(true); return false; }//endif return true; } /**=======================================================================** * [## private boolean isState(int aRow[]) {} ]: * 參數(shù) :int aRom[] 表示要執(zhí)行刪除操作的行號(hào) * 返回值 :boolean * 修飾符 :private * 功能 :檢查房間的狀態(tài)是否可以刪除 **=======================================================================** */ private boolean isState(int aRow[]) { int ar = aRow.length; ResultSet rs = null; String aState = ""; try { for (int i = 0; i < ar; i++) { rs = sunsql.executeQuery("select state from roominfo where " + "delmark=0 and pk='" + dtm12.getValueAt(aRow[i], 0) + "'"); rs.next(); aState = rs.getString(1); if(aState.equals("占用")) { JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) + " ] 房間正處于占用狀態(tài),無法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE); return false; }else if(aState.equals("鐘點(diǎn)")) { JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) + " ] 房間正處于鐘點(diǎn)房狀態(tài),無法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE); return false; }else if(aState.equals("預(yù)訂")) { JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) + " ] 房間正處于預(yù)訂狀態(tài),無法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE); return false; }//Endif }//Endif } catch (Exception ex) { ex.printStackTrace(); System.out.println ("Setup.isState(): false"); }//End try return true; } /**=======================================================================** * ActionListener 監(jiān)聽 **=======================================================================** */ public void actionPerformed(ActionEvent ae) { Object o = ae.getSource(); if(o == bt11) {//======================================================= art.show(true); //添加房間類型 buildDTM11(); //刷新表數(shù)據(jù) buildDTM12(""); //刷新表數(shù)據(jù) buildDTM22(); //刷新表數(shù)據(jù) }else if(o == bt12) {//================================================= if(initMrt()) { //傳數(shù)據(jù)給窗口 mrt.show(true); //修改房間類型 buildDTM11(); //刷新表數(shù)據(jù) buildDTM12(""); //刷新表數(shù)據(jù) buildDTM22(); //刷新表數(shù)據(jù) }//Endif }else if(o == bt13) {//================================================= int rRow[] = tb11.getSelectedRows(); //刪除房間類型 int sysmark; for (int i = 0; i < rRow.length; i++) { //獲得得記錄的屬性標(biāo)志,并轉(zhuǎn)成整型 sysmark = Integer.parseInt(dtm11.getValueAt(rRow[i], 1) + ""); if(sysmark == 1) { JOptionPane.showMessageDialog(null, "[ " + dtm11.getValueAt(rRow[i], 4) + " ] 類型為系統(tǒng)級(jí)設(shè)置,不允許被刪除,系統(tǒng)終止了刪除操作 ...", "提示", JOptionPane.INFORMATION_MESSAGE); return; //不執(zhí)行刪除返回窗口 }//Endif }//Endfor String msg = "注意,刪除 [ 房間類型 ] 操作會(huì)將與 [ 房間類型 ] 相關(guān)" + "的所有 [ 房間信息 ] 一并刪除。\n您確定要?jiǎng)h除在表格中選中的類型條目嗎?"; if(delInfo ("roomtype", dtm11, rRow, msg)) { //執(zhí)行刪除操作 buildDTM11(); //刷新類型表數(shù)據(jù) buildDTM12(""); //刷新房間表數(shù)據(jù) buildDTM22(); //刷新類型表數(shù)據(jù) journal = "執(zhí)行了刪除房間類型的操作--刪除數(shù)量:" + rRow.length; Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_RT);//記錄操作日志 }//Endif }else if(o == bt14) {//================================================= if(initDis(tb11, dtm11)) { //房間費(fèi)打折 dis.show(true); }//Endif }else if(o == bt15) {//================================================= sunsql.initJComboBox(AddRoomInfo.cb1, "select r_type from roomtype where delmark = 0"); ari.show(true); //單個(gè)添加房間信息 buildDTM12(""); //刷新表數(shù)據(jù) }else if(o == bt16) {//================================================= sunsql.initJComboBox(AddRoomInfos.cb, "select r_type from roomtype where delmark = 0"); aris.show(true); //批量添加房間信息 buildDTM12(""); //刷新表數(shù)據(jù) }else if(o == bt18) {//================================================= sunsql.initJComboBox(ModiRoomInfo.cb1, "select r_type from roomtype where delmark = 0"); if(initMri()) { //傳數(shù)據(jù)給窗口 mri.show(true); //修改房間信息 buildDTM12(""); //刷新表數(shù)據(jù) }//Endif }else if(o == bt17) {//================================================= int rRow[] = tb12.getSelectedRows(); //刪除房間信息 if(isState(rRow)) { //判斷房間的狀態(tài)是否可以刪除 if(delInfo ("roominfo", dtm12, rRow, msg0)) { //執(zhí)行刪除操作 buildDTM12(""); //刷新房間表數(shù)據(jù) journal = "執(zhí)行了刪除房間信息的操作--刪除數(shù)量:" + rRow.length; Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_RI);//記錄操作日志 }//Endif } }else if(o == bt19) {//================================================= if(!suntools.isNum(tf11.getText(),2 ,5 ,30)) { //保存退房后房間狀態(tài) JOptionPane.showMessageDialog(null, "結(jié)算后更改房間狀態(tài)的時(shí)間框只能為數(shù)字,且范圍在 5 - 30 之間", "提示", JOptionPane.INFORMATION_MESSAGE); tf11.requestFocus(true); return; } sunini.setIniKey(ini[16], cb12.getSelectedIndex() + ""); //將設(shè)置保存至緩沖區(qū) sunini.setIniKey(ini[17], tf11.getText()); sunini.saveIni(ini); //將緩沖區(qū)的設(shè)置保存至INI文件 }else if(o == bt20) {//================================================= int cbIndex = cb11.getSelectedIndex(); //篩選信息 if(cbIndex == cb11.getItemCount() - 1) { //顯示全部房間 buildDTM12(""); //刷新房間表數(shù)據(jù) }else { String rt = "and a.r_type_id = '" + dtm11.getValueAt(cbIndex, 2) + "'"; buildDTM12(rt); //根據(jù)指定房間類型刷新表數(shù)據(jù) }//Endif }else if(o == bt21) {//================================================= act.show(true); //添加客戶類型 buildDTM21(); }else if(o == bt22) {//================================================= if(initMct()) { //傳數(shù)據(jù)給窗口 mct.show(true); //修改客戶類型 buildDTM21(); //刷新表數(shù)據(jù) }//Endif }else if(o == bt23) {//================================================= int rRow[] = tb21.getSelectedRows(); //刪除客戶類型 if(delInfo ("customertype", dtm21, rRow, msg0)) { //執(zhí)行刪除操作 buildDTM21(); //刷新房間表數(shù)據(jù) journal = "執(zhí)行了刪除客戶類型的操作--刪除數(shù)量:" + rRow.length; Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_US);//記錄操作日志 }//Endif }else if(o == bt24) {//================================================= if(initDis(tb22, dtm22)) { //房間費(fèi)打折 dis.show(true); }//Endif }else if(o == bt31) {//===================================//登記操作員信息 if(String.valueOf(tf32.getPassword()).length() == 0) { JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示", JOptionPane.INFORMATION_MESSAGE); return; }else if(String.valueOf(tf33.getPassword()).length() == 0) { JOptionPane.showMessageDialog(null, " [ 確認(rèn)密碼 ] 不能為空", "提示", JOptionPane.INFORMATION_MESSAGE); return; }//Endif umAdd (); //執(zhí)行添加操作 buildDTM31(); //刷新表數(shù)據(jù) journal = "添加了新的操作員信息-- [ " + cb31.getEditor ().getItem () + " ]"; Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志 }else if(o == bt32) {//==================================//修改操作員信息 if(String.valueOf(tf31.getPassword()).length() == 0) { JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示", JOptionPane.INFORMATION_MESSAGE); return; }else if(String.valueOf(tf32.getPassword()).length() == 0) { JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示", JOptionPane.INFORMATION_MESSAGE); return; }else if(String.valueOf(tf33.getPassword()).length() == 0) { JOptionPane.showMessageDialog(null, " [ 確認(rèn)密碼 ] 不能為空", "提示", JOptionPane.INFORMATION_MESSAGE); return; }//Endif umUpdate (0); //執(zhí)行修改密碼操作 journal = "修改了操作員 [ " + cb31.getEditor ().getItem () + " ] 的設(shè)置"; Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志 }else if(o == bt33) {//=================================================//刪除操作員信息 if(String.valueOf(tf32.getPassword()).length() == 0) { JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示", JOptionPane.INFORMATION_MESSAGE); return; }else if(String.valueOf(tf33.getPassword()).length() == 0) { JOptionPane.showMessageDialog(null, " [ 確認(rèn)密碼 ] 不能為空", "提示", JOptionPane.INFORMATION_MESSAGE); return; }//Endif int wi = JOptionPane.showConfirmDialog(null,"您確認(rèn)要?jiǎng)h除當(dāng)前的用戶ID嗎?", "提示", JOptionPane.YES_NO_OPTION); if(wi == JOptionPane.YES_OPTION) { umUpdate (1); //執(zhí)行刪除用戶ID操作 buildDTM31(); //刷新表數(shù)據(jù) journal = "刪除了操作員 [ " + cb31.getEditor ().getItem () + " ] 的設(shè)置"; Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志 }//Endif }else if(o == bt41) {//================================================= if(isValidity()) { int saveJf = JOptionPane.showConfirmDialog(null, "您 確 實(shí) 要 保 存 " + "當(dāng) 前 的 計(jì) 費(fèi) 設(shè) 置 嗎 ?","保存設(shè)置",JOptionPane.YES_NO_OPTION); if(saveJf == JOptionPane.YES_OPTION) { //保存計(jì)費(fèi)設(shè)置 sunini.setIniKey("In_Room", tf41.getText()); //將設(shè)置保存至緩沖區(qū) sunini.setIniKey("Out_Room1", tf42.getText()); sunini.setIniKey("Out_Room2", tf43.getText()); sunini.setIniKey("ClockRoom1", tf44.getText()); sunini.setIniKey("ClockRoom2", tf45.getText()); sunini.setIniKey("InsuHour1", tf46.getText()); sunini.setIniKey("InsuHour2", tf47.getText()); if(ck.isSelected()) { //不足一天按一天收費(fèi) sunini.setIniKey("InsuDay","1"); }else { sunini.setIniKey("InsuDay","0"); }//Endif sunini.saveIni(ini); //將緩沖區(qū)的設(shè)置保存至INI文件 journal = "修改了系統(tǒng)的計(jì)費(fèi)設(shè)置"; Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_JF);//記錄操作日志 }//Endif }//Endif }else if(o == bt42) {//================================================= this.setVisible(false); //返回主窗口 }else if(o == tf41) { tf42.requestFocus(true); }else if(o == tf42) { tf43.requestFocus(true); }else if(o == tf43) { tf44.requestFocus(true); }else if(o == tf44) { tf45.requestFocus(true); }else if(o == tf45) { tf46.requestFocus(true); }else if(o == tf46) { tf47.requestFocus(true); }else if(o == rb31) {//================================================= bt31.setEnabled (true); //操作范圍--添加新操作員 bt32.setEnabled (false); bt33.setEnabled (false); rb34.setEnabled (true); rb35.setEnabled (true); tf31.setEditable(false); tf32.setEditable(true); tf33.setEditable(true); cb31.setEditable (true); }else if(o == rb32) { //操作范圍--操作員修改密碼 bt31.setEnabled (false); bt32.setEnabled (true); bt33.setEnabled (false); rb34.setEnabled (false); rb35.setEnabled (false); tf31.setEditable(true); tf32.setEditable(true); tf33.setEditable(true); cb31.setEditable (false); }else if(o == rb33) { //操作范圍--刪除操作員 bt31.setEnabled (false); bt32.setEnabled (false); bt33.setEnabled (true); rb34.setEnabled (false); rb35.setEnabled (false); tf31.setEditable(false); tf32.setEditable(true); tf33.setEditable(true); cb31.setEditable (false); }//Endif }//End actionPerformed /**=======================================================================** * MouseListener 監(jiān)聽 **=======================================================================** */ public void mouseClicked (MouseEvent me) { } public void mousePressed (MouseEvent me) { } public void mouseReleased(MouseEvent me) { } public void mouseEntered (MouseEvent me) { //鼠標(biāo)移進(jìn)提示 Object o = me.getSource (); if(o == bt11) { HotelFrame.lbA.setText (HotelFrame.clue + "添加新的房間類型 "); }else if(o == bt12) { HotelFrame.lbA.setText (HotelFrame.clue + "修改指定的房間類型 "); }else if(o == bt13) { HotelFrame.lbA.setText (HotelFrame.clue + "刪除指定的房間類型 "); }else if(o == bt14) { HotelFrame.lbA.setText (HotelFrame.clue + "設(shè)置指定房間類型的消費(fèi)折扣 "); }else if(o == bt15) { HotelFrame.lbA.setText (HotelFrame.clue + "為指定的房間類型添加新的客房 "); }else if(o == bt16) { HotelFrame.lbA.setText (HotelFrame.clue + "為指定的房間類型一次添加多個(gè)新客房 "); }else if(o == bt17) { HotelFrame.lbA.setText (HotelFrame.clue + "修改指定客房信息設(shè)置 "); }else if(o == bt18) { HotelFrame.lbA.setText (HotelFrame.clue + "刪除指定的客房 "); }else if(o == bt19) { HotelFrame.lbA.setText (HotelFrame.clue + "保存房間退房后的狀態(tài) "); }else if(o == bt20) { HotelFrame.lbA.setText (HotelFrame.clue + "以左邊指定的類型顯示房間信息 "); } if(o == bt21) { HotelFrame.lbA.setText (HotelFrame.clue + "添加新的客戶類型 "); }else if(o == bt22) { HotelFrame.lbA.setText (HotelFrame.clue + "修改指定的客戶資料 "); }else if(o == bt23) { HotelFrame.lbA.setText (HotelFrame.clue + "刪除指定的客戶資料 "); }else if(o == bt24) { HotelFrame.lbA.setText (HotelFrame.clue + "設(shè)置指定房間類型的消費(fèi)折扣 "); }else if(o == bt31) { HotelFrame.lbA.setText (HotelFrame.clue + "添加新的操作員 "); }else if(o == bt32) { HotelFrame.lbA.setText (HotelFrame.clue + "修改指定的操作員密碼 "); }else if(o == bt33) { HotelFrame.lbA.setText (HotelFrame.clue + "刪除指定的操作員 "); }else if(o == bt41) { HotelFrame.lbA.setText (HotelFrame.clue + "保存當(dāng)前的計(jì)費(fèi)設(shè)置至INI配置文件 "); }else if(o == bt42) { HotelFrame.lbA.setText (HotelFrame.clue + "返回主窗口 "); } } public void mouseExited (MouseEvent me) { HotelFrame.lbA.setText (HotelFrame.clue + "請(qǐng)選擇功能項(xiàng) ... "); } }
3.登錄窗口:
/** *############################################################################## * * [ 項(xiàng)目名 ] : 陽光酒店管理系統(tǒng) * [ 公司名 ] : 清華IT * [ 模塊名 ] : 系統(tǒng)登陸窗口 * [ 文件名 ] : Login.java * [ 相關(guān)文件 ] : * [ 文件實(shí)現(xiàn)功能] : 系統(tǒng)登陸窗口 * [ 作者 ] : 顧俊 * [ 版本 ] : 1.1 * ---------------------------------------------------------------------------- * [ 備注 ] : * ---------------------------------------------------------------------------- * [ 修改記錄 ] : * * [ 日 期 ] [版本] [修改人] [修改內(nèi)容] * 2006/04/02 1.0 顧俊 創(chuàng)建 * 2006/04/06 1.1 顧俊 增加注釋 * 2006/04/19 1.2 顧俊 自動(dòng)記錄登錄日志 * ##-------------------------------------------------------------------------- * 版權(quán)所有(c) 2006-2007, SunshineSOFT Corporation * --------------------------------------------------------------------------## * * [ 函數(shù)說明 ] : * * [## public Login() {} ]: * 功能: 構(gòu)造函數(shù) 組建登錄窗口 * * [## private void buildCenter() {} ]: * 功能: 組建用戶名密碼面板,僅類內(nèi)使用 * * [## private void quit() {} ]: * 功能: 關(guān)閉系統(tǒng)函數(shù),僅類內(nèi)使用 * * [## private void dengLu() {} ]: * 功能: 密碼驗(yàn)證通過,進(jìn)入主操作界面,僅類內(nèi)使用 * * [ 遺留問題 ] : * *############################################################################## */ //package com.sunshine.login; import javax.swing.*; import javax.swing.border.*; import java.awt.*; import java.awt.event.*; import java.sql.*; import com.sunshine.sunsdk.sql.*; import com.sunshine.sunsdk.swing.*; import com.sunshine.sunsdk.system.*; import com.sunshine.mainframe.*; public class Login extends JFrame implements ActionListener, KeyListener, ItemListener, FocusListener { JLabel top, bott; JComboBox cb; JPasswordField pf; JButton bt1, bt2; JPanel panelMain, panelInfo; String clue = " 提 示 : "; int flag = 0; //登記次數(shù)記數(shù)器 /**=======================================================================** * [## public Login() {} ]: 構(gòu)造函數(shù) * 參數(shù) :無 * 返回值 :無 * 修飾符 :public * 功能 :組建登錄窗口 **=======================================================================** */ public Login() { super("系 統(tǒng) 登 錄"); top = new JLabel (new ImageIcon("pic/login_top.gif")); bott = new JLabel(); panelMain = new JPanel(new BorderLayout(10, 10)); bott.setBorder(new LineBorder (new Color(184, 173, 151))); buildCenter(); panelMain.add("North", top); panelMain.add("South", bott); panelMain.add(panelInfo); //加事件監(jiān)聽 bt1.addActionListener(this); bt2.addActionListener(this); bt1.addFocusListener (this); bt2.addFocusListener (this); bt1.addKeyListener (this); bt2.addKeyListener (this); cb.addItemListener (this); cb.addFocusListener(this); pf.addFocusListener(this); cb.addKeyListener (this); pf.addKeyListener (this); //加窗口監(jiān)聽 new WindowAdapter適配器類 this.addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent we) { quit(); }//End windowClosing }); this.setContentPane(panelMain); //設(shè)置窗口面板 this.setSize(350, 235); this.setResizable (false); //設(shè)置窗口不可放大縮小 this.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE); sunswing.setWindowCenter(this); this.setVisible(true); pf.requestFocus(true); //設(shè)置焦點(diǎn)給密碼框 } /**=======================================================================** * [## private void buildCenter() {} ]: 制作用戶名密碼面板 * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :組建用戶名密碼面板,僅類內(nèi)使用 **=======================================================================** */ private void buildCenter() { JLabel lb1, lb2; JPanel pa1, pa2, pa3; lb1 = new JLabel("用 戶 名 :"); lb2 = new JLabel("登錄密碼 :"); cb = new JComboBox(); pf = new TJPasswordField (15); bt1 = new TJButton ("pic/key.gif", "登 錄", "登錄系統(tǒng)"); bt2 = new TJButton ("pic/exit.gif", "退 出", "關(guān)閉系統(tǒng)"); sunsql.initJComboBox (cb, "select userid from pwd where delmark=0"); //定義面板為無部局 panelInfo = new JPanel(null); //加入組件 panelInfo.add(lb1); panelInfo.add(lb2); panelInfo.add(cb); panelInfo.add(pf); panelInfo.add(bt1); panelInfo.add(bt2); lb1.setBounds(50,14,60,20); lb2.setBounds(50,48,60,20); bt1.setBounds(68,77,86,28); bt2.setBounds(186,77,86,28); cb.setBounds (115,12,168,23); pf.setBounds (115,46,170,23); //設(shè)定邊框線 panelInfo.setBorder(BorderFactory.createTitledBorder("")); } /**=======================================================================** * [## private void quit() {} ]: 系統(tǒng)退出 * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :關(guān)閉系統(tǒng)函數(shù),僅類內(nèi)使用 **=======================================================================** */ private void quit() { int flag = 0; String msg = "您 現(xiàn) 在 要 關(guān) 閉 系 統(tǒng) 嗎 ?"; flag = JOptionPane.showConfirmDialog(null, msg, "提示", JOptionPane.YES_NO_OPTION); if(flag == JOptionPane.YES_OPTION) { this.setVisible(false); System.exit(0); }//End if(flag == JOptionPane.YES_OPTION) return; } /**=======================================================================** * [## private void dengLu() {} ]: 系統(tǒng)登錄 * 參數(shù) :無 * 返回值 :無 * 修飾符 :private * 功能 :密碼驗(yàn)證通過,進(jìn)入主操作界面,僅類內(nèi)使用 **=======================================================================** */ private void dengLu() { String user = cb.getSelectedItem() + ""; String pwd = String.valueOf(pf.getPassword()); String code = "select pwd,puis from pwd where delmark=0 and userid='" + user + "'"; ResultSet rs = sunsql.executeQuery (code); try { if(rs.next()) { //用戶名存在 if(pwd.equals(rs.getString(1))) { bott.setText(clue + "登錄成功,正在進(jìn)入系統(tǒng) ..."); String puis = rs.getString(2); //獲得操作員權(quán)限 boolean flag = Journal.writeJournalInfo(user, "登錄本系統(tǒng)", Journal.TYPE_LG); if(flag) { //記錄日志 new com.sunshine.mainframe.HotelFrame(user, puis); //進(jìn)入主程序窗口(用戶名, 權(quán)限) this.setVisible(false); }else { String msg = "寫日志錯(cuò)誤,請(qǐng)與系統(tǒng)管理員聯(lián)系 ..."; JOptionPane.showMessageDialog(null, msg, "錯(cuò)誤", JOptionPane.ERROR_MESSAGE); System.exit(0); } } else { bott.setText(clue + "用戶 [ " + user + " ] 的密碼不正確,請(qǐng)重新輸入 ..."); flag++; if(flag == 3) { //三次密碼驗(yàn)證 JOptionPane.showMessageDialog(null, "您不是本系統(tǒng)的管理員,系統(tǒng)關(guān)閉 ...", "警告", JOptionPane.ERROR_MESSAGE); System.exit(0); }//End if(flag == 3) return; }//End if(pwd.equals(rs.getString(1))) } else { bott.setText(clue + "用戶ID [ " + user + " ] 不存在 ..."); }//End if(rs.next()) } catch (Exception ex) { ex.printStackTrace(); }//End try } /**=======================================================================** * ActionListener 監(jiān)聽 **=======================================================================** */ public void actionPerformed (ActionEvent ae) { //動(dòng)作監(jiān)聽 if(ae.getSource() == bt1) { //登錄按鍵 dengLu(); } else { quit(); }//End if(ae.getSource() == bt1) } /**=======================================================================** * ItemListener 監(jiān)聽 **=======================================================================** */ public void itemStateChanged (ItemEvent ie) { pf.requestFocus(true); } /**=======================================================================** * KeyListener 監(jiān)聽 **=======================================================================** */ public void keyPressed (KeyEvent ke) { //鍵盤按下監(jiān)聽 int key = ke.getKeyCode(); if(key == KeyEvent.VK_ENTER) { if(ke.getSource() == cb) pf.requestFocus(true); //將焦點(diǎn)從用戶名給密碼 if(pf.getPassword().length > 0) dengLu(); //按Enter鍵登錄系統(tǒng) } else if(key == KeyEvent.VK_ESCAPE) { //按ESC鍵退出系統(tǒng) quit(); }//End if } public void keyReleased (KeyEvent ke) { //鍵盤釋放監(jiān)聽 } public void keyTyped (KeyEvent ke) { //按鍵型監(jiān)聽 } /**=======================================================================** * FocusListener 監(jiān)聽 **=======================================================================** */ public void focusGained (FocusEvent fe) { //焦點(diǎn)監(jiān)聽 if(fe.getSource() == cb) //窗口最下方的功能提示 bott.setText(clue + "請(qǐng)選擇操作員名稱 ..."); else if(fe.getSource() == pf) bott.setText(clue + "請(qǐng)輸入登錄密碼 ..."); else if(fe.getSource() == bt1) bott.setText(clue + "登錄系統(tǒng) ..."); else if(fe.getSource() == bt2) bott.setText(clue + "退出系統(tǒng) ..."); } public void focusLost (FocusEvent fe) { //失去焦點(diǎn)監(jiān)聽 } /**=======================================================================** * [## public static void main(String sd[]) {} ]: 主函數(shù) * 參數(shù) :String sd[] * 返回值 :無 * 修飾符 :public static * 功能 :程序入口 **=======================================================================** */ public static void main(String sd[]) { sunswing.setWindowStyle(sunini.getIniKey("Sys_style").charAt(0)); new FStartWindow ("pic/Login.gif", new Frame(), 1200); new Login(); } }
獲取地址:Java swing實(shí)現(xiàn)酒店管理系統(tǒng)
更多學(xué)習(xí)資料請(qǐng)關(guān)注專題《管理系統(tǒng)開發(fā)》。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java代碼實(shí)現(xiàn)酒店管理系統(tǒng)
- Java實(shí)現(xiàn)簡(jiǎn)單酒店管理系統(tǒng)
- Java實(shí)戰(zhàn)之酒店人事管理系統(tǒng)的實(shí)現(xiàn)
- Java 實(shí)戰(zhàn)練手項(xiàng)目之酒店管理系統(tǒng)的實(shí)現(xiàn)流程
- 基于JavaSwing設(shè)計(jì)和實(shí)現(xiàn)的酒店管理系統(tǒng)
- Java實(shí)現(xiàn)簡(jiǎn)單的酒店管理系統(tǒng)
- java實(shí)現(xiàn)酒店管理系統(tǒng)
- Java實(shí)現(xiàn)酒店客房管理系統(tǒng)
- Java代碼實(shí)現(xiàn)簡(jiǎn)單酒店管理系統(tǒng)
相關(guān)文章
Java日期工具類時(shí)間校驗(yàn)實(shí)現(xiàn)
一般項(xiàng)目中需要對(duì)入?yún)⑦M(jìn)行校驗(yàn),比如必須是一個(gè)合法的日期,本文就來介紹一下Java日期工具類時(shí)間校驗(yàn)實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12讓Java后臺(tái)MySQL數(shù)據(jù)庫能夠支持emoji表情的方法
最近開發(fā)的iOS項(xiàng)目因?yàn)樾枰脩粑谋镜拇鎯?chǔ),自然就遇到了emoji等表情符號(hào)如何被mysql DB支持的問題。下面這篇文章主要介紹了關(guān)于讓Java后臺(tái)MySQL數(shù)據(jù)庫能夠支持emoji表情的方法,需要的朋友可以參考下。2017-03-03Java事件處理機(jī)制(自定義事件)實(shí)例詳解
這篇文章主要介紹了Java事件處理機(jī)制(自定義事件)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2016-12-12Java日期時(shí)間格式化操作DateUtils 的整理
這篇文章主要介紹了Java日期時(shí)間格式化操作DateUtils 的整理的相關(guān)資料,這里總結(jié)了java日期格式化的操作,需要的朋友可以參考下2017-07-07java自定義驗(yàn)證器的實(shí)現(xiàn)示例
在對(duì)外暴露接口中,我們通常會(huì)對(duì)入?yún)⑦M(jìn)行驗(yàn)證,比如一些字符串非空判斷等,本文主要介紹了java自定義驗(yàn)證器的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01Java HelloWorld原理分析_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
我們初學(xué)java的第一個(gè)程序是"hello world"。下面通過實(shí)例代碼給大家講解Java HelloWorld原理分析,感興趣的朋友一起學(xué)習(xí)吧2017-05-05