CN109976697A - 获取音频数据的方法及装置、设备、计算机可读存储介质 - Google Patents
获取音频数据的方法及装置、设备、计算机可读存储介质 Download PDFInfo
- Publication number
- CN109976697A CN109976697A CN201711466375.7A CN201711466375A CN109976697A CN 109976697 A CN109976697 A CN 109976697A CN 201711466375 A CN201711466375 A CN 201711466375A CN 109976697 A CN109976697 A CN 109976697A
- Authority
- CN
- China
- Prior art keywords
- audio data
- sound card
- virtual sound
- application program
- application
- 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
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/16—Sound input; Sound output
- G06F3/162—Interface to dedicated audio devices, e.g. audio drivers, interface to CODECs
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Multimedia (AREA)
- Health & Medical Sciences (AREA)
- Audiology, Speech & Language Pathology (AREA)
- General Health & Medical Sciences (AREA)
- Human Computer Interaction (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Telephone Function (AREA)
Abstract
本发明适用于音频技术领域,提供了一种获取音频数据的方法及装置、设备、计算机可读存储介质,其中,获取音频数据的方法包括:若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡;控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据;将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。本发明实施例通过在驱动层为至少两个需要获取音频数据的应用程序分别配置虚拟声卡,每个虚拟声卡将从同一个实体声卡获取到的音频数据发送给每个虚拟声卡对应的应用程序,能够使得至少两个应用程序可以同时获取实时的音频数据或录音数据。
Description
技术领域
本发明属于音频技术领域,尤其涉及一种获取音频数据的方法及装置、设备、计算机可读存储介质。
背景技术
随着人工智能(Artificial Intelligence,AI)技术的发展,人工智能广泛应用于自驾、个人助理(例如,智能手机上的语音助理、语音输入,家庭管家以及陪护机器人等),智能安防(例如,智能监控、安保机器人等)、电商零售(例如,仓储物流、智能导购和客服等)、教育(例如,智能测评、个性化辅导和儿童陪伴等)等领域。
目前,在AI技术中,语音识别作为人机交互的入口之一,语音相关技术占有非常重要的地位。在实际的AI产品中,往往存在有多个应用程序(Application,App)需要同时获取音频数据的情况。例如,语音识别唤醒应用需要获取音频数据,视频监控应用也需要获取音频数据,网络电话等应用也需要获取语音等音频数据。
然而,在一个设备中,一般只有一个用于拾取和传递声音的部件(例如,麦克风Microphone),只允许一个应用程序使用该部件获取音频数据,在不增加用于拾取和传递声音的部件的情况下,无法实现多个应用程序同时使用同一个用于拾取和传递声音的部件获取音频数据。
发明内容
有鉴于此,本发明实施例提供了一种获取音频数据的方法及装置、设备、计算机可读存储介质,以解决现有技术中在不增加用于拾取和传递声音的部件以及实体声卡的数量的前提下,无法实现多个应用程序同时使用同一个用于拾取和传递声音的装置进行录音的问题。
本发明实施例的第一方面提供了一种获取音频数据的方法,包括:
若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡;
控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据;
将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。
本发明实施例的第二方面提供了一种获取音频数据的装置,包括:
配置单元,用于若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡;
获取单元,用于控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据;
音频数据传递单元,用于将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。
本发明实施例的第三方面提供了一种获取音频数据的设备,包括:存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述第一方面的获取音频数据的方法。
本发明实施例的第四方面提供了一种计算机可读存储介质,所述计算机存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时使所述处理器执行上述第一方面的方法。
本发明实施例与现有技术相比存在的有益效果是:在驱动层为至少两个需要获取音频数据的应用程序分别配置虚拟声卡,控制每个虚拟声卡获取同一个实体声卡实时采集到的音频数据,并将每个虚拟声卡获取到的音频数据发送给每个虚拟声卡对应的应用程序,从而在不增加用于拾取和传递声音的部件以及实体声卡的数量的前提下,能够使得至少两个应用程序可以同时获取实时的音频数据或录音数据。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例提供的获取音频数据的方法的实现流程示意图;
图2是本发明另一实施例提供的获取音频数据的方法的实现流程示意图;
图3是本发明实施例提供的获取音频数据的装置的示意图;
图4是本发明实施例提供的获取音频数据的设备的示意图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本发明实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本发明。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本发明的描述。
为了说明本发明所述的技术方案,下面通过具体实施例来进行说明。
请参阅图1,图1是本发明实施例提供的获取音频数据的方法的实现流程示意图。在本实施例中获取音频数据的方法的执行主体是获取音频数据的设备,获取音频数据的设备可以是机器人,也可以是智能手机、平板电脑、PAD、可穿戴设备等移动终端,但并不限于此,还可以是内置有至少两个应用程序需要同时获取音频数据的设备,此处不做限制。如图所示的获取音频数据的方法可包括如下步骤:
S101:若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡。
获取音频数据的设备在检测到用于启动需要获取音频数据的至少两个应用程序的指令时,识别为该至少两个应用程序触发了用于请求获取音频数据的第一指令。需要获取音频数据的应用程序可以包括但不限于语音识别应用、具有视频监控功能的应用程序或网络电话应用。
或者,获取音频数据的设备在检测到至少两个应用程序调用内置的用于管理音频数据的应用程序的应用程序编程接口(Application Programming Interface,API)时,识别为该至少两个应用程序触发了用于请求获取音频数据的第一指令。
为了实现至少两个应用程序同时获取音频数据,获取音频数据的设备在检测到至少两个应用程序触发用于请求获取音频数据的第一指令时,在驱动层为触发了第一指令的每个应用程序分别配置虚拟声卡。
虚拟声卡与触发了第一指令的应用程序一一对应,不同的应用程序配置的虚拟声卡各不相同。被分配的虚拟声卡的状态可以设置为被占用状态,同一时间内一个虚拟声卡只能向与其对应的应用程序输出实体声卡采集到的音频信息。
虚拟声卡用于获取实时音频数据,在驱动层创建的所有虚拟声卡获取到的音频数据均来自一个实体声卡,实体声卡即声卡(Sound Card)也叫音频卡声卡,是多媒体技术中最基本的组成部分,是实现声波/数字信号相互转换的一种硬件。操作系统架构中一般包括硬件层、驱动层、操作系统层以及应用层。
声卡的基本功能是把来自话筒、磁带、光盘的原始声音信号加以转换,输出到耳机、扬声器、扩音机、录音机等声响设备,或通过音乐设备数字接口(MusicalInstrumentDigitalInterface,MIDI)使乐器发出美妙的声音。
可以理解的是,获取音频数据的设备在驱动层为该至少两个应用程序分别配置虚拟声卡时,可以根据应用程序的标识以及分配给该应用程序的虚拟声卡的标识,绑定该应用程序以及配置给该应用程序使用的虚拟声卡。
S102:控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据。
获取音频数据的设备调用用于获取音频数据的服务从硬件层获取实体声卡实时采集到的音频数据,以及控制每个虚拟声卡获取该实体声卡采集到的音频数据。实体声卡采集到的音频数据是实体声卡对拾取和传递声音的部件(例如,麦克风)实时采集的语音信息进行转换后得到。
其中,麦克风的数量可以为一个也可以为至少两个,当麦克风的数量为至少两个时,实体声卡可以将每个麦克风采集到的语音信息合并成一个音频文件,然后分离出每个麦克风采集到的音频数据,以进行声源定位。
为了提高音频的音质,在获取到实时采集的语音信息时,可以对其进行消噪处理以及回声消除处理,之后,对处理后的语音信息进行模数转换以及信号放大处理后得到音频数据或录音数据。消噪处理是指消除外界噪声干扰。回声消除是指消除回音。
从回音产生的原因看,回音可以分为声学回音(Acoustic Echo)和线路回音(LineEcho),相应的回声消除技术就叫声学回声消除(Acoustic Echo Cancellation,AEC)和线路回声消除(Line Echo Cancellation,LEC)。声学回音是由于在免提或者会议应用中,扬声器的声音多次反馈到麦克风引起的;线路回音是由于物理电子线路的二四线匹配耦合引起的。
S103:将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。
例如,当第一虚拟声卡被配置给网络电话应用时,获取音频数据的设备将第一虚拟声卡获取到的音频数据发送给网络电话应用。
当第二虚拟声卡被配置给语音识别唤醒应用时,获取音频数据的设备将第二虚拟声卡获取到的音频数据发送给语音识别唤醒应用,以使语音识别唤醒应用根据获取到的音频数据进行语音识别。
当第三虚拟声卡被配置给语音识别唤醒应用时,获取音频数据的设备将第三虚拟声卡获取到的音频数据发送给视频监控应用,以使视频监控应用能够将第三虚拟声卡缓存的音频数据与拍摄到的图像进行整合、存储或播放。
上述方案,通过在驱动层为至少两个需要获取音频数据的应用程序分别配置虚拟声卡,控制每个虚拟声卡获取同一个实体声卡实时采集到的音频数据,并将每个虚拟声卡获取到的音频数据发送给每个虚拟声卡对应的应用程序,从而在不增加用于拾取和传递声音的部件以及实体声卡的数量的前提下,能够使得至少两个应用程序可以同时获取实时的音频数据或录音数据。
请参阅图2,图2是本发明实施例提供的获取音频数据的方法的实现流程示意图。在本实施例中获取音频数据的方法的执行主体是获取音频数据的设备,获取音频数据的设备可以是机器人,也可以是智能手机、平板电脑、PAD、可穿戴设备等移动终端,但并不限于此,还可以是内置有至少两个应用程序需要同时获取音频数据的设备,此处不做限制。如图所示的获取音频数据的方法可包括如下步骤:
S201:若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡。
获取音频数据的设备在检测到用于启动需要获取音频数据的至少两个应用程序的指令时,识别为该至少两个应用程序触发了用于请求获取音频数据的第一指令。需要获取音频数据的应用程序可以包括但不限于语音识别应用、具有视频监控功能的应用程序或网络电话应用。
或者,获取音频数据的设备在检测到至少两个应用程序调用内置的用于管理音频数据的应用程序的应用程序编程接口(Application Programming Interface,API)时,识别为该至少两个应用程序触发了用于请求获取音频数据的第一指令。
为了实现至少两个应用程序同时获取音频数据,获取音频数据的设备在检测到至少两个应用程序触发用于请求获取音频数据的第一指令时,在驱动层为触发了第一指令的每个应用程序分别配置虚拟声卡。
虚拟声卡与触发了第一指令的应用程序一一对应,不同的应用程序配置的虚拟声卡各不相同。被分配的虚拟声卡的状态可以设置为被占用状态,同一时间内一个虚拟声卡只能向与其对应的应用程序输出实体声卡采集到的音频信息。
虚拟声卡用于获取实时音频数据,在驱动层创建的所有虚拟声卡获取到的音频数据均来自一个实体声卡,实体声卡即声卡(Sound Card)也叫音频卡声卡,是多媒体技术中最基本的组成部分,是实现声波/数字信号相互转换的一种硬件。操作系统架构中一般包括硬件层、驱动层、操作系统层以及应用层。
声卡的基本功能是把来自话筒、磁带、光盘的原始声音信号加以转换,输出到耳机、扬声器、扩音机、录音机等声响设备,或通过音乐设备数字接口(MusicalInstrumentDigitalInterface,MIDI)使乐器发出美妙的声音。
可以理解的是,获取音频数据的设备在驱动层为该至少两个应用程序分别配置虚拟声卡时,可以根据应用程序的标识以及分配给该应用程序的虚拟声卡的标识,绑定该应用程序以及配置给该应用程序使用的虚拟声卡。
可选地,S201可以具体为:若检测到至少两个应用程序触发用于请求获取音频数据的第一指令,则在驱动层创建预设数目的虚拟声卡;为每个应用程序分配虚拟声卡;其中,所述预设数目大于或等于所述至少两个应用程序的总数。
当虚拟声卡设有状态标识时,可以根据状态标识确定当前的虚拟声卡是否被占用,当状态标识表示该虚拟声卡被占用时,不能分配给其他的应用程序,当状态标识表示该虚拟声卡未被占用时,可以将该虚拟声卡分配给需要的应用程序使用。
在一实施方式中,获取音频数据的设备可以统计触发用于请求获取音频数据的第一指令的应用程序的总数,并根据该总数在驱动层模拟出实体声卡的音虚拟声卡,从而创建虚拟声卡,其中,创建的虚拟声卡的数量可以与该总数相等,以使得每个应用程序均能被分配到虚拟声卡。
在另一实施方式中,获取音频数据的设备在检测到至少两个应用程序触发用于请求获取音频数据的第一指令时,可以根据获取音频数据的设备中已经安装的需要获取音频数据的应用程序的数量,在驱动层模拟出同一实体声卡对应的预设数目的虚拟声卡,以创建预设数目的虚拟声卡。预设数目为已安装的需要获取音频数据的应用程序的总数,预设数目大于或等于触发第一指令的应用程序的数量,以使得每个触发第一指令的应用程序均能被分配到音虚拟声卡。
可选地,为了减少虚拟声卡所占用的系统资源,获取音频数据的设备还可以根据需要获取音频数据的应用程序的数量实时创建虚拟声卡,此时,S201还可以具体为:若检测到至少两个应用程序触发用于请求获取音频数据的第一指令,则创建所述至少两个应用程序各自对应的虚拟声卡。
即,获取音频数据的设备为每个触发第一指令的应用程序分别创建虚拟声卡。
S202:控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据。
获取音频数据的设备调用用于获取音频数据的服务从硬件层获取实体声卡实时采集到的音频数据,以及控制每个虚拟声卡获取该实体声卡采集到的音频数据。实体声卡采集到的音频数据是实体声卡对拾取和传递声音的部件(例如,麦克风)实时采集的语音信息进行转换后得到。
其中,麦克风的数量可以为一个也可以为至少两个,当麦克风的数量为至少两个时,实体声卡可以将每个麦克风采集到的语音信息合并成一个音频文件,然后分离出每个麦克风采集到的音频数据,以进行声源定位。
为了提高音频的音质,在获取到实时采集的语音信息时,可以对其进行消噪处理以及回声消除处理,之后,对处理后的语音信息进行模数转换以及信号放大处理后得到音频数据或录音数据。消噪处理是指消除外界噪声干扰。回声消除是指消除回音。
从回音产生的原因看,回音可以分为声学回音(Acoustic Echo)和线路回音(LineEcho),相应的回声消除技术就叫声学回声消除(Acoustic Echo Cancellation,AEC)和线路回声消除(Line Echo Cancellation,LEC)。声学回音是由于在免提或者会议应用中,扬声器的声音多次反馈到麦克风引起的;线路回音是由于物理电子线路的二四线匹配耦合引起的。
进一步地,S202具体包括:通过每个所述虚拟声卡对应的设备节点文件访问实体声卡,获取所述实体声卡采集到的音频数据。
获取音频数据的设备每创建一个虚拟声卡,生成一个该虚拟声卡对应的设备节点文件。获取音频数据的设备可以通过每个虚拟声卡对应的设备节点文件访问实体声卡,获取实体声卡采集到的音频数据。
可选地,获取音频数据的方法还可以包括S203:获取采集到所述音频数据的时间信息。
获取音频数据的设备获取实体声卡采集到音频数据的时间信息。
采集到音频数据的时间信息用于:在至少两个应用程序在不同的时刻触发第一指令时,能够根据每个应用程序触发第一指令的时间确定需要传递给每个应用程序的目标音频数据。其中,目标音频数据携带的时间信息包含的起始时刻可以与触发第一指令的时刻相同。
需要传递给每个应用程序的目标音频数据可以相同,也可以不同。当不同的应用程序在不同时刻触发第一指令时,传递给这些不同的应用程序的目标音频数据不同。当不同的应用程序在相同时刻触发第一指令时,传递给这些不同的应用程序的目标音频数据相同。
可以理解的是,S202与S203不分先后顺序,可以同时执行。
S204:将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。
例如,当第一虚拟声卡被配置给网络电话应用时,获取音频数据的设备将第一虚拟声卡获取到的音频数据发送给网络电话应用。
当第二虚拟声卡被配置给语音识别唤醒应用时,获取音频数据的设备将第二虚拟声卡获取到的音频数据发送给语音识别唤醒应用,以使语音识别唤醒应用根据获取到的音频数据进行语音识别。
当第三虚拟声卡被配置给语音识别唤醒应用时,获取音频数据的设备将第三虚拟声卡获取到的音频数据发送给视频监控应用,以使视频监控应用能够将第三虚拟声卡缓存的音频数据与拍摄到的图像进行整合、存储或播放。
进一步地,当获取音频数据的方法包括S203时,S204具体可以包括:
S2041:根据每个所述应用程序各自触发所述第一指令的时间信息以及采集到所述音频数据的时间信息,确定每个所述应用程序各自对应的目标音频数据。
例如,获取音频数据的设备在第一时刻检测到网络电话应用触发第一指令时,将在第一时刻采集到的音频数据识别为网络电话应用对应的目标音频数据。
每个应用程序对应的目标音频数据可以相同,也可以不同。当不同的应用程序在同一时刻触发第一指令时,这些不同的应用程序的目标音频数据相同;当不同的应用程序在不同时刻触发第一指令时,这些不同的应用程序的目标音频数据不同。
S2042:将每个所述虚拟声卡获取到的目标音频数据发送给每个所述虚拟声卡对应的应用程序。
S205:若检测到第一应用程序触发用于表示停止获取音频数据的第二指令,则释放所述第一应用程序对应的虚拟声卡。
由于获取音频数据的设备在为至少两个应用程序分别配置虚拟声卡时,建立了虚拟声卡与应用程序之间的绑定关系,在检测到第一应用程序触发用于表示停止获取音频数据的第二指令时,可以解除第一应用程序与第一应用程序对应的虚拟声卡之间的绑定关系,以释放第一应用程序对应的虚拟声卡。第一应用程序对应的虚拟声卡被释放后,可以将该虚拟声卡设置为未被占用的状态。第一应用程序泛指触发第二指令的应用程序。
解除第一应用程序与第一应用程序对应的虚拟声卡之间的绑定关系之后,该虚拟声卡可以重新与第二应用程序重新建立绑定关系,以使得该虚拟声卡可以被重新配置给第二应用程序,第二应用程序是指除第一应用程序之外的其他触发第一指令的应用程序。
为了节省存储资源,在解除第一应用程序与第一应用程序对应的虚拟声卡之间的绑定关系之后,还可以删除第一应用程序对应的虚拟声卡。在检测到触发用于请求获取音频数据的第一指令时,再为触发该第一指令的应用程序创建虚拟声卡。
上述方案,通过在驱动层为至少两个需要获取音频数据的应用程序分别配置虚拟声卡,控制每个虚拟声卡获取同一个实体声卡实时采集到的音频数据,并将每个虚拟声卡获取到的音频数据发送给每个虚拟声卡对应的应用程序,从而在不增加用于拾取和传递声音的部件以及实体声卡的数量的前提下,能够使得至少两个应用程序可以同时获取实时的音频数据或录音数据。
在检测到至少两个应用程序触发用于请求获取音频数据的第一指令时,动态创建至少两个应用程序各自对应的虚拟声卡,可以节省系统资源。
在检测到第一应用程序触发用于表示停止获取音频数据的第二指令时,释放第一应用程序对应的虚拟声卡,以便将该虚拟声卡重新分配给其他需要的应用程序,能够灵活配置虚拟声卡,避免不需要获取音频数据的虚拟声卡占用系统资源,造成资源浪费。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本发明实施例的实施过程构成任何限定。
请参阅图3,图3是本发明实施例提供的获取音频数据的装置的示意图。本实施例中的获取音频数据的装置3包括的各单元用于执行图1或图2对应的实施例中的各步骤,具体请参阅图1或图2对应的实施例中各步骤的描述,此处不赘述。如图3所示的获取音频数据的装置包括:配置单元310、获取单元320以及音频数据传递单元330。
配置单元310用于配置单元,用于若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡。
进一步地,配置单元310具体用于:若检测到至少两个应用程序触发用于获取音频数据的第一指令,则在驱动层创建预设数目的虚拟声卡;为每个应用程序分配虚拟声卡;其中,所述预设数目大于或等于所述至少两个应用程序的总数;或
若检测到至少两个应用程序触发用于获取音频数据的第一指令,则创建所述至少两个应用程序各自对应的虚拟声卡。
获取单元320用于控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据。
进一步地,获取单元320具体用于:通过每个所述虚拟声卡对应的设备节点文件访问实体声卡,获取所述实体声卡采集到的音频数据。
音频数据传递单元330用于将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。
进一步地,获取音频数据的装置还可以包括:
释放单元340,用于若检测到第一应用程序触发用于表示停止获取音频数据的第二指令,则释放所述第一应用程序对应的虚拟声卡。
可选地,获取单元320还用于:获取采集到所述音频数据的时间信息;
音频数据传递单元330具体用于:根据每个所述应用程序各自触发所述第一指令的时间信息以及采集到所述音频数据的时间信息,确定每个所述应用程序各自对应的目标音频数据;
将每个所述虚拟声卡获取到的目标音频数据发送给每个所述虚拟声卡对应的应用程序。
上述方案,通过在驱动层为至少两个需要获取音频数据的应用程序分别配置虚拟声卡,控制每个虚拟声卡获取同一个实体声卡实时采集到的音频数据,并将每个虚拟声卡获取到的音频数据发送给每个虚拟声卡对应的应用程序,从而在不增加用于拾取和传递声音的部件以及实体声卡的数量的前提下,能够使得至少两个应用程序可以同时获取实时的音频数据或录音数据。
在检测到至少两个应用程序触发用于请求获取音频数据的第一指令时,动态创建至少两个应用程序各自对应的虚拟声卡,可以节省系统资源。
在检测到第一应用程序触发用于表示停止获取音频数据的第二指令时,释放第一应用程序对应的虚拟声卡,以便将该虚拟声卡重新分配给其他需要的应用程序,能够灵活配置虚拟声卡,避免不需要获取音频数据的虚拟声卡占用系统资源,造成资源浪费。
图4是本发明一实施例提供的获取音频数据的设备的示意图。如图4所示,该实施例的获取音频数据的设备4包括:处理器401、存储器402以及存储在所述存储器402中并可在所述处理器401上运行的计算机程序403。所述处理器401执行所述计算机程序403时实现上述各个获取音频数据的方法实施例中的步骤,例如图1所示的S101至S103。或者,所述处理器401执行所述计算机程序403时实现上述各装置实施例中各模块/单元的功能,例如图3所示的单元310至340的功能。
示例性的,所述计算机程序403可以被分割成一个或多个模块/单元,所述一个或者多个模块/单元被存储在所述存储器402中,并由所述处理器401执行,以完成本发明。所述一个或多个模块/单元可以是能够完成特定功能的一系列计算机程序指令段,该指令段用于描述所述计算机程序403在所述的获取音频数据的设备4中的执行过程。例如,所述计算机程序403可以被分割成配置单元、获取单元以及音频数据传递单元,还可以被分割成释放单元,各单元具体功能如下:
配置单元用于配置单元,用于若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡。
进一步地,配置单元具体用于:若检测到至少两个应用程序触发用于获取音频数据的第一指令,则在驱动层创建预设数目的虚拟声卡;为每个应用程序分配虚拟声卡;其中,所述预设数目大于或等于所述至少两个应用程序的总数;或
若检测到至少两个应用程序触发用于获取音频数据的第一指令,则创建所述至少两个应用程序各自对应的虚拟声卡。
获取单元用于控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据。
进一步地,获取单元具体用于:通过每个所述虚拟声卡对应的设备节点文件访问实体声卡,获取所述实体声卡采集到的音频数据。
音频数据传递单元用于将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。
进一步地,获取音频数据的装置还可以包括:
释放单元用于若检测到第一应用程序触发用于表示停止获取音频数据的第二指令,则释放所述第一应用程序对应的虚拟声卡。
可选地,获取单元还用于:获取采集到所述音频数据的时间信息;
音频数据传递单元具体用于:根据每个所述应用程序各自触发所述第一指令的时间信息以及采集到所述音频数据的时间信息,确定每个所述应用程序各自对应的目标音频数据;
将每个所述虚拟声卡获取到的目标音频数据发送给每个所述虚拟声卡对应的应用程序。
所述获取音频数据的设备4可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备,还可以是机器人。所述获取音频数据的设备可包括,但不仅限于,处理器401、存储器402。本领域技术人员可以理解,图4仅仅是获取音频数据的设备4的示例,并不构成对获取音频数据的设备4的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如所述获取音频数据的设备还可以包括输入输出设备、网络接入设备、总线等。
所称处理器401可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器402可以是所述获取音频数据的设备的4的内部存储单元,例如获取音频数据的设备4的硬盘或内存。所述存储器402也可以是所述获取音频数据的设备4的外部存储设备,例如所述获取音频数据的设备4上配备的插接式硬盘,智能存储卡(Smart MediaCard,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,所述存储器402还可以既包括所述获取音频数据的设备4的内部存储单元也包括外部存储设备。所述存储器402用于存储所述计算机程序以及所述获取音频数据的设备所需的其他程序和数据。所述存储器402还可以用于暂时地存储已经输出或者将要输出的数据。所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
在本发明所提供的实施例中,应该理解到,所揭露的装置/终端设备和方法,可以通过其它的方式实现。例如,以上所描述的装置/终端设备实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(Read-Only Memory,ROM)、随机存取存储器(RandomAccess Memory,RAM)、电载波信号、电信信号以及软件分发介质等。需要说明的是,所述计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括电载波信号和电信信号。
以上所述实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围,均应包含在本发明的保护范围之内。
Claims (11)
1.一种获取音频数据的方法,其特征在于,包括:
若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡;
控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据;
将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。
2.如权利要求1所述的方法,其特征在于,所述若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡,包括:
若检测到至少两个应用程序触发用于获取音频数据的第一指令,则在驱动层创建预设数目的虚拟声卡;为每个应用程序分配虚拟声卡;其中,所述预设数目大于或等于所述至少两个应用程序的总数。
3.根据权利要求1所述的方法,其特征在于,所述若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡,包括:
若检测到至少两个应用程序触发用于获取音频数据的第一指令,则创建所述至少两个应用程序各自对应的虚拟声卡。
4.根据权利要求1-3任一项所述的方法,其特征在于,所述控制每个所述虚拟声卡获取实体声卡采集到的音频数据,包括:
通过每个所述虚拟声卡对应的设备节点文件访问实体声卡,获取所述实体声卡采集到的音频数据。
5.根据权利要求2或3所述的方法,其特征在于,所述将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序之后,还包括:
若检测到第一应用程序触发用于表示停止获取音频数据的第二指令,则释放所述第一应用程序对应的虚拟声卡。
6.根据权利要求4所述的方法,其特征在于,所述控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据,包括:
获取采集到所述音频数据的时间信息;
所述将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序,包括:
根据每个所述应用程序各自触发所述第一指令的时间信息以及采集到所述音频数据的时间信息,确定每个所述应用程序各自对应的目标音频数据;
将每个所述虚拟声卡获取到的目标音频数据发送给每个所述虚拟声卡对应的应用程序。
7.一种获取音频数据的装置,其特征在于,包括:
配置单元,用于若检测到至少两个应用程序触发用于获取录音数据的第一指令,则在驱动层为所述至少两个应用程序分别配置虚拟声卡;
获取单元,用于控制每个所述虚拟声卡获取实体声卡实时采集到的音频数据;
音频数据传递单元,用于将每个所述虚拟声卡获取到的音频数据发送给每个所述虚拟声卡对应的应用程序。
8.根据权利要求7所述的装置,其特征在于,还包括:
释放单元,用于若检测到第一应用程序触发用于表示停止获取音频数据的第二指令,则释放所述第一应用程序对应的虚拟声卡。
9.根据权利要求7或8任一项所述的装置,其特征在于,
所述获取单元还用于:获取采集到所述音频数据的时间信息;
所述音频数据传递单元具体用于:根据每个所述应用程序各自触发所述第一指令的时间信息以及采集到所述音频数据的时间信息,确定每个所述应用程序各自对应的目标音频数据;
将每个所述虚拟声卡获取到的目标音频数据发送给每个所述虚拟声卡对应的应用程序。
10.一种获取音频数据的设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至6任一项所述方法的步骤。
11.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至6任一项所述方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201711466375.7A CN109976697A (zh) | 2017-12-28 | 2017-12-28 | 获取音频数据的方法及装置、设备、计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201711466375.7A CN109976697A (zh) | 2017-12-28 | 2017-12-28 | 获取音频数据的方法及装置、设备、计算机可读存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN109976697A true CN109976697A (zh) | 2019-07-05 |
Family
ID=67075299
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201711466375.7A Pending CN109976697A (zh) | 2017-12-28 | 2017-12-28 | 获取音频数据的方法及装置、设备、计算机可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109976697A (zh) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110808060A (zh) * | 2019-10-15 | 2020-02-18 | 广州国音智能科技有限公司 | 音频处理方法、装置、设备及计算机可读存储介质 |
CN110968288A (zh) * | 2019-11-28 | 2020-04-07 | 北京视博云科技有限公司 | 应用音频隔离采集的方法、装置、存储介质及设备 |
CN111796794A (zh) * | 2020-07-09 | 2020-10-20 | 西安万像电子科技有限公司 | 语音数据的处理方法、系统及虚拟机 |
CN111954028A (zh) * | 2020-10-19 | 2020-11-17 | 深圳乐播科技有限公司 | 音频数据的投屏方法、装置、设备及存储介质 |
CN113238613A (zh) * | 2021-04-28 | 2021-08-10 | 广州朗国电子科技有限公司 | 一体机设备及其麦克风使用方法、存储介质 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102647615A (zh) * | 2012-03-15 | 2012-08-22 | 北京视博云科技有限公司 | 一种多媒体应用数据提供方法、装置及系统 |
US20120297383A1 (en) * | 2011-05-20 | 2012-11-22 | Steven Meisner | Methods and systems for virtualizing audio hardware for one or more virtual machines |
CN102902638A (zh) * | 2011-07-26 | 2013-01-30 | 北大方正集团有限公司 | 硬件设备控制方法及驱动模块 |
WO2016197862A1 (zh) * | 2015-06-11 | 2016-12-15 | 阿里巴巴集团控股有限公司 | 一种数据传输方法、装置和智能电视系统 |
CN106504777A (zh) * | 2016-11-25 | 2017-03-15 | 维沃移动通信有限公司 | 一种录音数据的处理方法及移动终端 |
CN106897146A (zh) * | 2017-02-09 | 2017-06-27 | 青岛海信移动通信技术股份有限公司 | 一种终端的麦克风的数据处理方法和具有麦克风的终端 |
CN107369452A (zh) * | 2017-07-25 | 2017-11-21 | 上海闻泰电子科技有限公司 | 音频数据的处理方法及系统 |
-
2017
- 2017-12-28 CN CN201711466375.7A patent/CN109976697A/zh active Pending
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120297383A1 (en) * | 2011-05-20 | 2012-11-22 | Steven Meisner | Methods and systems for virtualizing audio hardware for one or more virtual machines |
CN102902638A (zh) * | 2011-07-26 | 2013-01-30 | 北大方正集团有限公司 | 硬件设备控制方法及驱动模块 |
CN102647615A (zh) * | 2012-03-15 | 2012-08-22 | 北京视博云科技有限公司 | 一种多媒体应用数据提供方法、装置及系统 |
WO2016197862A1 (zh) * | 2015-06-11 | 2016-12-15 | 阿里巴巴集团控股有限公司 | 一种数据传输方法、装置和智能电视系统 |
CN106504777A (zh) * | 2016-11-25 | 2017-03-15 | 维沃移动通信有限公司 | 一种录音数据的处理方法及移动终端 |
CN106897146A (zh) * | 2017-02-09 | 2017-06-27 | 青岛海信移动通信技术股份有限公司 | 一种终端的麦克风的数据处理方法和具有麦克风的终端 |
CN107369452A (zh) * | 2017-07-25 | 2017-11-21 | 上海闻泰电子科技有限公司 | 音频数据的处理方法及系统 |
Non-Patent Citations (1)
Title |
---|
刘永泰 等: "《网络信息安全知识读本》", 31 December 2014 * |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110808060A (zh) * | 2019-10-15 | 2020-02-18 | 广州国音智能科技有限公司 | 音频处理方法、装置、设备及计算机可读存储介质 |
CN110968288A (zh) * | 2019-11-28 | 2020-04-07 | 北京视博云科技有限公司 | 应用音频隔离采集的方法、装置、存储介质及设备 |
CN111796794A (zh) * | 2020-07-09 | 2020-10-20 | 西安万像电子科技有限公司 | 语音数据的处理方法、系统及虚拟机 |
CN111796794B (zh) * | 2020-07-09 | 2023-12-22 | 西安万像电子科技有限公司 | 语音数据的处理方法、系统及虚拟机 |
CN111954028A (zh) * | 2020-10-19 | 2020-11-17 | 深圳乐播科技有限公司 | 音频数据的投屏方法、装置、设备及存储介质 |
CN113238613A (zh) * | 2021-04-28 | 2021-08-10 | 广州朗国电子科技有限公司 | 一体机设备及其麦克风使用方法、存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109976697A (zh) | 获取音频数据的方法及装置、设备、计算机可读存储介质 | |
CN109976696A (zh) | 获取音频数据的方法及装置、设备、计算机可读存储介质 | |
CN107612968B (zh) | 通过智能终端控制其所连接设备的方法、设备与系统 | |
CN103081004B (zh) | 用于向语音使能应用程序提供输入的方法和装置 | |
CN104580624B (zh) | 在电话通话期间的选择性语音传输 | |
CN108769745A (zh) | 视频播放方法和装置 | |
CN109918040A (zh) | 语音指令分发方法和装置、电子设备及计算机可读介质 | |
CN110010125A (zh) | 一种智能机器人的控制方法、装置、终端设备及介质 | |
CN109215679A (zh) | 基于用户情绪的对话方法和装置 | |
CN108922528A (zh) | 用于处理语音的方法和装置 | |
CN107247629A (zh) | 云计算系统及用于控制服务器的云计算方法和装置 | |
CN109976698A (zh) | 获取音频数据的方法及装置、设备、计算机可读存储介质 | |
CN108369806A (zh) | 可配置的通用语言理解模型 | |
CN107864270A (zh) | 一种处理来电的方法、终端及计算机可读存储介质 | |
CN109754072A (zh) | 网络离线模型的处理方法、人工智能处理装置及相关产品 | |
CN109600324A (zh) | 视频通信方法、装置、计算机设备及存储介质 | |
CN108829518A (zh) | 用于推送信息的方法和装置 | |
CN107506494B (zh) | 文件处理方法、移动终端及计算机可读存储介质 | |
CN114851210A (zh) | 基于云平台的机器人调度方法及调度云平台 | |
CN110223694A (zh) | 语音处理方法、系统和装置 | |
CN109933508A (zh) | 用于发送信息的方法和装置 | |
WO2021068247A1 (zh) | 神经网络调度方法、装置、计算机设备及可读存储介质 | |
CN110874343B (zh) | 基于深度学习芯片进行语音处理的方法和深度学习芯片 | |
CN110351435A (zh) | 通话黑名单设置方法及装置 | |
CN111312243A (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 | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20190705 |