0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

RA-RTT RA2L1 PM2.5采集显示器

冬至子 来源:kun222 作者:kun222 2023-10-12 14:08 次阅读

二、工作原理

通过串口读取传感器数值解释完后,显示到数码管数码管显示方式为动态扫描
程序分为2个线程,一个数据解释线程,一个数码管扫描显示线程

三、硬件连接

1.jpg

四、rt-thread studio驱动配置

打开UART0

1.jpg

五、RA Smart Configurator配置

添加g_uart0 UART驱动

1.jpg

配置SC0为异步串口,选择101 100引脚

1.jpg

六、代码编写

PM2.5 接收及解释

#include
#include
#include
#include "display.h"
#define DBG_TAG "app.pm25"
#define DBG_LVL DBG_LOG
#include
static rt_device_t serial;
static pm25_state_t pm25_state;
uint16_t pm25_data_convert(uint8_t h, uint8_t l)
{
return h<<8|l;
}
void pm25_thread_entry(void parameter)
{
uint8_t ch;
serial = rt_device_find("uart0");
if (!serial)
{
LOG_E("find %s failed!n", "uart1");
return;
}
else{
struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT; /
初始化配置参数 /
/
step2:修改串口配置参数 /
config.baud_rate = BAUD_RATE_9600; //修改波特率为 9600
config.data_bits = DATA_BITS_8; //数据位 8
config.stop_bits = STOP_BITS_1; //停止位 1
config.tx_bufsz = 0; //修改缓冲区 buff size 为 128
config.rx_bufsz = 128; //修改缓冲区 buff size 为 128
config.parity = PARITY_NONE; //无奇偶校验位
/
step3:控制串口设备。通过控制接口传入命令控制字,与控制参数 */
rt_device_control(serial, RT_DEVICE_CTRL_CONFIG, &config);
rt_device_open(serial, RT_DEVICE_FLAG_RX_NON_BLOCKING | RT_DEVICE_FLAG_TX_BLOCKING);
}
while(1){
// rt_thread_delay(10);
if( rt_device_read(serial, -1, &ch, 1) > 0 ){
pm25_state.recv_time = 10;
switch( pm25_state.recv_state )
{
case RECV_START1:
if( ch==0x42 ){
pm25_state.recv_state++;
pm25_state.recv_buf[pm25_state.recv_index++] = ch;
}
break;
case RECV_START2:
if( ch==0x4d ){
pm25_state.recv_state++;
pm25_state.recv_buf[pm25_state.recv_index++] = ch;
}
break;
case RECV_LEN1:
pm25_state.recv_state++;
pm25_state.recv_buf[pm25_state.recv_index++] = ch;
pm25_state.recv_len = ch<<8;
break;
case RECV_LEN2:
pm25_state.recv_state++;
pm25_state.recv_buf[pm25_state.recv_index++] = ch;
pm25_state.recv_len |= ch;
break;
case RECV_DATA:
if( pm25_state.recv_index < pm25_state.recv_len ){
pm25_state.recv_buf[pm25_state.recv_index++] = ch;
if( pm25_state.recv_index == pm25_state.recv_len ){
pm25_state.recv_state++;
}
}
break;
case RECV_END:
// LOG_HEX("REPLY", 16, pm25_state.recv_buf, 32);
pm25_state.recv_state = 0;
pm25_state.recv_index = 0;
pm25_decode_t *pm25_decode_ptr = (pm25_decode_t *)pm25_state.recv_buf;
pm25_state.pm25_data.pm1_0 = pm25_data_convert(pm25_decode_ptr->pm1_0_h,pm25_decode_ptr->pm1_0_l);
pm25_state.pm25_data.pm2_5 = pm25_data_convert(pm25_decode_ptr->pm2_5_h,pm25_decode_ptr->pm2_5_l);
pm25_state.pm25_data.pm10 = pm25_data_convert(pm25_decode_ptr->pm10_h,pm25_decode_ptr->pm10_l);
pm25_state.pm25_data.pm1_0_air = pm25_data_convert(pm25_decode_ptr->pm1_0_air_h,pm25_decode_ptr->pm1_0_air_l);
pm25_state.pm25_data.pm2_5_air = pm25_data_convert(pm25_decode_ptr->pm2_5_air_h,pm25_decode_ptr->pm2_5_air_l);
pm25_state.pm25_data.pm10_air = pm25_data_convert(pm25_decode_ptr->pm10_air_h,pm25_decode_ptr->pm10_air_l);
pm25_state.pm25_data.quantity_0_3 = pm25_data_convert(pm25_decode_ptr->quantity_0_3_h,pm25_decode_ptr->quantity_0_3_l);
pm25_state.pm25_data.quantity_0_5 = pm25_data_convert(pm25_decode_ptr->quantity_0_5_h,pm25_decode_ptr->quantity_0_5_l);
pm25_state.pm25_data.quantity_1_0 = pm25_data_convert(pm25_decode_ptr->quantity_1_0_h,pm25_decode_ptr->quantity_1_0_l);
pm25_state.pm25_data.quantity_2_5 = pm25_data_convert(pm25_decode_ptr->quantity_2_5_h,pm25_decode_ptr->quantity_2_5_l);
pm25_state.pm25_data.quantity_5_0 = pm25_data_convert(pm25_decode_ptr->quantity_5_0_h,pm25_decode_ptr->quantity_5_0_l);
pm25_state.pm25_data.quantity_10 = pm25_data_convert(pm25_decode_ptr->quantity_10_h,pm25_decode_ptr->quantity_10_l);
pm25_state.pm25_data.version = pm25_decode_ptr->version;
pm25_state.pm25_data.err_code = pm25_decode_ptr->err_code;
display_dig(pm25_state.pm25_data.pm2_5_air);
//
// LOG_D("pm1_0 = %d",pm25_state.pm25_data.pm1_0);
// LOG_D("pm2_5 = %d",pm25_state.pm25_data.pm2_5);
// LOG_D("pm10 = %d",pm25_state.pm25_data.pm10);
//
// LOG_D("pm1_0_air = %d",pm25_state.pm25_data.pm1_0_air);
// LOG_D("pm2_5_air = %d",pm25_state.pm25_data.pm2_5_air);
// LOG_D("pm10_air = %d",pm25_state.pm25_data.pm10_air);
//
// LOG_D("quantity_0_3 = %d",pm25_state.pm25_data.quantity_0_3);
// LOG_D("quantity_0_5 = %d",pm25_state.pm25_data.quantity_0_5);
// LOG_D("quantity_1_3 = %d",pm25_state.pm25_data.quantity_1_0);
// LOG_D("quantity_2_5 = %d",pm25_state.pm25_data.quantity_2_5);
// LOG_D("quantity_5_0 = %d",pm25_state.pm25_data.quantity_5_0);
// LOG_D("quantity_10 = %d",pm25_state.pm25_data.quantity_10);
// LOG_D("n");
break;
default:
break;
}
if( pm25_state.recv_time > 0 ){
pm25_state.recv_time --;
if( pm25_state.recv_time==0 ){
pm25_state.recv_state = RECV_START1;
pm25_state.recv_index = 0;
LOG_E("recv timeout");
}
}
}
// rt_device_write(serial, 0,"hello world",11);
rt_thread_delay(10);
}
}
void pm25_init(void)
{
rt_thread_t tid1 = RT_NULL;
tid1 = rt_thread_create("pm25",
pm25_thread_entry, RT_NULL,
512,
10, 10);
if (tid1 != RT_NULL)
rt_thread_startup(tid1);
}
INIT_APP_EXPORT(pm25_init);

