CN112616024A - Usb摄像头数据获取方法、装置、电子设备和存储介质 - Google Patents

Usb摄像头数据获取方法、装置、电子设备和存储介质 Download PDF

Info

Publication number
CN112616024A
CN112616024A CN202011634502.1A CN202011634502A CN112616024A CN 112616024 A CN112616024 A CN 112616024A CN 202011634502 A CN202011634502 A CN 202011634502A CN 112616024 A CN112616024 A CN 112616024A
Authority
CN
China
Prior art keywords
shared memory
usb camera
image data
memory
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.)
Pending
Application number
CN202011634502.1A
Other languages
English (en)
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.)
Deep Blue Technology Shanghai Co Ltd
Original Assignee
Deep Blue Technology Shanghai 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 Deep Blue Technology Shanghai Co Ltd filed Critical Deep Blue Technology Shanghai Co Ltd
Priority to CN202011634502.1A priority Critical patent/CN112616024A/zh
Publication of CN112616024A publication Critical patent/CN112616024A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N23/00Cameras or camera modules comprising electronic image sensors; Control thereof
    • H04N23/60Control of cameras or camera modules
    • H04N23/665Control of cameras or camera modules involving internal camera communication with the image sensor, e.g. synchronising or multiplexing SSIS control signals
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/544Buffers; Shared memory; Pipes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/76Television signal recording
    • H04N5/765Interface circuits between an apparatus for recording and another apparatus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/76Television signal recording
    • H04N5/907Television signal recording using static stores, e.g. storage tubes or semiconductor memories

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Studio Devices (AREA)

Abstract

本申请实施例涉及数据传输技术领域,提供了一种USB摄像头数据获取方法、装置、电子设备和存储介质,所述方法包括:监听USB摄像头的设备状态;若所述USB摄像头为初始化状态,则基于所述写内存服务进程创建共享内存;基于所述写内存服务进程,通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据,并将所述图像数据存入所述共享内存,以供各个客户端进程从所述共享内存中读取所述图像数据。本申请提供的USB摄像头数据获取方法、装置、电子设备和存储介质,实现了USB摄像头的数据分流,且单次数据的获取过程中,仅需一次数据编解码,即可实现数据分流,提高了数据获取的效率,降低了数据获取的性能损耗。

Description

