EMIPLIB
|
00001 /* 00002 00003 This file is a part of EMIPLIB, the EDM Media over IP Library. 00004 00005 Copyright (C) 2006-2011 Hasselt University - Expertise Centre for 00006 Digital Media (EDM) (http://www.edm.uhasselt.be) 00007 00008 This library is free software; you can redistribute it and/or 00009 modify it under the terms of the GNU Lesser General Public 00010 License as published by the Free Software Foundation; either 00011 version 2.1 of the License, or (at your option) any later version. 00012 00013 This library is distributed in the hope that it will be useful, 00014 but WITHOUT ANY WARRANTY; without even the implied warranty of 00015 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00016 Lesser General Public License for more details. 00017 00018 You should have received a copy of the GNU Lesser General Public 00019 License along with this library; if not, write to the Free Software 00020 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 00021 USA 00022 00023 */ 00024 00029 #ifndef MIPOPENALOUTPUT_H 00030 00031 #define MIPOPENALOUTPUT_H 00032 00033 #include "mipconfig.h" 00034 00035 #ifdef MIPCONFIG_SUPPORT_OPENAL 00036 00037 #include "mipcomponent.h" 00038 #include <al.h> 00039 #include <alc.h> 00040 #include <map> 00041 00055 class EMIPLIB_IMPORTEXPORT MIPOpenALOutput : public MIPComponent 00056 { 00057 public: 00058 MIPOpenALOutput(); 00059 virtual ~MIPOpenALOutput(); 00060 00068 bool open(int sampRate, int channels, int precision = 16); 00069 00071 bool close(); 00072 00077 bool setSourcePosition(uint64_t sourceID, real_t pos[3]); 00078 00084 bool setOwnPosition(real_t pos[3], real_t frontDirection[3], real_t upDirection[3]); 00085 00086 bool push(const MIPComponentChain &chain, int64_t iteration, MIPMessage *pMsg); 00087 bool pull(const MIPComponentChain &chain, int64_t iteration, MIPMessage **pMsg); 00088 00089 private: 00090 bool getSource(uint64_t sourceID, ALuint *pSource); 00091 bool enqueueData(ALuint source, void *pData, size_t size); 00092 static ALenum calcFormat(int channels, int precision); 00093 00094 private: 00095 bool m_init; 00096 00097 int m_sampRate; 00098 int m_channels; 00099 00100 ALenum m_format; 00101 ALCdevice *m_pDevice; 00102 ALCcontext *m_pContext; 00103 00104 std::map<uint64_t, ALuint> m_sources; 00105 }; 00106 00107 #endif // MIPCONFIG_SUPPORT_OPENAL 00108 00109 #endif // MIPOPENALOUTPUT_H