/* * Copyright (C) 2023 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. */ #include "avmuxer_engine_demo.h" #include #include #include #include #include #include #include namespace OHOS { namespace MediaAVCodec { int AVMuxerEngineDemo::DoWriteSample(uint32_t trackIndex, std::shared_ptr sample) { if (avmuxer_ != nullptr && avmuxer_->WriteSample(trackIndex, sample) == Status::OK) { return 0; } return -1; } int AVMuxerEngineDemo::DoAddTrack(int32_t &trackIndex, std::shared_ptr trackDesc) { Status ret; if ((ret = avmuxer_->AddTrack(trackIndex, trackDesc)) != Status::OK) { std::cout<<"AVMuxerEngineDemo::DoAddTrack failed! ret:"<(ret)< AVMuxerEngineDemo::DoGetInputBufferQueue(uint32_t trackIndex) { std::cout<<"AVMuxerEngineDemo::DoGetInputBufferQueue "<GetInputBufferQueue(trackIndex); } void AVMuxerEngineDemo::DoRunMuxer(const std::string &runMode) { std::string outFileName = GetOutputFileName("engine_mux_" + runMode); outFd_ = open(outFileName.c_str(), O_CREAT | O_WRONLY | O_TRUNC, S_IRUSR | S_IWUSR); if (outFd_ < 0) { std::cout << "Open file failed! filePath is: " << outFileName << std::endl; return; } std::cout<<"==== open success! =====\noutputFileName: "<(-1, -1); if (avmuxer_ == nullptr || avmuxer_->Init(outFd_, outputFormat_) != Status::OK) { std::cout << "avmuxer_ is null" << std::endl; return; } std::cout << "create muxer success " << avmuxer_ << std::endl; SetParameter(); AddAudioTrack(audioParams_); AddVideoTrack(videoParams_); AddCoverTrack(coverParams_); SetUserData(); std::cout << "add track success" << std::endl; if (avmuxer_->Start() != Status::OK) { return; } std::cout << "start muxer success" << std::endl; WriteCoverSample(); std::cout<<"AVMuxerEngineDemo::DoRunMuxer runMode is : "< vecThread; vecThread.emplace_back(MulThdWriteTrackSampleByBufferQueue, this, audioBufferQueue_, audioFile_); vecThread.emplace_back(MulThdWriteTrackSampleByBufferQueue, this, videoBufferQueue_, videoFile_); for (uint32_t i = 0; i < vecThread.size(); ++i) { vecThread[i].join(); } } std::cout << "write muxer success" << std::endl; if (avmuxer_->Stop() != Status::OK) { return; } std::cout << "stop muxer success" << std::endl; long long testTimeEnd = GetTimestamp(); std::cout << "muxer used time: " << testTimeEnd - testTimeStart << "us" << std::endl; } void AVMuxerEngineDemo::DoRunMuxer() { DoRunMuxer(std::string(RUN_NORMAL)); } void AVMuxerEngineDemo::DoRunMultiThreadCase() { DoRunMuxer(std::string(RUN_MUL_THREAD)); } void AVMuxerEngineDemo::SetParameter() { std::shared_ptr param = std::make_shared(); param->Set(Plugins::VideoRotation::VIDEO_ROTATION_0); param->Set("2023-12-19T03:16:00.000Z"); param->Set(22.67f); // 22.67f test latitude param->Set(114.06f); // 114.06f test longitude param->Set("ohos muxer"); param->Set("ohos muxer"); param->Set("ohos muxer"); param->Set("2023-12-19"); param->Set("ohos muxer"); param->Set("ohos muxer"); param->Set("ohos muxer"); param->Set("{marketing-name:\"HW P60\"}"); if (avmuxer_->SetParameter(param) != Status::OK) { std::cout<<"set parameter failed!"< userMeta = std::make_shared(); userMeta->SetData("com.openharmony.version", 5); // 5 test version userMeta->SetData("com.openharmony.model", "LNA-AL00"); userMeta->SetData("com.openharmony.manufacturer", "HW"); userMeta->SetData("com.openharmony.marketing_name", "HW P60"); userMeta->SetData("com.openharmony.capture.fps", 30.00f); // 30.00f test capture fps userMeta->SetData("model", "LNA-AL00"); userMeta->SetData("com.openharmony.flag", true); if (avmuxer_->SetUserMeta(userMeta) != Status::OK) { std::cout<<"set user meta failed!"<