CN110446069B - 一种基于视联网终端的视频通信方法、装置及存储介质 - Google Patents

一种基于视联网终端的视频通信方法、装置及存储介质 Download PDF

Info

Publication number
CN110446069B
CN110446069B CN201910620272.4A CN201910620272A CN110446069B CN 110446069 B CN110446069 B CN 110446069B CN 201910620272 A CN201910620272 A CN 201910620272A CN 110446069 B CN110446069 B CN 110446069B
Authority
CN
China
Prior art keywords
video
video data
terminal
network
data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201910620272.4A
Other languages
English (en)
Other versions
CN110446069A (zh
Inventor
李云龙
高丰
张美聪
王艳辉
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Visionvera Information Technology Co Ltd
Original Assignee
Visionvera Information Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Visionvera Information Technology Co Ltd filed Critical Visionvera Information Technology Co Ltd
Priority to CN201910620272.4A priority Critical patent/CN110446069B/zh
Publication of CN110446069A publication Critical patent/CN110446069A/zh
Application granted granted Critical
Publication of CN110446069B publication Critical patent/CN110446069B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
    • H04N21/4402Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/14Systems for two-way working
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/18Closed-circuit television [CCTV] systems, i.e. systems in which the video signal is not broadcast

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)

Abstract

本发明提供了一种基于视联网终端的视频通信方法、装置和计算机可读存储介质,其中方法应用于视频通信系统中的第一视联网终端,视频通信系统中还部署有视联网服务器,第一视联网终端外接有第一视频采集终端,第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据,其中方法包括:接收第一视频采集终端发送的第一编码视频数据,接收联网服务器发送的第二编码视频数据,对所述第一编码视频数据和所述第二编码视频数据进行解码,对解码后的第一视频数据和第二视频数据进行显示,采用本发明可以避免利用第一视联网终端进行采集视频数据并编码,能够减少视频编码过程对第一视联网终端内存的占用,提高视联网终端间通信的稳定性。

Description