USB摄像头数据获取方法、装置、电子设备和存储介质
技术领域
本申请涉及数据传输技术领域,尤其涉及一种USB摄像头数据获取方法、装置、电子设备和存储介质。
背景技术
USB摄像头可以利用通用的USB接口连接到各种终端设备上,例如个人电脑,尤其是支持通过USB-OTG接口连接到智能移动终端上,得到了广泛应用。为了对摄像头采集的数据进行处理,例如对采集的图像数据进行图像分析,获取图像中的目标信息,又或者通过Onvif协议将USB摄像头采集的图像数据传递给远端的NVR (Network Video Recorder,网络视频录像机)设备。
目前读取USB摄像头媒体数据的方法通常是客户端进程通过使用USB端口读取摄像头采集的媒体流数据。然而该数据获取方式中, USB摄像头的端口会被当前获取数据的客户端进程独占,在这个过程中其他需要获取摄像头媒体数据的客户端进程将无法读取摄像头采集的数据。例如,当客户端进程A利用USB摄像头对应的USB端口进行数据读取时,该USB端口已被客户端进程A独占,其他客户端进程无法申请该USB端口号,便无从读取摄像头的数据。因此,为了使得多个客户端进程可以同时获取摄像头实时采集的媒体数据,需要将读取到USB摄像头的数据进行分流。
虽然目前可以使用RTSP协议提供的多播方式进行数据分流,然而,使用RTSP协议进行多播时存在多次数据编解码操作,性能损耗较大,影响下游任务,例如图像分析任务的处理效率。
发明内容
本申请提供一种USB摄像头数据获取方法、装置、电子设备和存储介质,以实现USB摄像头的数据分流,并降低数据获取的性能损耗。
本申请提供一种USB摄像头数据获取方法,包括:
监听USB摄像头的设备状态;
若所述USB摄像头为初始化状态,则基于写内存服务进程创建共享内存;
基于所述写内存服务进程,通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据,并将所述图像数据存入所述共享内存,以供各个客户端进程从所述共享内存中读取所述图像数据。
根据本申请提供的一种USB摄像头数据获取方法,所述若所述 USB摄像头为初始化状态,则基于写内存服务进程创建共享内存,之后还包括:
将所述共享内存的物理地址映射到客户端进程的逻辑地址空间,得到对应所述客户端进程的共享内存逻辑地址,以供所述客户端进程根据所述共享内存逻辑地址读取所述共享内存中存储的图像数据。
根据本申请提供的一种USB摄像头数据获取方法,还包括:
获取当前系统内存的空间占用率;
若当前系统内存的空间占用率高于预设阈值,则结束所述写内存服务进程,并清空所述共享内存,以及删除对应的共享内存逻辑地址。
根据本申请提供的一种USB摄像头数据获取方法,所述监听 USB摄像头的设备状态,具体包括:
监听所述USB摄像头的设备状态,并获取所述USB摄像头的配置信息;
所述配置信息包括所述USB摄像头采集图像的帧率以及采集的图像分辨率。
根据本申请提供的一种USB摄像头数据获取方法,所述共享内存的存储空间是基于所述USB摄像头采集的图像分辨率确定的。
根据本申请提供的一种USB摄像头数据获取方法,所述通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据,并将所述图像数据存入所述共享内存,具体包括:
基于所述USB摄像头的图像采集帧率,通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据;
若所述共享内存的存储空间已满,则删除所述共享内存中存储时间最早的若干个图像数据,并将当前读取的图像数据存入所述共享内存中。
本申请还提供一种USB摄像头数据获取方法,包括:
开启客户端进程;
基于所述客户端进程,从共享内存中读取USB摄像头采集的图像数据;
其中,所述图像数据是写内存服务进程通过所述USB摄像头的端口读取并存入到所述共享内存的。
根据本申请提供的一种USB摄像头数据获取方法,所述从共享内存中读取USB摄像头采集的图像数据,具体包括:
将所述共享内存的共享内存逻辑地址转换为物理地址;
基于所述共享内存的物理地址,读取所述共享内存中存储的图像数据。
本申请还提供一种USB摄像头数据获取装置,包括:
设备监听单元,用于监听USB摄像头的设备状态;
共享内存创建单元,用于若所述USB摄像头为初始化状态,则基于写内存服务进程创建共享内存;
数据获取单元,用于基于所述写内存服务进程,读取所述USB 摄像头采集的图像数据,并将所述图像数据存入所述共享内存,以供各个客户端进程从所述共享内存中读取所述图像数据。
根据本申请提供的一种USB摄像头数据获取装置,还包括:
地址空间映射单元,用于将所述共享内存的物理地址映射到客户端进程的逻辑地址空间,得到对应所述客户端进程的共享内存逻辑地址,以供所述客户端进程根据所述共享内存逻辑地址读取所述共享内存中存储的图像数据。
本申请还提供一种USB摄像头数据获取装置,包括:
客户端进程开启单元,用于开启客户端进程;
数据读取单元,用于基于所述客户端进程,从共享内存中读取 USB摄像头采集的图像数据;
其中,所述图像数据是写内存服务进程通过所述USB摄像头的端口读取并存入到所述共享内存的。
根据本申请提供的一种USB摄像头数据获取装置,
所述数据获取单元,具体包括:
地址转换单元,用于将所述共享内存的共享内存逻辑地址转换为物理地址;
读取单元,用于基于所述共享内存的物理地址,读取所述共享内存中存储的图像数据。
本申请还提供一种电子设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述任一种所述USB摄像头数据获取方法的步骤。
本申请还提供一种非暂态计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现如上述任一种所述USB 摄像头数据获取方法的步骤。
本申请提供的USB摄像头数据获取方法、装置、电子设备和存储介质,通过创建共享内存,并基于写内存服务进程,通过USB摄像头的端口读取USB摄像头采集的图像数据,并将图像数据存入共享内存,以供各个客户端进程从共享内存中读取图像数据,使得多个客户端进程可以同时读取共享内存中存储的图像数据,实现了USB 摄像头的数据分流,且单次数据的获取过程中,仅需一次数据编解码,即可实现数据分流,提高了数据获取的效率,降低了数据获取的性能损耗。
附图说明
为了更清楚地说明本申请或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作一简单地介绍,显而易见地,下面描述中的附图是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请提供的USB摄像头数据获取方法的流程示意图之一;
图2为本申请提供的内存空间管理方法的流程示意图;
图3为本申请提供的数据存储方法的流程示意图;
图4为本申请提供的USB摄像头数据获取方法的流程示意图之二;
图5为本申请提供的数据获取方法的流程示意图;
图6为本申请提供的USB摄像头数据获取方法的流程示意图之三;
图7为本申请提供的数据流向示意图;
图8为本申请提供的USB摄像头数据获取装置的结构示意图之一;
图9为本申请提供的内存空间管理单元的结构示意图;
图10为本申请提供的数据获取单元的结构示意图;
图11为本申请提供的USB摄像头数据获取装置的结构示意图之二;
图12为本申请提供的数据读取单元的结构示意图;
图13为本申请提供的电子设备的结构示意图。
具体实施方式
为使本申请的目的、技术方案和优点更加清楚,下面将结合本申请中的附图,对本申请中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
图1为本申请实施例提供的USB摄像头数据获取方法的流程示意图之一,如图1所示,该方法应用于终端设备的中间件中,该方法包括:
步骤110,监听USB摄像头的设备状态;
步骤120,若USB摄像头为初始化状态,则基于写内存服务进程创建共享内存;
步骤130,基于写内存服务进程,通过USB摄像头的端口读取 USB摄像头采集的图像数据,并将图像数据存入共享内存,以供各个客户端进程从共享内存中读取图像数据。
具体地,本申请实施例提供的方法应用于终端系统的中间件中。其中,中间件是指终端设备中介于应用系统和系统软件之间的一类软件,中间件可以使用系统软件所提供的基础服务,衔接应用系统的各个部分或不同的应用,从而达到资源共享、功能共享的目的。在中间件中创建并开启写内存服务进程。其中,该写内存服务进程为在系统后台一直运行的系统进程,用于对内存进行数据写入操作。
USB摄像头可以通过USB接口连接到终端设备上,当USB摄像头连接到终端设备上之后会开始进行USB设备初始化,并在初始化完毕后开始采集图像数据。因此,为了在摄像头开始采集图像数据时实时获取其采集的图像数据以供客户端应用对其进行处理,可以对USB摄像头的设备状态进行监听。此处,对USB摄像头进行监听,一方面是为了获知当前USB摄像头是否连接到终端设备上,另一方面是为了获取USB摄像头当前的设备状态,以确定进行图像数据读取的时机。由于终端设备上可能存在多个USB接口,以接纳多个USB 设备的连接,因此为了从多个USB设备中确定USB摄像头的设备状态,可以根据连接到终端设备上的USB设备的设备名称,确定USB 摄像头。
若USB摄像头为初始化状态,即USB摄像头即将开始采集图像数据,此时,可以基于写内存服务进程在系统内存中开辟出一块内存空间,作为共享内存。其中,共享内存中的数据可被多个客户端进程共享,一旦共享内存中存储的数据发生更新,则多个客户端进程可以同时感知到该更新,并获取到最新的数据。需要说明的是,各个客户端进程与写内存服务进程运行于同一个终端设备中。
随后,USB摄像头会不断采集图像数据,并等待写内存服务进程读取该图像数据。与此同时,写内存服务进程会通过USB摄像头的USB端口读取其采集的图像数据,并将读取的图像数据按顺序存储到共享内存中,以供各个客户端进程从该共享内存中读取上述图像数据。由于USB摄像头采集的图像数据被写内存服务进程读取并存入到了共享内存中,而共享内存可以接受多个进程同时读取数据的请求,因此多个客户端进程可以同时读取共享内存中存储的图像数据,实现了USB摄像头的数据分流。此外,由于仅由写内存服务进程通过USB端口读取USB摄像头采集的图像数据,因此单次数据的获取过程中,仅需一次数据编解码,即可实现数据分流,提高了数据获取的效率,降低了数据获取的性能损耗。
本申请实施例提供的方法,通过创建共享内存,并基于写内存服务进程,通过USB摄像头的端口读取USB摄像头采集的图像数据,并将图像数据存入共享内存,以供各个客户端进程从共享内存中读取图像数据,使得多个客户端进程可以同时读取共享内存中存储的图像数据,实现了USB摄像头的数据分流,且单次数据的获取过程中,仅需一次数据编解码,即可实现数据分流,提高了数据获取的效率,降低了数据获取的性能损耗。
基于上述实施例,步骤130之后还包括:
将共享内存的物理地址映射到客户端进程的逻辑地址空间,得到对应客户端进程的共享内存逻辑地址,以供客户端进程根据共享内存逻辑地址读取共享内存中存储的图像数据。
具体地,客户端进程无法直接根据共享内存的物理地址进行内存访问,并且在操作系统中,每个进程都有属于该进程本身的进程控制块和地址空间,并且都有与其对应的页表,用于将该进程的地址空间内的虚拟地址与内存的物理地址进行映射。因此,为了使多个客户端进程可以读取共享内存中存储的数据,可以将共享内存的物理地址映射到各个客户端进程的逻辑地址空间,得到对应客户端进程的共享内存逻辑地址。即,根据各个客户端进程的逻辑地址空间的布局方式,将共享内存的物理地址分别映射到各个客户端进程的逻辑地址空间中。基于映射得到的对应各个客户端进程的共享内存逻辑地址,各个客户端进程可以利用自己的页表将对应的共享内存逻辑地址转换为物理地址,且各个客户端进程转换得到的物理地址均对应系统内存中的同一块空间,即共享内存。基于转换得到的物理地址,各个客户端进程即可访问共享内存,并读取其中存储的图像数据。
本发明实施例提供的方法,通过将共享内存的物理地址映射到客户端进程的逻辑地址空间,得到对应客户端进程的共享内存逻辑地址,使得客户端进程可以根据共享内存逻辑地址读取共享内存中存储的图像数据。
基于上述任一实施例,图2为本申请实施例提供的内存空间管理方法的流程示意图,如图2所示,该方法还包括:
步骤210,获取当前系统内存的空间占用率;
步骤220,若当前系统内存的空间占用率高于预设阈值,则结束写内存服务进程,并清空共享内存,以及删除对应的共享内存逻辑地址。
具体地,当终端设备上的系统内存空间较为紧张时,为了避免终端设备上运行的其他进程无法正常工作,此时可以将共享内存占用的内存空间让渡出来,以供其他更重要的进程使用。因此,可以监控当前系统内存的空间占用率。若获取得到的当前系统内存的空间占用率高于预设阈值,例如90%,此时系统内存空间已十分紧张,因此可以暂停通过共享内存读取USB摄像头数据的方式,结束写内存服务进程,并清空共享内存中存储的图像数据,以归还内存空间。在结束写内存服务进程并清空共享内存后,各个客户端进程无法再通过共享内存读取USB摄像头采集的图像数据,因此也可以将各个客户端进程对应的共享内存逻辑地址删除。
本发明实施例提供的方法,通过获取当前系统内存的空间占用率,若当前系统内存的空间占用率高于预设阈值,则结束写内存服务进程,并清空共享内存,以及删除对应的共享内存逻辑地址,避免数据获取影响整个终端设备的正常运行。
基于上述任一实施例,步骤110具体包括:
监听USB摄像头的设备状态,并获取USB摄像头的配置信息;
其中,配置信息包括USB摄像头采集图像的帧率以及采集的图像分辨率。
具体地,在监听USB摄像头的设备状态时,还可以获取USB摄像头的配置信息,以根据具体连接到终端设备上的USB摄像头的具体配置情况,调整数据获取过程中的相应配置,从而提高数据获取的准确性。其中,配置信息包括USB摄像头采集图像的帧率以及采集的图像分辨率。此处,采集图像的帧率为USB摄像头每秒采集的图像数量,可以体现USB摄像头采集图像的速率,帧率越大,USB摄像头采集图像的速率越快。而采集的图像分辨率则可以体现USB摄像头采集的图像清晰度以及图像大小,图像分辨率越大,图像越清晰且图像所需的存储空间越大。
基于上述任一实施例,共享内存的存储空间是基于USB摄像头采集的图像分辨率确定的。
具体地,由于图像分辨率越大,图像所需的存储空间越大,为了避免在将USB摄像头采集的图像数据存储到共享内存中时,由于共享内存存储空间有限,无法将当前采集的图像数据存储到共享内存中,或是将尚未被客户端进程读取的图像数据删除,导致在数据存储过程中丢帧,可以基于USB摄像头采集的图像分辨率确定共享内存的存储空间大小。其中,图像分辨率越高,共享内存的存储空间越大。由于共享内存的存储空间是基于USB摄像头采集的图像分辨率确定的,因此共享内存的存储空间既能满足数据存储的需求,也不会因为分配过大存储空间从而影响其他进程的工作。
本申请实施例提供的方法,基于USB摄像头采集的图像分辨率确定共享内存的存储空间大小,可以避免在数据存储过程中丢帧,同时避免分配过大存储空间从而影响其他进程的工作。
基于上述任一实施例,图3为本申请实施例提供的数据存储方法的流程示意图,如图3所示,步骤130具体包括:
步骤131,基于USB摄像头的图像采集帧率,通过USB摄像头的端口读取USB摄像头采集的图像数据;
步骤132,若共享内存的存储空间已满,则删除共享内存中存储时间最早的若干个图像数据,并将当前读取的图像数据存入共享内存中。
具体地,帧率越大,USB摄像头采集图像的速率越快,为了避免在数据获取过程中由于数据读取速率太慢丢帧,需要以更快的速率进行数据读取。因此,可以以USB摄像头的图像采集帧率为数据读取速率,通过USB摄像头的端口读取USB摄像头采集的图像数据,以跟上图像采集的速率。若当前共享内存的存储空间已满,则可以删除共享内存中存储时间最早的若干个图像数据,以腾出空间存放当前读取的图像数据。由于共享内存的空间足够大,在逐渐存满共享内存的存储空间过程中,最早存入共享内存的图像数据已被各个客户端进程读取,因此可以删除存储时间最早的若干个图像数据,并将当前读取的图像数据存入共享内存中。
本申请实施例提供的方法,基于USB摄像头的图像采集帧率,通过USB摄像头的端口读取USB摄像头采集的图像数据,可以避免在数据读取过程中丢帧。
基于上述任一实施例,图4为本申请实施例提供的USB摄像头数据获取方法的流程示意图之二,如图4所示,该方法应用于终端设备的客户端中,该方法包括:
步骤410,开启客户端进程;
步骤420,基于客户端进程,从共享内存中读取USB摄像头采集的图像数据;
其中,图像数据是写内存服务进程通过USB摄像头的端口读取并存入到共享内存的。
具体地,本申请实施例提供的方法应用于终端设备的客户端应用中。首先,开启客户端进程。其中,每个客户端应用分别对应一个客户端进程,例如onvif server进程,算法分析进程等,客户端进程用于对共享内存进行数据读取操作。
当客户端进程感知到共享内存中的数据发生了更新时,可以从共享内存中读取USB摄像头采集的图像数据,以进行后续处理。其中,图像数据是写内存服务进程通过USB摄像头的端口读取并存入到共享内存的。此处,写内存服务进程会预先在系统内存中开辟出一块内存空间,作为共享内存。随后,USB摄像头开始采集图像数据,并等待写内存服务进程读取该图像数据。与此同时,写内存服务进程会通过USB摄像头的USB端口读取其采集的图像数据,并将读取的图像数据按顺序存储到共享内存中。然后,客户端进程即可从该共享内存中读取上述图像数据。由于USB摄像头采集的图像数据被写内存服务进程读取并存入到了共享内存中,因此客户端进程可以读取共享内存中存储的图像数据,实现USB摄像头的数据分流。此外,由于仅由写内存服务进程通过USB端口读取USB摄像头采集的图像数据,而客户端进程不与USB摄像头直接进行数据交互,因此单次数据的获取过程中,仅需一次数据编解码,即可实现数据分流,提高了数据获取的效率,降低了数据获取的性能损耗。
本申请实施例提供的方法,基于客户端进程,从共享内存中读取 USB摄像头采集的图像数据,其中,图像数据是写内存服务进程通过USB摄像头的端口读取并存入到共享内存的,使得客户端进程可以读取共享内存中存储的图像数据,实现了USB摄像头的数据分流,且单次数据的获取过程中,仅需一次数据编解码,即可实现数据分流,提高了数据获取的效率,降低了数据获取的性能损耗。
基于上述任一实施例,图5为本申请实施例提供的数据获取方法的流程示意图,如图5所示,步骤420具体包括:
步骤421,将共享内存的共享内存逻辑地址转换为物理地址;
步骤422,基于共享内存的物理地址,读取共享内存中存储的图像数据。
具体地,为了使客户端进程可以读取共享内存中存储的数据,可以将该客户端进程对应的共享内存逻辑地址转换为物理地址。即,根据各个客户端进程的逻辑地址空间的布局方式,将客户端进程对应的共享内存逻辑地址转换为共享内存的物理地址。基于转换得到的共享内存的物理地址,客户端进程可以在内存中定位到共享内存,并读取其中存储的图像数据。
本发明实施例提供的方法,通过共享内存的共享内存逻辑地址转换为物理地址,基于共享内存的物理地址,读取共享内存中存储的图像数据,使得客户端进程可以根据共享内存逻辑地址读取共享内存中存储的图像数据。
基于上述任一实施例,图6为本申请实施例提供的USB摄像头数据获取方法的流程示意图之三,如图6所示,该方法包括:
当USB摄像头开启且连接到终端设备上时,USB摄像头会开始设备初始化。与此同时,中间件会开启写内存服务进程,并创建共享内存。
共享内存创建完毕后,将共享内存的物理地址映射到各个客户端进程的逻辑地址空间中,得到对应各个客户端进程的共享内存逻辑地址。本申请实施例中客户端进程为onvif server进程和算法分析进程。
USB摄像头开始采集图像数据,并等待写内存服务进程读取该图像数据。写内存服务进程通过USB摄像头的端口从USB设备中读取图像数据,并将读取的数据写入共享内存。然后,判断写内存服务进程是否存活,若存活则重复执行上述数据读取和数据写入的操作;若写内存服务进程已被结束,则删除共享内存的物理地址映射的共享内存逻辑地址。当写内存服务进程将读取的USB摄像头采集的图像数据写入到共享内存后,onvif server进程和算法分析进程均可以根据对应的共享内存逻辑地址从共享内存中读取图像数据,并进行相应的数据处理操作。
以网络视频监控为例,图7为本申请实施例提供的数据流向示意图,如图7所示,当USB摄像头采集到图像数据后,图像数据会被中间件上的写内存服务进程读取并存储到共享内存中,然后各个客户端进程,即Onvif Server进程和算法分析进程可以从共享内存中读取图像数据,实现数据分流。其中,流向Onvif Server进程的数据流视为主码流,而流向算法分析进程的数据流视为副码流。随后,Onvif Server进程可以将自身读取的图像数据,以及算法分析进程根据读取的图像数据进行相应处理后的数据,通过RTSP协议传输至远端的 NVR设备上。
下面对本申请提供的USB摄像头数据获取装置进行描述,下文描述的USB摄像头数据获取装置与上文描述的USB摄像头数据获取方法可相互对应参照。
基于上述任一实施例,图8为本申请实施例提供的USB摄像头数据获取装置的结构示意图之一,如图8所示,该装置包括:设备监听单元810、共享内存创建单元820和数据获取单元830。
其中,设备监听单元810用于监听USB摄像头的设备状态;
共享内存创建单元820用于若USB摄像头为初始化状态,则基于写内存服务进程创建共享内存;
数据获取单元830用于基于写内存服务进程,读取USB摄像头采集的图像数据,并将图像数据存入共享内存,以供各个客户端进程从共享内存中读取图像数据。
本申请实施例提供的装置,通过创建共享内存,并基于写内存服务进程,通过USB摄像头的端口读取USB摄像头采集的图像数据,并将图像数据存入共享内存,以供各个客户端进程从共享内存中读取图像数据,使得多个客户端进程可以同时读取共享内存中存储的图像数据,实现了USB摄像头的数据分流,且单次数据的获取过程中,仅需一次数据编解码,即可实现数据分流,提高了数据获取的效率,降低了数据获取的性能损耗。
基于上述任一实施例,该装置还包括:
地址空间映射单元,用于将共享内存的物理地址映射到客户端进程的逻辑地址空间,得到对应客户端进程的共享内存逻辑地址,以供客户端进程根据共享内存逻辑地址读取共享内存中存储的图像数据。
本发明实施例提供的装置,通过将共享内存的物理地址映射到客户端进程的逻辑地址空间,得到对应客户端进程的共享内存逻辑地址,使得客户端进程可以根据共享内存逻辑地址读取共享内存中存储的图像数据。
基于上述任一实施例,该装置还包括内存空间管理单元,图9为本申请实施例提供的内存空间管理单元的结构示意图,如图9所示,内存空间管理单元具体包括:
空间占用率获取单元8401,用于获取当前系统内存的空间占用率;
清空单元8402,用于若当前系统内存的空间占用率高于预设阈值,则结束写内存服务进程,并清空共享内存,以及删除对应的共享内存逻辑地址。
本发明实施例提供的装置,通过获取当前系统内存的空间占用率,若当前系统内存的空间占用率高于预设阈值,则结束写内存服务进程,并清空共享内存,以及删除对应的共享内存逻辑地址,避免数据获取影响整个终端设备的正常运行。
基于上述任一实施例,设备监听单元810具体用于:
监听USB摄像头的设备状态,并获取USB摄像头的配置信息;
其中,配置信息包括USB摄像头采集图像的帧率以及采集的图像分辨率。
基于上述任一实施例,共享内存的存储空间是基于USB摄像头采集的图像分辨率确定的。
本申请实施例提供的装置,基于USB摄像头采集的图像分辨率确定共享内存的存储空间大小,可以避免在数据存储过程中丢帧,同时避免分配过大存储空间从而影响其他进程的工作。
基于上述任一实施例,图10为本申请实施例提供的数据获取单元的结构示意图,如图10所示,数据获取单元830具体包括:
USB端口读取单元831,用于基于USB摄像头的图像采集帧率,通过USB摄像头的端口读取USB摄像头采集的图像数据;
写入单元832,用于若共享内存的存储空间已满,则删除共享内存中存储时间最早的若干个图像数据,并将当前读取的图像数据存入共享内存中。
本申请实施例提供的装置,基于USB摄像头的图像采集帧率,通过USB摄像头的端口读取USB摄像头采集的图像数据,可以避免在数据读取过程中丢帧。
基于上述任一实施例,图11为本申请实施例提供的USB摄像头数据获取装置的结构示意图之二,如图11所示,该装置包括:客户端进程开启单元1110和数据读取单元1120。
其中,客户端进程开启单元1110用于开启客户端进程;
数据读取单元1120用于基于客户端进程,从共享内存中读取 USB摄像头采集的图像数据;
其中,图像数据是写内存服务进程通过USB摄像头的端口读取并存入到共享内存的。
本申请实施例提供的装置,基于客户端进程,从共享内存中读取 USB摄像头采集的图像数据,其中,图像数据是写内存服务进程通过USB摄像头的端口读取并存入到共享内存的,使得客户端进程可以读取共享内存中存储的图像数据,实现了USB摄像头的数据分流,且单次数据的获取过程中,仅需一次数据编解码,即可实现数据分流,提高了数据获取的效率,降低了数据获取的性能损耗。
基于上述任一实施例,图12为本申请实施例提供的数据读取单元的结构示意图,如图12所示,数据读取单元1120具体包括:
地址转换单元1121,用于将共享内存的共享内存逻辑地址转换为物理地址;
读取单元1122,用于基于共享内存的物理地址,读取共享内存中存储的图像数据。
本发明实施例提供的装置,通过共享内存的共享内存逻辑地址转换为物理地址,基于共享内存的物理地址,读取共享内存中存储的图像数据,使得客户端进程可以根据共享内存逻辑地址读取共享内存中存储的图像数据。
本申请实施例提供的USB摄像头数据获取装置用于执行上述 USB摄像头数据获取方法,其实施方式与本申请提供的USB摄像头数据获取方法的实施方式一致,且可以达到相同的有益效果,此处不再赘述。
图13示例了一种电子设备的实体结构示意图,如图13所示,该电子设备可以包括:处理器(processor)1310、通信接口(Communications Interface)1320、存储器(memory)1330和通信总线1340,其中,处理器1310,通信接口1320,存储器1330通过通信总线1340完成相互间的通信。处理器1310可以调用存储器1330中的逻辑指令,以执行 USB摄像头数据获取方法,该方法包括:监听USB摄像头的设备状态;若所述USB摄像头为初始化状态,则基于所述写内存服务进程创建共享内存;基于所述写内存服务进程,通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据,并将所述图像数据存入所述共享内存,以供各个客户端进程从所述共享内存中读取所述图像数据。
此外,上述的存储器1330中的逻辑指令可以通过软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
本申请实施例提供的电子设备中的处理器1310可以调用存储器 1330中的逻辑指令,实现上述USB摄像头数据获取方法,其实施方式与本申请提供的USB摄像头数据获取方法的实施方式一致,且可以达到相同的有益效果,此处不再赘述。
另一方面,本申请还提供一种计算机程序产品,下面对本申请提供的计算机程序产品进行描述,下文描述的计算机程序产品与上文描述的USB摄像头数据获取方法可相互对应参照。
所述计算机程序产品包括存储在非暂态计算机可读存储介质上的计算机程序,所述计算机程序包括程序指令,当所述程序指令被计算机执行时,计算机能够执行上述各方法所提供的USB摄像头数据获取方法,该方法包括:监听USB摄像头的设备状态;若所述USB摄像头为初始化状态,则基于所述写内存服务进程创建共享内存;基于所述写内存服务进程,通过所述USB摄像头的端口读取所述USB 摄像头采集的图像数据,并将所述图像数据存入所述共享内存,以供各个客户端进程从所述共享内存中读取所述图像数据。
本申请实施例提供的计算机程序产品被执行时,实现上述USB 摄像头数据获取方法,其实施方式与本申请提供的USB摄像头数据获取方法的实施方式一致,且可以达到相同的有益效果,此处不再赘述。
又一方面,本申请还提供一种非暂态计算机可读存储介质,下面对本申请提供的非暂态计算机可读存储介质进行描述,下文描述的非暂态计算机可读存储介质与上文描述的USB摄像头数据获取方法可相互对应参照。
本申请还提供一种非暂态计算机可读存储介质,其上存储有计算机程序,该计算机程序被处理器执行时实现以执行上述各提供的USB 摄像头数据获取方法,该方法包括:监听USB摄像头的设备状态;若所述USB摄像头为初始化状态,则基于所述写内存服务进程创建共享内存;基于所述写内存服务进程,通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据,并将所述图像数据存入所述共享内存,以供各个客户端进程从所述共享内存中读取所述图像数据。
本申请实施例提供的非暂态计算机可读存储介质上存储的计算机程序被执行时,实现上述USB摄像头数据获取方法,其实施方式与本申请提供的USB摄像头数据获取方法的实施方式一致,且可以达到相同的有益效果,此处不再赘述。
以上所描述的装置实施例仅仅是示意性的,其中所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。本领域普通技术人员在不付出创造性的劳动的情况下,即可以理解并实施。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到各实施方式可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件。基于这样的理解,上述技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如ROM/RAM、磁碟、光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行各个实施例或者实施例的某些部分所述的方法。
最后应说明的是:以上实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围。

