当前位置: 首页 > article >正文

AHT20温湿度传感器在STM32上的应用:从数据采集到OLED显示

AHT20温湿度传感器在STM32上的实战应用从数据采集到OLED可视化在物联网和智能硬件开发中环境数据的实时监测与可视化是基础却关键的一环。AHT20作为新一代数字温湿度传感器以其高精度、低功耗和I2C接口的便捷性成为STM32开发者构建环境监测系统的热门选择。本文将完整呈现如何从零开始在STM32平台上实现AHT20的数据采集、处理并通过OLED屏幕进行专业级可视化展示。1. 硬件架构设计与环境搭建1.1 核心组件选型与连接项目所需的核心硬件包括STM32F103C8T6性价比极高的Cortex-M3内核MCUAHT20传感器模块工作电压3.3VI2C地址0x380.96寸OLED显示屏SSD1306驱动128x64分辨率杜邦线用于各模块间的连接硬件连接示意图STM32引脚连接目标备注PB6OLED SCLI2C1时钟线PB7OLED SDAI2C1数据线PB10AHT20 SCL软件模拟I2C时钟线PB11AHT20 SDA软件模拟I2C数据线3.3V模块VCC统一供电GND模块GND共地连接提示AHT20对电源噪声敏感建议在VCC与GND之间添加0.1μF去耦电容1.2 开发环境配置使用STM32CubeIDE作为开发环境需进行以下基础配置创建新工程选择对应STM32型号配置系统时钟为72MHz启用SWD调试接口添加必要的库文件stm32f1xx_hal_i2c.hstm32f1xx_hal_gpio.hstm32f1xx_hal_delay.h// 系统时钟配置示例 void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct {0}; RCC_OscInitStruct.OscillatorType RCC_OSCILLATORTYPE_HSE; RCC_OscInitStruct.HSEState RCC_HSE_ON; RCC_OscInitStruct.HSEPredivValue RCC_HSE_PREDIV_DIV1; RCC_OscInitStruct.PLL.PLLState RCC_PLL_ON; RCC_OscInitStruct.PLL.PLLSource RCC_PLLSOURCE_HSE; RCC_OscInitStruct.PLL.PLLMUL RCC_PLL_MUL9; HAL_RCC_OscConfig(RCC_OscInitStruct); RCC_ClkInitStruct.ClockType RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.AHBCLKDivider RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider RCC_HCLK_DIV2; RCC_ClkInitStruct.APB2CLKDivider RCC_HCLK_DIV1; HAL_RCC_ClockConfig(RCC_ClkInitStruct, FLASH_LATENCY_2); }2. AHT20传感器驱动开发2.1 软件模拟I2C实现由于STM32硬件I2C可能存在稳定性问题我们采用GPIO模拟方式// I2C引脚初始化 void AHT20_I2C_Init(void) { GPIO_InitTypeDef GPIO_InitStruct {0}; __HAL_RCC_GPIOB_CLK_ENABLE(); // 配置PB10和PB11为开漏输出 GPIO_InitStruct.Pin GPIO_PIN_10|GPIO_PIN_11; GPIO_InitStruct.Mode GPIO_MODE_OUTPUT_OD; GPIO_InitStruct.Pull GPIO_NOPULL; GPIO_InitStruct.Speed GPIO_SPEED_FREQ_HIGH; HAL_GPIO_Init(GPIOB, GPIO_InitStruct); // 初始置高 HAL_GPIO_WritePin(GPIOB, GPIO_PIN_10|GPIO_PIN_11, GPIO_PIN_SET); } // I2C起始信号 void I2C_Start(void) { SDA_HIGH(); SCL_HIGH(); delay_us(5); SDA_LOW(); delay_us(5); SCL_LOW(); } // 读取AHT20状态字 uint8_t AHT20_Read_Status(void) { uint8_t status 0; I2C_Start(); I2C_Send_Byte(0x71); // 读地址 status I2C_Read_Byte(0); // 不发送ACK I2C_Stop(); return status; }2.2 传感器初始化与校准AHT20首次上电需要执行初始化校准#define AHT20_ADDRESS 0x38 1 void AHT20_Init(void) { uint8_t cmd[3] {0xBE, 0x08, 0x00}; // 发送初始化命令 I2C_Start(); I2C_Send_Byte(AHT20_ADDRESS | 0x00); I2C_Send_Byte(cmd[0]); I2C_Send_Byte(cmd[1]); I2C_Send_Byte(cmd[2]); I2C_Stop(); HAL_Delay(10); // 等待校准完成 // 检查校准状态 uint8_t status AHT20_Read_Status(); if(!(status 0x08)) { // 校准失败处理 Error_Handler(); } }2.3 温湿度数据采集与处理完整的温湿度读取流程void AHT20_Read_Data(float *temperature, float *humidity) { uint8_t data[6] {0}; uint32_t temp_raw 0, humi_raw 0; // 触发测量 uint8_t trigger_cmd[3] {0xAC, 0x33, 0x00}; I2C_Start(); I2C_Send_Byte(AHT20_ADDRESS | 0x00); for(int i0; i3; i) { I2C_Send_Byte(trigger_cmd[i]); } I2C_Stop(); // 等待测量完成 HAL_Delay(80); // 读取数据 I2C_Start(); I2C_Send_Byte(AHT20_ADDRESS | 0x01); for(int i0; i6; i) { data[i] I2C_Read_Byte(i5?0:1); } I2C_Stop(); // 数据处理 humi_raw ((uint32_t)data[1] 12) | ((uint32_t)data[2] 4) | (data[3] 4); temp_raw ((uint32_t)(data[3] 0x0F) 16) | ((uint32_t)data[4] 8) | data[5]; *humidity (float)humi_raw * 100 / 1048576.0; *temperature (float)temp_raw * 200 / 1048576.0 - 50; }注意AHT20每次测量后需要至少2秒的间隔时间连续读取会导致数据不准确3. OLED显示界面设计3.1 SSD1306驱动实现采用硬件I2C驱动OLEDvoid OLED_Init(void) { // 初始化序列 uint8_t init_cmd[] { 0xAE, 0xD5, 0x80, 0xA8, 0x3F, 0xD3, 0x00, 0x40, 0x8D, 0x14, 0x20, 0x00, 0xA1, 0xC8, 0xDA, 0x12, 0x81, 0xCF, 0xD9, 0xF1, 0xDB, 0x40, 0xA4, 0xA6, 0xAF }; HAL_I2C_Mem_Write(hi2c1, 0x78, 0x00, 1, init_cmd, sizeof(init_cmd), 100); OLED_Clear(); } // 显示字符串 void OLED_ShowString(uint8_t x, uint8_t y, char *str) { while(*str) { OLED_ShowChar(x, y, *str); x 8; if(x 120) { x 0; y 2; } str; } } // 显示温湿度数据 void OLED_ShowTempHumidity(float temp, float humi) { char buffer[16]; // 温度显示 sprintf(buffer, Temp:%.1fC, temp); OLED_ShowString(0, 0, buffer); // 湿度显示 sprintf(buffer, Humi:%.1f%%, humi); OLED_ShowString(0, 2, buffer); // 添加简单的图形指示 uint8_t level (uint8_t)(humi / 10); for(uint8_t i0; ilevel; i) { OLED_DrawRectangle(90 i*3, 16, 92 i*3, 48, 1); } }3.2 专业级数据可视化技巧提升显示效果的几种方法动态曲线绘制实现历史数据趋势图#define HISTORY_SIZE 128 float temp_history[HISTORY_SIZE]; uint8_t history_index 0; void Update_Temp_Graph(float temp) { // 更新历史数据 temp_history[history_index] temp; history_index (history_index 1) % HISTORY_SIZE; // 清空图形区域 OLED_Fill(0, 32, 127, 63, 0); // 绘制坐标轴 OLED_DrawLine(0, 48, 127, 48, 1); // 绘制曲线 for(uint8_t i0; iHISTORY_SIZE-1; i) { uint8_t x1 i; uint8_t y1 48 - (uint8_t)(temp_history[i] * 0.8); uint8_t x2 i1; uint8_t y2 48 - (uint8_t)(temp_history[i1] * 0.8); OLED_DrawLine(x1, y1, x2, y2, 1); } }多页面显示通过按键切换不同视图typedef enum { PAGE_MAIN, PAGE_DETAIL, PAGE_HISTORY } DisplayPage; DisplayPage current_page PAGE_MAIN; void Update_Display(float temp, float humi) { switch(current_page) { case PAGE_MAIN: OLED_ShowTempHumidity(temp, humi); break; case PAGE_DETAIL: Show_Detail_Info(temp, humi); break; case PAGE_HISTORY: Update_Temp_Graph(temp); break; } }报警提示功能当数值超出阈值时闪烁显示void Check_Alarm(float temp, float humi) { static uint8_t blink 0; if(temp 30.0 || humi 80.0) { blink !blink; if(blink) { OLED_InvertArea(0, 127, 0, 15); } HAL_Delay(500); } }4. 系统优化与实战技巧4.1 低功耗设计策略传感器间歇工作模式void Enter_LowPower_Mode(void) { // 关闭OLED OLED_Write_Cmd(0xAE); // 设置AHT20为睡眠模式 I2C_Start(); I2C_Send_Byte(AHT20_ADDRESS | 0x00); I2C_Send_Byte(0xB0); I2C_Send_Byte(0x00); I2C_Stop(); // 配置STM32进入STOP模式 HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI); // 唤醒后重新初始化 SystemClock_Config(); OLED_Init(); AHT20_Init(); }动态刷新率调整uint32_t last_update 0; uint32_t update_interval 1000; // 默认1秒 void Adjust_Refresh_Rate(float temp_diff) { // 温度变化大时提高刷新率 if(fabs(temp_diff) 2.0) { update_interval 500; } // 温度稳定时降低刷新率 else if(fabs(temp_diff) 0.5) { update_interval 2000; } else { update_interval 1000; } }4.2 数据滤波与校准移动平均滤波#define FILTER_SIZE 5 float temp_filter[FILTER_SIZE] {0}; uint8_t filter_index 0; float Apply_Filter(float new_value) { temp_filter[filter_index] new_value; filter_index (filter_index 1) % FILTER_SIZE; float sum 0; for(uint8_t i0; iFILTER_SIZE; i) { sum temp_filter[i]; } return sum / FILTER_SIZE; }传感器校准补偿typedef struct { float temp_offset; float humi_offset; } CalibrationParams; CalibrationParams calib {0.5, -2.0}; // 示例校准值 float Apply_Calibration(float temp, float humi) { return temp calib.temp_offset, humi calib.humi_offset; }4.3 异常处理与系统健壮性I2C总线恢复机制void I2C_Recovery(void) { // 发送9个时钟脉冲尝试恢复 for(uint8_t i0; i9; i) { SCL_LOW(); delay_us(5); SCL_HIGH(); delay_us(5); } // 发送STOP条件 I2C_Stop(); // 重新初始化 AHT20_I2C_Init(); AHT20_Init(); }数据有效性检查uint8_t Is_Data_Valid(float temp, float humi) { // 检查数值范围 if(temp -40.0 || temp 85.0) return 0; if(humi 0.0 || humi 100.0) return 0; // 检查变化率是否合理 static float last_temp 25.0; static float last_humi 50.0; if(fabs(temp - last_temp) 5.0) return 0; if(fabs(humi - last_humi) 10.0) return 0; last_temp temp; last_humi humi; return 1; }5. 项目扩展与进阶应用5.1 多传感器数据融合结合其他传感器提升系统功能// 气压传感器BMP280数据读取 float Read_BMP280_Pressure(void) { // 实现气压读取逻辑 return 1013.25; // 示例值 } // 综合环境舒适度计算 float Calculate_Comfort_Index(float temp, float humi) { // 简化的不适指数计算 return temp 0.3 * humi; } void Update_Comfort_Display(void) { float temp, humi; AHT20_Read_Data(temp, humi); float pressure Read_BMP280_Pressure(); float comfort Calculate_Comfort_Index(temp, humi); char buffer[20]; sprintf(buffer, Comfort: %.1f, comfort); OLED_ShowString(0, 4, buffer); // 根据舒适度给出建议 if(comfort 21) { OLED_ShowString(0, 6, Suggestion: Normal); } else if(comfort 25) { OLED_ShowString(0, 6, Suggestion: Warm); } else { OLED_ShowString(0, 6, Suggestion: Hot!); } }5.2 无线数据传输实现通过ESP8266添加Wi-Fi功能void ESP8266_Send_Data(float temp, float humi) { char cmd[128]; sprintf(cmd, ATCIPSTART\TCP\,\api.thingspeak.com\,80\r\n); HAL_UART_Transmit(huart1, (uint8_t*)cmd, strlen(cmd), 1000); sprintf(cmd, GET /update?api_keyYOUR_KEYfield1%.1ffield2%.1f\r\n, temp, humi); uint16_t len strlen(cmd); char send_cmd[64]; sprintf(send_cmd, ATCIPSEND%d\r\n, len); HAL_UART_Transmit(huart1, (uint8_t*)send_cmd, strlen(send_cmd), 1000); HAL_UART_Transmit(huart1, (uint8_t*)cmd, len, 1000); }5.3 本地数据存储方案使用SPI Flash存储历史数据#define FLASH_SECTOR_SIZE 4096 void Save_To_Flash(float temp, float humi) { static uint32_t write_addr 0; // 准备数据 uint8_t data[8]; memcpy(data, temp, 4); memcpy(data4, humi, 4); // 写入Flash HAL_FLASH_Unlock(); FLASH_Erase_Sector(FLASH_SECTOR_5, VOLTAGE_RANGE_3); HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD, 0x08020000 write_addr, *(uint32_t*)data); HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD, 0x08020004 write_addr, *(uint32_t*)(data4)); HAL_FLASH_Lock(); write_addr (write_addr 8) % FLASH_SECTOR_SIZE; }在项目开发过程中调试AHT20时发现其I2C时序要求比常规传感器更为严格特别是在起始条件后的第一个字节传输间隔需要精确控制。通过逻辑分析仪捕获的信号显示在SCL高电平期间保持SDA稳定的时间至少需要4.7μs才能确保可靠通信。