一种基于视联网终端的视频通信方法、装置及存储介质
技术领域
本发明涉及视频通信技术领域,特别是涉及一种基于视联网终端的视频通信方法、装置及存储介质。
背景技术
视联网是网络发展的重要里程碑,是互联网的更高级形态,是一个实时网络,能够实现目前互联网无法实现的全网高清视频实时传输,将众多互联网应用推向高清视频化,高清面对面。最终将实现世界无距离,实现全球范围内人与人的距离只是一个屏幕的距离。
随着视联网业务不断扩大,全国各地召开的视联网会议日益增多。现有的视联网会议通常是通过在一台终端设备与另一台终端设备之间进行通信实现的。终端设备之间在进行通信时会有两个步骤,一是对本地摄像头采集的视频数据进行编码,将编码后的视频数据发送到远端终端设备,二是对接收的远端视频编码数据进行解码,再显示在本地屏幕,采用现有的终端设备之间通信步骤会导致视联网会议稳定性差。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种基于视联网终端的视频通信方法、装置,以及一种计算机可读存储介质。
为了解决上述问题,本发明实施例公开了一种基于视联网终端的视频通信方法,所述方法应用于视频通信系统中的第一视联网终端,所述视频通信系统中还部署有视联网服务器;所述第一视联网终端外接有第一视频采集终端;所述第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据;所述的方法包括:
接收所述第一视频采集终端发送的第一编码视频数据;
接收所述视联网服务器发送的第二编码视频数据;
对所述第一编码视频数据和所述第二编码视频数据进行解码;
对解码后的第一视频数据和第二视频数据进行显示。
可选地,所述视频通信系统中还部署有第二视联网终端;所述第二视联网终端外接有第二视频采集终端;所述第二视频采集终端能够对采集的视频数据进行编码得到第二编码视频数据;所述第二编码视频数据是由第二视频采集终端发送到第二视联网终端,再由第二视联网终端发送到视联网服务器的。
可选地,所述对所述第一编码视频数据和所述第二编码视频数据进行解码,包括:
将所述第一编码视频数据和所述第二编码视频数据分别实时存入第一队列和第二队列;
将所述第一队列中的所述第一编码视频数据以异步的方式放入解码器并进行解码,将所述第二队列中的所述第二编码视频数据以同步的方式放入解码器并进行解码。
可选地,所述方法还包括:
配置解码后的所述第一视频数据和所述第二视频数据显示的画布;
所述对解码后的第一视频数据和第二视频数据进行显示,包括:
将解码后的第一视频数据和第二视频数据显示在配置的画布上。
为了解决上述问题,本发明实施例还公开了一种基于视联网终端的视频通信装置,所述装置应用于视频通信系统中的第一视联网终端,所述视频通信系统中还部署有视联网服务器;所述第一视联网终端外接有第一视频采集终端;所述第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据;所述的装置包括:
第一接收模块,用于接收所述第一视频采集终端发送的第一编码视频数据;
第二接收模块,用于接收所述视联网服务器发送的第二编码视频数据;
解码模块,用于对所述第一编码视频数据和所述第二编码视频数据进行解码;
显示模块,用于对解码后的第一视频数据和第二视频数据进行显示。
可选地,所述视频通信系统中还部署有第二视联网终端;所述第二视联网终端外接有第二视频采集终端;所述第二视频采集终端能够对采集的视频数据进行编码得到第二编码视频数据;所述第二编码视频数据是由第二视频采集终端发送到第二视联网终端,再由第二视联网终端发送到视联网服务器的。
可选地,所述解码模块包括:
第一存入子模块,用于将所述第一编码视频数据实时存入第一队列;
第二存入子模块,用于将所述第二编码视频数据实时存入第二队列;
第一解码子模块,用于将所述第一队列中的所述第一编码视频数据以异步的方式放入解码器并进行解码;
第二解码子模块,用于将所述第二队列中的所述第二编码视频数据以同步的方式放入解码器进行解码。
可选地,所述装置还包括:
配置模块,用于配置解码后的所述第一视频数据和所述第二视频数据显示的画布;
显示子模块,用于将解码后的第一视频数据和第二视频数据显示在配置的画布上。
本发明实施例还公开了一种基于视联网终端的视频通信装置,包括:
一个或多个处理器;和
其上存储有指令的一个或多个计算机可读介质,当由所述一个或多个处理器执行时,使得所述装置执行如本发明实施例任一所述的基于视联网终端的视频通信方法。
本发明实施例还公开了一种计算机可读存储介质,其存储的计算机程序使得处理器执行如本发明实施例所述的基于视联网终端的视频通信方法。
与现有技术相比,本发明实施例包括以下优点:
在本发明实施例中,通过第一视联网终端接收所述第一视频采集终端发送的第一编码视频数据,其中,所述第一视联网终端外接有第一视频采集终端,所述第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据,以及接收所述视联网服务器发送的第二编码视频数据,接着通过第一视联网终端对所述第一编码视频数据和所述第二编码视频数据进行解码,对解码后的第一视频数据和第二视频数据进行显示。第一编码视频数据是由第一视联网终端外接的第一视频采集终端采集并编码产生的,避免了利用第一视联网终端进行采集视频数据并编码,能够减少视频编码过程对第一视联网终端内存的占用,提高视联网终端间通信的稳定性。
附图说明
图1是本发明的一种视联网的组网示意图;
图2是本发明的一种节点服务器的硬件结构示意图;
图3是本发明的一种接入交换机的硬件结构示意图;
图4是本发明的一种以太网协转网关的硬件结构示意图;
图5是本发明实施例的一种基于视联网终端的视频通信方法一种实施例的步骤流程图;
图6是本发明实施例的一种基于视联网终端的视频通信方法另一种实施例的步骤流程图;
图7是本发明实施例的一种基于视联网终端的视频通信方法又一种实施例的步骤流程图
图8是本发明实施例的一种基于视联网终端的视频通信装置一种实施例的结构框图;
图9是本发明实施例的一种基于视联网终端的视频通信装置另一种实施例的结构框图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
视联网是网络发展的重要里程碑,是一个实时网络,能够实现高清视频实时传输,将众多互联网应用推向高清视频化,高清面对面。
视联网采用实时高清视频交换技术,可以在一个网络平台上将所需的服务,如高清视频会议、视频监控、智能化监控分析、应急指挥、数字广播电视、延时电视、网络教学、现场直播、VOD点播、电视邮件、个性录制(PVR)、内网(自办)频道、智能化视频播控、信息发布等数十种视频、语音、图片、文字、通讯、数据等服务全部整合在一个系统平台,通过电视或电脑实现高清品质视频播放。
为使本领域技术人员更好地理解本发明实施例,以下对视联网进行介绍:
视联网所应用的部分技术如下所述:
网络技术(Network Technology)
视联网的网络技术创新改良了传统以太网(Ethernet),以面对网络上潜在的巨大第一视频流量。不同于单纯的网络分组包交换(Packet Switching)或网络电路交换(Circuit Switching),视联网技术采用Packet Switching满足Streaming需求。视联网技术具备分组交换的灵活、简单和低价,同时具备电路交换的品质和安全保证,实现了全网交换式虚拟电路,以及数据格式的无缝连接。
交换技术(Switching Technology)
视联网采用以太网的异步和包交换两个优点,在全兼容的前提下消除了以太网缺陷,具备全网端到端无缝连接,直通用户终端,直接承载IP数据包。用户数据在全网范围内不需任何格式转换。视联网是以太网的更高级形态,是一个实时交换平台,能够实现目前互联网无法实现的全网大规模高清视频实时传输,将众多网络视频应用推向高清化、统一化。
服务器技术(Server Technology)
视联网和统一视频平台上的服务器技术不同于传统意义上的服务器,它的流媒体传输是建立在面向连接的基础上,其数据处理能力与流量、通讯时间无关,单个网络层就能够包含信令及数据传输。对于语音和视频业务来说,视联网和统一视频平台流媒体处理的复杂度比数据处理简单许多,效率比传统服务器大大提高了百倍以上。
储存器技术(Storage Technology)
统一视频平台的超高速储存器技术为了适应超大容量和超大流量的媒体内容而采用了最先进的实时操作系统,将服务器指令中的节目信息映射到具体的硬盘空间,媒体内容不再经过服务器,瞬间直接送达到用户终端,用户等待一般时间小于0.2秒。最优化的扇区分布大大减少了硬盘磁头寻道的机械运动,资源消耗仅占同等级IP互联网的20%,但产生大于传统硬盘阵列3倍的并发流量,综合效率提升10倍以上。
网络安全技术(Network Security Technology)
视联网的结构性设计通过每次服务单独许可制、设备与用户数据完全隔离等方式从结构上彻底根除了困扰互联网的网络安全问题,一般不需要杀毒程序、防火墙,杜绝了黑客与病毒的攻击,为用户提供结构性的无忧安全网络。
服务创新技术(Service Innovation Technology)
统一视频平台将业务与传输融合在一起,不论是单个用户、私网用户还是一个网络的总合,都不过是一次自动连接。用户终端、机顶盒或PC直接连到统一视频平台,获得丰富多彩的各种形态的多媒体视频服务。统一视频平台采用“菜谱式”配表模式来替代传统的复杂应用编程,可以使用非常少的代码即可实现复杂的应用,实现“无限量”的新业务创新。
视联网的组网如下所述:
视联网是一种集中控制的网络结构,该网络可以是树型网、星型网、环状网等等类型,但在此基础上网络中需要有集中控制节点来控制整个网络。
如图1所示,视联网分为接入网和城域网两部分。
接入网部分的设备主要可以分为3类:节点服务器,接入交换机,终端(包括各种机顶盒、编码板、存储器等)。节点服务器与接入交换机相连,接入交换机可以与多个终端相连,并可以连接以太网。
其中,节点服务器是接入网中起集中控制功能的节点,可控制接入交换机和终端。节点服务器可直接与接入交换机相连,也可以直接与终端相连。
类似的,城域网部分的设备也可以分为3类:城域服务器,节点交换机,节点服务器。城域服务器与节点交换机相连,节点交换机可以与多个节点服务器相连。
其中,节点服务器即为接入网部分的节点服务器,即节点服务器既属于接入网部分,又属于城域网部分。
城域服务器是城域网中起集中控制功能的节点,可控制节点交换机和节点服务器。城域服务器可直接连接节点交换机,也可直接连接节点服务器。
由此可见,整个视联网络是一种分层集中控制的网络结构,而节点服务器和城域服务器下控制的网络可以是树型、星型、环状等各种结构。
形象地称,接入网部分可以组成统一视频平台(虚线圈中部分),多个统一视频平台可以组成视联网;每个统一视频平台可以通过城域以及广域视联网互联互通。
视联网设备分类
1.1本发明实施例的视联网中的设备主要可以分为3类:服务器,交换机(包括以太网协转网关),终端(包括各种机顶盒,编码板,存储器等)。视联网整体上可以分为城域网(或者国家网、全球网等)和接入网。
1.2其中接入网部分的设备主要可以分为3类:节点服务器,接入交换机(包括以太网协转网关),终端(包括各种机顶盒,编码板,存储器等)。
各接入网设备的具体硬件结构为:
节点服务器:
如图2所示,主要包括网络接口模块201、交换引擎模块202、CPU模块203、磁盘阵列模块204;
其中,网络接口模块201,CPU模块203、磁盘阵列模块204进来的包均进入交换引擎模块202;交换引擎模块202对进来的包进行查地址表205的操作,从而获得包的导向信息;并根据包的导向信息把该包存入对应的包缓存器206的队列;如果包缓存器206的队列接近满,则丢弃;交换引擎模块202轮询所有包缓存器队列,如果满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零。磁盘阵列模块204主要实现对硬盘的控制,包括对硬盘的初始化、读写等操作;CPU模块203主要负责与接入交换机、终端(图中未示出)之间的协议处理,对地址表205(包括下行协议包地址表、上行协议包地址表、数据包地址表)的配置,以及,对磁盘阵列模块204的配置。
接入交换机:
如图3所示,主要包括网络接口模块(下行网络接口模块301、上行网络接口模块302)、交换引擎模块303和CPU模块304;
其中,下行网络接口模块301进来的包(上行数据)进入包检测模块305;包检测模块305检测包的目地地址(DA)、源地址(SA)、数据包类型及包长度是否符合要求,如果符合,则分配相应的流标识符(stream-id),并进入交换引擎模块303,否则丢弃;上行网络接口模块302进来的包(下行数据)进入交换引擎模块303;CPU模块304进来的数据包进入交换引擎模块303;交换引擎模块303对进来的包进行查地址表306的操作,从而获得包的导向信息;如果进入交换引擎模块303的包是下行网络接口往上行网络接口去的,则结合流标识符(stream-id)把该包存入对应的包缓存器307的队列;如果该包缓存器307的队列接近满,则丢弃;如果进入交换引擎模块303的包不是下行网络接口往上行网络接口去的,则根据包的导向信息,把该数据包存入对应的包缓存器307的队列;如果该包缓存器307的队列接近满,则丢弃。
交换引擎模块303轮询所有包缓存器队列,可以包括两种情形:
如果该队列是下行网络接口往上行网络接口去的,则满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零;3)获得码率控制模块产生的令牌;
如果该队列不是下行网络接口往上行网络接口去的,则满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零。
码率控制模块308是由CPU模块304来配置的,在可编程的间隔内对所有下行网络接口往上行网络接口去的包缓存器队列产生令牌,用以控制上行转发的码率。
CPU模块304主要负责与节点服务器之间的协议处理,对地址表306的配置,以及,对码率控制模块308的配置。
以太网协转网关
如图4所示,主要包括网络接口模块(下行网络接口模块401、上行网络接口模块402)、交换引擎模块403、CPU模块404、包检测模块405、码率控制模块408、地址表406、包缓存器407和MAC添加模块409、MAC删除模块410。
其中,下行网络接口模块401进来的数据包进入包检测模块405;包检测模块405检测数据包的以太网MAC DA、以太网MAC SA、以太网length or frame type、视联网目地地址DA、视联网源地址SA、视联网数据包类型及包长度是否符合要求,如果符合则分配相应的流标识符(stream-id);然后,由MAC删除模块410减去MAC DA、MAC SA、length or frame type(2byte),并进入相应的接收缓存,否则丢弃;
下行网络接口模块401检测该端口的发送缓存,如果有包则根据包的视联网目地地址DA获知对应的终端的以太网MAC DA,添加终端的以太网MAC DA、以太网协转网关的MACSA、以太网length or frame type,并发送。
以太网协转网关中其他模块的功能与接入交换机类似。
终端:
主要包括网络接口模块、业务处理模块和CPU模块;例如,机顶盒主要包括网络接口模块、视音频编解码引擎模块、CPU模块;编码板主要包括网络接口模块、视音频编码引擎模块、CPU模块;存储器主要包括网络接口模块、CPU模块和磁盘阵列模块。
1.3城域网部分的设备主要可以分为2类:节点服务器,节点交换机,城域服务器。其中,节点交换机主要包括网络接口模块、交换引擎模块和CPU模块;城域服务器主要包括网络接口模块、交换引擎模块和CPU模块构成。
2、视联网数据包定义
2.1接入网数据包定义
接入网的数据包主要包括以下几部分:目的地址(DA)、源地址(SA)、保留字节、payload(PDU)、CRC。
如下表所示,接入网的数据包主要包括以下几部分:
DA SA Reserved Payload CRC
其中:
目的地址(DA)由8个字节(byte)组成,第一个字节表示数据包的类型(例如各种协议包、组播数据包、单播数据包等),最多有256种可能,第二字节到第六字节为城域网地址,第七、第八字节为接入网地址;
源地址(SA)也是由8个字节(byte)组成,定义与目的地址(DA)相同;
保留字节由2个字节组成;
payload部分根据不同的数据报的类型有不同的长度,如果是各种协议包的话是64个字节,如果是单组播数据包话是32+1024=1056个字节,当然并不仅仅限于以上2种;
CRC有4个字节组成,其计算方法遵循标准的以太网CRC算法。
2.2城域网数据包定义
城域网的拓扑是图型,两个设备之间可能有2种、甚至2种以上的连接,即节点交换机和节点服务器、节点交换机和节点交换机、节点交换机和节点服务器之间都可能超过2种连接。但是,城域网设备的城域网地址却是唯一的,为了精确描述城域网设备之间的连接关系,在本发明实施例中引入参数:标签,来唯一描述一个城域网设备。
本说明书中标签的定义和MPLS(Multi-Protocol Label Switch,多协议标签交换)的标签的定义类似,假设设备A和设备B之间有两个连接,那么数据包从设备A到设备B就有2个标签,数据包从设备B到设备A也有2个标签。标签分入标签、出标签,假设数据包进入设备A的标签(入标签)是0x0000,这个数据包离开设备A时的标签(出标签)可能就变成了0x0001。城域网的入网流程是集中控制下的入网过程,也就意味着城域网的地址分配、标签分配都是由城域服务器主导的,节点交换机、节点服务器都是被动的执行而已,这一点与MPLS的标签分配是不同的,MPLS的标签分配是交换机、服务器互相协商的结果。
如下表所示,城域网的数据包主要包括以下几部分:
DA SA Reserved 标签 Payload CRC
即目的地址(DA)、源地址(SA)、保留字节(Reserved)、标签、payload(PDU)、CRC。其中,标签的格式可以参考如下定义:标签是32bit,其中高16bit保留,只用低16bit,它的位置是在数据包的保留字节和payload之间。
在视联网终端之间进行视联网视频会议时,通常是通过在一台终端设备与另一台终端设备之间进行视频通信实现的,现有的视频通信用视联网终端设备均采用内置摄像头,内置摄像头采集的视频数据一方面直接使用显示在本地屏幕,另一方面,本地视联网终端将内置摄像头采集的视频数据进行编码后发送到远端视联网终端,远端视联网终端接收编码后的视频数据后,对编码后的视频数据进行解码并显示于远端屏幕,由于是在一台终端设备与另一台终端设备之间进行视频通信,这样就导致对于每一台视联网终端设备均要进行编码与解码工作,当视频数据的编码与解码均在视联网终端上进行的时候,会占用视联网终端的内存,并且由于视联网视频会议用视联网终端性能普遍不高,内存较小,若视频数据的编码与解码均在视联网终端上进行会降低视频通信稳定性。
参考图5,图5示出了本发明实施例的一种基于视联网终端的视频通信方法的步骤流程图,该方法可应用于视频通信系统中的第一视联网终端,视频通信系统中还部署有视联网服务器,第一视联网终端外接有第一视频采集终端,第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据,具体可以包括如下步骤:
步骤S501,接收所述第一视频采集终端发送的第一编码视频数据。
需要说明的是,视频通信具体可以为视频会议,第一视联网终端可以是视联网视频会议的本地一侧,也可以是视联网视频会议的远端一侧。在本实施例中,为了方便描述,本实施例中将第一视联网终端一侧看做是视联网会议中的本地侧。
在进行视联网视频会议时,由于第一视联网终端外接有第一视频采集终端,因此本地侧的视频数据由第一视频数据采集终端采集,第一视视频采集终端采集本地原始视频数据后对视频数据进行编码,生成第一编码视频数据,接着第一视视频采集终端将第一编码视频数据发送到第一视联网终端。
在本实施例中,第一视频采集终端可以是具有编码功能的摄像头,优选地,可以采用罗技USB C930e摄像头。
步骤S502,接收所述视联网服务器发送的第二编码视频数据。
在本实施例中,视频通信系统中还部署有第二视联网终端,第二视联网终端外接有第二视频采集终端,第二视频采集终端能够对采集的视频数据进行编码得到第二编码视频数据。
需要说明的是,第二视联网终端可以是视联网视频会议的本地一侧,也可以是视联网视频会议的远端一侧。在本实施例中,为了方便描述,可以将第二视联网终端一侧看作是远端侧。
在进行视联网视频会议时,由于在视联网中部署有第一视联网终端、第二视联网终端和视联网服务器,可以先建立视联网服务器与第一视联网终端和第二视联网终端的通信连接,在建立视联网服务器与第一视联网终端和第二视联网终端的通信连接后,第二视联网终端可以将接收到的远端侧的第二编码视频数据发送到视联网服务器,再由视联网服务器实时将第二编码视频数据发送到第一视联网终端。
在本发明的一种优选实施例中,第一视联网终端和第二视联网终端均设置有视联网号码,第一视联网终端接收视联网服务器发送的第二编码视频数据之前,建立第一视联网终端和第二视联网终端之间的通信连接,在第一视联网终端输入第二视联网终端对应的视联网号码进行呼叫,视联网服务器在接收到第一视联网终端的呼叫指令后向第二视联网终端发送来自第一视联网终端的呼叫消息,第二视联网终端选择接听第一视联网终端的呼叫后向视联网服务器发送接听指令,视联网服务器向第一视联网终端发送接听指令,第一视联网终端和第二视联网终端建立通信连接,进入视频通话页面。
步骤S503,对所述第一编码视频数据和所述第二编码视频数据进行解码。
在本实施例中,第一视联网终端接收到的第一编码视频数据和第二编码视频数据均是编码的视频数据,因此需要将第一编码视频数据和第二编码视频数据经过解码器进行解码才能正常显示。
步骤S504,对解码后的第一视频数据和第二视频数据进行显示。
在进行视联网视频会议时,在本地终端会显示本地侧和远端侧两路视频画面,对第一编码视频数据解码后得到第一视频数据,对第二编码视频数据解码后得到第二视频数据,确定本地视频画面要显示的第一视频数据和第二视频数据后,将要显示的第一视频数据和第二视频数据进行输出显示,例如输出到显示屏上进行显示,从而实现在本地终端正常接听远端的视频通话。
在本实施例中,通过第一视联网终端接收所述第一视频采集终端发送的第一编码视频数据,其中,所述第一视联网终端外接有第一视频采集终端,所述第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据,以及接收所述视联网服务器发送的第二编码视频数据,接着通过第一视联网终端对所述第一编码视频数据和所述第二编码视频数据进行解码,对解码后的第一视频数据和第二视频数据进行显示。第一编码视频数据是由第一视联网终端外接的第一视频采集终端采集并编码产生的,避免了利用第一视联网终端进行采集视频数据并编码,能够减少视频编码过程对第一视联网终端内存的占用,提高视联网终端间通信的稳定性。
参考图6,图6示出了本发明的一种基于视联网终端的视频通信方法另一种实施例的步骤流程图,具体可以包括如下步骤:
步骤S601,接收所述第一视频采集终端发送的第一编码视频数据。
此步骤与步骤S501相同,在此不再详述。
步骤S602,接收所述视联网服务器发送的第二编码视频数据。
此步骤与步骤S502相同,在此不再详述。
步骤S603,对所述第一编码视频数据和所述第二编码视频数据进行解码。
优选地,在本发明的另一种实施例中,步骤S603具体包括:
子步骤S6031,将所述第一编码视频数据和所述第二编码视频数据分别实时存入第一队列和第二队列。
在本发明实施例中,当接收到第一编码视频数据和第二编码视频数据后,第一视联网终端调用第一队列的Add方法将第一编码视频数据存入第一队列,调用第二队列的Add方法将第二编码视频数据存入第二队列,以达到实时将第一编码视频数据和第二编码视频数据分别存入第一队列和第二队列的目的,从而使得第一编码视频数据和第二编码视频数据在解码后能实时显示。
子步骤S6032,将所述第一队列中的所述第一编码视频数据以异步的方式放入解码器并进行解码,将所述第二队列中的所述第二编码视频数据以同步的方式放入解码器并进行解码。
在本发明实施例中,第二视频采集终端采集的第二编码视频数据发送到第一视联网终端时,需要经过视联网服务器的传输,降低了第二编码视频数据的稳定性,因此在视联网服务器将第二编码视频数据发送到第一视联网终端进行实时显示时,需要阻塞等待,采取同步的方式能够保证第二编码视频数据在第一视联网终端实时显示;第一视频数据采集终端采集的第一编码视频数据在第一视联网终端显示时不需要经过视联网服务器传输,因此第一编码视频数据比较稳定,要达到实时显示,不需要阻塞等待,在本实施例中采用异步的方式,可以降低内存消耗,提高视联网终端间通信的稳定性。
同步的方式:解码器循环的索取第二队列中的第二编码视频数据,如果第二编码视频数据为空,则进行阻塞等待,期间不能进行其他工作,占用内存资源。
异步的方式:解码器循环的索取第一队列中的第一编码视频数据,如果第一编码视频数据为空,不会进行阻塞等待,期间可以进行其他工作,相当于被动地接收数据,不占用内存资源。
步骤S604,对解码后的第一视频数据和第二视频数据进行显示。
此步骤与步骤S504相同,在此不再详述。
在本实施例中,将第一队列中的第一编码视频数据以异步的方式放入解码器并进行解码,将第二队列中的第二编码视频数据以同步的方式放入解码器并进行解码,能够达到在第一视联网终端实时显示第一视频数据和第二视频数据的功能,同时,也能够节约第一视联网终端的内存占用,进一步提高视联网终端间通信的稳定性。
参考图7,图7示出了本发明的一种基于视联网终端的视频通信方法又一种实施例的步骤流程图,具体可以包括如下步骤:
步骤S701,接收所述第一视频采集终端发送的第一编码视频数据。
此步骤与步骤S501相同,在此不再详述。
步骤S702,接收所述视联网服务器发送的第二编码视频数据。
此步骤与步骤S502相同,在此不再详述。
步骤S703,配置解码后的所述第一视频数据和所述第二视频数据显示的画布。
在本发明实施例中,画布可以理解为视图,由于解码后的视频数据要显示在视图上,因此解码之前需要配置解码后的视频数据显示的视图大小。优选地,第一视联网终端和第二视联网终端为安卓系统终端,在配置解码后第一视频数据和第二视频数据显示的视图大小时,通过调用安卓系统的API,将要显示的第一视频数据和第二视频数据要显示的视图大小,传入到解码器,优选地,对于本地侧的第一视频数据可以选择视图大小为30%,对于远端侧的第二视频数据可以选择视图大小为100%,即铺满全屏。
步骤S704,对所述第一编码视频数据和所述第二编码视频数据进行解码。
在本发明实施例中,通过调用安卓系统的API,将第一视频数据和第二视频数据要显示的视图,传入到解码器后,调用安卓系统的Start方法开始解码。
步骤S705,将解码后的第一视频数据和第二视频数据显示在配置的画布上。
在本发明实施例中,根据第一视频数据和第二视频数据的画布配置情况,即根据第一视频数据和第二视频数据要显示的视图大小,在屏幕上显示相应的解码后的第一视频数据和第二视频数据。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
基于相同的技术构思,请参考图8,图8示出了本发明实施例的一种基于视联网终端的视频通信装置,所述装置应用于视频通信系统中的第一视联网终端,所述视频通信系统中还部署有视联网服务器,所述第一视联网终端外接有第一视频采集终端,所述第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据;所述的装置可以包括如下模块:
第一接收模块801,用于接收所述第一视频采集终端发送的第一编码视频数据;
第二接收模块802,用于接收所述视联网服务器发送的第二编码视频数据;
解码模块803,用于对所述第一编码视频数据和所述第二编码视频数据进行解码;
显示模块804,用于对解码后的第一视频数据和第二视频数据进行显示。
可选地,所述装置还包括如下模块:
配置模块,用于配置解码后的所述第一视频数据和所述第二视频数据显示的画布;
显示子模块,用于将解码后的第一视频数据和第二视频数据显示在配置的画布上。
请参考图9,图9示出了本发明实施例的一种基于视联网终端的视频通信装置另一种实施例的结构框图,所述装置应用于视频通信系统中的第一视联网终端,所述视频通信系统中还部署有视联网服务器,所述第一视联网终端外接有第一视频采集终端,所述第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据,视频通信系统中还部署有第二视联网终端,所述第二视联网终端外接有第二视频采集终端,所述第二视频采集终端能够对采集的视频数据进行编码得到第二编码视频数据,所述第二编码视频数据是由第二视频采集终端发送到第二视联网终端,再由第二视联网终端发送到视联网服务器的,所述装置具体可以包括如下模块:
第一接收模块901,用于接收所述第一视频采集终端发送的第一编码视频数据;
第二接收模块902,用于接收所述视联网服务器发送的第二编码视频数据;
解码模块903,用于对所述第一编码视频数据和所述第二编码视频数据进行解码;优选地,解码模块具体包括:
第一存入子模块9031,用于将所述第一编码视频数据实时存入第一队列;
第二存入子模块9032,用于将所述第二编码视频数据实时存入第二队列;
第一解码子模块9033,用于将所述第一队列中的所述第一编码视频数据以异步的方式放入解码器并进行解码;
第二解码子模块9034,用于将所述第二队列中的所述第二编码视频数据以同步的方式放入解码器进行解码;
显示模块904,用于对解码后的第一视频数据和第二视频数据进行显示。
本发明实施例还提供了一种基于视联网终端的视频通信装置,包括:
一个或多个处理器;和
其上存储有指令的一个或多个计算机可读介质,当由所述一个或多个处理器执行时,使得所述装置执行如本发明实施例任一所述的基于视联网终端的视频通信方法。
本发明实施例还提供了一种计算机可读存储介质,其存储的计算机程序使得处理器执行如本发明实施例所述的基于视联网终端的视频通信方法。
对于基于视联网终端的视频通信装置实施例而言,由于其与基于视联网终端的视频通信方法实施例基本相似,所以描述的比较简单,相关之处参见基于视联网终端的视频通信方法实施例的部分说明即可。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种基于视联网终端的视频通信方法、一种基于视联网终端的视频通信装置和一种计算机可读存储介质进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。

