实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端)

这篇具有很好参考价值的文章主要介绍了实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在网页里实现文字聊天是比较容易的,但若要实现视频聊天,就比较麻烦了。本文将实现一个纯Web版的视频聊天和桌面分享的Demo,可直接在浏览器中运行,不需要安装任何插件。

一. 主要功能及支持平台

1.本Demo的主要功能有

(1)一对一语音视频聊天。

(2)远程桌面观看。

(3)当客户端掉线时,会进行自动重连,当网络恢复后,重连成功。

2.支持的平台

(1)支持的操作系统包括:Windows、信创国产Linux(银河麒麟、统信UOS)、Android、iOS、Mac、鸿蒙OS。

(2)支持的CPU架构:X86/X64、ARM、MIPS、Loongarch。

(3)支持几乎所有的主流浏览器:Chrome、Edge、Firefox、Safari、360浏览器、QQ浏览器等。    

(4)另外,我们测试过,使用APP套壳,在WebView控件中加载Demo页面,也是可以正常视频聊天的。

         如此,可以在C/S架构的客户端或手机APP中嵌入WebView控件来引入视频聊天或桌面分享功能的。

二. 开发环境

1. 服务端:

    服务端开发环境是 Visual Sudio 2022 ,开发语言是 C# 。

2. Web端:

    PC版Web开发环境是 VS Code 1.85 ,使用 vue 3。

    手机版Web开发环境是 HBuilder 3.8.12,uni-app(导出H5)。

三. 运行效果

     此Demo的源码分为三个部分,分别是服务端,PC端Web(横版)和手机端Web(竖版)。接下来首先来看移动端Web的运行效果。 

(1)首先是登录界面,在登录界面有三个输入框,依次为服务器IP、用户账号和用户密码,在本Demo中,用户账号和用户密码均可随便填写。           

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

移动端登录页面

(2)接下来是首页界面,首页界面有一个已连接的提示框,代表的意思是目前与服务端是连接状态,当因为网络原因或者其他原因断开时,则会提示已断开连接。   

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

移动端主页面

(3)发起视频聊天,输入对方的账号,然后点击请求视频会话按钮即可向对方发起视频聊天请求,对方接受请求和即可聊天了。    

         下图是手机端视频聊天效果:

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

移动端视频聊天

注意:手机端是不支持分享自己的桌面的,但是移动端可以观看PC端桌面。

(4)接下来看看一下PC端的运行效果。

         登录之后主页界面,左上角是关于自己的一些信息,右边窗口则是显示连接对方的摄像头或者桌面。

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

PC端主页面

(4)下图是在PC端观看他人桌面。

         输入对方的账号,然后点击请求远程桌面,在对方同意后便可以观看别人的屏幕了。  

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

PC端桌面分享

四. 服务端源码说明

        注意,由于浏览器的限制,如果你要将Web端部署到公网上,需要使用HTTPS协议,否则无法访问摄像头。

        与之对应的,服务端也需要使用到WSS协议,因此需要准备一份SSL证书用于部署。如果你仅仅只是在本地运行看一下效果,则无需准备。

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

 上图为服务端初始化代码,若不打算部署只是在浏览器中加载本地Demo页面,则应将上图中的第六行注释掉,并将第七行中MultimediaServerFactory.CreateMultimediaServer方法中的wssOption用null替换掉。

   若打算将网站部署在服务器上,则需要将第五行X509Certificate2中的两个参数分别修改为你证书的路径和密码。

五. Web端源码说明

       本Demo的中的Web端包含两套代码,其中移动端Web采用Uniapp进行开发,PC端Web采用Vue框架进行开发。为了便于理解,下面对源码中的关键点进行讲解说明,两套代码逻辑基本相同,因此这里不作区分。 

1. 消息定义

在本Demo中,我们定义了10个消息类型,用于Web端之间进行通信,其定义如下:

