QQ好友列表树形列表java代码实现代码

以前在网上瞎转悠的时候就发现很多人为用Java实现QQ登陆后的面板的问题感到十分头疼,最近我因在写模拟QQ的项目,故不可或缺的遇到了这一个问题,在网上我google了,百度了,最终发现的是有很多人被这一问题困扰,却没有解决的方案,估计是那些写出来了的人,没有发布到网上来,如今,经过自己的多方面查找资料,终于把他写出来了,也不枉昨晚熬夜了,呵呵,好了先让我们来看看实现的效果截图:

好了,效果就是这样了,虽然实现了基本功能,但是还是不完美,比如说好友面板不能随着窗口改变大小而改变,不过应该已经可以解决了,只是还没实践,下面就发上源代码:

一共有三个类:

MemberModel.java //显示类QQ似好友标签信息的模板类;        

TestPane.java    //添加多个模板的容器类;             

TestFrame.java   //窗体类;

核心部分是前面两个类,注意,第二个类的布局方式不能为空,否则不能是容器显示滚动条,这是实现这个面板功能的一个难题,因为我不怎么会使用其他的布局方式,就只经常用空布局,经过这次才知道,光用空布局是不行的,空布局的应用受到了太多的限制。

在TestPane.java中添加好友信息的方式应该是代码添加黑名单信息的方式,可在其他类中调用方法,传递参数(数组)过来,然后对信息模板进行初始化,还有面板上的信息模板从程序刚开始运行就生成了,只是设置了不可见,后点击相关分类标签后的可视与不可视是同理的,也就是说你有多少个好友就一直会有多少个JLabel存在你的面板上,只是你可能看不见他们,我感觉自己的实现方式不是很好。还有在我所用的这种布局方式中,显示Label的宽度是一定的,我不知道怎么设置他的宽度和高度,所以通过在Label上添加了一个白色图标(185 X 60)来使Label变宽,然后再添加模板JPanel,如果网友们还有好的解决方法,希望不吝赐教。

下面是源码:

package coolbaby6;

import javax.swing.ImageIcon;

import javax.swing.JPanel;
import javax.swing.JButton;
import java.awt.Color;
import java.awt.Rectangle;
import javax.swing.JLabel;
import java.awt.Dimension;
import java.awt.Font;

public class MemberModel{

 private static final long serialVersionUID = 1L;

 public JButton jButton = null;//显示好友头像;

 public JPanel jPanel = new JPanel();//模板容器;

 private JLabel lb_nickName = null;//显示昵称;

 private int pic;

 private String nickname = null;

 private JLabel lb_mood = null;//显示心情;

 public MemberModel(int pic, String nickname, int len) {
 super();
 this.pic = pic;//头像编(有多种方法可以实现,这种最简单)
 this.nickname = nickname;//昵称;
 initialize();
 }

 private void initialize() {
 lb_mood = new JLabel();
 lb_mood.setBounds(new Rectangle(51, 30, 131, 20));
 lb_mood.setFont(new Font("Dialog", Font.PLAIN, 12));
 lb_mood.setText("世界上最遥远的距离不是生与死,而是我站在你面前你却不知道我爱你!");
 lb_mood.addMouseListener(new java.awt.event.MouseAdapter() {
  public void mouseEntered(java.awt.event.MouseEvent e) {
  exchangeEnter();
  lb_mood.setToolTipText(lb_mood.getText());
  }
  public void mouseExited(java.awt.event.MouseEvent e) {
  exchangeExited();
  }

 });
 lb_nickName = new JLabel();
 lb_nickName.setBounds(new Rectangle(52, 10, 80, 20));
 lb_nickName.setFont(new Font("Dialog", Font.BOLD, 14));
 lb_nickName.setText(nickname);
 jPanel.setSize(new Dimension(185, 60));
 jPanel.setLayout(null);
 jPanel.add(getJButton(), null);
 jPanel.add(lb_nickName, null);
 jPanel.add(lb_mood, null);
 jPanel.addMouseListener(new java.awt.event.MouseAdapter() {
  public void mouseExited(java.awt.event.MouseEvent e) {
  exchangeExited();//鼠标移出模板区,改变背景颜色;
  }

  public void mouseEntered(java.awt.event.MouseEvent e) {
  exchangeEnter();//鼠标移进模板区,改变背景颜色;
  }
 });
 }

