• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2025 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "media_manager_adapter.h"
17 #include "dp_log.h"
18 #include "dp_utils.h"
19 #include "basic_definitions.h"
20 
21 namespace OHOS {
22 namespace CameraStandard {
23 namespace DeferredProcessing {
MediaManagerAdapter()24 MediaManagerAdapter::MediaManagerAdapter()
25 {
26     DP_DEBUG_LOG("MediaManagerAdapter constructor");
27 }
28 
~MediaManagerAdapter()29 MediaManagerAdapter::~MediaManagerAdapter()
30 {
31     DP_DEBUG_LOG("MediaManagerAdapter destructor");
32 }
33 
MpegAcquire(const std::string & requestId,const sptr<IPCFileDescriptor> & inputFd)34 int32_t MediaManagerAdapter::MpegAcquire(const std::string& requestId, const sptr<IPCFileDescriptor>& inputFd)
35 {
36     DP_DEBUG_LOG("MpegAcquire called with requestId: %{public}s", requestId.c_str());
37     mpegManager_ = MpegManagerFactory::GetInstance().Acquire(requestId, inputFd);
38     DP_CHECK_ERROR_RETURN_RET_LOG(mpegManager_ == nullptr, DP_ERR, "mpeg manager is nullptr.");
39     DP_DEBUG_LOG("DPS_VIDEO: Acquire MpegManager.");
40     return DP_OK;
41 }
42 
MpegUnInit(const int32_t result)43 int32_t MediaManagerAdapter::MpegUnInit(const int32_t result)
44 {
45     DP_DEBUG_LOG("MpegUnInit called with result: %{public}d", static_cast<int32_t>(result));
46     DP_CHECK_ERROR_RETURN_RET_LOG(mpegManager_ == nullptr, DP_ERR, "mpeg manager is nullptr.");
47     mpegManager_->UnInit(static_cast<MediaResult>(result));
48     return DP_OK; // Success
49 }
50 
MpegGetResultFd()51 sptr<IPCFileDescriptor> MediaManagerAdapter::MpegGetResultFd()
52 {
53     DP_DEBUG_LOG("MpegGetResultFd called");
54     DP_CHECK_ERROR_RETURN_RET_LOG(mpegManager_ == nullptr, nullptr, "mpeg manager is nullptr.");
55     return mpegManager_->GetResultFd();
56 }
57 
MpegAddUserMeta(std::unique_ptr<MediaUserInfo> userInfo)58 void MediaManagerAdapter::MpegAddUserMeta(std::unique_ptr<MediaUserInfo> userInfo)
59 {
60     DP_DEBUG_LOG("MpegAddUserMeta called");
61     DP_CHECK_ERROR_RETURN_LOG(mpegManager_ == nullptr, "mpeg manager is nullptr.");
62     DP_CHECK_ERROR_RETURN_LOG(userInfo == nullptr, "userProxyInfo is nullptr.");
63     mpegManager_->AddUserMeta(std::move(userInfo));
64 }
65 
MpegGetProcessTimeStamp()66 uint64_t MediaManagerAdapter::MpegGetProcessTimeStamp()
67 {
68     DP_DEBUG_LOG("MpegGetProcessTimeStamp called");
69     DP_CHECK_ERROR_RETURN_RET_LOG(mpegManager_ == nullptr, 0, "mpeg manager is nullptr.");
70     return mpegManager_->GetProcessTimeStamp();
71 }
72 
MpegGetSurface()73 sptr<Surface> MediaManagerAdapter::MpegGetSurface()
74 {
75     DP_DEBUG_LOG("MpegGetSurface called");
76     DP_CHECK_ERROR_RETURN_RET_LOG(mpegManager_ == nullptr, nullptr, "mpeg manager is nullptr.");
77     return mpegManager_->GetSurface();
78 }
79 
MpegGetMakerSurface()80 sptr<Surface> MediaManagerAdapter::MpegGetMakerSurface()
81 {
82     DP_DEBUG_LOG("MpegGetMakerSurface called");
83     DP_CHECK_ERROR_RETURN_RET_LOG(mpegManager_ == nullptr, nullptr, "mpeg manager is nullptr.");
84     return mpegManager_->GetMakerSurface();
85 }
86 
MpegSetMarkSize(int32_t size)87 void MediaManagerAdapter::MpegSetMarkSize(int32_t size)
88 {
89     DP_DEBUG_LOG("MpegSetMarkSize called with size: %{public}d", size);
90     DP_CHECK_ERROR_RETURN_LOG(mpegManager_ == nullptr, "mpeg manager is nullptr.");
91     mpegManager_->SetMarkSize(size);
92 }
93 
MpegRelease()94 int32_t MediaManagerAdapter::MpegRelease()
95 {
96     DP_DEBUG_LOG("MpegRelease called");
97     MpegManagerFactory::GetInstance().Release(mpegManager_);
98     mpegManager_.reset();
99     DP_INFO_LOG("DPS_VIDEO: Release MpegManager.");
100     return DP_OK; // Success
101 }
102 
createMediaManagerIntf()103 extern "C" MediaManagerIntf *createMediaManagerIntf()
104 {
105     return new MediaManagerAdapter();
106 }
107 } // namespace DeferredProcessing
108 } // namespace CameraStandard
109 } // namespace OHOS