一步一步学习SignalR进行实时通信_8_案例2
一步一步学习SignalR进行实时通信\_8_案例2
SignalR
前言
这讲分析一个案例,在一个画板上画画实时在其他客户端上显示。
配置Hub
在Startup中进行配置:
public void Configuration(IAppBuilder app){app.MapSignalR();}
建立DrawingHub
public class Drawing : Hub{private const int BoardWidth = 300, BoardHeight = 300;private static int[,] _buffer = new int[BoardWidth, BoardHeight];public Task BroadcastPoint(int x, int y){if (x < 0) x = 0;if (x >= BoardWidth) x = BoardWidth - 1;if (y < 0) y = 0;if (y >= BoardHeight) y = BoardHeight - 1;int color = 0;int.TryParse(Clients.Caller.color, out color);_buffer[x, y] = color;return Clients.Others.DrawPoint(x, y, Clients.Caller.color);}public Task BroadcastClear(){_buffer = new int[BoardWidth, BoardHeight];return Clients.Others.Clear();}public override Task OnConnected(){return Clients.Caller.Update(_buffer);}}
用一个二位数组来缓存画板,一共就三个方法
1. 当客户端连接时调用Update()方法刷新整个画板
2.BroadcastClear()是点击清除按钮时讲整个画板擦出
3. 最后一个就是画画方法,客户端按下鼠标画画时,调用该方法进行绘制。
页面
<!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head><title>Drawing board</title><script src="Scripts/jquery-1.6.4.min.js"></script><script src="Scripts/jquery.signalR-2.0.0.min.js"></script><script src="/signalr/js"></script><script src="Scripts/DrawingBoard.js"></script><style>div {margin: 3px;}canvas {border: 2px solid #808080;cursor: default;}</style></head><body><div><div><label for="color">Color: </label><select id="color"></select></div><canvas id="canvas" width="300" height="300"></canvas><div><button id="clear">Clear canvas</button></div></div></body></html>
页面非常简单,一个选择颜色的下拉框,一个画板,和一个清除按钮。
javascript
$(function () {//初始化var colors = ["black", "red", "green", "blue", "yellow", "magenta", "white"];var canvas = $("#canvas");var colorElement = $("#color");for (var i = 0; i < colors.length; i++) {colorElement.append("<option value='" + (i + 1) + "'>" + colors[i] + "</li>");}//画板鼠标事件var buttonPressed = false;canvas.mousedown(function () {buttonPressed = true;}).mouseup(function () {buttonPressed = false;}).mousemove(function (e) {if (buttonPressed) {setPoint(e.offsetX, e.offsetY, colorElement.val());}});var ctx = canvas[0].getContext("2d");//画画function setPoint(x, y, color) {ctx.fillStyle = colors[color - 1];ctx.beginPath();ctx.arc(x, y, 2, 0, Math.PI * 2);ctx.fill();}//清除function clearPoints() {ctx.clearRect(0, 0, canvas.width(), canvas.height());}$("#clear").click(function () {clearPoints();});//signalRvar hub = $.connection.drawingBoard;//缓存颜色hub.state.color = colorElement.val();var connected = false;//改变颜色colorElement.change(function () {hub.state.color = $(this).val();});//当连接时且鼠标按下时调用canvas.mousemove(function (e) {if (buttonPressed && connected) {hub.server.broadcastPoint(Math.round(e.offsetX), Math.round(e.offsetY));}});$("#clear").click(function () {if (connected) {hub.server.broadcastClear();}});hub.client.clear = function () {clearPoints();};hub.client.drawPoint = function (x, y, color) {setPoint(x, y, color);};//更新整个画板hub.client.update = function (points) {if (!points) return;for (var x = 0; x < 300; x++) {for (var y = 0; y < 300; y++) {if (points[x][y]) {setPoint(x, y, points[x][y]);}}}};$.connection.hub.start().done(function () {connected = true;});});
实现效果

结束语
参考文献
一步一步学习SignalR进行实时通信_8_案例2的更多相关文章
- 一步一步学习SignalR进行实时通信_6_案例
原文:一步一步学习SignalR进行实时通信_6_案例 一步一步学习SignalR进行实时通信\_6_案例1 一步一步学习SignalR进行实时通信_6_案例1 前言 类的定义 各块功能 后台 上线 ...
- 一步一步学习SignalR进行实时通信_1_简单介绍
一步一步学习SignalR进行实时通信\_1_简单介绍 SignalR 一步一步学习SignalR进行实时通信_1_简单介绍 前言 SignalR介绍 支持的平台 相关说明 OWIN 结束语 参考文献 ...
- 一步一步学习SignalR进行实时通信_9_托管在非Web应用程序
原文:一步一步学习SignalR进行实时通信_9_托管在非Web应用程序 一步一步学习SignalR进行实时通信\_9_托管在非Web应用程序 一步一步学习SignalR进行实时通信_9_托管在非We ...
- 一步一步学习SignalR进行实时通信_7_非代理
原文:一步一步学习SignalR进行实时通信_7_非代理 一步一步学习SignalR进行实时通信\_7_非代理 SignalR 一步一步学习SignalR进行实时通信_7_非代理 前言 代理与非代理 ...
- 一步一步学习SignalR进行实时通信_5_Hub
原文:一步一步学习SignalR进行实时通信_5_Hub 一步一步学习SignalR进行实时通信\_5_Hub SignalR 一步一步学习SignalR进行实时通信_5_Hub 前言 Hub命名规则 ...
- 一步一步学习SignalR进行实时通信_4_Hub
原文:一步一步学习SignalR进行实时通信_4_Hub 一步一步学习SignalR进行实时通信\_4_Hub SignalR 一步一步学习SignalR进行实时通信_4_Hub 前言 创建Hub 配 ...
- 一步一步学习SignalR进行实时通信_3_通过CORS解决跨域
原文:一步一步学习SignalR进行实时通信_3_通过CORS解决跨域 一步一步学习SignalR进行实时通信\_3_通过CORS解决跨域 SignalR 一步一步学习SignalR进行实时通信_3_ ...
- 一步一步学习SignalR进行实时通信_2_Persistent Connections
原文:一步一步学习SignalR进行实时通信_2_Persistent Connections 一步一步学习SignalR进行实时通信\_2_Persistent Connections Signal ...
- 12.Linux软件安装 (一步一步学习大数据系列之 Linux)
1.如何上传安装包到服务器 有三种方式: 1.1使用图形化工具,如: filezilla 如何使用FileZilla上传和下载文件 1.2使用 sftp 工具: 在 windows下使用CRT 软件 ...
随机推荐
- 瑕疵(bug)严重性定义
======================== 严重性定义缺陷: o 最先进的–造成执行中断(应用程序崩溃),该功能未预期实现,测试等工作无法进行. o 急-事件是非常重要的,须要立即给予关注. o ...
- Java堆栈详解 .
1. Java中堆栈(stack)和堆(heap) (1)内存分配的策略 按照编译原理的观点,程序运行时的内存分配有三种策略,分别是静态的,栈式的,和堆式的. 静态存储分配是指在编译时就能确定每个数据 ...
- Annotation Type @bean,@Import,@configuration使用--官方文档
@Target(value={METHOD,ANNOTATION_TYPE}) @Retention(value=RUNTIME) @Documented public @interface Bean ...
- Java——(二)Java集合容器
------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 一.基本概念 1)Collection:一个独立元素的序列,这些元素都服从一条或多条规则.Lis ...
- git常见指令
master : 默认开发分支: origin : 默认远程版本库 初始化操作 $ git config -global user.name <name> #设置提交者名字 $ ...
- 兼容IE浏览器的placeholder【超不错】
jQuery EnPlaceholder plug (兼容IE浏览器的placeholder)使用 >>>>>>>>>>>>&g ...
- ASP.NET-FineUI开发实践-16(一)
还是基础的东西,grid全选没有事件,给加个事件,除了需要会复制粘贴外还要点推荐那! 第一步:原理 事件被触发,方法被实现. 对于全选事件,被触发有两种方式可写,一个是通过原生extjs方式触发 ...
- angularjs ngTable -Custom filter template-calendar
jsp页面: <script type="text/ng-template" id="path/to/your/filters/top-Date-One.html& ...
- tomcat发布项目时,空文件夹未发布成功
问题背景: 项目发布到服务器时,缺少文件夹,到时向此文件夹写数据时发生错误. 后来经查,缺少这个文件夹,项目部署发布时,并不会把空文件夹发布上去 解决: 1.在空文件中加入,一个文件.就可以发布成功 ...
- 【转】iOS开发6:UIActionSheet与UIAlertView
原文: http://my.oschina.net/plumsoft/blog/42763 iOS程序中的Action Sheet就像Windows中的 “确定-取消”对话框一样,用于强制用户进行选择 ...