Claims (8)

1.一种基于视联网终端的视频通信方法,其特征在于,所述方法应用于视频通信系统中的第一视联网终端,所述视频通信系统中还部署有视联网服务器;所述第一视联网终端外接有第一视频采集终端;所述第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据;所述的方法包括:
接收所述第一视频采集终端发送的第一编码视频数据;
接收所述视联网服务器发送的第二编码视频数据;
对所述第一编码视频数据和所述第二编码视频数据进行解码,包括:将所述第一编码视频数据和所述第二编码视频数据分别实时存入第一队列和第二队列;将所述第一队列中的所述第一编码视频数据以异步的方式放入解码器并进行解码,将所述第二队列中的所述第二编码视频数据以同步的方式放入解码器并进行解码;
对解码后的第一视频数据和第二视频数据进行显示;
其中,所述同步的方式为:所述解码器循环的索取所述第二队列中的第二编码视频数据,如果所述第二编码视频数据为空,则进行阻塞等待,期间不能进行其他工作,占用内存资源;
所述异步的方式为:所述解码器循环的索取所述第一队列中的第一编码视频数据,如果所述第一编码视频数据为空,则不进行阻塞等待,期间能够进行其他工作,不占用内存资源。
2.根据权利要求1所述的方法,其特征在于,所述视频通信系统中还部署有第二视联网终端;所述第二视联网终端外接有第二视频采集终端;所述第二视频采集终端能够对采集的视频数据进行编码得到第二编码视频数据;所述第二编码视频数据是由第二视频采集终端发送到第二视联网终端,再由第二视联网终端发送到视联网服务器的。
3.根据权利要求1所述的方法,其特征在于,还包括:
配置解码后的所述第一视频数据和所述第二视频数据显示的画布;
所述对解码后的第一视频数据和第二视频数据进行显示,包括:
将解码后的第一视频数据和第二视频数据显示在配置的画布上。
4.一种基于视联网终端的视频通信装置,其特征在于,所述装置应用于视频通信系统中的第一视联网终端,所述视频通信系统中还部署有视联网服务器;所述第一视联网终端外接有第一视频采集终端;所述第一视频采集终端能够对采集的视频数据进行编码得到第一编码视频数据;所述的装置包括:
第一接收模块,用于接收所述第一视频采集终端发送的第一编码视频数据;
第二接收模块,用于接收所述视联网服务器发送的第二编码视频数据;
解码模块,用于对所述第一编码视频数据和所述第二编码视频数据进行解码,所述解码模块包括:第一存入子模块,用于将所述第一编码视频数据实时存入第一队列;第二存入子模块,用于将所述第二编码视频数据实时存入第二队列;第一解码子模块,用于将所述第一队列中的所述第一编码视频数据以异步的方式放入解码器并进行解码;第二解码子模块,用于将所述第二队列中的所述第二编码视频数据以同步的方式放入解码器进行解码;
显示模块,用于对解码后的第一视频数据和第二视频数据进行显示;
其中,所述同步的方式为:所述解码器循环的索取所述第二队列中的第二编码视频数据,如果所述第二编码视频数据为空,则进行阻塞等待,期间不能进行其他工作,占用内存资源;
所述异步的方式为:所述解码器循环的索取所述第一队列中的第一编码视频数据,如果所述第一编码视频数据为空,则不进行阻塞等待,期间能够进行其他工作,不占用内存资源。
5.根据权利要求4所述的装置,其特征在于,所述视频通信系统中还部署有第二视联网终端;所述第二视联网终端外接有第二视频采集终端;所述第二视频采集终端能够对采集的视频数据进行编码得到第二编码视频数据;所述第二编码视频数据是由第二视频采集终端发送到第二视联网终端,再由第二视联网终端发送到视联网服务器的。
6.根据权利要求4所述的装置,其特征在于,还包括:
配置模块,用于配置解码后的所述第一视频数据和所述第二视频数据显示的画布;
显示子模块,用于将解码后的第一视频数据和第二视频数据显示在配置的画布上。
7.一种基于视联网终端的视频通信装置,其特征在于,包括:
一个或多个处理器;和
其上存储有指令的一个或多个计算机可读介质,当所述指令由所述一个或多个处理器执行时,使得所述基于视联网终端的视频通信装置执行如权利要求1至3任一项所述的基于视联网终端的视频通信方法。
8.一种计算机可读存储介质,其特征在于,其存储的计算机程序使得处理器执行如权利要求1至3任一项所述的基于视联网终端的视频通信方法。
CN201910620272.4A 2019-07-10 2019-07-10 一种基于视联网终端的视频通信方法、装置及存储介质 Active CN110446069B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910620272.4A CN110446069B (zh) 2019-07-10 2019-07-10 一种基于视联网终端的视频通信方法、装置及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910620272.4A CN110446069B (zh) 2019-07-10 2019-07-10 一种基于视联网终端的视频通信方法、装置及存储介质

