鸿蒙应用开发之媒体(相机)

本文档详细介绍了如何在HarmonyOS中开发相机应用,包括相机的基本概念如静态能力、物理相机和逻辑相机,以及开发流程和权限申请。在创建相机设备时,需要遵循特定的接口调用顺序,并监听相机的状态变化。此外,还提供了权限申请的示例代码,确保应用具备相机、麦克风、位置和存储访问权限。在实际操作中,开发者需要处理相机创建、配置和释放等过程中的各种状态回调。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、概述

HarmonyOS相机模块支持相机业务的开发,开发者可以通过已开放的接口实现相机硬件的访问、操作和新功能开发,最常见的操作如:预览、拍照、连拍和录像等。

1、基本概念

  • 相机静态能力

    用于描述相机的固有能力的一系列参数,比如朝向、支持的分辨率等信息。

  • 物理相机

    物理相机就是独立的实体摄像头设备。物理相机ID是用于标志每个物理摄像头的唯一字串。

  • 逻辑相机

    逻辑相机是多个物理相机组合出来的抽象设备,逻辑相机通过同时控制多个物理相机设备来完成相机某些功能,如大光圈、变焦等功能。逻辑摄像机ID是一个唯一的字符串,标识多个物理摄像机的抽象能力。

  • 帧捕获

    相机启动后对帧的捕获动作统称为帧捕获。主要包含单帧捕获、多帧捕获、循环帧捕获。

  • 单帧捕获

    指的是相机启动后,在帧数据流中捕获一帧数据,常用于普通拍照。

  • 多帧捕获

    指的是相机启动后,在帧数据流中连续捕获多帧数据,常用于连拍。

  • 循环帧捕获

    指的是相机启动后,在帧数据流中一直捕获帧数据,常用于预览和录像。

2、约束与限制

  • 在同一时刻只能有一个相机应用在运行中。
  • 相机模块内部有状态控制,开发者必须按照指导文档中的流程进行接口的顺序调用,否则可能会出现调用失败等问题。
  • 为了开发的相机应用拥有更好的兼容性,在创建相机对象或者参数相关设置前请务必进行能力查询。

3、开发流程

img

二、开发前的一些说明及必要步骤

1、三个重要接口

包名 功能
ohos.media.camera.CameraKit 相机功能入口类。获取当前支持的相机列表及其静态能力信息,创建相机对象。
ohos.media.camera.device 相机设备操作类。提供相机能力查询、相机配置、相机帧捕获、相机状态回调等功能。
ohos.media.camera.params 相机参数类。提供相机属性、参数和操作结果的定义。

2、权限申请

相机涉及到的权限有如下四个

权限名称 权限属性值 是否必选
相机权限 ohos.permission.CAMERA 必选
录音权限 ohos.permission.MICROPHONE 可选(需要录像时申请)
存储权限 ohos.permission.WRITE_USER_STORAGE 可选(需要保存图像及视频到设备的外部存储时申请)
位置权限 ohos.permission.LOCATION 可选(需要保存图像及视频位置信息时申请)

在配置文件中声明权限,这里图方便,我把以上四个权限都请求了,做Demo的时候就不用一个一个加了

"reqPermissions": [
  {
   
    "name": "ohos.permission.CAMERA",
    "name": "ohos.permission.MICROPHONE",
    "name": "ohos.permission.LOCATION",
    "name": "ohos.permission.WRITE_USER_STORAGE"
  }

image-20210120141535344

MainAbilityOnStart方法中对权限进行请求

public class MainAbility extends Ability {
   
    @Override
    public void onStart(Intent intent) {
   
        super.onStart(intent);
        super.setMainRoute(MainAbilitySlice.class.getName());
        String[] permissions = {
   "ohos.permission.CAMERA"
                , "ohos.permission.MICROPHONE"
                , "ohos.permission.LOCATION"
                , "ohos.permission.WRITE_USER_STORAGE"};
        requestPermissionsFromUser(permissions, 0);
    }
}

image-20210120142147059

三、相机设备的创建

CameraKit类是相机的入口API类,用于获取相机设备特性、打开相机,其接口如下表。

接口名 描述
createCamera(String cameraId, CameraStateCallback callback, EventHandler handler) 创建相机对象。
getCameraAbility(String cameraId) 获取指定逻辑相机或物理相机的静态能力。
getCameraIds() 获取当前逻辑相机列表。
getCameraInfo(String cameraId) 获取指定逻辑相机的信息。
getInstance(Context context) 获取CameraKit实例。
registerCameraDeviceCallback(CameraDeviceCallback callback, EventHandler handler) 注册相机使用状态回调。
unregisterCameraDeviceCallback(CameraDeviceCallback callback) 注销相机使用状态回调。

基于HarmonyOS实现一个相机应用,无论将来想应用到哪个或者哪些设备上,都必须先创建一个独立的相机设备,然后才能继续相机的其他操作。

流程

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值