相关文章:

AHT20温湿度传感器在STM32上的应用:从数据采集到OLED显示

AHT20温湿度传感器在STM32上的实战应用:从数据采集到OLED可视化 在物联网和智能硬件开发中,环境数据的实时监测与可视化是基础却关键的一环。AHT20作为新一代数字温湿度传感器,以其高精度、低功耗和I2C接口的便捷性,成为STM32开发…...

031. 从零到一:打造你的专属“王思鱼指纹浏览器”实战指南

1. 什么是“王思鱼指纹浏览器”? 最近在帮朋友做社交媒体运营时,发现一个头疼的问题:同一个IP登录多个账号容易被平台识别关联。试过各种方法都不太理想,直到发现了这个叫“王思鱼指纹浏览器”的神器。简单来说,它就是…...

nlp_gte_sentence-embedding_chinese-large实战案例:客服工单自动归类与聚类分析

nlp_gte_sentence-embedding_chinese-large实战案例:客服工单自动归类与聚类分析 1. 引言:客服工单处理的痛点与解决方案 每天处理成千上万的客服工单是什么体验?想象一下这样的场景:客服团队每天收到大量用户反馈,从…...

GLM-4.7-Flash多场景落地:保险条款解读、理赔话术生成与客户异议应答

GLM-4.7-Flash多场景落地:保险条款解读、理赔话术生成与客户异议应答 保险行业每天都要处理海量的文本工作:厚厚的保单条款需要解读,复杂的理赔申请需要沟通,客户的各种疑问需要专业、及时地回应。这些工作不仅繁琐,而…...

