• 【毕业设计】基于单片机的无接触测温枪 - MLX90614 红外测温仪 嵌入式 物联网 stm32



    0 前言

    🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师的要求。

    为了大家能够顺利以及最少的精力通过毕设,学长分享优质毕业设计项目,今天要分享的是

    🚩 基于单片机的无接触测温枪

    🥇学长这里给一个题目综合评分(每项满分5分)

    • 难度系数:4分
    • 工作量:4分
    • 创新点:3分

    🧿 选题指导, 项目分享:

    https://gitee.com/dancheng-senior/project-sharing-1/blob/master/%E6%AF%95%E8%AE%BE%E6%8C%87%E5%AF%BC/README.md

    在这里插入图片描述


    1 简介

    疫情当前,电子测温枪供不应求,本项目实现了基于MLX90614的红外测温仪。含有3段温度区段报警功能:分为绿蓝红区,低于绿区设定值不报警,介于绿区红区设定值鸣响5声,高于红区设定值鸣响10声。

    2 主要器件

    • Atmel Mega168主控芯片
    • MLX90614为红外温度传感器
    • 3位0.28寸共阳数码管为屏幕显示
    • 18650电池
    • IP5306升压转换SOC

    3 实现效果

    正常温度-绿色在这里插入图片描述
    中等温度-蓝色
    在这里插入图片描述
    严重高温-红色
    在这里插入图片描述
    实物检测
    在这里插入图片描述
    在这里插入图片描述

    4 相关模块、配置介绍

    mlx90614红外传感器
    MLX90614是一款红外非接触温度计。TO-39金属封装里同时集成了红外感应热电堆探测器芯片和信号处理专用集成芯片。由于集成了低噪声放大器、17位模数转换器和强大的数字信 号处理单元,使得高精度和高分辨度的温度计得以实现。温度计具备出厂校准化,有数字 PWM和 SMBus(系统管理 总线)输出模式。作为标准,配置为 10 位的 PWM 输出格式用于连续传送温 度范围为-20…120 ˚C 的物体温度,其分辨率为 0.14 ˚C。 POR 默认模式是 SMBus 输出格式。
    实物
    在这里插入图片描述

    硬件电路图如下:
    在这里插入图片描述

    烧录配置(部分)
    在这里插入图片描述在“1”框内选择相应的芯片型号
    选择完成后,按下“2”
    按下“3”进入熔丝位设置

    设置对应的熔丝位,完成后点击“写入”
    在这里插入图片描述
    在这里插入图片描述
    选择相应的固件,点击“打开”
    在这里插入图片描述

    主要原理图
    在这里插入图片描述

    5 部分核心代码

    void setup() {
      // put your setup code here, to run once:
      pinMode(RIGHT, INPUT_PULLUP);
      pinMode(LEFT, INPUT_PULLUP);
      pinMode(MAIN, INPUT_PULLUP);
      pinMode(RED, OUTPUT);
      pinMode(YELLOW, OUTPUT);
      pinMode(GREEN, OUTPUT);
      pinMode(BUZZER, OUTPUT);
      Wire.begin();
      byte highTCA = EEPROM.read(temperatureCalibrationAddress);
      byte lowOTCA = EEPROM.read(temperatureCalibrationAddress + 1);
      byte highBSA = EEPROM.read(buzStateAddress);
      byte lowbBSA = EEPROM.read(buzStateAddress + 1);
      temperatureCalibration = (highTCA << 8) + lowOTCA;
      buzState = (highBSA << 8) + lowbBSA;
      sevseg.begin(hardwareConfig, numDigits, digitPins, segmentPins); //初始化数码管
      sevseg.setBrightness(45);
      digitalWrite(RED, HIGH);
      delay(175);
      digitalWrite(RED, LOW);
      digitalWrite(YELLOW, HIGH);
      delay(175);
      digitalWrite(YELLOW, LOW);
      digitalWrite(GREEN, HIGH);
      delay(175);
      digitalWrite(GREEN, LOW);
    
      if (temperatureCalibration < -25 or temperatureCalibration > 25)
      {
        temperatureCalibration = 0;
      }
      if (buzState < 0 or buzState > 1)
      {
        buzState = 0;
      } 
      /*
      由于使用固件烧录会擦除EEPROM,所以烧录完程序启动时,读取到的EEPROM会不正常
      为了避免系统异常,就增加这几行代码,用作数据纠正
      */
      if (buzState == 1)
      {
        digitalWrite(BUZZER, HIGH);
        delay(85);
        digitalWrite(BUZZER, LOW);
      }
      else
      {
        digitalWrite(BUZZER, LOW);
      }
      sevseg.setChars("--.-");
    }
    
    void loop() {
      if (digitalRead(MAIN) == 0)
      {
        keyState1 = 1;
        sevseg.refreshDisplay();
      }
      else
      {
        keyState1 = 0;
      }
      if (digitalRead(LEFT) == 0)
      {
        keyState2 = 1;
        sevseg.refreshDisplay();
      }
      else
      {
        keyState2 = 0;
      }
      if (digitalRead(RIGHT) == 0)
      {
        keyState3 = 1;
        sevseg.refreshDisplay();
      }
      else
      {
        keyState3 = 0;
      }
    
      if (keyState2 == 1)
      {
        delayCount = delayCount + 1;
      }
      if (delayCount >= delayCountMax3)
      {
        delayCount = 0;
        menu = menu + 1;
        digitalWrite(RED, LOW);
        digitalWrite(GREEN, LOW);
        digitalWrite(YELLOW, LOW);
      }
      if (menu > menuMax)
      {
        survey();
        sevseg.refreshDisplay();
        menu = 0;
      }
      switch (menu)
      {
        case 0 :
          menu_0();
          sevseg.refreshDisplay();
          break;
        case 1 :
          menu_1();
          sevseg.refreshDisplay();
          break;
        case 2 :
          menu_2();
          sevseg.refreshDisplay();
          break;
      }
    
      if (buzState == 1 && buzRingFrequency > 0)
      {
        buzDelayCount = buzDelayCount + 1;
        if (buzDelayCount == (delayCountMax4 / 5) * 4)
        {
          digitalWrite(BUZZER, HIGH);
        }
        if (buzDelayCount >= delayCountMax4)
        {
          digitalWrite(BUZZER, LOW);
          buzDelayCount = 0;
          buzRingFrequency = buzRingFrequency - 1;
        }
      }
      if (buzState == 0 or buzRingFrequency == 0)
      {
        digitalWrite(BUZZER, LOW);
      }
    }
    
    void menu_0()
    {
      if (keyState1 == 1)
      {
        delayCount = delayCount + 1;
      }
      if (delayCount >= delayCountMax3)
      {
        delayCount = 0;
        survey();
        buzRingFrequency = 1;
        if (temperature < minTemperature)
        {
          digitalWrite(GREEN, LOW);
          digitalWrite(RED, LOW);
          digitalWrite(YELLOW, LOW);
          sevseg.setChars("Lo");
          sevseg.refreshDisplay();
        }
        if (temperature >= minTemperature && temperature < yellowTemperature)
        {
          digitalWrite(GREEN, HIGH);
          digitalWrite(YELLOW, LOW);
          digitalWrite(RED, LOW);
        }
        if (temperature >= yellowTemperature && temperature < redTemperature)
        {
          digitalWrite(YELLOW, HIGH);
          digitalWrite(GREEN, LOW);
          digitalWrite(RED, LOW);
          buzRingFrequency = 5;
        }
        if (temperature >= redTemperature && temperature < maxTemperature)
        {
          digitalWrite(RED, HIGH);
          digitalWrite(GREEN, LOW);
          digitalWrite(YELLOW, LOW);
          buzRingFrequency = 10;
        }
        if (temperature >= maxTemperature)
        {
          digitalWrite(RED, LOW);
          digitalWrite(GREEN, LOW);
          digitalWrite(YELLOW, LOW);
        }
        if (temperature >= maxTemperature)
        {
          survey();
          sevseg.setChars("HIG");
          sevseg.refreshDisplay();
        }
      }
    }
    
    void menu_1()
    {
      if (keyState3 == 1)
      {
        delayCount = delayCount + 1;
      }
      if (delayCount >= delayCountMax3)
      {
        buzState = buzState + 1;
        delayCount = 0;
      }
      if (buzState > 1)
      {
        buzState = 0;
      } 
      switch (buzState)
      {
        case 0:
          //buzState = 0;
          sevseg.setChars("bof");
          sevseg.refreshDisplay();
          break;
        case 1:
          //buzState = 1;
          sevseg.setChars("bon");
          sevseg.refreshDisplay();
          break;
      }
      sevseg.refreshDisplay();
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103
    • 104
    • 105
    • 106
    • 107
    • 108
    • 109
    • 110
    • 111
    • 112
    • 113
    • 114
    • 115
    • 116
    • 117
    • 118
    • 119
    • 120
    • 121
    • 122
    • 123
    • 124
    • 125
    • 126
    • 127
    • 128
    • 129
    • 130
    • 131
    • 132
    • 133
    • 134
    • 135
    • 136
    • 137
    • 138
    • 139
    • 140
    • 141
    • 142
    • 143
    • 144
    • 145
    • 146
    • 147
    • 148
    • 149
    • 150
    • 151
    • 152
    • 153
    • 154
    • 155
    • 156
    • 157
    • 158
    • 159
    • 160
    • 161
    • 162
    • 163
    • 164
    • 165
    • 166
    • 167
    • 168
    • 169
    • 170
    • 171
    • 172
    • 173
    • 174
    • 175
    • 176
    • 177
    • 178
    • 179
    • 180
    • 181
    • 182
    • 183
    • 184
    • 185
    • 186
    • 187
    • 188
    • 189
    • 190
    • 191
    • 192
    • 193
    • 194
    • 195
    • 196
    • 197
    • 198
    • 199
    • 200
    • 201
    • 202
    • 203
    • 204
    • 205
    • 206
    • 207
    • 208
    • 209
    • 210
    • 211
    • 212
    • 213
    • 214
    • 215
    • 216
    • 217
    • 218
    • 219
    • 220

    5 最后

  • 相关阅读:
    政务问答系统模型动转静,插入milvus.ipynb
    React基础 (3)
    国内某知名半导体公司:实现虚拟化环境下的文件跨网安全交换
    Mybatis,其中难点问题做了详细解释
    Spring Framework
    大数据课程K19——Spark的电影推荐案例&&推荐系统的冷启动问题
    树与二叉树(考研版)
    ZigBee 3.0理论教程-通用-1-11:安全加密-网络层(NWK)安全
    mac安装nvm
    【每日渗透笔记】覆盖漏洞+修改隐藏数据实战尝试
  • 原文地址:https://blog.csdn.net/m0_71572576/article/details/126404833