• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2021 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 "dcamera_handler.h"
17 
18 #include <functional>
19 
20 #include "anonymous_string.h"
21 #include "avcodec_info.h"
22 #include "avcodec_list.h"
23 #include "dcamera_manager_callback.h"
24 #include "dcamera_utils_tools.h"
25 #include "distributed_camera_constants.h"
26 #include "distributed_camera_errno.h"
27 #include "distributed_hardware_log.h"
28 #include "metadata_utils.h"
29 
30 namespace OHOS {
31 namespace DistributedHardware {
32 IMPLEMENT_SINGLE_INSTANCE(DCameraHandler);
33 
~DCameraHandler()34 DCameraHandler::~DCameraHandler()
35 {
36     DHLOGI("~DCameraHandler");
37 }
38 
Initialize()39 int32_t DCameraHandler::Initialize()
40 {
41     DHLOGI("DCameraHandler::Initialize");
42     cameraManager_ = CameraStandard::CameraManager::GetInstance();
43     if (cameraManager_ == nullptr) {
44         DHLOGE("DCameraHandler::Initialize cameraManager getInstance failed");
45         return DCAMERA_INIT_ERR;
46     }
47     std::shared_ptr<DCameraManagerCallback> cameraMgrCallback = std::make_shared<DCameraManagerCallback>();
48     cameraManager_->SetCallback(cameraMgrCallback);
49     DHLOGI("DCameraHandler::Initialize success");
50     return DCAMERA_OK;
51 }
52 
Query()53 std::vector<DHItem> DCameraHandler::Query()
54 {
55     std::vector<DHItem> itemList;
56     std::vector<sptr<CameraStandard::CameraDevice>> cameraList = cameraManager_->GetSupportedCameras();
57     DHLOGI("DCameraHandler::Query get %d cameras", cameraList.size());
58     if (cameraList.empty()) {
59         DHLOGE("DCameraHandler::Query no camera device");
60         return itemList;
61     }
62     for (auto& info : cameraList) {
63         if (info->GetConnectionType() != CameraStandard::ConnectionType::CAMERA_CONNECTION_BUILT_IN) {
64             DHLOGI("DCameraHandler::Query connection type: %d", info->GetConnectionType());
65             continue;
66         }
67         DHLOGI("DCameraHandler::Query get %s, position: %d, cameraType: %d",
68             GetAnonyString(info->GetID()).c_str(), info->GetPosition(), info->GetCameraType());
69         DHItem item;
70         if (CreateDHItem(info, item) == DCAMERA_OK) {
71             itemList.emplace_back(item);
72         }
73     }
74     DHLOGI("DCameraHandler::Query success, get %d items", itemList.size());
75     return itemList;
76 }
77 
QueryExtraInfo()78 std::map<std::string, std::string> DCameraHandler::QueryExtraInfo()
79 {
80     DHLOGI("DCameraHandler::QueryExtraInfo");
81     std::map<std::string, std::string> extraInfo;
82     return extraInfo;
83 }
84 
IsSupportPlugin()85 bool DCameraHandler::IsSupportPlugin()
86 {
87     DHLOGI("DCameraHandler::IsSupportPlugin");
88     return false;
89 }
90 
RegisterPluginListener(std::shared_ptr<PluginListener> listener)91 void DCameraHandler::RegisterPluginListener(std::shared_ptr<PluginListener> listener)
92 {
93     DHLOGI("DCameraHandler::RegisterPluginListener");
94     if (listener == nullptr) {
95         DHLOGE("DCameraHandler unregistering plugin listener");
96     }
97     pluginListener_ = listener;
98 }
99 
UnRegisterPluginListener()100 void DCameraHandler::UnRegisterPluginListener()
101 {
102     DHLOGI("DCameraHandler::UnRegisterPluginListener");
103     pluginListener_ = nullptr;
104 }
105 
GetCameras()106 std::vector<std::string> DCameraHandler::GetCameras()
107 {
108     std::vector<std::string> cameras;
109     std::vector<sptr<CameraStandard::CameraDevice>> cameraList = cameraManager_->GetSupportedCameras();
110     DHLOGI("DCameraHandler::GetCameras get %d cameras", cameraList.size());
111     if (cameraList.empty()) {
112         DHLOGE("DCameraHandler::GetCameras no camera device");
113         return cameras;
114     }
115     for (auto& info : cameraList) {
116         sptr<CameraStandard::CameraOutputCapability> capability = cameraManager_->GetSupportedOutputCapability(info);
117         if (capability == nullptr) {
118             DHLOGI("DCameraHandler::GetCameras get supported capability is null");
119             continue;
120         }
121         if (info->GetConnectionType() != CameraStandard::ConnectionType::CAMERA_CONNECTION_BUILT_IN) {
122             DHLOGI("DCameraHandler::GetCameras connection type: %d", info->GetConnectionType());
123             continue;
124         }
125         DHLOGI("DCameraHandler::GetCameras get %s, position: %d, cameraType: %d",
126             GetAnonyString(info->GetID()).c_str(), info->GetPosition(), info->GetCameraType());
127         std::string dhId = CAMERA_ID_PREFIX + info->GetID();
128         cameras.emplace_back(dhId);
129     }
130     DHLOGI("DCameraHandler::GetCameras success, get %d items", cameras.size());
131     return cameras;
132 }
133 
CreateDHItem(sptr<CameraStandard::CameraDevice> & info,DHItem & item)134 int32_t DCameraHandler::CreateDHItem(sptr<CameraStandard::CameraDevice>& info, DHItem& item)
135 {
136     std::string id = info->GetID();
137     item.dhId = CAMERA_ID_PREFIX + id;
138     DHLOGI("DCameraHandler::CreateDHItem camera id: %s", GetAnonyString(id).c_str());
139 
140     Json::Value root;
141     root[CAMERA_PROTOCOL_VERSION_KEY] = Json::Value(CAMERA_PROTOCOL_VERSION_VALUE);
142     root[CAMERA_POSITION_KEY] = Json::Value(GetCameraPosition(info->GetPosition()));
143 
144     std::shared_ptr<Media::AVCodecList> avCodecList = Media::AVCodecListFactory::CreateAVCodecList();
145     std::vector<std::shared_ptr<Media::VideoCaps>> videoCapsList = avCodecList->GetVideoEncoderCaps();
146     for (auto& videoCaps : videoCapsList) {
147         std::shared_ptr<Media::AVCodecInfo> codecInfo = videoCaps->GetCodecInfo();
148         std::string name = codecInfo->GetName();
149         root[CAMERA_CODEC_TYPE_KEY].append(name);
150         DHLOGI("DCameraHandler::CreateDHItem codec type: %s", name.c_str());
151     }
152 
153     sptr<CameraStandard::CameraOutputCapability> capability = cameraManager_->GetSupportedOutputCapability(info);
154     if (capability == nullptr) {
155         DHLOGI("DCameraHandler::CreateDHItem get supported capability is null");
156         return DCAMERA_BAD_VALUE;
157     }
158     std::vector<CameraStandard::Profile> photoProfiles = capability->GetPhotoProfiles();
159     ConfigFormatAndResolution(SNAPSHOT_FRAME, root, photoProfiles);
160 
161     std::vector<CameraStandard::Profile> previewProfiles = capability->GetPreviewProfiles();
162     ConfigFormatAndResolution(CONTINUOUS_FRAME, root, previewProfiles);
163 
164     sptr<CameraStandard::CameraInput> cameraInput = nullptr;
165     int rv = cameraManager_->CreateCameraInput(info, &cameraInput);
166     if (rv != DCAMERA_OK) {
167         DHLOGE("DCameraHandler::CreateDHItem create cameraInput failed");
168         return DCAMERA_BAD_VALUE;
169     }
170 
171     std::hash<std::string> h;
172     std::string abilityString = cameraInput->GetCameraSettings();
173     DHLOGI("DCameraHandler::CreateDHItem abilityString hash: %zu, length: %zu",
174         h(abilityString), abilityString.length());
175 
176     std::string encodeString = Base64Encode(reinterpret_cast<const unsigned char *>(abilityString.c_str()),
177         abilityString.length());
178     DHLOGI("DCameraHandler::CreateDHItem encodeString hash: %zu, length: %zu",
179         h(encodeString), encodeString.length());
180     root[CAMERA_METADATA_KEY] = Json::Value(encodeString);
181 
182     item.attrs = root.toStyledString();
183     if (cameraInput->Release() != DCAMERA_OK) {
184         DHLOGE("DCameraHandler::CreateDHItem cameraInput Release failed");
185     }
186     return DCAMERA_OK;
187 }
188 
GetCameraPosition(CameraStandard::CameraPosition position)189 std::string DCameraHandler::GetCameraPosition(CameraStandard::CameraPosition position)
190 {
191     DHLOGI("DCameraHandler::GetCameraPosition position: %d", position);
192     std::string ret = "";
193     switch (position) {
194         case CameraStandard::CameraPosition::CAMERA_POSITION_BACK: {
195             ret = CAMERA_POSITION_BACK;
196             break;
197         }
198         case CameraStandard::CameraPosition::CAMERA_POSITION_FRONT: {
199             ret = CAMERA_POSITION_FRONT;
200             break;
201         }
202         case CameraStandard::CameraPosition::CAMERA_POSITION_UNSPECIFIED: {
203             ret = CAMERA_POSITION_UNSPECIFIED;
204             break;
205         }
206         default: {
207             DHLOGE("DCameraHandler::GetCameraPosition unknown camera position");
208             break;
209         }
210     }
211     DHLOGI("DCameraHandler::GetCameraPosition success ret: %s", ret.c_str());
212     return ret;
213 }
214 
ConfigFormatAndResolution(const DCStreamType type,Json::Value & root,std::vector<CameraStandard::Profile> & profileList)215 void DCameraHandler::ConfigFormatAndResolution(const DCStreamType type, Json::Value& root,
216     std::vector<CameraStandard::Profile>& profileList)
217 {
218     DHLOGI("DCameraHandler::ConfigFormatAndResolution camera Profile size: %d", profileList.size());
219     std::set<int32_t> formatSet;
220     for (auto& profile : profileList) {
221         CameraStandard::CameraFormat format = profile.GetCameraFormat();
222         CameraStandard::Size picSize = profile.GetSize();
223         int32_t dformat = CovertToDcameraFormat(format);
224         formatSet.insert(dformat);
225         std::string formatName = std::to_string(dformat);
226         if (IsValid(type, picSize)) {
227             std::string resolutionValue = std::to_string(picSize.width) + "*" + std::to_string(picSize.height);
228             if (type == SNAPSHOT_FRAME) {
229                 root[CAMERA_FORMAT_PHOTO][CAMERA_RESOLUTION_KEY][formatName].append(resolutionValue);
230             } else if (type == CONTINUOUS_FRAME) {
231                 root[CAMERA_FORMAT_PREVIEW][CAMERA_RESOLUTION_KEY][formatName].append(resolutionValue);
232                 root[CAMERA_FORMAT_VIDEO][CAMERA_RESOLUTION_KEY][formatName].append(resolutionValue);
233             }
234         }
235     }
236 
237     for (auto format : formatSet) {
238         if (type == SNAPSHOT_FRAME) {
239             root[CAMERA_FORMAT_PHOTO][CAMERA_FORMAT_KEY].append(format);
240         } else if (type == CONTINUOUS_FRAME) {
241             root[CAMERA_FORMAT_PREVIEW][CAMERA_FORMAT_KEY].append(format);
242             root[CAMERA_FORMAT_VIDEO][CAMERA_FORMAT_KEY].append(format);
243         }
244     }
245 }
246 
CovertToDcameraFormat(CameraStandard::CameraFormat format)247 int32_t DCameraHandler::CovertToDcameraFormat(CameraStandard::CameraFormat format)
248 {
249     DHLOGI("DCameraHandler::CovertToDcameraFormat format: %d", format);
250     int32_t ret = -1;
251     switch (format) {
252         case CameraStandard::CameraFormat::CAMERA_FORMAT_RGBA_8888:
253             ret = camera_format_t::OHOS_CAMERA_FORMAT_RGBA_8888;
254             break;
255         case CameraStandard::CameraFormat::CAMERA_FORMAT_YCBCR_420_888:
256             ret = camera_format_t::OHOS_CAMERA_FORMAT_YCBCR_420_888;
257             break;
258         case CameraStandard::CameraFormat::CAMERA_FORMAT_YUV_420_SP:
259             ret = camera_format_t::OHOS_CAMERA_FORMAT_YCRCB_420_SP;
260             break;
261         case CameraStandard::CameraFormat::CAMERA_FORMAT_JPEG:
262             ret = camera_format_t::OHOS_CAMERA_FORMAT_JPEG;
263             break;
264         default:
265             DHLOGE("DCameraHandler::CovertToDcameraFormat invalid camera format");
266             break;
267     }
268     return ret;
269 }
270 
IsValid(const DCStreamType type,const CameraStandard::Size & size)271 bool DCameraHandler::IsValid(const DCStreamType type, const CameraStandard::Size& size)
272 {
273     bool ret = false;
274     switch (type) {
275         case CONTINUOUS_FRAME: {
276             ret = (size.width >= RESOLUTION_MIN_WIDTH) &&
277                     (size.height >= RESOLUTION_MIN_HEIGHT) &&
278                     (size.width <= RESOLUTION_MAX_WIDTH_CONTINUOUS) &&
279                     (size.height <= RESOLUTION_MAX_HEIGHT_CONTINUOUS);
280             break;
281         }
282         case SNAPSHOT_FRAME: {
283             uint64_t dcResolution = static_cast<uint64_t>(size.width * size.width);
284             uint64_t dcMaxResolution = static_cast<uint64_t>(RESOLUTION_MAX_WIDTH_SNAPSHOT *
285                                                              RESOLUTION_MAX_HEIGHT_SNAPSHOT);
286             uint64_t dcMinResolution = static_cast<uint64_t>(RESOLUTION_MIN_WIDTH *
287                                                              RESOLUTION_MIN_HEIGHT);
288             ret = (dcResolution >= dcMinResolution) && (dcResolution <= dcMaxResolution);
289             break;
290         }
291         default: {
292             DHLOGE("DCameraHandler::isValid unknown stream type");
293             break;
294         }
295     }
296     return ret;
297 }
298 
GetHardwareHandler()299 IHardwareHandler* GetHardwareHandler()
300 {
301     DHLOGI("DCameraHandler::GetHardwareHandler");
302     return &DCameraHandler::GetInstance();
303 }
304 } // namespace DistributedHardware
305 } // namespace OHOS