⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mssndcard.h

📁 linphone-2.1,最新版本的LINUX平台下的SIP电话源代码
💻 H
字号:
/*mediastreamer2 library - modular sound and video processing and streamingCopyright (C) 2006  Simon MORLAT (simon.morlat@linphone.org)This program is free software; you can redistribute it and/ormodify it under the terms of the GNU General Public Licenseas published by the Free Software Foundation; either version 2of the License, or (at your option) any later version.This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with this program; if not, write to the Free SoftwareFoundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.*/#ifndef sndcard_h#define sndcard_h#include "mscommon.h"/** * @file mssndcard.h * @brief mediastreamer2 mssndcard.h include file * * This file provide the API needed to manage * soundcard filters. * *//** * @defgroup mediastreamer2_soundcard Sound Card API - manage audio capture/play filters. * @ingroup mediastreamer2_api * @{ */struct _MSSndCardManager{	MSList *cards;};/** * Structure for sound card manager object. * @var MSSndCardManager */typedef struct _MSSndCardManager MSSndCardManager;enum _MSSndCardMixerElem{	MS_SND_CARD_MASTER,	MS_SND_CARD_PLAYBACK,	MS_SND_CARD_CAPTURE};/** * Structure for sound card mixer values. * @var MSSndCardMixerElem */typedef enum _MSSndCardMixerElem MSSndCardMixerElem;enum _MSSndCardCapture {	MS_SND_CARD_MIC,	MS_SND_CARD_LINE};/** * Structure for sound card capture source values. * @var MSSndCardCapture */typedef enum _MSSndCardCapture MSSndCardCapture;struct _MSSndCard;typedef void (*MSSndCardDetectFunc)(MSSndCardManager *obj);typedef void (*MSSndCardInitFunc)(struct _MSSndCard *obj);typedef void (*MSSndCardUninitFunc)(struct _MSSndCard *obj);typedef void (*MSSndCardSetLevelFunc)(struct _MSSndCard *obj, MSSndCardMixerElem e, int percent);typedef void (*MSSndCardSetCaptureFunc)(struct _MSSndCard *obj, MSSndCardCapture e);typedef int (*MSSndCardGetLevelFunc)(struct _MSSndCard *obj, MSSndCardMixerElem e);typedef struct _MSFilter * (*MSSndCardCreateReaderFunc)(struct _MSSndCard *obj);typedef struct _MSFilter * (*MSSndCardCreateWriterFunc)(struct _MSSndCard *obj);typedef struct _MSSndCard * (*MSSndCardDuplicateFunc)(struct _MSSndCard *obj);struct _MSSndCardDesc{	const char *driver_type;	MSSndCardDetectFunc detect;	MSSndCardInitFunc init;	MSSndCardSetLevelFunc set_level;	MSSndCardGetLevelFunc get_level;	MSSndCardSetCaptureFunc set_capture;	MSSndCardCreateReaderFunc create_reader;	MSSndCardCreateWriterFunc create_writer;	MSSndCardUninitFunc uninit;	MSSndCardDuplicateFunc duplicate;};/** * Structure for sound card description object. * @var MSSndCardDesc */typedef struct _MSSndCardDesc MSSndCardDesc;#define MS_SND_CARD_CAP_CAPTURE (1)#define MS_SND_CARD_CAP_PLAYBACK (1<<1)struct _MSSndCard{	MSSndCardDesc *desc;	char *name;	char *id;	unsigned int capabilities;	void *data;};/** * Structure for sound card object. * @var MSSndCard */typedef struct _MSSndCard MSSndCard;#ifdef __cplusplusextern "C"{#endif/** * @defgroup mediastreamer2_soundcardmanager Sound Card Manager API * @ingroup mediastreamer2_soundcard * @{ *//** * Retreive a sound card manager object. * * Returns: MSSndCardManager if successfull, NULL otherwise. */MSSndCardManager * ms_snd_card_manager_get(void);/** * Destroy a sound card manager object. * */void ms_snd_card_manager_destroy(void);/** * Retreive a sound card object based on its name. * * @param m    A sound card manager containing sound cards. * @param id   A name for card to search. * * Returns: MSSndCard if successfull, NULL otherwise. */MSSndCard * ms_snd_card_manager_get_card(MSSndCardManager *m, const char *id);/** * Retreive the default sound card object. * * @param m    A sound card manager containing sound cards. * * Returns: MSSndCard if successfull, NULL otherwise. */MSSndCard * ms_snd_card_manager_get_default_card(MSSndCardManager *m);/** * Retreive the list of sound card objects. * * @param m    A sound card manager containing sound cards. * * Returns: MSList of cards if successfull, NULL otherwise. */const MSList * ms_snd_card_manager_get_list(MSSndCardManager *m);/** * Add a sound card object in a sound card manager's list. * * @param m    A sound card manager containing sound cards. * @param c    A sound card object. * */void ms_snd_card_manager_add_card(MSSndCardManager *m, MSSndCard *c);/** * Register a sound card description in a sound card manager. * * @param m      A sound card manager containing sound cards. * @param desc   A sound card description object. * */void ms_snd_card_manager_register_desc(MSSndCardManager *m, MSSndCardDesc *desc);/** @} *//** * @defgroup mediastreamer2_soundcardfilter Sound Card Filter API * @ingroup mediastreamer2_soundcard * @{ *//** * Create an INPUT filter based on the selected sound card. * * @param obj      A sound card object. * * Returns: A MSFilter if successfull, NULL otherwise. */struct _MSFilter * ms_snd_card_create_reader(MSSndCard *obj);/** * Create an OUPUT filter based on the selected sound card. * * @param obj      A sound card object. * * Returns: A MSFilter if successfull, NULL otherwise. */struct _MSFilter * ms_snd_card_create_writer(MSSndCard *obj);/** * Create a new sound card object. * * @param desc   A sound card description object. * * Returns: MSSndCard if successfull, NULL otherwise. */MSSndCard * ms_snd_card_new(MSSndCardDesc *desc);/** * Destroy sound card object. * * @param obj   A MSSndCard object. */void ms_snd_card_destroy(MSSndCard *obj);/** * Duplicate a sound card object. * * This helps to open several time a sound card. * * @param card   A sound card object. * * Returns: MSSndCard if successfull, NULL otherwise. */MSSndCard * ms_snd_card_dup(MSSndCard *card);/** * Retreive a sound card's driver type string. * * Internal driver types are either: "OSS, ALSA, WINSND, PASND, CA" * * @param obj   A sound card object. * * Returns: a string if successfull, NULL otherwise. */const char *ms_snd_card_get_driver_type(const MSSndCard *obj);/** * Retreive a sound card's name. * * @param obj   A sound card object. * * Returns: a string if successfull, NULL otherwise. */const char *ms_snd_card_get_name(const MSSndCard *obj);/** * Retreive sound card's name ($driver_type: $name). * * @param obj    A sound card object. * * Returns: A string if successfull, NULL otherwise. */const char *ms_snd_card_get_string_id(MSSndCard *obj);/** * Retreive sound card's capabilities. * * <PRE> *   MS_SND_CARD_CAP_CAPTURE *   MS_SND_CARD_CAP_PLAYBACK *   MS_SND_CARD_CAP_CAPTURE|MS_SND_CARD_CAP_PLAYBACK * </PRE> * * @param obj    A sound card object. * * Returns: A unsigned int if successfull, 0 otherwise. */unsigned int ms_snd_card_get_capabilities(const MSSndCard *obj);/** * Set some mixer level value. * * <PRE> *   MS_SND_CARD_MASTER, *   MS_SND_CARD_PLAYBACK, *   MS_SND_CARD_CAPTURE * </PRE> * Note: not implemented on all sound card filters. * * @param obj      A sound card object. * @param e        A sound card mixer object. * @param percent  A volume level. * */void ms_snd_card_set_level(MSSndCard *obj, MSSndCardMixerElem e, int percent);/** * Get some mixer level value. * * <PRE> *   MS_SND_CARD_MASTER, *   MS_SND_CARD_PLAYBACK, *   MS_SND_CARD_CAPTURE * </PRE> * Note: not implemented on all sound card filters. * * @param obj      A sound card object. * @param e        A sound card mixer object. * * Returns: A int if successfull, 0 otherwise. */int ms_snd_card_get_level(MSSndCard *obj, MSSndCardMixerElem e);/** * Set some source for capture. * * <PRE> *   MS_SND_CARD_MIC, *   MS_SND_CARD_LINE * </PRE> * Note: not implemented on all sound card filters. * * @param obj      A sound card object. * @param c        A sound card capture value. * * Returns: A int if successfull, 0 otherwise. */void ms_snd_card_set_capture(MSSndCard *obj, MSSndCardCapture c);/** * Create a alsa card with user supplied pcm name and mixer name. * @param pcmdev The pcm device name following alsa conventions (ex: plughw:0) * @param mixdev The mixer device name following alsa conventions. * * Returns: a MSSndCard object, NULL if alsa support is not available. */MSSndCard * ms_alsa_card_new_custom(const char *pcmdev, const char *mixdev);/** @} */#ifdef __cplusplus}#endif/** @} */#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -