【Java】仿真qq尝试:聊天界面 && 响应用户输入
需求分析:
逐步完善一个“qq仿真”程序。
参考:
1、文本框与文本区:http://www.weixueyuan.net/view/6062.html
2、java布局:http://www.cnblogs.com/hthuang/p/3460234.html
效果:
login界面:

主界面:

思路:
1、先完成“精简”的本地版本
2、考虑与服务器交互
3、逐步完善功能
代码:
窗体大小方案一:
// 取得屏幕的尺寸
Toolkit kit = Toolkit.getDefaultToolkit();
Dimension screenSize = kit.getScreenSize();
int screenWidth = screenSize.width;
int screenHeight = screenSize.height; // 设置窗体尺寸、位置
setSize(screenWidth/6, screenHeight/6);
setLocationRelativeTo(null); // 居中
QQLogin:
package com.xkfx.qq.ui; import javax.swing.*;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; public class QQLogin extends JFrame implements ActionListener {
private static final int DEFAULT_WIDTH = 300;
private static final int DEFAULT_HEIGHT = 200; private JButton btnLogin = new JButton("Sign in");
private JButton btnRegister = new JButton("Sign up"); private JLabel labUsername = new JLabel("Username");
private JLabel labPassword = new JLabel("Password");
private JTextField txtUsername = new JTextField();
private JTextField txtPassword = new JTextField(); private void setComponents() {
// 组件1
JPanel panUser = new JPanel();
panUser.setLayout(new GridLayout(2, 2)); panUser.add(labUsername);
panUser.add(txtUsername);
panUser.add(labPassword);
panUser.add(txtPassword); // 组件2
JPanel panBtn = new JPanel();
panBtn.setLayout(new FlowLayout()); panBtn.add(btnLogin);
panBtn.add(btnRegister); // 组合
setLayout(new BorderLayout()); add(panUser, BorderLayout.CENTER);
add(panBtn, BorderLayout.SOUTH);
} private void listenComponents() {
btnLogin.addActionListener(this);
btnRegister.addActionListener(this);
} public QQLogin() {
// 设置窗体大小和位置
setSize(DEFAULT_WIDTH, DEFAULT_HEIGHT);
setResizable(false);
setLocationRelativeTo(null); // 居中 // 设置组件
setComponents(); // 设置监听组件
listenComponents();
} @Override
public void actionPerformed(ActionEvent e) {
if (e.getActionCommand().equals("Sign in")) {
System.out.println("用户点击了登陆");
} if (e.getActionCommand().equals("Sign up")) {
System.out.println("用户点击了注册");
}
}
// 其实这里不需要暴露actionPerformed方法,但是无法设置成private。。。
} class QQLoginTest {
public static void main(String[] args) {
// 暂时简单地把这里看作启动Swing程序的神器代码
EventQueue.invokeLater(() -> {
JFrame frame = new QQLogin();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
// 关闭窗体就结束程序。默认情况下,当关闭窗体时只是把窗体“隐藏”起来。
frame.setVisible(true);
});
}
}
QQMain:
package com.xkfx.qq.ui; import javax.swing.*;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; public class QQMain extends JFrame implements ActionListener {
private static final int DEFAULT_WIDTH = 400;
private static final int DEFAULT_HEIGHT = 400; private JTextField txtMessage = new JTextField();
private JComboBox cmbUser = new JComboBox();
private JButton btnSend = new JButton("Send"); private JTextArea txtArea = new JTextArea();
private JScrollPane spArea = new JScrollPane(txtArea); //(参考书)
private void setComponents() {
// 组件1
JPanel panSmall = new JPanel();
panSmall.setLayout(new GridLayout(1, 2)); panSmall.add(cmbUser);
panSmall.add(btnSend); // 组件2
JPanel panBig = new JPanel();
panBig.setLayout(new GridLayout(2, 1)); panBig.add(txtMessage);
panBig.add(panSmall); // 组合
setLayout(new BorderLayout()); add(txtArea, BorderLayout.CENTER);
add(panBig, BorderLayout.NORTH);
} private void listenComponents() {
btnSend.addActionListener(this);
} public QQMain() {
// 设置窗体大小和位置
setSize(DEFAULT_WIDTH, DEFAULT_HEIGHT);
setResizable(false);
setLocationRelativeTo(null); // 居中 // 设置组件
setComponents(); // 设置监听组件
listenComponents();
} @Override
public void actionPerformed(ActionEvent e) {
if (e.getActionCommand().equals("Send")) {
System.out.println("用户点击了发送");
}
}
} class QQMainTest {
public static void main(String[] args) {
EventQueue.invokeLater(() -> {
JFrame frame = new QQMain();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setVisible(true);
});
}
}
后续 & 补充:
1、用blog来管理代码多少有点不方便。。。因为代码是不断修改的。。。等到一定规模考虑搬到github上去。。。
2、用git管理本地代码。根据个人经验,小量的本地代码只需要用到:git init、git add --all、git commit -m "words"、git reflog、git reset --hard hashcode就行了。。。(防止代码被改烂。。)
【Java】仿真qq尝试:聊天界面 && 响应用户输入的更多相关文章
- 微信小程序开发系列五:微信小程序中如何响应用户输入事件
微信小程序开发系列教程 微信小程序开发系列一:微信小程序的申请和开发环境的搭建 微信小程序开发系列二:微信小程序的视图设计 微信小程序开发系列三:微信小程序的调试方法 微信小程序开发系列四:微信小程序 ...
- Java基础之使用Scanner类获取用户输入
创建 Scanner 对象的基本语法: Scanner s = new Scanner(System.in); Scanner 类的 next() 方法 import java.util.Scanne ...
- android 仿QQ气泡聊天界面
1.现在的QQ,微信等一些APP的聊天界面都是气泡聊天界面,左边是接收到的消息,右边是发送的消息, 这个效果其实就是一个ListView在加载它的Item的时候,分别用了不同的布局xml文件. 2.效 ...
- Java入门:基础算法之获取用户输入
本部分演示如何获取用户输入.我们使用Scanner类来得到用户输入.下面的实例代码中演示了如何获取用户输入的字符串.整数和float数据.主要用到了以下方法: 1)public String next ...
- 【Java】仿真qq尝试:用户注册(三)
需求: 实现用户名和密码存入数据库. 思路: 1.连接数据表用静态加载块 2.crud写成4个静态方法 具体流程: from:https://www.tutorialspoint.com/jdbc/j ...
- 【Java】仿真qq尝试:用户注册(二)
参考: 1.corejavaI:使用解耦的try/catch与try/finally 2.Java中try catch finally语句中含有return语句的执行情况(总结版):http://bl ...
- 【Java】仿真qq尝试:用户注册(一)
需求: 1.流程分析:客户端程序拿到用户名和密码,将用户名和密码发送到服务端(在客户端验证合法性),服务端接收并存储用户名和密码,返回给客户端一个信息(可能是成功也可能是失败.) 2.数据怎么存?服务 ...
- safari 浏览器 input textarea select 等不能响应用户输入
解决办法 -webkit-user-select:auto; /*webkit浏览器*/ user-select:auto; -o-user-select:auto; -ms-user-select: ...
- QQ聊天界面的布局和设计(IOS篇)-第二季
QQChat Layout - 第二季 本来第二季是快写好了, 也花了点功夫, 结果gitbook出了点问题, 给没掉了.有些细节可能会一带而过, 如有疑问, 相互交流进步~. 在第一季中我们完成了Q ...
随机推荐
- 你 get 了无数技能,为什么一事无成
前 几日看到阮一峰老师的发的一句话,颇有感慨,「你只是坐在电脑前,往网上发表了一段文字或者一张图片,随便什么,就能够接触到多少陌生的灵魂.这就是我热 爱互联网的原因」.我打心底认为这是一个最好的时代, ...
- android去权限反编译,签名,zipalign优化
反编译:上工具ApkTool 下载自行搜索google apktool github cd apktool目录 java -jar apktool_2.0.1.jar d xx.apk 生成xx目录 ...
- java -Mac搭建本地服务器并映射到外网
最近在学习Html,小有进步变想着写一个浪漫的静态页面给女朋友浪漫一下,那么问题就来了,如何把我的网页让对网络一窍不通的女朋友看到,所以便想到了是用自己电脑作为服务器的想法.百度以后整理如下: 首先搭 ...
- uva 1478 - Delta Wave(递推+大数+卡特兰数+组合数学)
option=com_onlinejudge&Itemid=8&category=471&page=show_problem&problem=4224" st ...
- 将坐标转化为与X轴正半轴夹角模板
//还需加PI 和 mabs 函数 double chg(double x,double y) { double tmps; )<1e-) { ) tmps=90.0; else tmps=27 ...
- 表达式求值(java)
今天去面试,考了这个,短时间没想出来... 太笨了! 后来想用栈和递归做 但是看了网上才知道,可以将中缀表达式转为后缀表达式,就极其方便了. import java.util.Scanner; imp ...
- Html5-draggable元素拖动
Html5元素拖动 在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放. Internet Explorer 9+, Firefox, Opera, Chrome, 和 Safari 支持拖动 ...
- 四、H5 录制视频 Web Real-Time Communication
Web Real-Time Communication HTML5实现视频直播功能思路详解_html5教程技巧_脚本之家 https://m.jb51.net/html5/587215.html
- for...in循环取Json数据
var result = { "Tables":{ "B2B_DS_ORDERMX0":{ "ordernum":"tables- ...
- 从一个git仓库迁移到另外一个git仓库
1 从原地址克隆一份裸版本库,比如原本托管于 GitHub. git clone --bare git://github.com/username/project.git git操作的结果会有一个XX ...