Publications (2)

Publication Number Publication Date
CN110446069A CN110446069A (zh) 2019-11-12
CN110446069B true CN110446069B (zh) 2021-08-06

Family

ID=68430089

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910620272.4A Active CN110446069B (zh) 2019-07-10 2019-07-10 一种基于视联网终端的视频通信方法、装置及存储介质

Country Status (1)

Country Link
CN (1) CN110446069B (zh)

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5842357B2 (ja) * 2011-03-25 2016-01-13 富士ゼロックス株式会社 画像処理装置及び画像処理プログラム
CN203167160U (zh) * 2013-03-04 2013-08-28 四川九洲电器集团有限责任公司 一种视频图像和遥测数据无线同步传输的系统
US9591254B2 (en) * 2015-03-26 2017-03-07 Qualcomm Incorporated Device and method for processing video data
CN108124158B (zh) * 2016-11-29 2019-04-26 视联动力信息技术股份有限公司 多媒体终端及多媒体终端的数据处理方法
CN108574816B (zh) * 2017-09-06 2020-08-25 视联动力信息技术股份有限公司 一种视联网终端以及基于视联网终端的通信方法、装置
CN108881794B (zh) * 2017-12-08 2019-11-19 视联动力信息技术股份有限公司 一种基于视联网终端的网络会议通信方法和装置

