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 MIPHRIRLISTEN_H 00030 00031 #define MIPHRIRLISTEN_H 00032 00033 #include "mipconfig.h" 00034 #include "miphrirbase.h" 00035 #include <cmath> 00036 #include <list> 00037 00038 class MIPRawFloatAudioMessage; 00039 00045 class EMIPLIB_IMPORTEXPORT MIPHRIRListen : public MIPHRIRBase 00046 { 00047 public: 00048 MIPHRIRListen(); 00049 ~MIPHRIRListen(); 00050 00066 bool init(const std::string &baseDirectory, int maxFilterLength = 48, 00067 bool allowAmbientSound = true, bool useDistance = true); 00068 00070 bool destroy(); 00071 00078 bool selectHRIRSet(int subjectNumber, bool compensated = true); 00079 00081 int getSamplingRate() const { return m_sampingRate; } 00082 00084 bool getSubjectNumbers(std::list<int> &subjectNumbers, bool compensated = true); 00085 00086 bool push(const MIPComponentChain &chain, int64_t iteration, MIPMessage *pMsg); 00087 bool pull(const MIPComponentChain &chain, int64_t iteration, MIPMessage **pMsg); 00088 private: 00089 void clearMessages(); 00090 void clearHRIRSets(); 00091 bool searchDirectory(const std::string &path, bool reportOpenError = false); 00092 bool processFile(const std::string &baseDir, const std::string &fileName); 00093 00094 bool m_init; 00095 bool m_ambient; 00096 bool m_useDistance; 00097 int m_sampingRate; 00098 int m_maxFilterLength; 00099 00100 std::list<HRIRInfo *> m_rawHRIRSets; 00101 std::list<HRIRInfo *> m_compensatedHRIRSets; 00102 00103 HRIRInfo *m_pCurHRIRSet; 00104 00105 int64_t m_prevIteration; 00106 std::list<MIPRawFloatAudioMessage *> m_messages; 00107 std::list<MIPRawFloatAudioMessage *>::const_iterator m_msgIt; 00108 }; 00109 00110 #endif // MIPHRIRLISTEN_H 00111