1.Swing界面开发
流程:首先在类里定义主函数,主函数中实例化对象,并调用实现界面的方法。
接下来就是定义实现界面的方法的步骤概要:
第一步,实例化一个窗体对象,并且设置窗体属性,如:大小,初始位置等,这些属性都是以set开头,代码提示会告知需要传入的参数,这些依照要求来就好。需要注意的是有一个setVisible(),必须设置为true才是可见的。
第二步,设置布局,常用的布局有流式布局,边框布局,网格布局。流式布局是指按顺序排列,放不下则换行。边框布局分为东南西北中五块。网格布局是一种对齐的布局方式。
第三步,添加组件,常用组件有JLabel,JTextField,JButton等。先实例化,然后用add()添加即可。
2.实现QQ登录界面
了解了上面那些基本知识,我选择边框布局来实现QQ登录界面。 北面放图片,西边放头像,中间放待填写的登录信息,以及是否记住密码等,东边放注册账号等待选项目,南边放登录按钮。现将组件添加到面板上,再将面板添加到窗体上。
代码如下:
public class Practice { public static void main(String args[]){ Practice pra = new Practice(); pra.initUI(); } public void initUI(){ //实例化一个窗体对象 javax.swing.JFrame window = new javax.swing.JFrame(); //IconImage icon =new IconImage("you.jpg"); //window.setIconImage(icon); //设置属性 //设置标题 window.setTitle("登录"); //设置大小 window.setSize(370,285); //是否可调整大小 window.setResizable(false); //起始点大小 window.setLocation(400,200); //关闭时退出 window.setDefaultCloseOperation(2); window.setFont(new Font("宋体" ,Font.BOLD,30)); ImageIcon Image1 = new ImageIcon("image/QQ/ic.jpg"); window.setIconImage(Image1.getImage()); //设置背景图片 ImageIcon Image = new ImageIcon("image/QQ/xia.jpg"); JLabel blackground = new JLabel(Image); //设置标签的大小 blackground.setBounds(0, 220,Image.getIconWidth(), Image.getIconHeight()); //将标签添加到LayeredPane window.getLayeredPane().add(blackground, new Integer(Integer.MIN_VALUE)); //将LayeredPane上一层的面板设置为透明 JPanel contentPanel = (JPanel)window.getContentPane(); //设置面板为透明 contentPanel.setOpaque(false); //设置布局 window.setLayout(new java.awt.BorderLayout()); //上的实例化 JPanel panelUp = new JPanel(); panelUp.setLayout(new java.awt.FlowLayout(java.awt.FlowLayout.LEADING,0,0)); JLabel jlaImage = new JLabel(new ImageIcon("image/QQ/up.jpg")); panelUp.add(jlaImage); //setBackground(black); window.add(panelUp,java.awt.BorderLayout.NORTH); //左边实例化 JPanel panelleft = new JPanel(); panelleft.setPreferredSize(new java.awt.Dimension(100,60)); panelleft.setLayout(new java.awt.FlowLayout(java.awt.FlowLayout.LEFT,0,0)); JLabel jlaImage2 = new JLabel(new ImageIcon("image/QQ/west.jpg")); //JLabel jlaImage3 = new JLabel(new ImageIcon("image/you.jpg")); panelleft.add(jlaImage2); //panelleft.add(jlaImage3); window.add(panelleft,java.awt.BorderLayout.WEST); //中间实例化 JPanel panelCenter = new JPanel(); panelCenter.setOpaque(false); panelCenter.setLayout(new java.awt.FlowLayout(java.awt.FlowLayout.LEADING,9,8)); //中间的组件 javax.swing.JTextField username=new javax.swing.JTextField(16); javax.swing.JPasswordField psw1=new javax.swing.JPasswordField("mima",16); javax.swing.JCheckBox box1 = new javax.swing.JCheckBox(); javax.swing.JLabel rem = new javax.swing.JLabel("记住密码"); rem.setFont(new Font("微软雅黑",Font.ROMAN_BASELINE,14)); javax.swing.JCheckBox box2 = new javax.swing.JCheckBox(); javax.swing.JLabel auto = new javax.swing.JLabel("自动登录"); auto.setFont(new Font("微软雅黑",Font.ROMAN_BASELINE,14)); //将中间的组件添加到面板上 panelCenter.add(username); panelCenter.add(psw1); panelCenter.add(box1); panelCenter.add(rem); panelCenter.add(box2); panelCenter.add(auto); //panelCenter.setPreferredSize(new java.awt.Dimension(20,50)); window.add(panelCenter,java.awt.BorderLayout.CENTER); //右的实例化 JPanel panelRight = new JPanel(); panelRight.setOpaque(false); //布局 panelRight.setLayout(new java.awt.FlowLayout(java.awt.FlowLayout.RIGHT,10,11)); panelRight.setPreferredSize(new java.awt.Dimension(70,100)); //实例化 javax.swing.JLabel sign = new javax.swing.JLabel("注册账号"); javax.swing.JLabel find = new javax.swing.JLabel("找回密码"); sign.setFont(new Font("微软雅黑",Font.ROMAN_BASELINE,14)); find.setFont(new Font("微软雅黑",Font.ROMAN_BASELINE,14)); //添加 panelRight.add(sign); panelRight.add(find); window.add(panelRight,java.awt.BorderLayout.EAST); //下的实例化 JPanel panelDown = new JPanel(); panelDown.setOpaque(false); panelDown.setPreferredSize(new java.awt.Dimension(370,35)); javax.swing.JButton login = new javax.swing.JButton("登录"); panelDown.add(login); window.add(panelDown,java.awt.BorderLayout.SOUTH); //实例化一个LoginListener对象 LoginListener l = new LoginListener(username,psw1); //给事件源对象添加动作监听器方法 login.addActionListener(l); //设置为可见 window.setVisible(true); } }
3.定义监听器,判断用户名与密码是否正确,不是则弹出错误界面,如果正确则进入计算器界面。 只添加了这一个简单的监听器。
public class LoginListener implements ActionListener{ private JTextField username; private JPasswordField psw1; public LoginListener(JTextField username,JPasswordField psw1){ this.username=username; this.psw1=psw1; } public void actionPerformed(ActionEvent e){ String str1 = username.getText(); String str2=new String (psw1.getPassword()); if(str1.equals("admin")&&str2.equals("123456")) { cn.gsj.study0605.cal.Calculator cal = new cn.gsj.study0605.cal.Calculator(); cal.show(); } else JOptionPane.showMessageDialog(null,"账号或密码错误!"); } }