web大作业(9)共享涂鸦的实现

2024-01-27 03:58
文章标签 实现 web 共享 作业 涂鸦

本文主要是介绍web大作业(9)共享涂鸦的实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

要实现教师端上传图片,进行标注并下发到学生端,需要使用websocket或socket.io。使用npm 安装socket.io。下面是教师端绘图和学生端绘图的网页源代码。

教师端:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>绘图</title>
</head>
<script src="jquery.js"></script>
<body><div class="paint"><canvas id="canvas" width="500" height="400" style="border:1px solid #c3c3c3;"></canvas></div><input accept="image/*"  type="file" id="uploadIMG"  onchange="btnUploadFile(event)"/>
</body>
<script src="./socket.io.js"></script>
<script>var socket = io("http://localhost:3000");socket.on('connect',function(){console.log('连接成功')})socket.on('disconnect',function(){console.log('断开连接')})function btnUploadFile(e,type){var files = e.target.files;var file = files[0];if (!/\/(?:jpeg|jpg|png)/i.test(file.type)){return;}var reader = new FileReader();reader.onload = function() { var result = this.result;  socket.emit("send",result)};reader.readAsDataURL(file);    }socket.on('msg',function(data){var img=new Image()//console.log(data)img.src=data;var canvas = document.getElementById("canvas");var context = canvas.getContext("2d");//console.log(result)img.onload = function(){context.drawImage(img,0,0,500,400);}})window.onload=function(){var canvas = document.getElementById("canvas");var context = canvas.getContext("2d");paint(context);}function paint(context){var temp = false;$("canvas").mousedown(function(e){temp=true;var x = e.pageX-8;var y = e.pageY-8;context.moveTo(x,y);socket.emit("send1",[x,y])})$("canvas").mousemove(function(e){var x = e.pageX-8;var y = e.pageY-8;//$("#info").html("( "+x+" , "+y+" )");socket.emit("send2",[x,y])if(temp){context.lineTo(x,y);context.stroke();}})$("canvas").mouseup(function(e){temp=false;socket.emit("send3",1)})}
</script>
</html>

学生端:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>看图</title>
</head>
<script src="jquery.js"></script>
<body><div class="paint"><canvas id="canvas" width="500" height="400" style="border:1px solid #c3c3c3;"></canvas></div>
</body>
<script src="./socket.io.js"></script>
<script src="../node_modules/socket.io-client/dist/socket.io.js"></script>
<script>var socket = io("http://localhost:3000");socket.on('connect',function(){console.log('连接成功')})socket.on('msg',function(data){var img=new Image()img.src=data;var canvas = document.getElementById("canvas");var context = canvas.getContext("2d");//console.log(result)img.onload = function(){context.drawImage(img,0,0,500,400);}})socket.on('disconnect',function(){console.log('断开连接')})window.onload=function(){var canvas = document.getElementById("canvas");var context = canvas.getContext("2d");var temp = false;socket.on('msg1',function(data){temp=true;var x=data[0];var y=data[1];context.moveTo(x,y);})socket.on('msg2',function(data){var x=data[0];var y=data[1];if(temp){context.lineTo(x,y);context.stroke();}})socket.on("msg3",function(data){if(data==1){temp=false;}})}</script>
</html>

以及路由:

var app = express();var server = require("http").createServer(app);
var io = require('socket.io')(server);
io.on('connection',function(socket){socket.on("send",function(data){io.emit("msg",data)})socket.on("send1",function(data){io.emit("msg1",data)})socket.on("send2",function(data){io.emit("msg2",data)})socket.on("send3",function(data){io.emit("msg3",data)})socket.on('reply',function(){})
})

这里做一些简单的说明,首先是教师端使用socket.emit(“内容名”,内容)向服务器上传信息,服务器使用socket.on(“内容名”,function(data){ io.emit(内容名2,内容) })将信息传递给所有客户端,客户端再通过socket.on(“内容名2”,function(data){ 处理内容 }),这样就实现了共享。

这篇关于web大作业(9)共享涂鸦的实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/649001

相关文章

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义