类似QQ的聊天工程
首先建立一个html:<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>far</title> <style> #chatWindow{ font-family: 微软雅黑; height:700px; width:800px; font-size:12px;/*字体大小*/ position: absolute;/*绝对定位*/ /*margin:auto;自动布局,容器居中*/ /*阴影效果*/ box-shadow: gray 0px 4px 5px;/*阴影:颜色*/
display: none;/*开始不显示chatWindow这个div*/ } #title{ height:40px; line-height:40px; /**/ /*背景渐变*/ background:-webkit-linear-gradient(left, #4B8CFE 0%,#ffffff 120%); text-align: center;/*容器中的内容居中*/ color:white;/*字体颜色*/ } #data{ height:400px; border-top:1px solid gray; border-bottom:1px solid gray; overflow-y:auto;/*溢出部分显示滚动条*/ padding: 2px; } #util>a{ display: inline-block; width: 30px; height: 25px; margin: 0 5px; } #util>a:hover{ background-color: gray; border-radius: 4px; } #send{ height:180px; padding: 5px;/*上下左右都和输入内容有点(5px)距离*/ outline: none;/*去掉边框*/ overflow-y:auto;/*溢出部分显示滚动条*/ } #btns{ text-align: right; padding-right: 10px;/*盒子的内容距离边框的距离,简称内距离*/ } .btnSetting{/* .代表class*/ width:72px; height:28px; display: inline-block;/*转成行块标签*/ line-height: 28px; border:1px solid gray; font-size:12px;font-family:"微软雅黑";text-align: center; border-radius: 3px;/*圆角*/ text-decoration: none;/*去除下划线*/ margin-right:10px;/*外间距,盒子与别的盒子的距离*/ vertical-align: 1px;/*垂直位置上的调整*/ } .i1{ background:url("/images/1.jpg") no-repeat center; } .i2{ background: url("/images/2.jpg") no-repeat center; } .i3{ background: url("/images/3.jpg") no-repeat center; } .dataBox{ border-radius: 5px; padding: 3px; background-color: #66afe9; color:black; width:auto;/*内容不固定大小,多少内容就用多少空间,可换行*/ display: inline-block; margin-left: 10px; } .fright{ float:right; clear: both; text-align: right; } .fleft{ float:left; clear: both; } .dou{ clear:both; text-align: center; line-height: 30px; border-radius: 5px; background-color: #4B8CFE; } #closeBtn { color: black; /*字体颜色*/ } #closeBtn:hover{ background-color: #EFEFF0; } #sendBtn { background-color: #4B8CFE; color:white;/*字体颜色*/ } #sendBtn:hover{ background-color: #47C8F8; } </style> <link rel="stylesheet" href="/css/facebox.css"> <script src="js/jquery-2.1.1.min.js"></script> <script src="js/jquery.qqFace.js"></script> <script> var ws; //#:找到id为chatBtn的节点,绑定一个点击事件 $符号代表框架。 $(document).ready(function () { $("#chatBtn").click(function () { //找到nickName获取val值。 var nickName = $("#nickName").val(); if ($.trim(nickName) == "") {//trim()函数的作用是去掉左右两边的空格。 alert("请输入昵称!"); return;//结束该函数 } var url = "ws://" + window.location.hostname + ":8080/chatHandle/" + nickName; //var url1="ws://"+window.location.hostname+":8080/chatHandle/"+fang; //document.write(url+url1); ws = new WebSocket(url); //当后台服务器发了消息的时候,获取到后台消息 ws.onmessage=function (chatBtn) { var index=chatBtn.data.indexOf("\0"); if(index>=0) { dou(); } $("#data").scrollTop(520); $("#data").append(chatBtn.data+"<br>"); } $("#join").hide(); $("#chatWindow").show(); /* 关闭按钮 */ $("#closeBtn").click(function () { ws.close();//关闭客户端与服务端的连接 $("#join").show(); $("#chatWindow").hide(); }) /* 发送按钮 */ $("#sendBtn").click(function () { var val=$("#send").html(); //清空 $("#send").html(""); //聚焦 $("#send").focus(); //获取并发送 ws.send(val); }) //添加快捷键 $("#send").keydown(function (event) { if(event.altKey && event.keyCode==67){ $("#closeBtn").click();//模拟手动点击,代码点击; } if((event.altKey && event.keyCode==83)|| event.keyCode==13){ $("#sendBtn").click();//模拟手动点击发送按钮,代码点击; } }) }) var reader=new FileReader(); var myFile=document.getElementById("myFile"); myFile.onchange=function () { var chooseFile=myFile.files[0]; reader.readAsDataURL(chooseFile); } reader.onload=function () { var obj=document.createElement("img"); obj.src=reader.result; $("#send").append(obj); } $("#myFile").hide(); $(".i1").click(function () { $("#myFile").click(); }) $(".i2").qqFace({ id:'facebox', assign:'send', path:'arclist/' }) /*拖拽部分*/ var title=document.getElementById("title"); var pyx,pyy; title.ondragstart=function (e) { pyx=e.offsetX; pyy=e.offsetY; } title.ondrag=function (e) { var x=e.pageX; var y=e.pageY; if(x==0&&y==0) return; $("#chatWindow").css("left",x-pyx); $("#chatWindow").css("top",y-pyy); } $(".i3").click(function () { ws.send("\0"); }) function dou() { var initx=$("#chatWindow").offset().left; var inity=$("#chatWindow").offset().top; for(var i=0;i<=10;i++){ $("#chatWindow").animate({"left":initx-10,"top":inity-10},10); $("#chatWindow").animate({"left":initx,"top":inity},10); $("#chatWindow").animate({"left":initx+10,"top":inity+10},10); $("#chatWindow").animate({"left":initx,"top":inity},10); } } }) </script></head><body><div id="join"><!-----div可以看成一个盒子,容器。固定页面布局。CSS(放head里面)相当对html的"化妆";-------> <input id="nickName" type="text"><br> <input id="chatBtn" type="button" value="加入聊天室"><br></div><div id="chatWindow"> <div id="title" draggable="true">far away</div> <div id="data"></div><!----聊天内容-------> <div id="util"><!--工具区域--> <input type="file" id="myFile"> <a class="i1" href="javascript:;"></a> <a class="i2" href="javascript:;"></a> <a class="i3" href="javascript:;"></a></div> <div id="send" contenteditable="true"></div><!----要发送内容-------> <div id="btns"><!------发送和关闭按钮--------> <a id="closeBtn" class="btnSetting" href="javascript:;">关闭(<u>C</u>)</a> <a id="sendBtn" class="btnSetting" href="javascript:;">发送(<u>S</u>)</a> </div></div></body></html>
后台控制代码:
package com.seecon.Chat.handle;
import javax.websocket.OnClose;import javax.websocket.OnMessage;import javax.websocket.OnOpen;import javax.websocket.Session;import javax.websocket.server.ServerEndpoint;import javax.websocket.server.PathParam;import java.util.ArrayList;import java.util.Calendar;import java.util.List;
@ServerEndpoint("/chatHandle/{nickName}")public class ChatHandle { //创建一个静态的“袋子”(跟对象无关),用来装所有的session,也就是所有用户的会话; private static List<Session> users=new ArrayList<Session>();//static可以共享。 public static synchronized void add(Session session){//静态方法不依赖对象 users.add(session); } public synchronized static void remove(Session session){ users.remove(session); } private void sendAll(String message){ for (Session user : users) { user.getAsyncRemote().sendText(message); } } private String nickName;/*当前会话的昵称*/ @OnOpen public void connect(Session session,@PathParam("nickName") String nickName) throws Exception { System.out.println(nickName + "连接上了后台服务器程序" + session); add(session); sendAll("<div class='fleft'>-----欢迎[" + nickName + "]------加入聊天室 "+"当前聊天室人数:"+users.size()+"</div>"); this.nickName=nickName; } @OnClose public void exit(Session session,@PathParam("nickName") String nickName) throws Exception{ remove(session); sendAll("<div class='fright'>----[" + nickName + "]------退出聊天室"+"当前聊天室人数:"+users.size()+"</div>"); } @OnMessage public void receiveMessage(Session session,String message) throws Exception{ Calendar c=Calendar.getInstance(); int hour=c.get(Calendar.HOUR_OF_DAY); String hourStr=hour>=10?hour+"":"0"+hour; int minute=c.get(Calendar.MINUTE); String minuteStr=minute>=10?minute+"":"0"+minute; int second=c.get(Calendar.SECOND); String secondStr=second>=10?second+"":"0"+second; String fullTime=hourStr+":"+minuteStr+":"+secondStr; //构建message if(message.equals("\0")){ message="<div class='dou'>"+nickName+"给您发送了一个窗口抖动</div>"; String str=" "+fullTime+"<br>"+message; sendAll("\0"+str); }else { message = "<div class='dataBox'>" + message + "</div>"; String str = nickName + "  " + fullTime + "<br>" + message; sendAllMessage(str, session); } } private void sendAllMessage(String message,Session session){ //把Message的数据通知给所有会话 for(Session user:users){ if(user==session){ user.getAsyncRemote().sendText("<div class='fright'>"+message+"</div>"); } else{ user.getAsyncRemote().sendText("<div class='fleft'>"+message+"</div>");
} } }
}
类似QQ的聊天工程的更多相关文章
- java网络编程(三):一个类似QQ的聊天程序
客户端: package QQ; import javax.swing.*; import java.awt.*; import java.awt.event.ActionEvent; import ...
- AndroidRichText 让Textview轻松的支持富文本(图像ImageSpan、点击效果等等类似QQ微信聊天)
代码地址:https://github.com/Luction/AndroidRichText AndroidRichText帮助实现像QQ,微信一样的,一个TextView里既有文字又有表情又有图片 ...
- 实现类似QQ对话聊天功能脚本
var skin : GUISkin; var showChat = false;private var inputField = "";private var display = ...
- [C# 网络编程系列]专题九:实现类似QQ的即时通信程序
转自:http://www.cnblogs.com/zhili/archive/2012/09/23/2666987.html 引言: 前面专题中介绍了UDP.TCP和P2P编程,并且通过一些小的示例 ...
- 基于Qt的类QQ气泡聊天的界面开发
近期在写IM 聊天界面,想设计出一个类似QQ气泡聊天的样式 使用了几种办法 1:使用Qt以下的QListview来实现QQ类似效果.差强人意 2:使用QWebview载入html css样式来完毕.发 ...
- 详解C# 网络编程系列:实现类似QQ的即时通信程序
https://www.jb51.net/article/101289.htm 引言: 前面专题中介绍了UDP.TCP和P2P编程,并且通过一些小的示例来让大家更好的理解它们的工作原理以及怎样.Net ...
- 转:【专题九】实现类似QQ的即时通信程序
引言: 前面专题中介绍了UDP.TCP和P2P编程,并且通过一些小的示例来让大家更好的理解它们的工作原理以及怎样.Net类库去实现它们的.为了让大家更好的理解我们平常中常见的软件QQ的工作原理,所以在 ...
- 专题九:实现类似QQ的即时通信程序
引言: 前面专题中介绍了UDP.TCP和P2P编程,并且通过一些小的示例来让大家更好的理解它们的工作原理以及怎样.Net类库去实现它们的.为了让大家更好的理解我们平常中常见的软件QQ的工作原理,所以在 ...
- MVC实现类似QQ的网页聊天功能-ajax(下)
此篇文章主要是对MVC实现类似QQ的网页聊天功能(上)的部分代码的解释. 首先说一下显示框的滚动条置底的问题: 结构很简单一个大的div(高度一定.overflow:auto)包含着两个小的div第一 ...
随机推荐
- JS对象原型的理解
基于原型的语言 JavaScript 常被描述为一种基于原型的语言 (prototype-based language)——每个对象拥有一个原型对象,对象以其原型为模板.从原型继承方法和属性.原型对象 ...
- JS原型链继承
继承普通版 继承逻辑上都差不多,普通版调用方式比较繁琐,不利于反复大量的使用: (function (){ //创建一个人员类 function Person(name){ this.name = n ...
- Python-MRO和C3算法
一. python多继承 在前面的学习过程中,我们已经知道了python中类与类之间可以有继承关系,当出现x是一种y的时候就可以使用继承关系.即'is-a'关系,在继承关系中子类自动拥有父类中除了私有 ...
- 如何在一台机器上运行2个Tomcat
比如:有两个版本的tomcat,一个5.*,一个6.*,此时由于两个工程分别部署在两个 版本的tomcat下,需要同时启动两个tomcat,以下是方法: 1.特别要注意:不要设置CATALINA_HO ...
- VS2013 C++ 动态链接库的生成
原文:http://www.cnblogs.com/djiankuo/p/5092025.html 这个东西搞了好几天,现在终于没有问题了,其实现在想来还是微软做的东西好用啊,在这里点个赞!!! LL ...
- canvas.addEventListener()
对 canvas 元素的事件监听用addEventListener()实现, 但是有一点缺陷是:canvas 不支持键盘事件,为了解决这个问题,可以采用以下两种方案: 方案一: key event - ...
- You must not call setTag() on a view Glide is targeting when use Glide
以下代码是一个显示图片的RecyclerView 的Adapter用到的,当点击图片,跳到另一个Activity显示大图.RecyclerView 与ListView不同 然而没有setOnClick ...
- Data Flow ->> Multiple Excel Sheet Loaded Into One Table
同个Excel文件中多个Sheet中的数据导入到单张表中,参考了文章:http://www.cnblogs.com/biwork/p/3478778.html 思路: 1) ForEach Loop组 ...
- 105 + 106. Construct Binary Tree from Preorder and Inorder Traversal (building trees)
Given preorder and inorder traversal of a tree, construct the binary tree. Note: You may assume that ...
- 关于Java中的反射的一个简单使用
把以前在其他地方的技术文章重新整理一遍, 方便自己回忆, 也方便他人借鉴. 刚工作的时候发过这么一段代码: package cn.com.hanbinit.test; import java.lang ...