const informationTypes = {
  // 视频请求
  VideoRequest: 0,

  // 回复视频请求的结果
  VideoResult: 1,

  // 通知对方 挂断 视频连接
  CloseVideo: 2,

  // 通知好友 网络原因,导致 视频中断
  NetReasonCloseVideo: 3,

  // 通知对方(忙线中) 挂断 视频连接
  BusyLine: 4,

  // 远程桌面请求
  DesktopRequest: 5,

  // 回复远程桌面请求的结果
  DesktopResult: 6,

  // 主动取消远程桌面请求
  CancelDesktop: 7,

  // 对方(主人端)主动断开远程桌面
  OwnerCloseDesktop: 8,

  // 客人端断开远程桌面连接
  GuestCloseDesktop: 9
};

 由于这些消息类型经常会使用到,因此需要将其放到一个全局都能访问到的地方,在移动端Web源码中,它被放在了Vuex中。而在PC端Web源码中,它放在src目录下的omcs目录下。 

2. 自定义消息处理器

     在登录成功后的这个时机,通过调用多媒体管理器上的 SetCustomMessageReceivedCallback 方法,我们向 multimediaManager(多媒体管理器)注册一个回调函数,这个回调函数会在接收到其他用户或服务端的消息时被触发。

      这个回调函数会接收一个对象类型的参数,其中包含了消息的类型和消息发起者的用户名数据,然后就可以根据消息的类型来完成自己的业务操作了。下图是本Demo中定义的消息处理器: 

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

3. 一对一语音视频

      在本Demo中,一对一语音视频聊天功能的实现逻辑简而言之就是:例如用户A想要与用户B视频聊天,那么用户A向用户B发送VideoRequest消息,在用户B收到来自用户A的VideoRequest消息时选择同意与否,并将携带用户B意愿数据的VideoResult消息发送用户A。

// 请求视频会话
const videoRequest = async () => {
  // ...
  multimediaManager.sendCustomMessage(targetUsername.value, InformationTypes.VideoRequest, null, null);
  // ...
};

// 响应视频会话
const videoResult = (flag) => {
  // ...
  multimediaManager.sendCustomMessage(targetUsername.value, InformationTypes.VideoResult, [flag ? 1 : 0], "");
  // ...
};

4. 桌面分享

     与一对一语音视频聊天功能类似,实现桌面分享也是一方发起请求,一方进行回应。与语音视频对应的,桌面分享的请求的消息类型为DesktopRequest,响应的消息类型为DesktopResult。

5. 断网重连

     在网络断开时,用户进入掉线状态(与服务器断开),每5秒会进行与服务器的重新连接。提前向多媒体管理器注入ConnectionInterrupted和ConnectionRebuildSucceed回调,能够在与媒体服务器断开和重新连接成功时做一些事情。 

六. 如何在本地部署运行Web端

     Web端包含两套代码,其中移动端Web的目录是H5MediaDemo_WebH5,PC端Web的目录是H5MediaDemo_WebPC。 

1. 移动端web:

      由于移动端web是采用uniapp开发的,而uniapp项目需要通过HBuilder X来运行,因此,你需要在电脑上安装一个HBuilder X,然后在HBuilderX中打开运行——>运行到浏览器,然后选择一个浏览器就可以运行起来了,如下图:

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

2. PC端web:

       PC端采用Vue3开发的,需要依赖NodeJS环境,因此,你需要在电脑上安装一个NodeJS(建议安装长期维护版)。在安装完后,通过在命令行窗口输入node -v和npm - v来检查是否安装成功:

实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

确定安装成功后,通过命令行进入到H5MediaDemo_WebPC的项目根目录,然后输入npm run dev即可将项目运行起来。  

 实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端),Linux 音视频开发,Web IM,视频聊天,语音聊天,web音视频,web屏幕共享,web远程桌面

七. 源码下载

(1)PC版源码

(2)手机版源码

      另外,我们已经部署好了测试服务器,以方便测试。

(1)PC  Web 测试网址 

(2)手机 Web 测试网址

      网页版视频聊天Demo实现的介绍就到这里了,欢迎交流,谢谢!文章来源地址https://www.toymoban.com/news/detail-818065.html