 private void exchangeEnter() {
 jPanel.setBackground(new Color(192,224,248));
 }

 private void exchangeExited() {
 jPanel.setBackground(null);
 }

 private JButton getJButton() {
 if (jButton == null) {
  jButton = new JButton();
  jButton.setBounds(new Rectangle(8, 10, 40, 40));
  jButton.setBackground(new Color(236, 255, 236));
  jButton.setIcon(new ImageIcon(pic + ".jpg"));
  jButton.addMouseListener(new java.awt.event.MouseAdapter() {
  public void mouseExited(java.awt.event.MouseEvent e) {
   exchangeExited();//鼠标移出模板区,改变背景颜色;
  }
  public void mouseEntered(java.awt.event.MouseEvent e) {
   exchangeEnter();//鼠标移进模板区,改变背景颜色;
  }
  });

 }
 return jButton;
 }
}
package coolbaby6;

import javax.swing.BorderFactory;
import javax.swing.JPanel;
import javax.swing.JLabel;
import javax.swing.BoxLayout;
import javax.swing.ImageIcon;

public class TestPane extends JPanel {

 private static final long serialVersionUID = 1L;
 private JLabel jLabel = null;
 private JLabel jLabel1 = null;
 private JLabel jLabel11 = null;
 private JLabel jLabel12 = null;
 private int clickF=0;
 private int clickB=0;

 public TestPane() {
 super();
 initialize();
 }

 private void initialize() {

 jLabel12 = new JLabel();
 jLabel12.setIcon(new ImageIcon("img/bg.jpg"));
 jLabel12.add(new MemberModel(3,"CoolBabY3",200).jPanel);
 jLabel12.setBorder(BorderFactory.createEmptyBorder(2, 2, 2, 2));

 jLabel11 = new JLabel();
 jLabel11.setIcon(new ImageIcon("img/bg.jpg"));
 jLabel11.add(new MemberModel(2,"CoolBabY2",200).jPanel);
 jLabel11.setBorder(BorderFactory.createEmptyBorder(2, 2, 2, 2));

 jLabel1 = new JLabel();
 jLabel1.setIcon(new ImageIcon("img/bg.jpg"));
 jLabel1.add(new MemberModel(1,"CoolBabY1",200).jPanel);
 jLabel1.setBorder(BorderFactory.createEmptyBorder(2, 2, 2, 2));

 jLabel = new JLabel();
 jLabel.setText("我的好友");
 jLabel.setIcon(new ImageIcon("img/ico.jpg"));
 jLabel.setBorder(BorderFactory.createEmptyBorder(2, 2, 2, 2));

 jLabel.addMouseListener(new java.awt.event.MouseAdapter() {
  public void mouseClicked(java.awt.event.MouseEvent e) {
  clickF+=1;
  if(clickF%2==1){
   jLabel1.setVisible(false);
   jLabel11.setVisible(false);
   jLabel12.setVisible(false);
   jLabel.setIcon(new ImageIcon("img/ico2.jpg"));
   update();
  }else{
   jLabel1.setVisible(true);
   jLabel11.setVisible(true);
   jLabel12.setVisible(true);
   jLabel.setIcon(new ImageIcon("img/ico.jpg"));
   update();
  }
  }
 });
 this.setLayout(new BoxLayout(this, BoxLayout.Y_AXIS));
 this.setSize(200, 408);
 this.setLocation(20, 5);
 this.add(jLabel, null);
 this.add(jLabel1, null);
 this.add(jLabel11, null);
 this.add(jLabel12, null);
 addJLabel();
 }

 private void update(){//更新UI界面;
 this.updateUI();
 }