595动态扫描显示线程

/*

Copyright (c) 2006-2021, RT-Thread Development Team

SPDX-License-Identifier: Apache-2.0

Change Logs:
Date Author Notes
2023-02-18 dmjku the first version
*/
#include
#include
#include "display.h"
disp_buf_t disp_buf;
#define SERIAL_RCLK_PIN "P302"
#define SERIAL_SCLK_PIN "P303"
#define SERIAL_DIO_PIN "P301"
rt_uint32_t rclk_pin;
rt_uint32_t sclk_pin;
rt_uint32_t dio_pin;
#define serial_rclk_pin(sta) rt_pin_write(rclk_pin, sta)
#define serial_sclk_pin(sta) rt_pin_write(sclk_pin, sta)
#define serial_dio_pin(sta) rt_pin_write(dio_pin, sta)
const uint8_t dig_code[]={
/ 生成 0-f 的编码 /
0xC0,////0
0xF9,////1
0xA4,////2
0xB0,////3
0x99,////4
0x92,////5
0x82,////6
0xF8,////7
0x80,////8
0x90,////9
0x88,////A
0x80,////B
0xC6,////C
0xC0,////D
0x86,////E
0x8E,////F
};
void display_dig(uint16_t dig)
{
uint8_t zero=0;
if( dig/1000 ){
disp_buf.dig[0] = dig_code[dig/1000];
dig %= 1000;
zero = 1;
}
else{
disp_buf.dig[0] = 0xff;
}
if( dig/100 ){
disp_buf.dig[1] = dig_code[dig/100];
dig %= 100;
zero = 1;
}
else if(zero){
disp_buf.dig[1] = dig_code[0];
}
else{
disp_buf.dig[1] = 0xff;
}
if( dig/10 ){
disp_buf.dig[2] = dig_code[dig/10];
dig %= 10;
zero = 1;
}
else if(zero){
disp_buf.dig[2] = dig_code[0];
}
else{
disp_buf.dig[2] = 0xff;
}
if( dig ){
disp_buf.dig[3] = dig_code[dig];
}
else if(zero){
disp_buf.dig[3] = dig_code[0];
}
else{
disp_buf.dig[3] = 0xff;
}
}
void display_led(void)
{
const uint8_t pos_v[] = {0x08,0x04,0x02,0x01};
static uint8_t pos = 0;
disp_buf.output[0] = pos_v[pos];
disp_buf.output[1] = disp_buf.dig[pos];
pos++;
if( pos>=4 )
pos = 0;
}
static void display_wr_byte(uint8_t data)
{
for( uint8_t i=0; i<8; i++ ){
serial_dio_pin(data&0x80?1:0);
// rt_hw_us_delay(1);
serial_sclk_pin(1);
// rt_hw_us_delay(1);
serial_sclk_pin(0);
data <<= 1;
}
}
static void display_refresh(void)
{
for( uint8_t i=DISP_BUF_LEN; i>0; i-- ){
display_wr_byte(disp_buf.output[i-1]);
}
serial_rclk_pin(1);
// rt_hw_us_delay(1);
serial_rclk_pin(0);
}
void display_thread_entry(void *paramter)
{
display_dig(1);
while( 1 ){
display_led();
display_refresh();
rt_thread_delay(5);
}
}
void display_init(void)
{
rclk_pin = rt_pin_get(SERIAL_RCLK_PIN);
sclk_pin = rt_pin_get(SERIAL_SCLK_PIN);
dio_pin = rt_pin_get(SERIAL_DIO_PIN);
// serial_rclk_pin(1);
// serial_rclk_pin(0);
// serial_sclk_pin(1);
// serial_sclk_pin(0);
// serial_dio_pin(1);
// serial_dio_pin(0);
rt_thread_t tid1 = RT_NULL;
tid1 = rt_thread_create("disp",
display_thread_entry, RT_NULL,
512,
10, 10);
if (tid1 != RT_NULL)
rt_thread_startup(tid1);
}
INIT_APP_EXPORT(display_init);