到了这里,关于实现纯Web语音视频聊天和桌面分享(附源码,PC端+移动端)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 网站在线客服系统实时语音视频聊天实战开发,利用peerjs vue.js实现webRTC网页音视频客服系统...

    webRTC机制和peerjs库的介绍在其他博客中已经有了很多介绍,这里我直接搬运过来 WebRTC(Web Real-Time Communication)即:网页即时通信。 简单点讲,它可以实现浏览器网页与网页之间的音视频实时通信(或传输其它任何数据),目前主流浏览器都支持该API,WebRTC现在已经纳入W3C标准。

    2024年02月04日
    浏览(58)
  • 手机视频聊天分享

    在人际互动的手机APP中,增加语音视频聊天功能是一个常见的需求。而现在,更进一步,在某些场景下,我们需要能将自己的手机屏幕分享给他人,或者是观看他人的手机屏幕。那么,这些常见的功能是如何实现的了? 我分享一个安卓版的Demo供大家参考。 一.功能介绍 1.

    2024年02月15日
    浏览(31)
  • WX Backup - 免费微信聊天记录备份导出与查看工具 (可提取图片/视频/语音)

    微信绝对是一个让人爱恨交织的 APP,它在国内几乎完全占据了人们的社交以及生活的方方面面,但腾讯却并没有为微信提供好用的「 聊天记录 」备份导出和查看的功能。 WX Backup 是一款完全免费的 微信聊天记录备份导出工具 ,支持 Windows 和 Mac,它能将你的微信聊天记录导

    2024年02月09日
    浏览(59)
  • 如何用AI技术实现和马斯克实时视频聊天

    前言 在直播盛行、短视频横飞、主播满地的今天,个人上传自己的生活视频来记录日常已经屡见不鲜了。拿起手机拍个视频,并且在上传前顺便美颜一下,乐此不疲。 但是最近看到的一些 AI 诈骗新闻却不得不令人担忧,网上你以为的帅哥美女、老弱病残真的是真实的吗?在

    2024年02月10日
    浏览(42)
  • PHP脉聊交友系统网站源码,可通过广告变现社交在线聊天交友即时通讯APP源码,附带视频搭建教程

    探索全新社交体验:一站式PHP交友网站解决方案 🌐  全球化交友,无界沟通 在数字化的浪潮下,社交已不再受地域限制。我们的PHP交友网站不仅支持多国语言,还配备了即时翻译功能,让您轻松跨越语言障碍,与全球各地的朋友畅聊无阻。 💬  即时通讯,沟通无延迟 无论

    2024年02月21日
    浏览(46)
  • 使用javafx实现的基于udp、tcp的聊天GUI应用,可用作Java大作业、计网课程设计+视频演示

    点击这里下载源码 项目使用javafx作为ui开发平台,基于udp和tcp实现聊天功能。 支持同一网络环境内多设备聊天(测试了多台windows、mac设备通过有线和无线连接到一个局域网的情况)。 通信的流程可以简单描述为: 每个用户登录时会生成一个带uuid的用户信息 使用udp向局域网

    2024年02月04日
    浏览(44)
  • 电脑微信视频摄像头怎么打开 微信视频聊天怎么打开电脑摄像头

    最近有用户在使用电脑微信视频聊天的时候,不知道怎么打开电脑摄像头的权限,今天小编就给大家带来了微信视频聊天打开电脑摄像头的具体方法。无论你是台式电脑还是联想、戴尔、华硕、华为等品牌都可以使用本文的方法,有需要的用户们赶紧来看一下吧。 电脑微信视

    2024年02月06日
    浏览(49)
  • 【音视频】基于webrtc的聊天室的设计

    目录 术语 webrtc建连流程  系统整体架构 信令服务器房间状态管理 用户加入房间流程 用户加入房间并推流: 其他用户订阅此用户流 用户加入房间并订阅房间其他所有用户 用户退出房间流程  平行集群模式​编辑 第一阶段demo 设计 参考文章 本想自己画一遍的,发现参考的文

    2024年02月11日
    浏览(66)
  • vue 在线聊天实战范例(含选择发送表情、图片、视频、音频,自定义右键快捷菜单,一键复制,左右聊天气泡)

    链接:https://pan.baidu.com/s/170pb-MJlMxG2nRj_3Y2VFw?pwd=oknr 提取码:oknr

    2024年02月07日
    浏览(61)
  • AI聊天 AI绘画 AI视频 AI制作PPT

    文章目录: 一:AI聊天 二:AI绘画 三:AI视频 四:AI制作PPT 这些平台工具太多了,我列举一些我用过还可以的,如果亲,您有什么推荐的,可以在下面评论留言,我到时补充上去!  这里主要放一些国内我感觉好用的,国外或者更多请移步——AI-Chat_Draw_Video_PPT 搜索AI伙伴:

    2024年01月16日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包