- 浏览: 1482676 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (691)
- linux (207)
- shell (33)
- java (42)
- 其他 (22)
- javascript (33)
- cloud (16)
- python (33)
- c (48)
- sql (12)
- 工具 (6)
- 缓存 (16)
- ubuntu (7)
- perl (3)
- lua (2)
- 超级有用 (2)
- 服务器 (2)
- mac (22)
- nginx (34)
- php (2)
- 内核 (2)
- gdb (13)
- ICTCLAS (2)
- mac android (0)
- unix (1)
- android (1)
- vim (1)
- epoll (1)
- ios (21)
- mysql (3)
- systemtap (1)
- 算法 (2)
- 汇编 (2)
- arm (3)
- 我的数据结构 (8)
- websocket (12)
- hadoop (5)
- thrift (2)
- hbase (1)
- graphviz (1)
- redis (1)
- raspberry (2)
- qemu (31)
- opencv (4)
- socket (1)
- opengl (1)
- ibeacons (1)
- emacs (6)
- openstack (24)
- docker (1)
- webrtc (11)
- angularjs (2)
- neutron (23)
- jslinux (18)
- 网络 (13)
- tap (9)
- tensorflow (8)
- nlu (4)
- asm.js (5)
- sip (3)
- xl2tp (5)
- conda (1)
- emscripten (6)
- ffmpeg (10)
- srt (1)
- wasm (5)
- bert (3)
- kaldi (4)
- 知识图谱 (1)
最新评论
-
wahahachuang8:
我喜欢代码简洁易读,服务稳定的推送服务,前段时间研究了一下go ...
websocket的helloworld -
q114687576:
http://www.blue-zero.com/WebSoc ...
websocket的helloworld -
zhaoyanzimm:
感谢您的分享,给我提供了很大的帮助,在使用过程中发现了一个问题 ...
nginx的helloworld模块的helloworld -
haoningabc:
leebyte 写道太NB了,期待早日用上Killinux!么 ...
qemu+emacs+gdb调试内核 -
leebyte:
太NB了,期待早日用上Killinux!
qemu+emacs+gdb调试内核
画图板
opencv的c++
参考
http://blog.csdn.net/morewindows/article/details/8426283
html版本,+tomcat7的websocket
LineWebSocketServlet.java
web.xml
opencv的c++
#include <opencv2/opencv.hpp> using namespace std; #pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"") const char *pstrWindowsMouseDrawTitle = "鼠标绘图(http://blog.csdn.net/MoreWindows)"; // 鼠标消息的回调函数 void on_mouse(int event, int x, int y, int flags, void* param) { static bool s_bMouseLButtonDown = false; static CvPoint s_cvPrePoint = cvPoint(0, 0); switch (event) { case CV_EVENT_LBUTTONDOWN: s_bMouseLButtonDown = true; s_cvPrePoint = cvPoint(x, y); break; case CV_EVENT_LBUTTONUP: s_bMouseLButtonDown = false; break; case CV_EVENT_MOUSEMOVE: if (s_bMouseLButtonDown) { CvPoint cvCurrPoint = cvPoint(x, y); cvLine((IplImage*)param, s_cvPrePoint, cvCurrPoint, CV_RGB(0, 0, 20), 3); s_cvPrePoint = cvCurrPoint; cvShowImage(pstrWindowsMouseDrawTitle, (IplImage*)param); } break; } } int main() { const int MAX_WIDTH = 500, MAX_HEIGHT = 400; const char *pstrSaveImageName = "MouseDraw.jpg"; IplImage *pSrcImage = cvCreateImage(cvSize(MAX_WIDTH, MAX_HEIGHT), IPL_DEPTH_8U, 3); cvSet(pSrcImage, CV_RGB(255, 255, 255)); //可以用cvSet()将图像填充成白色 cvNamedWindow(pstrWindowsMouseDrawTitle, CV_WINDOW_AUTOSIZE); cvShowImage(pstrWindowsMouseDrawTitle, pSrcImage); cvSetMouseCallback(pstrWindowsMouseDrawTitle, on_mouse, (void*)pSrcImage); int c; do{ c = cvWaitKey(0); switch ((char)c) { case 'r': cvSet(pSrcImage, CV_RGB(000, 000, 255)); cvShowImage(pstrWindowsMouseDrawTitle, pSrcImage); break; case 's': cvSaveImage(pstrSaveImageName, pSrcImage); break; } } while (c > 0 && c != 27); cvDestroyWindow(pstrWindowsMouseDrawTitle); cvReleaseImage(&pSrcImage); return 0; }
参考
http://blog.csdn.net/morewindows/article/details/8426283
html版本,+tomcat7的websocket
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>jiben</title> </head> <script type="text/javascript"> //--------------line----begin------- var w=1; var h=1; var col="blue"; function catchMouse(){ var x=event.clientX-50; var y=event.clientY-52; makedot(x,y); if (ws != null) { ws.send(x+","+y); } } function makedot(x,y){ var sp=document.getElementById("sspp"); sp.insertAdjacentHTML("BeforeEnd","<hr style='position:absolute;left:"+x+"px;top:"+y+"px;width:"+w+"px;height:"+h+"px;color:"+col+";'>"); } function myMouseDown(){ document.onmousemove=catchMouse } function myMouseUp(){ document.onmousemove=null; } //--------------line----end--------- </script> <script type="text/javascript"> var ws = null; function log(text) { document.getElementById("log").innerHTML = text + "<br>"+ document.getElementById("log").innerHTML; } function startServer() { var url = document.getElementById("serverip").value; if ('WebSocket' in window) { ws = new WebSocket(url); } else if ('MozWebSocket' in window) { ws = new MozWebSocket(url); } else { log('浏览器不支持'); return; } ws.onopen = function() { //log('Opened!'); }; ws.onmessage = function(event) { //log(event.data); var x_value =event.data.split(",")[0]; var y_value = event.data.split(",")[1]; makedot(x_value,y_value); }; ws.onclose = function() { //log('Closed!'); } } function sendMessage() { var textMessage = document.getElementById("textMessage").value; if (ws != null && textMessage != "") { ws.send(textMessage); } } function stopconn() { ws.close(); } </script> <body onload="startServer()"> <input id="serverip" type="text" size="20" style="display:none" value="ws://182.254.155.000:8080/webs/websocket/line" /> <div id="log" style="display:none"></div> <span id="sspp" onMouseDown="myMouseDown()" onMouseUp="myMouseUp()" style="position:absolute;top:50px;left:50px;width:1000px;height:1000px;background-color:#eeeeee "> </span> </body> </html>
LineWebSocketServlet.java
package com.hao; import java.io.IOException; import java.nio.ByteBuffer; import java.nio.CharBuffer; import java.util.HashMap; import java.util.Map; import javax.servlet.http.HttpServletRequest; import org.apache.catalina.websocket.MessageInbound; import org.apache.catalina.websocket.StreamInbound; import org.apache.catalina.websocket.WebSocketServlet; import org.apache.catalina.websocket.WsOutbound; public class LineWebSocketServlet extends WebSocketServlet { private static Map<String,MyMessageInbound> mmiList = new HashMap<String,MyMessageInbound>(); protected StreamInbound createWebSocketInbound(String subProtocol, HttpServletRequest arg1) { return new MyMessageInbound(); } private class MyMessageInbound extends MessageInbound { WsOutbound myoutbound; String mykey; @Override public void onOpen(WsOutbound outbound) { try { System.out.println("Open Client."); this.myoutbound = outbound; mykey ="open "+System.currentTimeMillis();; mmiList.put(mykey, this); System.out.println("mmiList size:"+mmiList.size()); outbound.writeTextMessage(CharBuffer.wrap(mykey)); } catch (IOException e) { e.printStackTrace(); } } @Override public void onClose(int status) { System.out.println("Close Client."); mmiList.remove(mykey); } @Override protected void onBinaryMessage(ByteBuffer arg0) throws IOException { } @Override protected void onTextMessage(CharBuffer message) throws IOException { System.out.println("LineWebSocketServlet.onTextMessage--->" + message.toString()); for (Map.Entry<String, MyMessageInbound> entry : mmiList.entrySet()) { MyMessageInbound mmib = (MyMessageInbound) entry.getValue(); CharBuffer buffer = CharBuffer.wrap(message); mmib.myoutbound.writeTextMessage(buffer); mmib.myoutbound.flush(); } } } }
web.xml
<servlet> <servlet-name>wsLine</servlet-name> <servlet-class>com.hao.LineWebSocketServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>wsLine</servlet-name> <url-pattern>/websocket/line</url-pattern> </servlet-mapping>
发表评论
-
weak_ptr解决循环引用问题
2021-03-08 21:12 1194C++11引入的三种智能指 ... -
gcc链接顺序
2019-10-12 18:25 658代码在 https://github.com/killinux ... -
c++11的function和bind
2019-09-10 16:12 538参考:https://www.cnblogs.co ... -
opengl的helloworld
2014-10-22 19:41 9091.我提供一个不需要配置环境就可运行的源码。 glut.h放在 ... -
opencv人脸检测的helloworld
2014-10-17 13:30 923注意两点 1.图片 2.haarcascade_frontal ... -
在mac下编译opencv的helloworld
2014-10-12 17:58 1912环境问题总是头疼 参考 http://www.cnblogs. ... -
opencv的helloworld
2014-10-02 10:36 2355参考 http://blog.csdn.net/tmxyz19 ... -
c语言内存
2014-07-02 10:26 6991、C中内存分为五个区 栈:用来存放函数的形参和函数内的局部变 ... -
重定向stdout到文件
2014-03-05 18:37 5494把stdout重定向到文件 两种方法: 第一种方法没有恢复 ... -
通过nginx远程执行shell
2014-03-03 10:26 5099saltstack远程执行shell,远程管理等返回json已 ... -
c的urldecode
2014-02-28 18:22 1368#include <stdio.h> #in ... -
pthread的pthread_mutex_lock 的使用
2014-02-25 16:54 26157参考http://haoningabc.iteye.com/b ... -
c调用c++
2013-10-12 15:24 1183参考 http://www.cppblog.com/frank ... -
用C语言,实现接收管道输出的结果,并显示
2013-04-23 21:35 1950在shell里利用“|”管道干的事情就是io重定向,把“|”命 ... -
关于char * 与 char[]
2013-04-22 21:56 966问题引入: 在实习过程中发现了一个以前一直默认的错误,同样ch ... -
单向链表翻转
2012-12-25 23:41 1026临时笔记,创建一个链表 #include <stdl ... -
trie 树 的代码
2012-12-14 23:20 1145想起搜狐老大的一句话 看代码先看h文件,擦,当初感觉他这句话很 ... -
指针函数与函数指针的区别
2012-12-14 22:44 1205一、 1、指针函数是指带指针的函数,即本质是一个函数。函数返回 ... -
指针和数组
2012-11-14 22:40 1076转载http://kan.weibo.com/con/3512 ... -
js备份
2012-10-31 23:56 1730<!DOCTYPE HTML PUBLIC " ...
相关推荐
这个代码例子使用了c c++实现了websocket 开发 包含了websocket服务器和websocket客户端,拥有详细的解释 这个库比libwebsocket更加简单方便,比libsocket更加高效便捷.
通过C++和libuv库,我们可以构建一个高效且灵活的WebSocket服务器。gbase的使用可能涉及到数据库操作,为服务器提供数据存储能力。实现过程中,需要深入理解WebSocket协议,以及如何有效地利用libuv的事件驱动模型。...
本项目是用C/C++语言实现的WebSocket模块,其主要优势在于比libwebsockets更加易用和方便。libwebsockets是一个开源库,虽然功能强大,但对于初学者或对库使用不熟悉的开发者来说,可能存在一定的学习曲线。这个实现...
你提到的"websocket c++ 实现版本"可能是一个自编写的WebSocket库,旨在为C++开发者提供与JavaScript交互的WebSocket长连接功能。JavaScript在Web前端有着天然的优势,通过WebSocket接口,可以在浏览器环境中与后端...
简单的c++实现websocket通信,客户端代码实现,简单高效
这个代码例子使用了c c++实现了websocket 开发 包含了websocket服务器和websocket客户端,拥有详细的解释 这个库比libwebsocket更加简单方便,比libsocket更加高效便捷.
在本项目中,我们将探讨如何在Linux环境下,利用C++的SOCKET编程技术来实现一个WebSocket服务器,而不依赖任何开源库。 首先,我们需要理解C++中的SOCKET编程基础。在C++中,SOCKET是网络编程的基本接口,它提供了...
在本案例中,我们讨论的是一个C++实现的WebSocket客户端,其核心是利用了MFC(Microsoft Foundation Classes)库和boost库以及websocketpp库。 MFC是微软提供的一个C++类库,它封装了Windows API,为开发者提供了...
在本文中,我们将深入探讨如何使用C++编程语言与WebSocket协议进行交互,特别是在结合Boost库、jsoncpp库和websocketpp库的情况下。这个压缩包提供的代码示例是一个完整的C++ WebSocket客户端或服务器应用,可以直接...
2. **WebSocket客户端**:客户端部分是用HTML实现的,可能还涉及JavaScript和WebSockets API。HTML(超文本标记语言)主要用于创建网页结构,而JavaScript则提供了与服务器交互的能力,包括初始化WebSocket连接、...
使用thrift、websocket在javascript和c++之间建立rpc调用机制。 如果要使用js+html来写界面,cpp来写底层业务逻辑,这就非常有用了。 当然,如果底层不用cpp来写,也可以参考本代码的js对thrift的rpc包装。
业务逻辑实现 QT WebSocket + QWebChannel 实现 C/C++ 与 javascript通信 界面使用前端electron + vue + vite + layui + qwebchannel.js 实现 qt子进程自动启动,websocket Client自动重连,C++与js/ts的双向异步...
本资源提供了一个用C++实现的WebSocket服务器,可以直接运行,这对于学习和理解WebSocket协议的工作原理以及C++网络编程是非常有价值的。VS工程中的.sln文件是Visual Studio解决方案文件,用于管理项目和依赖关系,...
总之,这个项目展示了如何使用C++和MFC来实现一个WebSocket服务器,通过这样的实践,开发者可以深入理解网络通信和GUI编程,提升自己的技能。在实际应用中,还可以根据需要添加更多的功能,如身份验证、权限控制等,...
WebSocket是一种在...综上所述,C语言实现WebSocket涉及TCP套接字编程、WebSocket协议理解和实现、以及可能的HTML辅助调试。这个过程需要深入理解网络协议和C语言编程,同时也提供了学习和实践网络编程的良好机会。
总的来说,WebSocket为实时通信提供了一种高效、低延迟的解决方案,Python和C++都有强大的库支持实现WebSocket服务器和客户端。理解其工作原理和使用这些库可以帮助开发者构建出高性能的实时应用。
本项目是基于C++的SOCKET编程实现的WebSocket服务器,特别适合于Windows平台上的开发和学习。 在C++中,SOCKET编程是通过Windows Socket API(Winsock)来实现的,这是一个低级别的网络编程接口。在创建WebSocket...
1 开发环境 - Visual Studio 2015 - Javascript - Windows 10 Pro x64 2 功能介绍 演示Websocket的C++服务端和JS客户端通信。 3. 接口文档