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,"账号或密码错误!");
}
}