OpenHarmony鸿蒙开发:(5.0 Beta) 驱动使用详解-ADC

  鸿蒙开发往期必看:

一分钟了解”纯血版!鸿蒙HarmonyOS Next应用开发!

“非常详细的” 鸿蒙HarmonyOS Next应用开发学习路线!(从零基础入门到精通)

 “一杯冰美式的时间” 了解鸿蒙HarmonyOS Next应用开发路径!


功能简介

ADC(Analog to Digital Converter),即模拟-数字转换器,可将模拟信号转换成对应的数字信号,便于存储与计算等操作。除电源线和地线之外,ADC只需要1根线与被测量的设备进行连接,其物理连线如图1所示:

图 1 ADC物理连线示意图

ADC接口定义了完成AD转换的通用方法集合,包括:

  • ADC设备管理:打开或关闭ADC设备。

  • ADC读取转换结果:读取AD转换结果。

基本概念

  • 分辨率

    分辨率指的是ADC模块能够转换的二进制位数,位数越多分辨率越高。

  • 转换误差

    转换误差通常是以输出误差的最大值形式给出。它表示A/D转换器实际输出的数字量和理论上的输出数字量之间的差别。常用最低有效位的倍数表示。

  • 转换时间

    转换时间是指A/D转换器从转换控制信号到来开始,到输出端得到稳定的数字信号所经过的时间。

运作机制

在HDF框架中,同类型设备对象较多时(可能同时存在十几个同类型配置器),如果采用独立服务模式则需要配置更多的设备节点,且相关服务会占据更多的内存资源。相反,采用统一服务模式可以使用一个设备服务作为管理器,统一处理所有同类型对象的外部访问(这会在配置文件中有所体现),实现便捷管理和节约资源的目的。ADC模块接口适配模式采用统一服务模式。

约束与限制

ADC模块仅支持轮询方式读取数据。

使用指导

场景介绍

ADC设备通常用于将模拟电压或电流转换为数字量,例如与NTC电阻搭配进行温度测量,或者将其他模拟传感器的输出量转换为数字量的场景。

接口说明

ADC模块提供的主要接口如表1所示,具体API详见//drivers/hdf_core/framework/include/platform/adc_if.h。

表 1 ADC驱动API接口功能介绍

接口名接口描述
DevHandle AdcOpen(uint32_t number)打开ADC设备
void AdcClose(DevHandle handle)关闭ADC设备
int32_t AdcRead(DevHandle handle, uint32_t channel, uint32_t *val)读取AD转换结果值

开发步骤

使用ADC设备的一般流程如图2所示。

图 2 ADC使用流程图

打开ADC设备

在进行AD转换之前,首先要调用AdcOpen打开ADC设备。

DevHandle AdcOpen(int16_t number);
c

表 2 AdcOpen参数和返回值描述

参数参数描述
numberint16_t类型,ADC设备号
返回值返回值描述
NULL打开ADC设备失败
设备句柄打开的ADC设备句柄

假设系统中存在2个ADC设备,编号从0到1,那么我们现在打开1号设备。

DevHandle adcHandle = NULL;  // ADC设备句柄

// 打开ADC设备
adcHandle = AdcOpen(1);
if (adcHandle == NULL) {
    HDF_LOGE("AdcOpen: fail\n");
    return NULL;
}
读取AD转换结果
int32_t AdcRead(DevHandle handle, uint32_t channel, uint32_t *val);

表 3 AdcRead参数和返回值描述

参数参数描述
handleDevHandle类型,ADC设备句柄
channeluint32_t类型,ADC设备通道号
valuint32_t类型指针,AD转换结果
返回值返回值描述
HDF_SUCCESS读取成功
负数读取失败

读取转换结果示例(以通道1为例):

uint32_t value;
int32_t ret;

ret = AdcRead(adcHandle, 1, &value);
if (ret != HDF_SUCCESS) {
    HDF_LOGE("ADC read fail!\n");
    return ret;
}
关闭ADC设备

ADC通信完成之后,需要关闭ADC设备。

void AdcClose(DevHandle handle); 

表 4 AdcClose参数和返回值描述

参数参数描述
handleDevHandle类型,ADC设备句柄
返回值返回值描述

关闭ADC设备示例:

AdcClose(adcHandle); // 关闭ADC设备

使用实例

本例拟对Hi3516DV300开发板上ADC设备进行简单的读取操作,基本硬件信息如下:

  • SOC:hi3516dv300。

  • 硬件连接:电位器挂接在0号ADC设备1通道下。

本例程对测试ADC进行连续读取操作,测试ADC功能是否正常。

示例如下:

#include "adc_if.h"          // ADC标准接口头文件
#include "hdf_log.h"         // 标准日志打印头文件

/// 设备号0,通道号1
#define ADC_DEVICE_NUM  0
#define ADC_CHANNEL_NUM 1
#define ADC_TEST_NUM    30

// ADC例程总入口
static int32_t TestCaseAdc(void)
{
    int32_t i;
    int32_t ret;
    DevHandle adcHandle = NULL;
    uint32_t readBuf[ADC_TEST_NUM] = {0};

    // 打开ADC设备
    adcHandle = AdcOpen(ADC_DEVICE_NUM);
    if (adcHandle == NULL) {
        HDF_LOGE("%s: Open ADC%u fail!", __func__, ADC_DEVICE_NUM);
        return -1;
    }

    // 连续进行30次AD转换并读取转换结果
    for (i = 0; i < ADC_TEST_NUM; i++) {
        ret = AdcRead(adcHandle, ADC_CHANNEL_NUM, &readBuf[i]);
        if (ret != HDF_SUCCESS) {
            HDF_LOGE("%s: ADC read fail!:%d", __func__, ret);
            AdcClose(adcHandle);
            return -1;
        }
    }
    HDF_LOGI("%s: ADC read successful!", __func__);

    // 访问完毕关闭ADC设备
    AdcClose(adcHandle);

    return 0;
}

最后

小编在之前的鸿蒙系统扫盲中,有很多朋友给我留言,不同的角度的问了一些问题,我明显感觉到一点,那就是许多人参与鸿蒙开发,但是又不知道从哪里下手,因为资料太多,太杂,无从选择。有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(HarmonyOS NEXT)文档用来跟着学习是非常有必要的。

如果你是一名有经验的资深Android移动开发、Java开发、前端开发、对鸿蒙感兴趣以及转行人员

GitCode - 全球开发者的开源社区,开源代码托管平台希望这一份鸿蒙学习文档能够给大家带来帮助~

  • 12
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值