summaryrefslogtreecommitdiff
path: root/src/audio
diff options
context:
space:
mode:
Diffstat (limited to 'src/audio')
-rw-r--r--src/audio/audio_task.cpp15
-rw-r--r--src/audio/include/audio_task.hpp4
2 files changed, 10 insertions, 9 deletions
diff --git a/src/audio/audio_task.cpp b/src/audio/audio_task.cpp
index baa0a52d..05a06ad1 100644
--- a/src/audio/audio_task.cpp
+++ b/src/audio/audio_task.cpp
@@ -56,18 +56,20 @@ static const char* kTag = "audio_dec";
static constexpr std::size_t kCodecBufferLength = 240 * 4;
-Timer::Timer(uint32_t sample_rate, uint32_t total_samples)
- : sample_rate_(sample_rate),
+Timer::Timer(const codecs::ICodec::OutputFormat& format)
+ : format_(format),
current_seconds_(0),
current_sample_in_second_(0),
- total_duration_seconds_(total_samples / sample_rate) {}
+ total_duration_seconds_(format.total_samples.value_or(0) /
+ format.num_channels / format.sample_rate_hz) {}
auto Timer::AddSamples(std::size_t samples) -> void {
bool incremented = false;
current_sample_in_second_ += samples;
- while (current_sample_in_second_ >= sample_rate_) {
+ while (current_sample_in_second_ >=
+ format_.sample_rate_hz * format_.num_channels) {
current_seconds_++;
- current_sample_in_second_ -= sample_rate_;
+ current_sample_in_second_ -= format_.sample_rate_hz * format_.num_channels;
incremented = true;
}
@@ -138,8 +140,7 @@ auto AudioTask::BeginDecoding(std::shared_ptr<codecs::IStream> stream) -> bool {
}
if (open_res->total_samples) {
- timer_.reset(
- new Timer(open_res->sample_rate_hz, open_res->total_samples.value()));
+ timer_.reset(new Timer(open_res.value()));
} else {
timer_.reset();
}
diff --git a/src/audio/include/audio_task.hpp b/src/audio/include/audio_task.hpp
index 5614fbbd..72b89ba2 100644
--- a/src/audio/include/audio_task.hpp
+++ b/src/audio/include/audio_task.hpp
@@ -23,12 +23,12 @@ namespace audio {
class Timer {
public:
- Timer(uint32_t sample_rate, uint32_t total_samples);
+ Timer(const codecs::ICodec::OutputFormat& format);
auto AddSamples(std::size_t) -> void;
private:
- uint32_t sample_rate_;
+ codecs::ICodec::OutputFormat format_;
uint32_t current_seconds_;
uint32_t current_sample_in_second_;