Claims (14)

1.一种USB摄像头数据获取方法,其特征在于,该方法应用于中间件中,包括:
监听USB摄像头的设备状态;
若所述USB摄像头为初始化状态,则基于写内存服务进程创建共享内存;
基于所述写内存服务进程,通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据,并将所述图像数据存入所述共享内存,以供各个客户端进程从所述共享内存中读取所述图像数据。
2.根据权利要求1所述的USB摄像头数据获取方法,其特征在于,所述若所述USB摄像头为初始化状态,则基于写内存服务进程创建共享内存,之后还包括:
将所述共享内存的物理地址映射到客户端进程的逻辑地址空间,得到对应所述客户端进程的共享内存逻辑地址,以供所述客户端进程根据所述共享内存逻辑地址读取所述共享内存中存储的图像数据。
3.根据权利要求2所述的USB摄像头数据获取方法,其特征在于,还包括:
获取当前系统内存的空间占用率;
若当前系统内存的空间占用率高于预设阈值,则结束所述写内存服务进程,并清空所述共享内存,以及删除对应的共享内存逻辑地址。
4.根据权利要求1所述的USB摄像头数据获取方法,其特征在于,所述监听USB摄像头的设备状态,具体包括:
监听所述USB摄像头的设备状态,并获取所述USB摄像头的配置信息;
所述配置信息包括所述USB摄像头采集图像的帧率以及采集的图像分辨率。
5.根据权利要求4所述的USB摄像头数据获取方法,其特征在于,所述共享内存的存储空间是基于所述USB摄像头采集的图像分辨率确定的。
6.根据权利要求4所述的USB摄像头数据获取方法,其特征在于,所述通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据,并将所述图像数据存入所述共享内存,具体包括:
基于所述USB摄像头的图像采集帧率,通过所述USB摄像头的端口读取所述USB摄像头采集的图像数据;
若所述共享内存的存储空间已满,则删除所述共享内存中存储时间最早的若干个图像数据,并将当前读取的图像数据存入所述共享内存中。
7.一种USB摄像头数据获取方法,其特征在于,该方法应用于客户端中,包括:
开启客户端进程;
基于所述客户端进程,从共享内存中读取USB摄像头采集的图像数据;
其中,所述图像数据是写内存服务进程通过所述USB摄像头的端口读取并存入到所述共享内存的。
8.根据权利要求7所述的USB摄像头数据获取方法,其特征在于,所述从共享内存中读取USB摄像头采集的图像数据,具体包括:
将所述共享内存的共享内存逻辑地址转换为物理地址;
基于所述共享内存的物理地址,读取所述共享内存中存储的图像数据。
9.一种USB摄像头数据获取装置,其特征在于,包括:
设备监听单元,用于监听USB摄像头的设备状态;
共享内存创建单元,用于若所述USB摄像头为初始化状态,则基于写内存服务进程创建共享内存;
数据获取单元,用于基于所述写内存服务进程,读取所述USB摄像头采集的图像数据,并将所述图像数据存入所述共享内存,以供各个客户端进程从所述共享内存中读取所述图像数据。
10.根据权利要求8所述的USB摄像头数据获取装置,其特征在于,还包括:
地址空间映射单元,用于将所述共享内存的物理地址映射到客户端进程的逻辑地址空间,得到对应所述客户端进程的共享内存逻辑地址,以供所述客户端进程根据所述共享内存逻辑地址读取所述共享内存中存储的图像数据。
11.一种USB摄像头数据获取装置,其特征在于,包括:
客户端进程开启单元,用于开启客户端进程;
数据读取单元,用于基于所述客户端进程,从共享内存中读取USB摄像头采集的图像数据;
其中,所述图像数据是写内存服务进程通过所述USB摄像头的端口读取并存入到所述共享内存的。
12.根据权利要求11所述的USB摄像头数据获取装置,其特征在于,所述数据获取单元,具体包括:
地址转换单元,用于将所述共享内存的共享内存逻辑地址转换为物理地址;
读取单元,用于基于所述共享内存的物理地址,读取所述共享内存中存储的图像数据。
13.一种电子设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求1至6任一项或如权利要求7或8所述USB摄像头数据获取方法的步骤。
14.一种非暂态计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至6任一项或如权利要求7或8所述USB摄像头数据获取方法的步骤。
CN202011634502.1A 2020-12-31 2020-12-31 Usb摄像头数据获取方法、装置、电子设备和存储介质 Pending CN112616024A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202011634502.1A CN112616024A (zh) 2020-12-31 2020-12-31 Usb摄像头数据获取方法、装置、电子设备和存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202011634502.1A CN112616024A (zh) 2020-12-31 2020-12-31 Usb摄像头数据获取方法、装置、电子设备和存储介质