 private void clickBlack2(JLabel []jb){//点击标签,将后面的标签全部设为不可视;
 for(int i=1;i<jb.length;i++){
  try{
  jb[i].setVisible(false);
  }catch(Exception e){
  e.printStackTrace();
  }
 }
 update();
 }
 private void clickBlack(JLabel []jb){//点击标签,将后面的标签全部设为可视;
 for(int i=1;i<jb.length;i++){
  try{
  jb[i].setVisible(true);
  }catch(Exception e){
  e.printStackTrace();
  }

 }
 update();
 }

 private void addJLabel(){//添加黑名单的内容;
 final JLabel []jb=new JLabel[7];
 jb[0] = new JLabel();
 jb[0].setText("黑名单");
 jb[0].setIcon(new ImageIcon("img/ico2.jpg"));
 jb[0].setBorder(BorderFactory.createEmptyBorder(2, 2, 2, 2));
 jb[0].addMouseListener(new java.awt.event.MouseAdapter() {
  public void mouseClicked(java.awt.event.MouseEvent e) {

  clickB+=1;
  if(clickB%2==1){
   clickBlack(jb);
   jb[0].setIcon(new ImageIcon("img/ico.jpg"));
  }else{
   clickBlack2(jb);
   jb[0].setIcon(new ImageIcon("img/ico2.jpg"));
  }

  }
 });
 this.add(jb[0],null);
 for(int i=1;i<jb.length;i++){
  jb[i]=new JLabel();
  jb[i].setIcon(new ImageIcon("img/bg.jpg"));
  jb[i].setBorder(BorderFactory.createEmptyBorder(2, 2, 2, 2));
  jb[i].add(new MemberModel((i+3),"CoolBabY"+(i+3),200).jPanel);
  jb[i].setVisible(false);
  this.add(jb[i],null);
 }

 }

}
package coolbaby6;

import java.awt.BorderLayout;

import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.ScrollPaneConstants;
import javax.swing.SwingUtilities;

public class TestFrame {

 private JFrame jFrame = null;

 private JPanel jContentPane = null;

 private JScrollPane scrollPane=null;

 public static void main(String[] args) {
 SwingUtilities.invokeLater(new Runnable() {
  public void run() {
  TestFrame application = new TestFrame();
  application.getJFrame().setVisible(true);
  }
 });
 }

 private JFrame getJFrame() {
 if (jFrame == null) {
  jFrame = new JFrame();
  jFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
  jFrame.setSize(230, 700);
  jFrame.setTitle("模拟实现QQ面板功能");
  jFrame.setContentPane(getJContentPane());
 }
 return jFrame;
 }

 private JScrollPane getScrollPane(){//给添加好友的容器JPanel添加滚动条;
 if(scrollPane==null){
  scrollPane=new JScrollPane(new TestPane());
  //scrollPane.setBounds(20,5, -1, 600);
  scrollPane.setHorizontalScrollBarPolicy(ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER );//不显示水平滚动条;
 }
 return scrollPane;
 }

 private JPanel getJContentPane() {//实例化底层的容器JPanel;
 if (jContentPane == null) {
  jContentPane = new JPanel();
  jContentPane.setLayout(new BorderLayout());
  jContentPane.add(getScrollPane(), BorderLayout.CENTER);
 }
 return jContentPane;
 }
}

