view engine/core/audio/soundclip.h @ 181:56ac89189bc4

fixed time handling in fife: - the time scaling method was unreliable when changing the time factors (jumping in the moment of the change) - replaced much calls to SDL_GetTicks with TimerManager::instance()->getTime() - some other time related cleanup
author spq@33b003aa-7bff-0310-803a-e67f0ece8222
date Sat, 31 Jan 2009 04:15:43 +0000
parents 90005975cdbb
children 3804348fe3fb
line wrap: on
line source

/***************************************************************************
 *   Copyright (C) 2005-2008 by the FIFE team                              *
 *   http://www.fifengine.de                                               *
 *   This file is part of FIFE.                                            *
 *                                                                         *
 *   FIFE is free software; you can redistribute it and/or                 *
 *   modify it under the terms of the GNU Lesser General Public            *
 *   License as published by the Free Software Foundation; either          *
 *   version 2.1 of the License, or (at your option) any later version.    *
 *                                                                         *
 *   This library is distributed in the hope that it will be useful,       *
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU     *
 *   Lesser General Public License for more details.                       *
 *                                                                         *
 *   You should have received a copy of the GNU Lesser General Public      *
 *   License along with this library; if not, write to the                 *
 *   Free Software Foundation, Inc.,                                       *
 *   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA          *
 ***************************************************************************/
 
#ifndef FIFE_SOUNDCLIP_H_
#define FIFE_SOUNDCLIP_H_

// Standard C++ library includes
#include <vector>

// Platform specific includes

// 3rd party library includes

// FIFE includes
// These includes are split up in two parts, separated by one empty line
// First block: files included from the FIFE root src directory
// Second block: files included from the same folder
#include "util/base/resourceclass.h"

#include "sounddecoder.h"

namespace FIFE {
	
	/** Different types of audio-file positions
	 */
	enum SoundPositionType {
		SD_SAMPLE_POS,
		SD_TIME_POS,
		SD_BYTE_POS
	};
	
	struct SoundBufferEntry {
		ALuint buffers[BUFFER_NUM];
		unsigned int usedbufs;
		unsigned long deccursor;
	};
	
	/**  Class to handle the buffers of an audio file
	 */
	class SoundClip : public ResourceClass {
	public:
	   
	   SoundClip(SoundDecoder* decptr, bool deletedecoder = true);
	
		~SoundClip();

		// TODO: fill in these stubs! Note: m_location is _not_ properly initialized.
		virtual const ResourceLocation& getResourceLocation() { return m_location; }

		virtual void setResourceLocation(const ResourceLocation& location) { }
		virtual void setResourceFile(const std::string& filename) { }
		
		/** Does this SoundClip require a streaming mechanism?
		 * 
		 * @return Returns true if streaming is required, false if not.
		 */
		bool isStream() {
			return m_isstream;
		}
		
		/** Returns the number of buffers used by the SoundClip
		 * (only for non-streaming sound clips)
		 *
		 * @return Returns the number of buffers.
		 */
		unsigned int countBuffers() {
			return m_buffervec.at(0)->usedbufs;
		}
		
		/** Returns the array of buffers for queuing
		 *
		 */
		ALuint* getBuffers(unsigned int streamid = 0) {
			return m_buffervec.at(streamid)->buffers;
		}
		
		/** Starts streaming the soundclip
		 * @return Returns the streamid
		 */
		unsigned int beginStreaming();
		
		/** Fills the streaming-buffers with initial data
		 *
		 * @param streamid The stream ID
		 */
		void acquireStream(unsigned int streamid);
		
		/** Sets the stream position
		 * @return True if position is invalid (EOF has been reached)
		 */
		bool setStreamPos(unsigned int streamid, SoundPositionType type, float value);
		
		/** Gets the stream position
		 */
		float getStreamPos(unsigned int streamid, SoundPositionType type);
		
		/** Refill a processed buffer with new data
		 * 
		 *  @return True if file was EOF
		 *  @param streamid The stream ID
		 */
		bool getStream(unsigned int streamid, ALuint buffer);
		
		/** Quits Streaming
		 */
		void quitStreaming(unsigned int streamid);
		
		//void addRef() {
		//	m_refcount++;
		//}
		//void decRef() {
		//	m_refcount--;
		//}
	//	unsigned int getRefCount() {
	//		return m_refcount;
	//	}
		
		/** Returns the attached decoder
		 */
		SoundDecoder* getDecoder() {
			return m_decoder;
		}
		
	private:
		ResourceLocation m_location;
		//unsigned int 		m_refcount;			// Reference count of that soundclip
		bool						m_isstream; 		// is stream?
		SoundDecoder*		m_decoder;			// attached decoder
		bool						m_deletedecoder;	// when loadFromDecoder-method is used, decoder shouldn't be deleted
		std::vector<SoundBufferEntry*> m_buffervec;
	};
}

#endif