本文整理汇总了C++中AudioDeviceGetProperty函数的典型用法代码示例。如果您正苦于以下问题:C++ AudioDeviceGetProperty函数的具体用法?C++ AudioDeviceGetProperty怎么用?C++ AudioDeviceGetProperty使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了AudioDeviceGetProperty函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: InitializeDeviceInfo
static PaError InitializeDeviceInfo(PaMacCoreDeviceInfo *macCoreDeviceInfo, AudioDeviceID macCoreDeviceId, PaHostApiIndex hostApiIndex )
{
PaDeviceInfo *deviceInfo = &macCoreDeviceInfo->inheritedDeviceInfo;
deviceInfo->structVersion = 2;
deviceInfo->hostApi = hostApiIndex;
PaError err = paNoError;
UInt32 propSize;
err = conv_err(AudioDeviceGetPropertyInfo(macCoreDeviceId, 0, 0, kAudioDevicePropertyDeviceName, &propSize, NULL));
// FIXME: this allocation should be part of the allocations group
char *name = PaUtil_AllocateMemory(propSize);
err = conv_err(AudioDeviceGetProperty(macCoreDeviceId, 0, 0, kAudioDevicePropertyDeviceName, &propSize, name));
if (!err) {
deviceInfo->name = name;
}
Float64 sampleRate;
propSize = sizeof(Float64);
err = conv_err(AudioDeviceGetProperty(macCoreDeviceId, 0, 0, kAudioDevicePropertyNominalSampleRate, &propSize, &sampleRate));
if (!err) {
deviceInfo->defaultSampleRate = sampleRate;
}
// Get channel info
err = GetChannelInfo(deviceInfo, macCoreDeviceId, 1);
err = GetChannelInfo(deviceInfo, macCoreDeviceId, 0);
return err;
}
示例2: getVolume
static int getVolume(int dir, double *left, double *right)
{
UInt32 sz;
AudioDeviceID id;
Float32 chan1, chan2;
if (!getDefaultDevice(&id, dir))
return 0;
sz= sizeof(chan1);
if (checkError(AudioDeviceGetProperty(id, 1, // left
dir, kAudioDevicePropertyVolumeScalar,
&sz, &chan1),
"GetProperty", "VolumeScalar"))
return 0;
sz= sizeof(chan2);
if (checkError(AudioDeviceGetProperty(id, 2, // right
dir, kAudioDevicePropertyVolumeScalar,
&sz, &chan2),
"GetProperty", "VolumeScalar"))
chan2= chan1;
*left= chan1;
*right= chan2;
return 1;
}
示例3: m_bIsRunning
CoreAudioDriver::CoreAudioDriver( audioProcessCallback processCallback )
: H2Core::AudioOutput( __class_name )
, m_bIsRunning( false )
, mProcessCallback( processCallback )
, m_pOut_L( NULL )
, m_pOut_R( NULL )
{
//INFOLOG( "INIT" );
m_nSampleRate = Preferences::get_instance()->m_nSampleRate;
// m_nBufferSize = Preferences::get_instance()->m_nBufferSize;
// BufferSize is currently set to match the default audio device.
OSStatus err;
UInt32 size = sizeof( AudioDeviceID );
err = AudioHardwareGetProperty(
kAudioHardwarePropertyDefaultOutputDevice,
&size,
&m_outputDevice
);
if ( err != noErr ) {
ERRORLOG( "Could not get Default Output Device" );
}
UInt32 dataSize = sizeof( m_nBufferSize );
err = AudioDeviceGetProperty(
m_outputDevice,
0,
false,
kAudioDevicePropertyBufferFrameSize,
&dataSize,
( void * )&m_nBufferSize
);
if ( err != noErr ) {
ERRORLOG( "get BufferSize error" );
}
INFOLOG( QString( "Buffersize: %1" ).arg( m_nBufferSize ) );
// print some info
AudioStreamBasicDescription outputStreamBasicDescription;
UInt32 propertySize = sizeof( outputStreamBasicDescription );
err = AudioDeviceGetProperty( m_outputDevice, 0, 0, kAudioDevicePropertyStreamFormat, &propertySize, &outputStreamBasicDescription );
if ( err ) {
printf( "AudioDeviceGetProperty: returned %d when getting kAudioDevicePropertyStreamFormat", err );
}
INFOLOG( QString("SampleRate: %1").arg( outputStreamBasicDescription.mSampleRate ) );
INFOLOG( QString("BytesPerPacket: %1").arg( outputStreamBasicDescription.mBytesPerPacket ) );
INFOLOG( QString("FramesPerPacket: %1").arg( outputStreamBasicDescription.mFramesPerPacket ) );
INFOLOG( QString("BytesPerFrame: %1").arg( outputStreamBasicDescription.mBytesPerFrame ) );
INFOLOG( QString("ChannelsPerFrame: %1").arg( outputStreamBasicDescription.mChannelsPerFrame ) );
INFOLOG( QString("BitsPerChannel: %1").arg( outputStreamBasicDescription.mBitsPerChannel ) );
}
示例4: AudioOutputGetVolume
OSStatus AudioOutputGetVolume(AudioDeviceID device, Float32 *left, Float32 *right) {
UInt32 size = (UInt32)sizeof(Float32);
OSStatus err = AudioObjectGetPropertyData(device, &kAudioOutputVolumeProperty, 0, NULL, &size, left);
if (noErr == err) {
*right = *left;
} else if (kAudioHardwareUnknownPropertyError == err) {
UInt32 channels[2];
size = (UInt32)sizeof(Float32);
err = AudioOutputGetStereoChannels(device, &channels[0], &channels[1]);
if (noErr == err) err = AudioDeviceGetProperty(device, channels[0], FALSE, kAudioDevicePropertyVolumeScalar, &size, left);
if (noErr == err) err = AudioDeviceGetProperty(device, channels[1], FALSE, kAudioDevicePropertyVolumeScalar, &size, right);
}
return err;
}
示例5: check_card_capability
static bool_t check_card_capability(AudioDeviceID id, bool_t is_input, char * devname, char *uidname, size_t name_len) {
unsigned int slen=name_len;
Boolean writable=0;
CFStringRef dUID=NULL;
bool_t ret=FALSE;
int err =AudioDeviceGetProperty(id, 0, is_input, kAudioDevicePropertyDeviceName, &slen,devname);
if (err != kAudioHardwareNoError) {
ms_error("get kAudioDevicePropertyDeviceName error %ld", err);
return FALSE;
}
err =AudioDeviceGetPropertyInfo(id, 0, is_input, kAudioDevicePropertyStreamConfiguration, &slen, &writable);
if (err != kAudioHardwareNoError) {
ms_error("get kAudioDevicePropertyDeviceName error %ld", err);
return FALSE;
}
AudioBufferList *buflist = ms_malloc(slen);
err =
AudioDeviceGetProperty(id, 0, is_input, kAudioDevicePropertyStreamConfiguration, &slen, buflist);
if (err != kAudioHardwareNoError) {
ms_error("get kAudioDevicePropertyDeviceName error %ld", err);
ms_free(buflist);
return FALSE;
}
UInt32 j;
for (j = 0; j < buflist->mNumberBuffers; j++) {
if (buflist->mBuffers[j].mNumberChannels > 0) {
ret=TRUE;
break;
}
}
ms_free(buflist);
if (ret==FALSE) return FALSE;
slen = sizeof(CFStringRef);
err =AudioDeviceGetProperty(id, 0, is_input, kAudioDevicePropertyDeviceUID, &slen,&dUID);
if (err != kAudioHardwareNoError) {
ms_error("get kAudioHardwarePropertyDevices error %ld", err);
return FALSE;
}
CFStringGetCString(dUID, uidname, sizeof(uidname),CFStringGetSystemEncoding());
ms_message("CA: devname:%s uidname:%s", devname, uidname);
return ret;
}
示例6: audio_cap_ca_help
static void audio_cap_ca_help(const char *driver_name)
{
UNUSED(driver_name);
OSErr ret;
AudioDeviceID *dev_ids;
int dev_items;
int i;
UInt32 size;
printf("\tcoreaudio : default CoreAudio input\n");
ret = AudioHardwareGetPropertyInfo(kAudioHardwarePropertyDevices, &size, NULL);
if(ret) goto error;
dev_ids = malloc(size);
dev_items = size / sizeof(AudioDeviceID);
ret = AudioHardwareGetProperty(kAudioHardwarePropertyDevices, &size, dev_ids);
if(ret) goto error;
for(i = 0; i < dev_items; ++i)
{
char name[128];
size = sizeof(name);
ret = AudioDeviceGetProperty(dev_ids[i], 0, 0, kAudioDevicePropertyDeviceName, &size, name);
fprintf(stderr,"\tcoreaudio:%d : %s\n", (int) dev_ids[i], name);
}
free(dev_ids);
return;
error:
fprintf(stderr, "[CoreAudio] error obtaining device list.\n");
}
示例7: SetFramesPerBuffer
static PaError SetFramesPerBuffer(AudioDeviceID device, unsigned long framesPerBuffer, int isInput)
{
PaError result = paNoError;
UInt32 preferredFramesPerBuffer = framesPerBuffer;
// while (preferredFramesPerBuffer > UINT32_MAX) {
// preferredFramesPerBuffer /= 2;
// }
UInt32 actualFramesPerBuffer;
UInt32 propSize = sizeof(UInt32);
result = conv_err(AudioDeviceSetProperty(device, NULL, 0, isInput, kAudioDevicePropertyBufferFrameSize, propSize, &preferredFramesPerBuffer));
result = conv_err(AudioDeviceGetProperty(device, 0, isInput, kAudioDevicePropertyBufferFrameSize, &propSize, &actualFramesPerBuffer));
if (result != paNoError) {
// do nothing
}
else if (actualFramesPerBuffer > framesPerBuffer) {
result = paBufferTooSmall;
}
else if (actualFramesPerBuffer < framesPerBuffer) {
result = paBufferTooBig;
}
return result;
}
示例8: AudioDeviceGetPropertyInfo
std::vector<UInt32> CoreAudioUtilities::dataSourceList(AudioDeviceID id, bool isInput) {
OSStatus status = noErr;
std::vector<UInt32> result;
Boolean input = (isInput ? TRUE : FALSE);
UInt32 size = 0;
status = AudioDeviceGetPropertyInfo(id, 0, input, kAudioDevicePropertyDataSources, &size, NULL);
if (status) {
LOG_ERROR("Can't get device property info: kAudioDevicePropertyDataSources");
return result;
}
if (!size) {
return result;
}
UInt32 * ids = (UInt32 *) malloc(size);
status = AudioDeviceGetProperty(id, 0, input, kAudioDevicePropertyDataSources, &size, ids);
if (status) {
LOG_ERROR("Can't get device property: kAudioDevicePropertyDataSources");
} else {
for (unsigned i = 0; i < (size / sizeof(UInt32)); i++) {
result.push_back(ids[i]);
}
}
free(ids);
return result;
}
示例9: m_deviceID
PlexAudioDevice::PlexAudioDevice(AudioDeviceID deviceID)
: m_deviceID(deviceID)
, m_isValid(false)
, m_supportsDigital(false)
{
UInt32 paramSize = 0;
OSStatus err = noErr;
// Retrieve the length of the device name.
SAFELY(AudioDeviceGetPropertyInfo(deviceID, 0, false, kAudioDevicePropertyDeviceName, ¶mSize, NULL));
if (err == noErr)
{
// Retrieve the name of the device.
char* pStrName = new char[paramSize];
pStrName[0] = '\0';
SAFELY(AudioDeviceGetProperty(deviceID, 0, false, kAudioDevicePropertyDeviceName, ¶mSize, pStrName));
if (err == noErr)
{
m_deviceName = pStrName;
// See if the device is writable (can output).
m_hasOutput = computeHasOutput();
// If the device does have output, see if it supports digital.
if (m_hasOutput)
m_supportsDigital = computeDeviceSupportsDigital();
m_isValid = true;
}
delete[] pStrName;
}
}
示例10: deviceIDsArraySize
QList<AudioDeviceID> UBAudioQueueRecorder::inputDeviceIDs()
{
QList<AudioDeviceID> inputDeviceIDs;
UInt32 deviceIDsArraySize(0);
AudioHardwareGetPropertyInfo(kAudioHardwarePropertyDevices, &deviceIDsArraySize, 0);
AudioDeviceID deviceIDs[deviceIDsArraySize / sizeof(AudioDeviceID)];
AudioHardwareGetProperty(kAudioHardwarePropertyDevices, &deviceIDsArraySize, deviceIDs);
int deviceIDsCount = deviceIDsArraySize / sizeof(AudioDeviceID);
for (int i = 0; i < deviceIDsCount; i ++)
{
AudioStreamBasicDescription sf;
UInt32 size = sizeof(AudioStreamBasicDescription);
if (noErr == AudioDeviceGetProperty(deviceIDs[i], 0, true, kAudioDevicePropertyStreamFormat, &size, &sf))
{
inputDeviceIDs << deviceIDs[i];
}
}
/*
foreach(AudioDeviceID id, inputDeviceIDs)
{
qDebug() << "Device" << id << deviceNameFromDeviceID(id) << deviceUIDFromDeviceID(id);
}
*/
return inputDeviceIDs;
}
示例11: Stream_setFormat
// setup conversion from Squeak to device frame format, or vice-versa.
// requires: stereo for output, stereo or mono for input.
//
static int Stream_setFormat(Stream *s, int frameCount, int sampleRate, int stereo)
{
int nChannels= 1 + stereo;
AudioStreamBasicDescription imgFmt, devFmt;
UInt32 sz= sizeof(devFmt);
if (0 == s->direction) nChannels= 2; // insist
if (checkError(AudioDeviceGetProperty(s->id, 0, s->direction,
kAudioDevicePropertyStreamFormat,
&sz, &devFmt),
"GetProperty", "StreamFormat"))
return 0;
debugf("stream %p[%d] device format:\n", s, s->direction); dumpFormat(&devFmt);
imgFmt.mSampleRate = sampleRate;
imgFmt.mFormatID = kAudioFormatLinearPCM;
#if defined(WORDS_BIGENDIAN)
imgFmt.mFormatFlags = kLinearPCMFormatFlagIsSignedInteger | kLinearPCMFormatFlagIsBigEndian;
#else
imgFmt.mFormatFlags = kLinearPCMFormatFlagIsSignedInteger;
#endif
imgFmt.mBytesPerPacket = SqueakFrameSize / (3 - nChannels);
imgFmt.mFramesPerPacket = 1;
imgFmt.mBytesPerFrame = SqueakFrameSize / (3 - nChannels);
imgFmt.mChannelsPerFrame = nChannels;
imgFmt.mBitsPerChannel = 16;
debugf("stream %p[%d] image format:\n", s, s->direction); dumpFormat(&imgFmt);
if (s->direction) // input
{
if (checkError(AudioConverterNew(&devFmt, &imgFmt, &s->converter), "AudioConverter", "New"))
return 0;
sz= sizeof(s->cvtBufSize);
s->cvtBufSize= 512 * devFmt.mBytesPerFrame;
if (checkError(AudioConverterGetProperty(s->converter, kAudioConverterPropertyCalculateOutputBufferSize,
&sz, &s->cvtBufSize),
"GetProperty", "OutputBufferSize"))
return 0;
}
else // output
{
if (checkError(AudioConverterNew(&imgFmt, &devFmt, &s->converter), "AudioConverter", "New"))
return 0;
}
s->channels= nChannels;
s->sampleRate= sampleRate;
s->imgBufSize= SqueakFrameSize * nChannels * frameCount;
frameCount= max(frameCount, 512 * sampleRate / devFmt.mSampleRate);
s->buffer= Buffer_new((s->direction ? DeviceFrameSize : SqueakFrameSize) * nChannels * frameCount * 2);
debugf("stream %p[%d] sound buffer size %d/%d (%d)\n", s, s->direction, s->imgBufSize, s->buffer->size, frameCount);
return 1;
}
示例12: SAFELY
bool PlexAudioDevice::computeDeviceSupportsDigital()
{
bool ret = false;
OSStatus err = noErr;
UInt32 paramSize = 0;
// Retrieve all the output streams.
SAFELY(AudioDeviceGetPropertyInfo(m_deviceID, 0, FALSE, kAudioDevicePropertyStreams, ¶mSize, NULL));
if (err == noErr)
{
int numStreams = paramSize / sizeof(AudioStreamID);
AudioStreamID* pStreams = (AudioStreamID *)malloc(paramSize);
SAFELY(AudioDeviceGetProperty(m_deviceID, 0, FALSE, kAudioDevicePropertyStreams, ¶mSize, pStreams));
if (err == noErr)
{
for (int i=0; i<numStreams && ret == false; i++)
{
if (computeStreamSupportsDigital(pStreams[i]))
ret = true;
}
}
free(pStreams);
}
return ret;
}
示例13: AudioDeviceGetPropertyInfo
/*
==========
idAudioHardwareOSX::GetAvailableNominalSampleRates
==========
*/
void idAudioHardwareOSX::GetAvailableNominalSampleRates( void )
{
UInt32 size;
OSStatus status;
int i, rangeCount;
AudioValueRange *rangeArray;
status = AudioDeviceGetPropertyInfo( selectedDevice, 0, false, kAudioDevicePropertyAvailableNominalSampleRates, &size, NULL );
if ( status != kAudioHardwareNoError )
{
common->Warning( "AudioDeviceGetPropertyInfo %d kAudioDevicePropertyAvailableNominalSampleRates failed. status: %s", selectedDevice, ExtractStatus( status ) );
return;
}
rangeCount = size / sizeof( AudioValueRange );
rangeArray = (AudioValueRange *)malloc( size );
common->Printf( "%d possible rate(s)\n", rangeCount );
status = AudioDeviceGetProperty( selectedDevice, 0, false, kAudioDevicePropertyAvailableNominalSampleRates, &size, rangeArray );
if ( status != kAudioHardwareNoError )
{
common->Warning( "AudioDeviceGetProperty %d kAudioDevicePropertyAvailableNominalSampleRates failed. status: %s", selectedDevice, ExtractStatus( status ) );
free( rangeArray );
return;
}
for( i = 0; i < rangeCount; i++ )
{
common->Printf( " %d: min %g max %g\n", i, rangeArray[ i ].mMinimum, rangeArray[ i ].mMaximum );
}
free( rangeArray );
}
示例14: AudioDeviceGetPropertyInfo
bool CAUOutputDevice::GetPreferredChannelLayout(CCoreAudioChannelLayout& layout)
{
if (!m_DeviceId)
return false;
UInt32 propertySize = 0;
Boolean writable = false;
OSStatus ret = AudioDeviceGetPropertyInfo(m_DeviceId, 0, false,
kAudioDevicePropertyPreferredChannelLayout, &propertySize, &writable);
if (ret)
return false;
void* pBuf = malloc(propertySize);
ret = AudioDeviceGetProperty(m_DeviceId, 0, false,
kAudioDevicePropertyPreferredChannelLayout, &propertySize, pBuf);
if (ret)
CLog::Log(LOGERROR, "CAUOutputDevice::GetPreferredChannelLayout: "
"Unable to retrieve preferred channel layout. Error = %s", GetError(ret).c_str());
else
{
// Copy the result into the caller's instance
layout.CopyLayout(*((AudioChannelLayout*)pBuf));
}
free(pBuf);
return (ret == noErr);
}
示例15: display_device_names
static OSStatus display_device_names()
{
UInt32 size;
Boolean isWritable;
int i, deviceNum;
OSStatus err;
CFStringRef UIname;
err = AudioHardwareGetPropertyInfo(kAudioHardwarePropertyDevices, &size, &isWritable);
if (err != noErr)
return err;
deviceNum = size/sizeof(AudioDeviceID);
AudioDeviceID devices[deviceNum];
err = AudioHardwareGetProperty(kAudioHardwarePropertyDevices, &size, devices);
if (err != noErr)
return err;
for (i = 0; i < deviceNum; i++) {
char device_name[256];
char internal_name[256];
size = sizeof(CFStringRef);
UIname = NULL;
err = AudioDeviceGetProperty(devices[i], 0, false, kAudioDevicePropertyDeviceUID, &size, &UIname);
if (err == noErr) {
CFStringGetCString(UIname, internal_name, 256, CFStringGetSystemEncoding());
} else {
goto error;
}
size = 256;
err = AudioDeviceGetProperty(devices[i], 0, false, kAudioDevicePropertyDeviceName, &size, device_name);
if (err != noErr)
return err;
jack_info("ICI");
jack_info("Device name = \'%s\', internal_name = \'%s\' (to be used as -d parameter)", device_name, internal_name);
}
return noErr;
error:
if (UIname != NULL)
CFRelease(UIname);
return err;
}