七、总结

第一次使用的瑞萨ARM系列芯片,在RT-thread studio的加持下结合RA Smart Configurator,不需看硬件手册,可以快速上手开发,真心好用,比keil+evn+stm32cubeMX还要顺手

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 传感器
    +关注

    关注

    2525

    文章

    48137

    浏览量

    740238
  • 数码管
    +关注

    关注

    31

    文章

    1827

    浏览量

    89952
  • ARM芯片
    +关注

    关注

    1

    文章

    123

    浏览量

    21258
  • stm32cubemx
    +关注

    关注

    5

    文章

    260

    浏览量

    14450
  • RTThread
    +关注

    关注

    7

    文章

    129

    浏览量

    40523
收藏 人收藏

    评论

    相关推荐

    PM2.5检测仪什么牌子好用?思乐智的PM2.5检测仪,PM2.5测试仪器怎么样?

    pm2.5检测仪主要技术指标:  1、配置40mm滤膜咱先采样:  2、具有可更换粒子切割pm
    发表于 11-29 16:54

    Renesas RA2L1开发板之UART模块测评

    1、Renesas RA2L1开发板之UART  评测任务  首先非常感谢RT-Thread和Renesas给予测评CPK-RA2L1开发板的机会,本人所测评的模块是UART。这款
    发表于 10-18 10:38

    Renesas RA2L1开发板之I2C测评

    1、Renesas RA2L1开发板之I2C  开发板介绍  CPK-RA2L1评估板是一款专门针对中国本地的开发板,主MCU是一款主频为48MHz,内核为Arm® Cortex®-M
    发表于 10-24 16:29

    Renesas RA2L1开发板之PWM呼吸灯功能设计实现

    1、Renesas RA2L1开发板之PWM呼吸灯功能实现  CPK-RA2L1评估板  MCU:R7FA2L1AB2DFM,48MHz,Arm Cortex®-M23 内核,256k
    发表于 10-25 14:48

    Renesas RA2L1开发板之CAN介绍

    1、Renesas RA2L1开发板之CAN介绍  功能模块的硬件介绍  CPK-RA2L1评估板是一款专门针对中国本地的开发板,主MCU是一款主频为48MHz,内核为Arm® Cortex
    发表于 11-01 11:46

    Renesas RA2L1开发板之PWM方波配置相关资料推荐

    1、Renesas RA2L1开发板之PWM方波配置  工程的配置  时钟的配置  本次直接基于官方的例程进行开发,使用瑞萨的 RA Configuration 进行工程的配置。RA
    发表于 11-02 15:31

    Renesas RA2L1开发板之I2C接口评测

    1、Renesas RA2L1 开发板之 I2C  开发板介绍  CPK-RA2L1评估板是一款专门针对中国本地的开发板,主MCU是一款主频为48MHz,内核为Arm® Cortex®
    发表于 11-04 14:26

    RA-RTT体验零代码点亮LED灯

    很荣幸能参加RA-RTT瑞萨开发板试用活动。目的介绍如何零代码体验点亮LED灯。开发板RA2L1开发板实现步聚1、打开RT-Thread Studio SDK管理,安装开发板支持包:
    发表于 02-22 15:13

    RA-RTT RA2L1 PM2.5采集显示器设计

    25_decode_ptr-》pm1_0_l);  pm25_state.pm25_data.pm2_5 = pm25_data_convert(pm25_decode_ptr-》
    发表于 02-28 15:00

    RT-Thread与Renesas RA2L1实现1.8寸TFT屏幕显示的步骤

    使用过,本次借着RTT和本次参与RT-Thread与Renesas RA2L1的学习大挑战更深入的去学习RTT和Renesas。  计划使用RA2L1实现
    发表于 04-03 16:45

    基于RA2L1开发板的初识点灯

      1. 开发板  2. 开发板介绍  瑞萨RA2L1产品组属于48MHz Arm® Cortex®-M23 超低功耗通用微控制 ,能够支持 1.6V 至 5.5V 宽电压工作,CP
    发表于 04-03 16:55

    如何使用Arduino UNO制作一台PM2.5显示器

    使用Arduino UNO制作一台PM2.5显示器
    的头像 发表于 10-29 10:45 4923次阅读

    RA2L1开发板资料

    RA2L1开发板资料
    发表于 11-07 19:50 18次下载
    <b class='flag-5'>RA2L1</b>开发板资料

    RA2L1 组数据表

    RA2L1 组数据表
    发表于 01-09 19:06 0次下载
    <b class='flag-5'>RA2L1</b> 组数据表

    RA2L1 组数据表

    RA2L1 组数据表
    发表于 06-30 18:50 0次下载
    <b class='flag-5'>RA2L1</b> 组数据表