突破学术翻译障碍:Zotero PDF Translate文献阅读效率提升指南

突破学术翻译障碍:Zotero PDF Translate文献阅读效率提升指南 【免费下载链接】zotero-pdf-translate 支持将PDF、EPub、网页内容、元数据、注释和笔记翻译为目标语言,并且兼容20多种翻译服务。 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-p…...

OFA图像语义蕴含模型效果展示:漫画分镜图+剧情假设的叙事逻辑连贯性验证

OFA图像语义蕴含模型效果展示:漫画分镜图剧情假设的叙事逻辑连贯性验证 1. 引言:当漫画遇上AI逻辑验证 你有没有过这样的经历?看漫画时突然发现前后剧情对不上,或者某个分镜的画面和对话明显矛盾?这种叙事逻辑的不连…...

IINA:macOS上最优雅的全能视频播放器终极指南

IINA:macOS上最优雅的全能视频播放器终极指南 【免费下载链接】iina 项目地址: https://gitcode.com/gh_mirrors/iin/iina 如果你在寻找一款既强大又美观的macOS视频播放器,IINA绝对是你的不二之选。这款基于mpv引擎的现代播放器,不仅…...

突破Windows权限限制:TrustedInstaller提权工具完全指南

突破Windows权限限制:TrustedInstaller提权工具完全指南 【免费下载链接】LeanAndMean snippets for power users 项目地址: https://gitcode.com/gh_mirrors/le/LeanAndMean 作为系统管理员或高级用户,你是否曾因"拒绝访问"而无法修改…...

