2 * Copyright (c) 2015 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
20 #include "CAudioIODef.h"
24 using namespace tizen_media_audio;
30 CAudioInfo::CAudioInfo() :
31 __mSampleRate(MAX_SYSTEM_SAMPLERATE),
32 __mChannel(EChannel::CHANNEL_MONO),
33 __mSampleType(ESampleType::SAMPLE_TYPE_U8),
34 __mAudioType(EAudioType::AUDIO_IN_TYPE_MEDIA),
38 CAudioInfo::CAudioInfo(unsigned int sampleRate, EChannel channel, ESampleType sampleType, EAudioType audioType, int audioIndex) :
39 __mSampleRate(sampleRate),
41 __mSampleType(sampleType),
42 __mAudioType(audioType),
43 __mAudioIndex(audioIndex),
44 __mReferenceDeviceId(0) {
45 // Check to invalid AudioInfo
46 if (sampleRate < CAudioInfo::MIN_SYSTEM_SAMPLERATE ||
47 sampleRate > CAudioInfo::MAX_SYSTEM_SAMPLERATE)
48 THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT,
49 "The sampleRate is invalid [sampleRate:%u]", sampleRate);
51 if (channel < CAudioInfo::EChannel::CHANNEL_MONO ||
52 channel >= CAudioInfo::EChannel::CHANNEL_MAX)
53 THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT,
54 "The channel is invalid [channel:%u]", to_integral(channel));
56 if (sampleType < CAudioInfo::ESampleType::SAMPLE_TYPE_U8 ||
57 sampleType >= CAudioInfo::ESampleType::SAMPLE_TYPE_MAX)
58 THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT,
59 "The sampleType is invalid [sampleType:%u]", to_integral(sampleType));
61 if (audioType < CAudioInfo::EAudioType::AUDIO_IN_TYPE_MEDIA ||
62 audioType >= CAudioInfo::EAudioType::AUDIO_TYPE_MAX)
63 THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT,
64 "The audioType is invalid [audioType:%u]", to_integral(audioType));
67 unsigned int CAudioInfo::getSampleRate() noexcept {
71 CAudioInfo::EChannel CAudioInfo::getChannel() noexcept {
75 CAudioInfo::ESampleType CAudioInfo::getSampleType() noexcept {
79 CAudioInfo::EAudioType CAudioInfo::getAudioType() noexcept {
83 void CAudioInfo::setAudioTypeByInputStreamType(const char* streamType) {
84 __mAudioType = convertInputStreamTypeToAudioType(streamType);
87 void CAudioInfo::setAudioTypeByOutputStreamType(const char* streamType) {
88 __mAudioType = convertOutputStreamTypeToAudioType(streamType);
91 int CAudioInfo::getAudioIndex() noexcept {
95 void CAudioInfo::setAudioIndex(int audioIndex) noexcept {
96 __mAudioIndex = audioIndex;
99 int CAudioInfo::getSampleSize() noexcept {
100 int bytes_in_sample = 0;
102 switch (__mSampleType) {
103 case ESampleType::SAMPLE_TYPE_U8:
106 case ESampleType::SAMPLE_TYPE_S16_LE:
109 case ESampleType::SAMPLE_TYPE_S24_LE:
112 case ESampleType::SAMPLE_TYPE_S24_32_LE:
113 case ESampleType::SAMPLE_TYPE_S32_LE:
117 AUDIO_IO_LOGW("As unrecognized sample type %d, let's assume S16_LE", static_cast<int>(__mSampleType));
122 return bytes_in_sample * static_cast<int>(__mChannel);
125 void CAudioInfo::bindEchoCancelReferenceDeviceId(int id) noexcept {
126 __mReferenceDeviceId = id;
129 int CAudioInfo::getEchoCancelReferenceDeviceId() noexcept {
130 return __mReferenceDeviceId;
133 const char* CAudioInfo::getConvertedStreamType() {
134 if (__mAudioType < CAudioInfo::EAudioType::AUDIO_IN_TYPE_MEDIA ||
135 __mAudioType >= CAudioInfo::EAudioType::AUDIO_TYPE_MAX)
136 THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE,
137 "The audioType is not supported [audioType:%u]", to_integral(__mAudioType));
139 return __STREAM_TYPE_TABLE[(unsigned int)__mAudioType];
142 CAudioInfo::EAudioType CAudioInfo::convertInputStreamTypeToAudioType(const char *streamType) {
143 for (auto i = (unsigned int)CAudioInfo::EAudioType::AUDIO_IN_TYPE_MEDIA;
144 i < (unsigned int)CAudioInfo::EAudioType::AUDIO_OUT_TYPE_MEDIA;
146 if (!strcmp(__STREAM_TYPE_TABLE[i], streamType))
147 return (CAudioInfo::EAudioType)i;
149 THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE,
150 "The streamType of input is not supported [streamType:%s]", streamType);
153 CAudioInfo::EAudioType CAudioInfo::convertOutputStreamTypeToAudioType(const char *streamType) {
154 for (auto i = (unsigned int)CAudioInfo::EAudioType::AUDIO_OUT_TYPE_MEDIA;
155 i < (unsigned int)CAudioInfo::EAudioType::AUDIO_TYPE_MAX;
157 if (!strcmp(__STREAM_TYPE_TABLE[i], streamType))
158 return (CAudioInfo::EAudioType)i;
160 THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE,
161 "The streamType of output is not supported [streamType:%s]", streamType);