Publications (1)

Publication Number Publication Date
CN112616024A true CN112616024A (zh) 2021-04-06

Family

ID=75252962

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202011634502.1A Pending CN112616024A (zh) 2020-12-31 2020-12-31 Usb摄像头数据获取方法、装置、电子设备和存储介质

Country Status (1)

Country Link
CN (1) CN112616024A (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112883003A (zh) * 2021-04-27 2021-06-01 智道网联科技(北京)有限公司 车载终端共享数据方法及装置
CN115174941A (zh) * 2022-07-06 2022-10-11 灵羲科技(北京)有限公司 基于多路视频流的实时运动表现分析及实时数据共享方法
CN116204337A (zh) * 2023-03-03 2023-06-02 广州市易鸿智能装备有限公司 一种图像传输方法、装置、设备和计算机存储介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101594510A (zh) * 2009-06-23 2009-12-02 腾讯科技(深圳)有限公司 一种实现摄像头资源共享的方法及系统
CN103327278A (zh) * 2013-07-10 2013-09-25 亿览在线网络技术(北京)有限公司 一种图像实时共享方法及装置
CN111698530A (zh) * 2020-05-27 2020-09-22 深圳壹账通智能科技有限公司 视频传输方法、装置、设备及计算机可读存储介质
CN112099970A (zh) * 2020-09-04 2020-12-18 中国第一汽车股份有限公司 一种视频数据处理方法、装置、设备及存储介质
CN112148693A (zh) * 2020-10-19 2020-12-29 腾讯科技(深圳)有限公司 一种数据处理方法、装置及存储介质

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101594510A (zh) * 2009-06-23 2009-12-02 腾讯科技(深圳)有限公司 一种实现摄像头资源共享的方法及系统
CN103327278A (zh) * 2013-07-10 2013-09-25 亿览在线网络技术(北京)有限公司 一种图像实时共享方法及装置
CN111698530A (zh) * 2020-05-27 2020-09-22 深圳壹账通智能科技有限公司 视频传输方法、装置、设备及计算机可读存储介质
CN112099970A (zh) * 2020-09-04 2020-12-18 中国第一汽车股份有限公司 一种视频数据处理方法、装置、设备及存储介质
CN112148693A (zh) * 2020-10-19 2020-12-29 腾讯科技(深圳)有限公司 一种数据处理方法、装置及存储介质

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112883003A (zh) * 2021-04-27 2021-06-01 智道网联科技(北京)有限公司 车载终端共享数据方法及装置
CN115174941A (zh) * 2022-07-06 2022-10-11 灵羲科技(北京)有限公司 基于多路视频流的实时运动表现分析及实时数据共享方法
CN116204337A (zh) * 2023-03-03 2023-06-02 广州市易鸿智能装备有限公司 一种图像传输方法、装置、设备和计算机存储介质
CN116204337B (zh) * 2023-03-03 2024-04-09 广州市易鸿智能装备股份有限公司 一种图像传输方法、装置、设备和计算机存储介质

Similar Documents

Publication Publication Date Title
CN112616024A (zh) Usb摄像头数据获取方法、装置、电子设备和存储介质
JP6475256B2 (ja) コンピュータ、制御デバイス及びデータ処理方法
CN111683252B (zh) 一种服务器以及一种视频压缩图像的输出系统和方法
JP2003046569A (ja) 負荷テスト実行装置及びシステム、及びその方法、及びそのプログラム
CN111028922A (zh) 医学影像数据的标准化方法、装置、服务器设备及介质
CN111182251B (zh) 一种应用于网上巡查同步转码且存储介质可热插拔的录像备份方法和装置
CN111679911A (zh) 云环境中gpu卡的管理方法、装置、设备及介质
CN112769876B (zh) 一种设备通道信息获取方法、装置、设备和介质
CN112925737A (zh) Pci异构系统数据融合方法、系统、设备及存储介质
CN108063809B (zh) 机器设备数据采集方法以及采集系统
CN111404842B (zh) 数据传输方法、装置及计算机存储介质
CN111126604A (zh) 模型训练方法、装置、服务器及存储介质
CN108289165B (zh) 一种基于手机控制相机的实现方法、装置及终端设备
CN111857462B (zh) 一种服务器及光标同步方法、装置、计算机可读存储介质
CN108805741B (zh) 一种电能质量数据的融合方法、装置及系统
CN111092817A (zh) 一种数据传输方法及装置
CN112055058A (zh) 数据的存储方法、装置及计算机可读存储介质
CN114051047B (zh) 一种会话消息的备份方法、装置、网络设备和存储介质
CN109510864A (zh) 一种缓存请求的转发方法、传输方法及相关装置
CN112003860B (zh) 适用于远程直接内存访问的内存管理方法、系统及介质
CN113127222B (zh) 数据发送方法、装置、设备和介质
CN117118876B (zh) 心跳连接检测方法、装置、电子设备及存储介质
WO2024082773A1 (zh) 一种迁移文件系统的方法和相关设备
CN113873014A (zh) 一种可支持海量设备的指令处理方法、终端及存储介质
JP3362547B2 (ja) 通信アダプタ

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
RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20210406