Qwen3.5-4B-Claude-Opus惊艳效果展示:分步骤推导二分查找O(log n)全过程

Qwen3.5-4B-Claude-Opus惊艳效果展示:分步骤推导二分查找O(log n)全过程 1. 模型能力概览 Qwen3.5-4B-Claude-4.6-Opus-Reasoning-Distilled-GGUF是一个专为推理任务优化的轻量级模型,特别擅长处理需要分步骤分析的技术问题。这个4B参数的模型通过蒸馏…...

3个革新性视角:Tomato-Novel-Downloader的内容自由解决方案

3个革新性视角:Tomato-Novel-Downloader的内容自由解决方案 【免费下载链接】Tomato-Novel-Downloader 番茄小说下载器不精简版 项目地址: https://gitcode.com/gh_mirrors/to/Tomato-Novel-Downloader 在数字阅读成为主流的今天,我们却常常陷入内…...

【服务器】上传百度网盘数据至服务器

目录方法一:使用开源命令行工具 BaiduPCS-Go (最推荐)实例:下载网盘数据实例:上传服务器数据至百度网盘单个文件测试上传批量裁剪文件参考方法一:使用开源命令行工具 BaiduPCS-Go (最推荐) 这是目前在 Linux/Windows 服务器上最流…...

LongCat-Image-Editn效果展示:建筑效果图‘添加中文标牌+调整光照’案例

LongCat-Image-Edit效果展示:建筑效果图‘添加中文标牌调整光照’案例 1. 开篇:当AI学会“装修”建筑效果图 想象一下,你手里有一张刚出炉的建筑效果图,客户突然提出两个新需求:“能不能给大楼加上我们公司的中文招牌…...

Nanbeige4.1-3B vLLM模型水印:输出内容可追溯的版权保护技术实现

Nanbeige4.1-3B vLLM模型水印:输出内容可追溯的版权保护技术实现 1. 引言:当AI生成内容遇上版权难题 你有没有想过,如果AI帮你写了一篇文章、一段代码或者一个创意方案,这份成果的“所有权”到底归谁?随着像Nanbeige…...

AHT10 vs DHT11:国产温湿度传感器性能对比与选型建议

AHT10 vs DHT11:国产温湿度传感器性能对比与选型建议 在物联网和智能硬件快速发展的今天,温湿度传感器作为环境感知的基础元件,其性能直接影响到整个系统的可靠性和精度。面对市场上众多的传感器选择,开发者常常需要在成本、精度和…...

OpenCore Legacy Patcher:3大突破让旧Mac重获新生的系统兼容性优化指南

OpenCore Legacy Patcher:3大突破让旧Mac重获新生的系统兼容性优化指南 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher OpenCore Legacy Patcher(O…...

开源工具权限重置指南:跨平台AI编程助手试用限制解决方案

开源工具权限重置指南:跨平台AI编程助手试用限制解决方案 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Youve reached your trial request limit. / Too many free trial accounts used on this machine. Please upgrade to pro. …...

零代码部署YOLOv9:官方镜像5分钟快速上手,实测效果惊艳

零代码部署YOLOv9:官方镜像5分钟快速上手,实测效果惊艳 1. 为什么选择YOLOv9官方镜像 目标检测领域的最新突破YOLOv9已经发布,但很多开发者在尝试部署时遇到了各种环境配置问题。这个官方预构建的镜像解决了三大核心痛点: 环境配置…...

如何用浏览器扩展将网页内容一键转换为AI知识库

如何用浏览器扩展将网页内容一键转换为AI知识库 【免费下载链接】anything-llm 这是一个全栈应用程序,可以将任何文档、资源(如网址链接、音频、视频)或内容片段转换为上下文,以便任何大语言模型(LLM)在聊天…...

Qwen3-ForcedAligner在开源项目中的贡献指南

Qwen3-ForcedAligner在开源项目中的贡献指南 1. 引言 如果你对语音识别和音频处理感兴趣,想要为开源项目做贡献,Qwen3-ForcedAligner是个绝佳的选择。这个项目专注于语音文本对齐技术,能够精确标注音频中每个词或字符的时间戳,对…...

iOSDeviceSupport:一站式解决Xcode设备调试兼容性问题

iOSDeviceSupport:一站式解决Xcode设备调试兼容性问题 【免费下载链接】iOSDeviceSupport All versions of iOS Device Support 项目地址: https://gitcode.com/gh_mirrors/ios/iOSDeviceSupport 当你的iOS设备连接Xcode却提示"Could not locate device…...

告别纸上谈兵:用Wireshark抓包实战分析FlexRay帧格式(含CRC校验)

实战解析FlexRay帧格式:用Wireshark抓包验证CRC与网络管理向量 车载工程师们常遇到这样的困境:明明熟读FlexRay协议文档,面对真实总线数据时却无从下手。本文将带您用Wireshark完成从抓包到解析的全流程实战,重点破解Header CRC校…...

智能配置黑苹果:三步快速部署OpenCore自动化工具终极指南

智能配置黑苹果:三步快速部署OpenCore自动化工具终极指南 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在为黑苹果复杂的EFI配置而头疼…...

Python服务OOM频发真相:20年C Python内核开发者首曝智能体内存管理策略架构图(含perf+eBPF验证数据)

第一章:Python智能体内存管理策略架构总览Python智能体的内存管理并非简单复用CPython的引用计数与垃圾回收机制,而是构建在多层级抽象之上的协同式策略体系。该体系需同时满足短期对话上下文缓存、长期知识图谱嵌入存储、跨会话记忆检索以及隐私敏感数据…...

言语主旨题和细节判断题

由于气温上升、降雨改变和极端气候事件,热带森林正频繁遭受干旱。气候压力对亚马孙雨林尤为明显,反复发生的干旱事件增加了树木的死亡率。根据《自然》杂志发表的一项研究,亚马孙森林树木对干旱的耐受取决于不同物种,这影响到它们…...

RVC语音训练实战:从零开始3分钟极速训练模型,打造你的专属AI歌手

RVC语音训练实战:从零开始3分钟极速训练模型,打造你的专属AI歌手 1. RVC简介与准备工作 RVC(Retrieval-based-Voice-Conversion)是一款强大的AI语音转换工具,能够让你快速训练出专属的AI歌手模型。与传统语音合成技术…...

如何永久保存微信聊天记录?WeChatExporter 开源工具帮你解决数据备份难题

如何永久保存微信聊天记录?WeChatExporter 开源工具帮你解决数据备份难题 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否曾担心微信聊天记录会随着手机…...

自定义调色盘组件

示例效果&#xff1a;调色盘组件代码&#xff1a;使用input[typecolor]实现<template><div class"color-plate-page"><div class"color-div" click.stop"onColorDivClick"></div><div class"color-plate" …...

医疗工作者的AI助手:MedGemma在症状鉴别诊断中的实战应用

医疗工作者的AI助手&#xff1a;MedGemma在症状鉴别诊断中的实战应用 1. 医疗AI的新范式&#xff1a;透明化诊断推理 在繁忙的临床工作中&#xff0c;医生们常常面临这样的挑战&#xff1a;如何在有限时间内准确识别症状组合背后的病因&#xff1f;传统方法依赖个人经验记忆和…...

Python 3.15 JIT深度解析(仅限首批内测用户验证的6项隐藏能力)

第一章&#xff1a;Python 3.15 JIT 的演进脉络与内测生态定位Python 3.15 并非官方已发布的正式版本&#xff0c;而是社区中围绕“Python JIT 加速”持续探索所形成的前瞻性技术代号&#xff0c;特指以 CPython 为核心、集成实验性即时编译器&#xff08;JIT&#xff09;的内测…...

万字长文 解析串口通信

一.目标 处理器与外部设备通信的两种方式 单工只允许一个方向 半双工就像对讲机 全双工就像打电话 按照有无时钟同步 分为 1帧等于1个起始位 加上数据位 加上效验位 停止位 波特率是一秒传输的字节数 起始位(Start Bit): 起始位是数据帧的同步标志位,固定为低电平(…...