鸿蒙Hi3861 ADC驱动 如何使用开发板上的3个按键

系统
本节主要介绍Hi3861 的 ADC功能,顺便实现ADC按键检测。这里先看效果吧。

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com/#zz

 本节主要介绍Hi3861 的 ADC功能,顺便实现ADC按键检测。这里先看效果吧。

查看开发板,可以看到除了复位按键之外,还有3个按键。而查看原理,我们可以看到这个3个按键其实都是接的GPIO5 引脚,而GPIO5引脚又可复用为ADC2引脚。


故而,我们可以猜测出来我们可以使用ADC检测电压,判断出来是哪个引脚被按下了。

看下效果:

当我按下 按键1的时候,串口会打印:

当我按下按键2的时候串口会打印:

当我按下 USER按键的时候串口会打印


其中 vlt_min 表示读取到ADC值的最小值,

vlt_max 表示读取到ADC值的最大值。

由此我们可以看到,按键1被按下的时候,ADC值得范围在 0.563 ~ 0.577

按键2按下后,ADC值在 0.963 ~ 0.970

USER按键按下后 ADC值 在 0.197 ~ 0.204

如果没有按键按下,则ADC值在 3.227 ~ 3.241

vlt_min:3.227, vlt_max:3.241

代码实现其实很简单。

(1)引脚初始化

这里由于GPIO5默认被复用为串口引脚,这里我们重新修改为普通GPIO引脚。初始化代码如下:

  1. (hi_void)hi_gpio_init(); 
  2.  
  3. hi_io_set_func(HI_IO_NAME_GPIO_5, HI_IO_FUNC_GPIO_5_GPIO); /* uart1 rx */ 
  4.  
  5. ret = hi_gpio_set_dir(HI_GPIO_IDX_5, HI_GPIO_DIR_IN); 
  6.  
  7. if (ret != HI_ERR_SUCCESS) { 
  8.  
  9. printf("===== ERROR ======gpio -> hi_gpio_set_dir1 ret:%d\r\n", ret); 
  10.  
  11. return
  12.  

 (2)读取ADC值

读取ADC值的代码页相对简单,这里,我是重复读取64次,减少误判。

  1. memset_s(g_adc_buf, sizeof(g_adc_buf), 0x0, sizeof(g_adc_buf)); 
  2.  
  3. for (i = 0; i < ADC_TEST_LENGTH; i++) { 
  4.  
  5. ret = hi_adc_read((hi_adc_channel_index)HI_ADC_CHANNEL_2, &data, HI_ADC_EQU_MODEL_1, HI_ADC_CUR_BAIS_DEFAULT, 0); 
  6.  
  7. if (ret != HI_ERR_SUCCESS) { 
  8.  
  9. printf("ADC Read Fail\n"); 
  10.  
  11. return
  12.  
  13.  
  14. g_adc_buf[i] = data; 
  15.  

 (3)对读出来的ADC值进行判断处理

S1对应的是按键1 、 S2对应的是按键2 、 S3对应的是 USER按键

  1. for (i = 0; i < data_len; i++) { 
  2.  
  3. vlt = g_adc_buf[i]; 
  4.  
  5. float voltage = (float)vlt * 1.8 * 4 / 4096.0; /* vlt * 1.8 * 4 / 4096.0: Convert code into voltage */ 
  6.  
  7. vlt_max = (voltage > vlt_max) ? voltage : vlt_max; 
  8.  
  9. vlt_min = (voltage < vlt_min) ? voltage : vlt_min; 
  10.  
  11.  
  12. //printf("vlt_min:%.3f, vlt_max:%.3f \n", vlt_min, vlt_max); 
  13.  
  14. vlt_val = (vlt_min + vlt_max)/2.0; 
  15.  
  16. if((vlt_val > 0.4) && (vlt_val < 0.6)) 
  17.  
  18.  
  19. if(key_flg == 0) 
  20.  
  21.  
  22. key_flg = 1; 
  23.  
  24. key_status = KEY_EVENT_S1; 
  25.  
  26.  
  27.  
  28. if((vlt_val > 0.8) && (vlt_val < 1.1)) 
  29.  
  30.  
  31. if(key_flg == 0) 
  32.  
  33.  
  34. key_flg = 1; 
  35.  
  36. key_status = KEY_EVENT_S2; 
  37.  
  38.  
  39.  
  40. if((vlt_val > 0.01) && (vlt_val < 0.3)) 
  41.  
  42.  
  43. if(key_flg == 0) 
  44.  
  45.  
  46. key_flg = 1; 
  47.  
  48. key_status = KEY_EVENT_S3; 
  49.  
  50.  
  51.  
  52. if(vlt_val > 3.0) 
  53.  
  54.  
  55. key_flg = 0; 
  56.  
  57. key_status = KEY_EVENT_NONE; 
  58.  

 (4)使用

编写好上面代码后,就可以直接在while循环中判断按键值了:

  1. while(1) 
  2.  
  3.  
  4. //读取ADC值 
  5.  
  6. app_demo_adc_test(); 
  7.  
  8. switch(get_key_event()) 
  9.  
  10.  
  11. case KEY_EVENT_NONE: 
  12.  
  13.  
  14.  
  15. break; 
  16.  
  17. case KEY_EVENT_S1: 
  18.  
  19.  
  20. printf("KEY_EVENT_S1 \r\n"); 
  21.  
  22.  
  23. break; 
  24.  
  25. case KEY_EVENT_S2: 
  26.  
  27.  
  28. printf("KEY_EVENT_S2 \r\n"); 
  29.  
  30.  
  31. break; 
  32.  
  33. case KEY_EVENT_S3: 
  34.  
  35.  
  36. printf("KEY_EVENT_S3 \r\n"); 
  37.  
  38.  
  39. break; 
  40.  
  41.  
  42. usleep(30000); 
  43.  

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com/#zz 

 

责任编辑:jianghua 来源: 鸿蒙社区
相关推荐

2020-11-18 11:56:06

鸿蒙Hi3861

2020-10-27 10:08:19

Hi3861ADC驱动

2020-11-06 10:15:16

HiBurn

2020-10-30 17:12:05

Hi3861

2020-10-14 09:37:03

HiBurn鸿蒙.bin文件

2020-11-06 11:32:11

NV操作

2020-10-30 17:42:36

鸿蒙 OS Hi386

2020-12-17 10:02:16

鸿蒙Hi3861开发板

2020-12-09 09:44:29

Hi3861硬件介绍鸿蒙开发板

2020-10-30 09:48:03

Hi3861开发板get请求

2020-12-15 11:57:49

Hi3861 HarmonyOS开发板

2021-06-25 15:32:13

鸿蒙HarmonyOS应用

2021-09-16 10:03:39

鸿蒙HarmonyOS应用

2020-12-11 12:45:04

鸿蒙Hi3861游戏

2020-11-03 12:26:55

Hi3861

2020-11-02 12:07:11

鸿蒙 GPIO

2022-08-19 10:54:47

操作系统鸿蒙

2020-10-29 09:53:06

Hi3861硬件开发板

2020-10-14 09:41:02

Hi3861GPIO点灯

2022-01-05 20:27:45

鸿蒙HarmonyOS应用
点赞
收藏

51CTO技术栈公众号