能成功编译成功我的源代码的方略: 
①、建一个项目,按我的类名建3个类,将源代码拷贝进去; 
②、在项目根目录下建一个名为img的文件夹,将要用到的图片放进去。(相关图片不再上传了,自己随便找几个图片测试即可) 
③、编译实现;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • JSON复杂数据处理之Json树形结构数据转Java对象并存储到数据库的实现

    在网站开发中经常遇到级联数据的展示,比如选择城市的时候弹出的省市县选择界面.很多前端制作人员习惯于从JSON中而不是从数据库中获取省市县数据.那么在选择了省市县中的某一个城市 ,存储到数据库中需要存储所选城市的代码.所以需要一个能将JSON数据(一般存储在javascript脚本中)结构全部导入到数据库中的功能. JSON的特点是支持层级结构.支持数组表示的对象 .下面的示例介绍如何将JSON的省市县数据保存到数据库中,实现原理非常简单,就是利用JSON的java工具包API,将层次结构的JSO

  • Java创建树形结构算法实例代码

    在JavaWeb的相关开发中经常会涉及到多级菜单的展示,为了方便菜单的管理需要使用数据库进行支持,本例采用相关算法讲数据库中的条形记录进行相关组装和排序讲菜单组装成树形结构. 首先是需要的JavaBean import java.io.Serializable; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.Date; import j

  • Java递归如何正确输出树形菜单

    本文实例为大家分享了java递归输出树形菜单的具体代码,供大家参考,具体内容如下 首先我们要建立树节点的类: package com.tree; public class Node { private Integer id; private Integer parentId; private String name; private String link; public Integer getId() { return id; } public void setId(Integer id) {

  • Java easyui树形表格TreeGrid的实现代码

    自己搞了一下午,终于用JAVA实现了数据网格.记录一下实现的代码.(PS:此处的easyui是1.5版本,楼主只贴了核心的代码) 实现图 JSP页面 <head> //权限列表 $( document ).ready(function(){ var parentId = 0; $('#tt').treegrid({ url:'queryPrivilege.action?parentId='+parentId, idField:'id', treeField:'RecordStatus', co

  • Java递归遍历树形结构

    废话不多说了,直接给大家贴代码,具体代码如下所示: //菜单树形结构 public JSONArray treeMenuList(JSONArray menuList, int parentId) { JSONArray childMenu = new JSONArray(); for (Object object : menuList) { JSONObject jsonMenu = JSONObject.fromObject(object); int menuId = jsonMenu.ge

  • Java遍历输出指定目录、树形结构所有文件包括子目录下的文件

    下面通过一段代码介绍下Java输出指定目录.树形结构下的所有文件包括子目录中的文件的方法,并附有效果图. import java.io.File; public class ReadDirectory { // 文件所在的层数 private int fileLevel; /** * 生成输出格式 * @param name 输出的文件名或目录名 * @param level 输出的文件名或者目录名所在的层次 * @return 输出的字符串 */ public String createPri

  • Java树形菜单的创建

    功能:实现创建一个树形菜单 说明:创建树形菜单结构与创建菜单栏类似,是按层次与模型创建的. 通过DefaultMutableTreeNode类创建根节点.子节点和孙节点对象,再通过DefaultTreeModel 类利用根节点创建树模型对象,然后通过treeModel.insertNodeInto方法将节点对象插入树模型中. 效果图: 代码: import java.awt.*; import javax.swing.*; import javax.swing.tree.*; import ja

  • java、js中实现无限层级的树形结构方法(类似递归)

    js中: var zNodes=[ {id:0,pId:-1,name:"Aaaa"}, {id:1,pId:0,name:"A"}, {id:11,pId:1,name:"A1"}, {id:12,pId:1,name:"A2"}, {id:13,pId:1,name:"A3"}, {id:2,pId:0,name:"B"}, {id:21,pId:2,name:"B1&qu

  • Python 将 QQ 好友头像生成祝福语的实现代码

    本文我们来看一下如何使用 Python 将 QQ 好友头像拼成"五一快乐"四个字.我们可以将整个实现过程分为两步:爬取 QQ 好友头像.利用好友头像生成文字. 爬取头像 爬取 QQ 好友头像我们需要借助于 QQ 邮箱,首先我们从浏览器上登录 QQ 邮箱,之后按 F12 键打开开发者工具并用鼠标选中 Network 选项,如下图所示: 再接着我们按 F5 键刷新一下网页,然后在 Filter 中输入 laddr_lastlist ,如下图所示: 我们再点 Name 下的链接,点击之后右侧

  • QQ好友列表树形列表java代码实现代码

    以前在网上瞎转悠的时候就发现很多人为用Java实现QQ登陆后的面板的问题感到十分头疼,最近我因在写模拟QQ的项目,故不可或缺的遇到了这一个问题,在网上我google了,百度了,最终发现的是有很多人被这一问题困扰,却没有解决的方案,估计是那些写出来了的人,没有发布到网上来,如今,经过自己的多方面查找资料,终于把他写出来了,也不枉昨晚熬夜了,呵呵,好了先让我们来看看实现的效果截图: 好了,效果就是这样了,虽然实现了基本功能,但是还是不完美,比如说好友面板不能随着窗口改变大小而改变,不过应该已经可以解

  • Android UI仿QQ好友列表分组悬浮效果

    本文实例为大家分享了Android UI仿QQ好友列表分组悬浮效果的具体代码,供大家参考,具体内容如下 楼主是在平板上測试的.图片略微有点大,大家看看效果就好 接下来贴源代码: PinnedHeaderExpandableListView.java 要注意的是 在 onGroupClick方法中parent.setSelectedGroup(groupPosition)这句代码的作用是点击分组置顶, 我这边不须要这个效果.QQ也没实用到,所以给凝视了.大家假设须要能够解开凝视 package c

  • JS仿QQ好友列表展开、收缩功能(第二篇)

    在上篇的基础上继续完善,点击一个li元素,其他li元素上的类名清除掉. 效果图如下所示: js: <script> window.onload = function(){ var list = document.getElementById('list'); var ah2 = list.getElementsByTagName('h2'); var uls = list.getElementsByTagName('ul'); var lis = null;//用于下面的存储 var arrl

  • JS仿QQ好友列表展开、收缩功能(第一篇)

    效果图如下所示: html: <ul id="list"> <li class="lis"> <h2>我的好友</h2> <ul> <li>张三</li> <li>李四</li> ... </ul> </li> <li class="lis"> <h2>企业好友</h2> <

  • Android自定义ListView实现仿QQ可拖拽列表功能

    我们大致的思路,其实是这样子的,也是我的设想,我们可以先去实现一个简单的ListView的数据,但是他的Adapter,我们可以用系统封装好的,然后传递进去一个实体类,最后自定义一个listview去操作,所以我们先把准备的工作做好,比如? list_item.xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.a

  • 易语言获取网页端的好友管理页面信息导出QQ好友的代码

    全局变量表 .版本 2 .全局变量 Cookie_Overall, 文本型 .全局变量 BKN_Overall, 文本型 QQ快捷启动的代码 .版本 2 .程序集 窗口程序集_窗口1 .子程序 _超文本浏览框1_跳转完毕 .局部变量 Cookie, 文本型 .局部变量 Uin, 文本型 .局部变量 Skey, 文本型 Cookie = 网页_取Cookie ("qun.qq.com") .如果真 (寻找文本 (Cookie, "p_skey", , 假) ≠ -1)

  • android RecycleView实现多级树形列表

    本文实例为大家分享了android RecycleView实现多级树形列表的具体代码,供大家参考,具体内容如下 实现多级树状列表: 1. Node.java public class Node<T, B> implements Serializable { /** * 传入的实体对象 */ public B bean; /** * 设置开启的图片 */ public int iconExpand = -1; /** * 设置关闭的图片 */ public int iconNoExpand =

  • php从数据库查询结果生成树形列表的方法

    本文实例讲述了php从数据库查询结果生成树形列表的方法.分享给大家供大家参考.具体分析如下: 本代码可以从数据库读取数据生成一个类似于windows的资源管理器的树形列表 <?php /* Here are the database definitions (for Solid) that i use in this code. * It should not be hard to adapt it to another database. */ /* CREATE TABLE dirent_t

  • 微信小程序开发之好友列表字母列表跳转对应位置

    微信小程序开发之好友列表字母列表跳转对应位置 前言: 在小程序里实现微信好友列表点击右侧字母列表跳转对应位置效果.写了个demo,核心部分很简单,所以没多少注释,如果遇到问题就加群问我吧. 核心技术点: 1.小程序scroll-view组件的scroll-into-view, scroll-with-animation. scroll-y属性. 2.小程序的touch事件的应用. 3.Js定时器的应用. view页面代码: index.wxml class="container" sc

随机推荐