Also Published As

Publication number Publication date
CN110446069A (zh) 2019-11-12

Similar Documents

Publication Publication Date Title
CN109640029B (zh) 一种视频流上墙展示的方法和装置
CN109168064B (zh) 一种电子数据的同步显示方法和系统
CN110049271B (zh) 一种视联网会议信息展示方法及装置
CN109120879B (zh) 一种视频会议的处理方法和系统
CN110475090B (zh) 一种会议控制的方法和系统
CN110460804B (zh) 会议数据发送方法、系统、设备和计算机可读存储介质
CN110572607A (zh) 一种视频会议方法、系统及装置和存储介质
CN110049273B (zh) 一种基于视联网的会议录制方法和中转服务器
CN109246135B (zh) 一种流媒体数据的获取方法和系统
CN111131754A (zh) 一种会议管理系统的控制分屏方法及装置
CN110049268B (zh) 一种可视电话连接方法及装置
CN109802952B (zh) 监控数据同步方法和装置
CN109547727B (zh) 数据缓存方法和装置
CN109005378B (zh) 一种视频会议的处理方法和系统
CN109302384B (zh) 一种数据的处理方法和系统
CN110769179B (zh) 一种音视频数据流的处理方法和系统
CN110769297A (zh) 一种音视频数据的处理方法和系统
CN111212255B (zh) 监控资源获取方法、装置及计算机可读存储介质
CN110049069B (zh) 一种数据获取方法及装置
CN110557594B (zh) 一种视频通话的处理方法、装置及存储介质
CN110401807B (zh) 一种可视电话系统的通信方法及装置
CN110233872B (zh) 一种基于视联网的数据传输方法和视联网终端
CN110087020B (zh) 一种iOS设备进行视联网会议的实现方法及系统
CN110177244B (zh) 一种轮询会议终端的方法及系统
CN109788231B (zh) 可视电话业务处理方法和装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant