harmony 鸿蒙手电筒使用(C++)
手电筒使用(C++)
手电筒模式的使用是通过手机启用手电筒功能,使设备的手电筒功能持续保持常亮状态。
在使用相机应用并操作手电筒功能时,存在以下几种情况说明:
- 当使用后置相机并设置闪光灯模式Camera_FlashMode关闭时,手电筒功能无法启用。
- 当使用前置相机时,手电筒可以正常启用并保持常亮状态。
- 从前置相机切换至后置相机时,如果手电筒原本处于开启状态,它将会被自动关闭。
开发步骤
详细的API说明请参考Camera API参考。
- 导入NDK接口。选择系统提供的NDK接口能力,导入NDK接口的方法如下。
// 导入NDK接口头文件。
#include "hilog/log.h"
#include "ohcamera/camera.h"
#include "ohcamera/camera_input.h"
#include "ohcamera/capture_session.h"
#include "ohcamera/camera_manager.h"
在CMake脚本中链接相关动态库。
target_link_libraries(entry PUBLIC libace_napi.z.so libohcamera.so libhilog_ndk.z.so )
通过OH_CameraManager_IsTorchSupported()方法,检测当前设备是否支持手电筒。
bool IsTorchSupported(Camera_Manager* cameraManager)
{
// 判断设备是否支持手电筒模式。
bool isTorchSupported = false;
Camera_ErrorCode ret = OH_CameraManager_IsTorchSupported(cameraManager, &isTorchSupported);
if (cameraManager == nullptr||ret != CAMERA_OK) {
OH_LOG_ERROR(LOG_APP, "OH_CameraManager_IsTorchSupported failed.");
}
if (isTorchSupported) {
OH_LOG_INFO(LOG_APP, "isTorchSupported success.");
} else {
OH_LOG_ERROR(LOG_APP, "isTorchSupported failed.");
}
return isTorchSupported;
}
- 通过OH_CameraManager_IsTorchSupportedByTorchMode()方法,检测当前设备是否支持指定的手电筒模式。
bool IsTorchSupportedByTorchMode(Camera_Manager* cameraManager, Camera_TorchMode torchMode)
{
bool torchModeSupported = false;
Camera_ErrorCode ret = OH_CameraManager_IsTorchSupportedByTorchMode(cameraManager, torchMode, &torchModeSupported);
if (cameraManager == nullptr||ret != CAMERA_OK) {
OH_LOG_ERROR(LOG_APP, "OH_CameraManager_IsTorchSupported failed.");
}
if (torchModeSupported) {
OH_LOG_INFO(LOG_APP, "isTorchModeSupported success.");
} else {
OH_LOG_ERROR(LOG_APP, "isTorchModeSupported failed. %{public}d ", ret);
}
return torchModeSupported;
}
- 通过OH_CameraManager_SetTorchMode()方法,设置当前设备的手电筒模式。
Camera_ErrorCode SetTorchMode(Camera_Manager* cameraManager, Camera_TorchMode torchMode)
{
// 在torchMode支持的情况下进行设置手电筒模式。
Camera_ErrorCode ret = OH_CameraManager_SetTorchMode(cameraManager, torchMode);
if (ret != CAMERA_OK) {
OH_LOG_ERROR(LOG_APP, "OH_CameraManager_SetTorchMode failed. %{public}d ", ret);
} else {
OH_LOG_INFO(LOG_APP, "OH_CameraManager_SetTorchMode success.");
}
return ret;
}
状态监听
在相机应用开发过程中,可以随时监听手电筒状态,包括手电筒打开、手电筒关闭、手电筒不可用、手电筒恢复可用。手电筒状态发生变化,可通过回调函数获取手电筒模式的变化。
通过注册torchStatus事件,通过回调返回监听结果,callback返回Camera_TorchStatusInfo参数,参数的具体内容可参考相机管理器回调接口实例Camera_TorchStatusInfo。
void TorchStatusCallback(Camera_Manager *cameraManager, Camera_TorchStatusInfo* torchStatus)
{
OH_LOG_INFO(LOG_APP, "TorchStatusCallback is called.");
}
Camera_ErrorCode RegisterTorchStatusCallback(Camera_Manager *cameraManager)
{
Camera_ErrorCode ret = OH_CameraManager_RegisterTorchStatusCallback(cameraManager, TorchStatusCallback);
if (ret != CAMERA_OK) {
OH_LOG_ERROR(LOG_APP, "OH_CameraManager_RegisterTorchStatusCallback failed.");
}
return ret;
}
你可能感兴趣的鸿蒙文章
harmony 鸿蒙高性能拍照实践(仅对系统应用开放)(ArkTS)
harmony 鸿蒙高性能拍照(仅对系统应用开放)(ArkTS)
0
赞
- 所属分类: 后端技术
- 本文标签:
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