• 仿QQ大战—界面篇


    之前在《仿QQ大战—服务器的搭建(ServerSocket)》中实现了服务器的搭建,以及一个简单地传递数据的实现,现在就是来实现类似与QQ聊天通信的功能。首先是界面的实现;

    首先:服务器和客户端的界面的实现,来看一下界面:

      • 在输入端口输入框中输入端口号,然后点击Start!按钮开始,服务器并开启。
      • 在开启服务器之后,当客户端实现连接到服务器之后,就会显示在服务器的下面的表格上。

    界面的实现

    JTable的使用

    这里主要介绍的是JTable来显示链接到了服务器的客户端的ID,姓名和IP地址;

    JTable:一共包括了三个方面:数据模型 、列模型和选择模型。在实例化时可以使用它默认模式也可以自己自己来构造;

    JTable的构造函数一共有7个,这里介绍2个:

    一: 构造一个 JTable 来显示二维数组 rowData 中的值,其列名称为 columnNames。

    JTable(Object[][] rowData, Object[] columnNames)

    String[] columnNames = { "用户名", "密码", "IP地址" };
    String[][] data = null;
    DefaultTableModel defaultTableModel = new DefaultTableModel(data, columnNames);
    JTable jtable = new JTable(data, columnNames);

    二: 构造一个 JTable,使用数据模型 、默认的列模型和默认的选择模型对其进行初始化。

    JTable(TableModel dm)

     String[] columnNames ={"用户名", "密码","IP地址"};
            String[][] data = null;
            DefaultTableModel defaultTableModel=new DefaultTableModel(data,columnNames);
       
            JTable jtable=new JTable(defaultTableModel);

    也可以自己来创建一个类然后实现接口TableModel ,重写里面的方法:

    ClientTableModel clientTableModel=new ClientTableModel(threadarray);
    //ClientTableModel实现了接口TableMode
    JTable jtable = new JTable(clientTableModel);// 表格

    需要重写的几个方法:

    1.getRowCount(),获得JTable中要显示的行数;

    @Override
    	public int getRowCount() {//得到行数;
    		return threadarray.size();
    	}
    	

    2.getColumnCount() ,获得JTable中要显示的列数

    @Override
    	public int getColumnCount() {//放回列数
    		return 3;
    	}

    3.getColumnName(int columnIndex),列表通过该方法来

    @Override
    	public String getColumnName(int columnIndex) {
    		if(columnIndex==0)
    			return "账号";
    		else if(columnIndex==1)
    			return "姓名";
    		else  if(columnIndex==2)
    			return "IP地址";
    		else 
    			return null;
    	}

    4.getColumnClass(int columnIndex)这个方法很重要,返回的是每一列的类型,如果没有写的话,就不能够往JTable中添加数据,他会报一个java.lang.NullPointerException,空指针异常;

    @Override
    	public Class<?> getColumnClass(int columnIndex) {//返回各列的类型
    		if(columnIndex==0)
    			return int.class;
    		else if(columnIndex==1)
    			return String.class;
    		else if(columnIndex==2)
    			return String.class;	
    		else 
    			return null;	
    	}

    5.getValueAt(int rowIndex, int columnIndex),返回第rowIndex行第columnIndex列的值。

    @Override
    	public Object getValueAt(int rowIndex, int columnIndex) {
    		if(columnIndex==0)
    			return clientarray.get(rowIndex).ID;
    		else if(columnIndex==1)
    			return clientarray.get(rowIndex).name;
    		else if(columnIndex==2)
    			return clientarray.get(rowIndex).getIP();	
    		else 
    			return null;		
    	}

    6.isCellEditable(int rowIndex, int columnIndex),类表是否可以编辑,返回true,可以对JTable进行编辑。

    @Override
    	public boolean isCellEditable(int rowIndex, int columnIndex) {
    		return true;
    	}

    JTable中的几个方法

      • 设置行高:
        jtable.setRowHeight(30); 
      • 设置是否选中行:
        jtable.setRowSelectionAllowed(true);// 设置可以选中行;
      • 设置选中行时,选中行变色:
        jtable.setSelectionBackground(new Color(111, 255, 255));
        

        JTable绑定JScrollPane 滚动条

    // 绑定滚动条
    JScrollPane scrollPane = new JScrollPane(jtable);// 滚动窗口
    scrollPane.setPreferredSize(new Dimension(500, 320));
    centerpanel.add(scrollPane);

    这样界面就做好了。

    当我们客户端连接上我们的服务器,然后把他添加到我们的TJable的数组里面。再在调用界面的repaint方法,界面上TJabel组件就可以显示上连接到服务器的客户。

          JTextPane(客户端聊天界面)

          方法

    • .设置是否可以编辑:
    • setEditable(false);//设置为不可以编辑;
      
    • 设置显示的字体: 
    setFont(new Font(Font.SERIF, Font.PLAIN, 18));
    /*
     *new Font(name, style, size) 
     *风格:三个常量 lFont.PLAIN, Font.BOLD,
     Font.ITALIC
     *字号:字的大小(磅数)
     */
  • 相关阅读:
    spring使用中ModelAttribute的内容被覆盖
    html中,纯数字或纯英文的一串字符超出父容器不会折行显示,如何解决?
    js实现刷新页面出现随机背景图
    为tomcat配置项目必须的引擎文件
    mysql如何出查出最近7天,最近30天,最近n天的记录?
    为了显示此页面,Firefox 必须发送将重复此前动作的数据(例如搜索或者下订单)
    git 恢复到旧版本命令
    七大经典排序算法总结(C语言描述)
    C语言描述栈的实现及操作(链表实现)
    C语言的文件读写操作函数小结
  • 原文地址:https://www.cnblogs.com/hesi/p/6114069.html
Copyright © 2020-2023  润新知