mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 22:12:44 +00:00 
			
		
		
		
	 563cc17a50
			
		
	
	
		563cc17a50
		
	
	
	
	
		
			
			LibAudio's WavLoader plugin for loading WAV files now supports loading audio files with 32-bit float or 64-bit float samples. By supporting these new non-int sample formats, Audio::Buffer now stores the sample format (out of a list of supported formats) instead of the raw bit depth. (The bit depth is easily calculated with pcm_bits_per_sample)
		
			
				
	
	
		
			75 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2021, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/ByteBuffer.h>
 | |
| #include <AK/RefCounted.h>
 | |
| #include <AK/RefPtr.h>
 | |
| #include <AK/StringView.h>
 | |
| #include <LibAudio/Buffer.h>
 | |
| #include <LibCore/File.h>
 | |
| 
 | |
| namespace Audio {
 | |
| 
 | |
| class LoaderPlugin {
 | |
| public:
 | |
|     virtual ~LoaderPlugin() { }
 | |
| 
 | |
|     virtual bool sniff() = 0;
 | |
| 
 | |
|     virtual bool has_error() { return false; }
 | |
|     virtual const char* error_string() { return ""; }
 | |
| 
 | |
|     virtual RefPtr<Buffer> get_more_samples(size_t max_bytes_to_read_from_input = 128 * KiB) = 0;
 | |
| 
 | |
|     virtual void reset() = 0;
 | |
|     virtual void seek(const int position) = 0;
 | |
| 
 | |
|     virtual int loaded_samples() = 0;
 | |
|     virtual int total_samples() = 0;
 | |
|     virtual u32 sample_rate() = 0;
 | |
|     virtual u16 num_channels() = 0;
 | |
|     virtual PcmSampleFormat pcm_format() = 0;
 | |
|     virtual RefPtr<Core::File> file() = 0;
 | |
| };
 | |
| 
 | |
| class Loader : public RefCounted<Loader> {
 | |
| public:
 | |
|     static NonnullRefPtr<Loader> create(const StringView& path) { return adopt_ref(*new Loader(path)); }
 | |
|     static NonnullRefPtr<Loader> create(const ByteBuffer& buffer) { return adopt_ref(*new Loader(buffer)); }
 | |
| 
 | |
|     bool has_error() const { return m_plugin ? m_plugin->has_error() : true; }
 | |
|     const char* error_string() const { return m_plugin ? m_plugin->error_string() : "No loader plugin available"; }
 | |
| 
 | |
|     RefPtr<Buffer> get_more_samples(size_t max_bytes_to_read_from_input = 128 * KiB) const { return m_plugin ? m_plugin->get_more_samples(max_bytes_to_read_from_input) : nullptr; }
 | |
| 
 | |
|     void reset() const
 | |
|     {
 | |
|         if (m_plugin)
 | |
|             m_plugin->reset();
 | |
|     }
 | |
|     void seek(const int position) const
 | |
|     {
 | |
|         if (m_plugin)
 | |
|             m_plugin->seek(position);
 | |
|     }
 | |
| 
 | |
|     int loaded_samples() const { return m_plugin ? m_plugin->loaded_samples() : 0; }
 | |
|     int total_samples() const { return m_plugin ? m_plugin->total_samples() : 0; }
 | |
|     u32 sample_rate() const { return m_plugin ? m_plugin->sample_rate() : 0; }
 | |
|     u16 num_channels() const { return m_plugin ? m_plugin->num_channels() : 0; }
 | |
|     u16 bits_per_sample() const { return m_plugin ? pcm_bits_per_sample(m_plugin->pcm_format()) : 0; }
 | |
|     RefPtr<Core::File> file() const { return m_plugin ? m_plugin->file() : nullptr; }
 | |
| 
 | |
| private:
 | |
|     Loader(const StringView& path);
 | |
|     Loader(const ByteBuffer& buffer);
 | |
| 
 | |
|     mutable OwnPtr<LoaderPlugin> m_plugin;
 | |
| };
 | |
| 
 | |
| }
 |