/* * Copyright (C) 2024 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef AVCODEC_AUDIO_AVBUFFER_DECODER_FLUSH_DEMO_H #define AVCODEC_AUDIO_AVBUFFER_DECODER_FLUSH_DEMO_H #include #include #include #include #include #include "native_avcodec_audiocodec.h" #include "nocopyable.h" #include "common/native_mfmagic.h" #include "native_avdemuxer.h" #include "avcodec_audio_common.h" namespace OHOS { namespace MediaAVCodec { namespace AudioBufferDemo { enum class AudioBufferFormatType : int32_t { TYPE_AAC = 0, TYPE_FLAC = 1, TYPE_MP3 = 2, TYPE_VORBIS = 3, TYPE_AMRNB = 4, TYPE_AMRWB = 5, TYPE_VIVID = 6, TYPE_OPUS = 7, TYPE_G711MU = 8, TYPE_APE = 9, TYPE_LBVC = 10, TYPE_MAX = 20, }; class ADecBufferSignal { public: std::mutex inMutex_; std::mutex outMutex_; std::mutex startMutex_; std::condition_variable inCond_; std::condition_variable outCond_; std::condition_variable startCond_; std::queue inQueue_; std::queue outQueue_; std::queue inBufferQueue_; std::queue outBufferQueue_; }; class ADecBufferDemo : public NoCopyable { public: ADecBufferDemo(); virtual ~ADecBufferDemo(); /** * @functionTest * @input inputFile * @output outputFile **/ bool InitFile(const std::string& inputFile); bool RunCaseFlush(const uint8_t *data, size_t size); OH_AVCodec* CreateByMime(const char* mime); OH_AVCodec* CreateByName(const char* name); OH_AVErrCode Destroy(OH_AVCodec* codec); OH_AVErrCode SetCallback(OH_AVCodec* codec); OH_AVErrCode Configure(OH_AVCodec* codec, OH_AVFormat* format, int32_t channel, int32_t sampleRate); OH_AVErrCode Prepare(OH_AVCodec* codec); OH_AVErrCode Start(OH_AVCodec* codec); OH_AVErrCode Stop(OH_AVCodec* codec); OH_AVErrCode Flush(OH_AVCodec* codec); OH_AVErrCode Reset(OH_AVCodec* codec); OH_AVFormat* GetOutputDescription(OH_AVCodec* codec); OH_AVErrCode PushInputData(OH_AVCodec* codec, uint32_t index); OH_AVErrCode FreeOutputData(OH_AVCodec* codec, uint32_t index); OH_AVErrCode IsValid(OH_AVCodec* codec, bool* isValid); uint32_t GetInputIndex(); OH_AVErrCode PushInputDataEOS(OH_AVCodec* codec, uint32_t index); uint32_t GetOutputIndex(); OH_AVErrCode SetParameter(OH_AVCodec* codec, OH_AVFormat* format, int32_t channel, int32_t sampleRate); private: int32_t CreateDec(); int32_t Configure(OH_AVFormat *format); int32_t Start(); int32_t Stop(); int32_t Flush(); int32_t Reset(); int32_t Release(); void InputFunc(); void OutputFunc(); void HandleInputEOS(const uint32_t index); bool InitFormat(OH_AVFormat *format); std::atomic isRunning_ = false; std::unique_ptr inputLoop_; std::unique_ptr outputLoop_; OH_AVCodec *audioDec_; ADecBufferSignal *signal_; struct OH_AVCodecCallback cb_; bool isFirstFrame_ = true; uint32_t frameCount_ = 0; AudioBufferFormatType audioType_; size_t inputdatasize = 0; std::string inputdata; bool eosFlag = false; }; } // namespace AudioBufferDemo } // namespace MediaAVCodec } // namespace OHOS #endif // AVCODEC_AUDIO_AVBUFFER_DECODER_FLUSH_DEMO_H