我们的数字压力传感器位于测量技术的前沿,提供无与伦比的精度,适用于从工业过程到科学研究的关键应用。
A
A
硬件概览
它是如何工作的?
Pressure 10 Click 基于 ALPS Alpine 的 HSPPAD042A 数字压力传感器。该传感器由压阻式压力感应元件和执行 A/D 转换并通过数字接口提供转换结果的混合信号 ASIC 组成。该传感器元件采用 MEMS 技术,提供 ±0.7hPa 绝对精度和 ±0.05hPa 相对精度的高感测精度,并且在低功耗模式下具有 1.8μA 的行业最低电流消耗。传感器封装在一个小型 LGA 封装中,可以在 300 hPa 到 1100 hPa 的范围内工作,但在膜破裂前可承受高达 30,000 hPa 的压力。HSPPAD042A 提供一组压力和温度测量选项。通过 0x0F 寄存器
中的 CTL1.MODE 位可以设置多种测量模式。在检测到软件复位命令后,数字调节器被禁用,所有寄存器值被重置,测量模式设置为寄存器动作模式。FIFO 缓冲器允许优化主机固件,减少通过通信接口的数据传输。中断可通过 RDY 引脚(数据准备引脚)提供,可用于指示测量完成。多个标志可以设置到 RDY 引脚。它们都是 OR 输出,并且即使在测量期间也会立即生效。Pressure 10 Click 提供两种接口选择:I2C 和 SPI。选择可以通过将标记为 COMM SEL 的 SMD 跳线放置到适当位置来完成。请注意,所有跳线
侧,否则 Click 板™ 可能会无响应。在选择 I2C 接口时,HSPPAD042A 允许选择其 I2C 从地址的最低有效位(LSB)。这可以通过使用标记为 ADDR SEL 的 SMD 跳线来完成。此 Click 板™ 使用 I2C 和 SPI 通信接口。它设计为仅使用 3.3V 逻辑电平。在将 Click 板™ 用于逻辑电平为 5V 的 MCU 之前,应进行适当的逻辑电压电平转换。有关 HSPPAD042A 的更多信息可以在附带的数据表中找到。但是,此 Click 板™ 配备了一个包含易于使用的函数和用法示例的库,可用作开发的参考。
功能概述
开发板
Clicker 4 for STM32F3 是一款紧凑型开发板,作为完整的解决方案而设计,可帮助用户快速构建具备独特功能的定制设备。该板搭载 STMicroelectronics 的 STM32F302VCT6 微控制器,配备四个 mikroBUS™ 插槽用于连接 Click boards™、完善的电源管理功能以及其他实用资源,是快速开发各类应用的理想平台。其核心 MCU STM32F302VCT6 基于高性能
Arm® Cortex®-M4 32 位处理器,运行频率高达 168MHz,处理能力强大,能够满足各种高复杂度任务的需求,使 Clicker 4 能灵活适应多种应用场景。除了两个 1x20 引脚排针外,板载最显著的连接特性是四个增强型 mikroBUS™ 插槽,支持接入数量庞大的 Click boards™ 生态系统,该生态每日持续扩展。Clicker 4 各功能区域标识清晰,界面直观简洁,极大
提升使用便捷性和开发效率。Clicker 4 的价值不仅在于加速原型开发与应用构建阶段,更在于其作为独立完整方案可直接集成至实际项目中,无需额外硬件修改。四角各设有直径 4.2mm(0.165")的安装孔,便于通过螺丝轻松固定。对于多数应用,只需配套一个外壳,即可将 Clicker 4 开发板转化为完整、实用且外观精美的定制系统。
微控制器概述
MCU卡片 / MCU

建筑
ARM Cortex-M4
MCU 内存 (KB)
256
硅供应商
STMicroelectronics
引脚数
100
RAM (字节)
40960
使用的MCU引脚
mikroBUS™映射器
“仔细看看!”
Click board™ 原理图

一步一步来
项目组装
软件支持
库描述
该库包含 Pressure 10 Click 驱动程序的 API。
关键功能:
pressure10_send_cmd- 发送命令pressure10_check_communication- 检查通信pressure10_get_status- 获取状态功能
开源
代码示例
完整的应用程序代码和一个现成的项目可以通过NECTO Studio包管理器直接安装到NECTO Studio。 应用程序代码也可以在MIKROE的GitHub账户中找到。
/*!
* \file
* \brief Pressure10 Click example
*
* # Description
* Pressure 10 Click features a digital interface barometric pressure sensor, based on
* piezoresistive bridge. It can use both SPI and I2C communication protocols, allowing
* it to be interfaced with a broad range of MCUs.
*
* The demo application is composed of two sections :
*
* ## Application Init
* Initializes the driver, checks the communication and configures the module for measurement.
*
* ## Application Task
* Reads the pressure and temperature data every 1500ms and displays the results on the USB UART.
*
* \author MikroE Team
*
*/
// ------------------------------------------------------------------- INCLUDES
#include "board.h"
#include "log.h"
#include "pressure10.h"
// ------------------------------------------------------------------ VARIABLES
static pressure10_t pressure10;
static log_t logger;
static uint8_t check_com;
// ------------------------------------------------------ APPLICATION FUNCTIONS
void application_init ( void )
{
log_cfg_t log_cfg;
pressure10_cfg_t cfg;
/**
* Logger initialization.
* Default baud rate: 115200
* Default log level: LOG_LEVEL_DEBUG
* @note If USB_UART_RX and USB_UART_TX
* are defined as HAL_PIN_NC, you will
* need to define them manually for log to work.
* See @b LOG_MAP_USB_UART macro definition for detailed explanation.
*/
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, "---- Application Init ----" );
// Click initialization.
pressure10_cfg_setup( &cfg );
PRESSURE10_MAP_MIKROBUS( cfg, MIKROBUS_1 );
pressure10_init( &pressure10, &cfg );
check_com = pressure10_check_communication( &pressure10 );
if ( check_com == 0 )
{
log_printf( &logger, ">> Communication [OK]\r\n" );
}
else
{
log_printf( &logger, ">> Communication [ERROR]\r\n" );
for( ; ; );
}
pressure10_default_cfg ( &pressure10 );
log_printf( &logger, "----------------------------\r\n" );
}
void application_task ( void )
{
float temperature;
float pressure;
pressure = pressure10_get_pressure( &pressure10 );
temperature = pressure10_get_temperature( &pressure10 );
log_printf( &logger, ">> Temperature: %.2f C\r\n", temperature );
log_printf( &logger, "----------------------------\r\n" );
log_printf( &logger, ">> Pressure: %.2f mBar\r\n", pressure );
log_printf( &logger, "----------------------------\r\n" );
Delay_ms ( 1000 );
Delay_ms ( 500 );
}
int main ( void )
{
/* Do not remove this line or clock might not be set correctly. */
#ifdef PREINIT_SUPPORTED
preinit();
#endif
application_init( );
for ( ; ; )
{
application_task( );
}
return 0;
}
// ------------------------------------------------------------------------ END
额外支持
资源
类别:压力
































