From 1d900940ab70964d60da06bc517a09bf3ab8f6c1 Mon Sep 17 00:00:00 2001 From: Dhilan007 Date: Fri, 5 Sep 2014 14:34:30 +0800 Subject: [PATCH] Refactoring API: 1.Remove Singleton Pattern 2.Make AudioProfile clear. --- cocos/audio/AudioEngine.cpp | 6 ++++-- cocos/audio/ios/AudioEngine-inl.h | 6 ++---- cocos/audio/ios/AudioEngine-inl.mm | 20 +++++++------------- 3 files changed, 13 insertions(+), 19 deletions(-) diff --git a/cocos/audio/AudioEngine.cpp b/cocos/audio/AudioEngine.cpp index bb94580e16..daa977063a 100644 --- a/cocos/audio/AudioEngine.cpp +++ b/cocos/audio/AudioEngine.cpp @@ -133,8 +133,10 @@ int AudioEngine::play2d(const std::string& filePath, bool loop, float volume, co audioRef.is3dAudio = false; audioRef.filePath = &it->first; - manage->lastPlayTime = utils::gettime(); - manage->audioIDs.push_back(ret); + if (manage) { + manage->lastPlayTime = utils::gettime(); + manage->audioIDs.push_back(ret); + } audioRef.profileManage = manage; } } while (0); diff --git a/cocos/audio/ios/AudioEngine-inl.h b/cocos/audio/ios/AudioEngine-inl.h index 8a6e4b846e..835367a06f 100644 --- a/cocos/audio/ios/AudioEngine-inl.h +++ b/cocos/audio/ios/AudioEngine-inl.h @@ -33,7 +33,6 @@ #include "AudioPlayer.h" NS_CC_BEGIN -class AudioEngine; class AudioProfile; #define kMaxSources 32 @@ -43,11 +42,11 @@ class AudioEngineThreadPool; class AudioEngineImpl : public cocos2d::Ref { public: - AudioEngineImpl(AudioEngine* audioEngine); + AudioEngineImpl(); ~AudioEngineImpl(); bool init(); - int play2d(const std::string &fileFullPath ,bool loop ,float volume, AudioProfile* profile); + int play2d(const std::string &fileFullPath ,bool loop ,float volume); void setVolume(int audioID,float volume); void setLoop(int audioID, bool loop); bool pause(int audioID); @@ -68,7 +67,6 @@ private: void _play2d(AudioCache *cache, int audioID); AudioEngineThreadPool* _threadPool; - AudioEngine* _audioEngine; ALuint _alSources[kMaxSources]; diff --git a/cocos/audio/ios/AudioEngine-inl.mm b/cocos/audio/ios/AudioEngine-inl.mm index 32b3b74f45..2c4769d567 100644 --- a/cocos/audio/ios/AudioEngine-inl.mm +++ b/cocos/audio/ios/AudioEngine-inl.mm @@ -132,9 +132,8 @@ namespace cocos2d { }; } -AudioEngineImpl::AudioEngineImpl(AudioEngine* audioEngine) -: _audioEngine(audioEngine) -, _lazyInitLoop(true) +AudioEngineImpl::AudioEngineImpl() +: _lazyInitLoop(true) , nextAudioID(0) , _threadPool(nullptr) { @@ -193,7 +192,7 @@ bool AudioEngineImpl::init() return ret; } -int AudioEngineImpl::play2d(const std::string &filePath ,bool loop ,float volume, AudioProfile* profile) +int AudioEngineImpl::play2d(const std::string &filePath ,bool loop ,float volume) { if (s_ALDevice == nullptr) { return AudioEngine::INVAILD_AUDIO_ID; @@ -233,11 +232,6 @@ int AudioEngineImpl::play2d(const std::string &filePath ,bool loop ,float volume _alSourceUsed[alSource] = true; - if (profile) { - profile->lastPlayTime = utils::gettime(); - profile->audioIDs.push_back(nextAudioID); - } - if (_lazyInitLoop) { _lazyInitLoop = false; @@ -254,7 +248,7 @@ void AudioEngineImpl::_play2d(AudioCache *cache, int audioID) auto playerIt = _audioPlayers.find(audioID); if (playerIt != _audioPlayers.end()) { if (playerIt->second.play2d(cache)) { - _audioEngine->_audioInfos[audioID].state = AudioEngine::AudioState::PLAYING; + AudioEngine::_audioInfos[audioID].state = AudioEngine::AudioState::PLAYING; } else{ _threadMutex.lock(); @@ -455,7 +449,7 @@ void AudioEngineImpl::update(float dt) if (playerIt != _audioPlayers.end()) { _alSourceUsed[playerIt->second._alSource] = false; _audioPlayers.erase(audioID); - _audioEngine->remove(audioID); + AudioEngine::remove(audioID); } } size_t removeCacheCount = _removeCaches.size(); @@ -478,12 +472,12 @@ void AudioEngineImpl::update(float dt) if (player._ready && sourceState == AL_STOPPED) { _alSourceUsed[player._alSource] = false; - auto& audioInfo = _audioEngine->_audioInfos[audioID]; + auto& audioInfo = AudioEngine::_audioInfos[audioID]; if (player._finishCallbak) { player._finishCallbak(audioID, *audioInfo.filePath); } - _audioEngine->remove(audioID); + AudioEngine::remove(audioID); it = _audioPlayers.erase(it); }