ESP8266-Arduino编程实例-OPT3001数字环境光传感器

OPT3001数字环境光传感器

1、OPT3001介绍

OPT3001 是一种测量可见光强度的传感器。 传感器的光谱响应与人眼的明视响应紧密匹配,并且包括显着的红外抑制。

OPT3001 是一款单芯片照度计,用于测量人眼可见的光强度。 该器件的精确光谱响应和强红外抑制使 OPT3001 能够准确测量人眼所见的光强度,而不受光源影响。 当工业设计要求将传感器安装在深色玻璃下以保持美观时,强大的 IR 抑制还有助于保持高精度。 OPT3001 专为为人类创造基于光的体验的系统而设计,是光电二极管、光敏电阻或其他人眼匹配和红外抑制较少的环境光传感器的理想首选替代品。

使用内置的满量程设置功能,无需手动选择满量程范围,即可在 0.01 勒克斯到 83k 勒克斯范围内进行测量。 此功能允许在 23 位有效动态范围内进行光测量。

数字化操作灵活,便于系统集成。 测量可以是连续的或单次的。 控制和中断系统具有自主操作功能,允许处理器在传感器搜索适当的唤醒事件以通过中断引脚报告时进入睡眠状态。 数字输出通过 I2C 和 SMBus 兼容的两线串行接口报告。

在这里插入图片描述

OPT3001具有如下特性:

  • 匹配人眼的精密光学过滤:
    • 拒绝 > 99%(典型值)的 IR
  • 自动满量程设置功能简化了软件并确保正确配置
  • 测量:0.01 勒克斯至 83 千勒克斯
  • 23 位有效动态范围
  • 自动增益范围
  • 12 个二进制加权满量程范围设置:
  • < 0.2%(典型值)范围之间的匹配
  • 低工作电流:1.8 µA(典型值)
  • 工作温度范围:–40°C 至 +85°C
  • 宽电源范围:1.6V 至 3.6V
  • 5.5V 容限 I/O

2、硬件准备

  • ESP8266 NodeMCU开发板一块
  • OPT3001传感器模块一个
  • 面板板一个
  • 杜邦线若干
  • 数据线一条

硬件接线如下:

传感器引脚 ESP8266开发板引脚
Vin 5v
Gnd Gnd
SCL D1
SDA D2

3、软件准备

  • Arduino IDE或VSCode + PlatformIO

在前面的文章中,对如何搭建ESP8266开发环境做了详细的介绍,请参考:

ESP8266 NodeMCU的引脚介绍在前面的文章中做了详细的介绍,请参考:

4、代码实现

本次实例使用如下驱动库:

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
#include <Wire.h>
#include <ClosedCube\_OPT3001.h>

ClosedCube_OPT3001 opt3001;

#define OPT3001\_ADDRESS 0x44

void setup()
{
Serial.begin(9600);
Serial.println("ClosedCube OPT3001 Arduino Test");

opt3001.begin(OPT3001_ADDRESS);
Serial.print("OPT3001 Manufacturer ID");
Serial.println(opt3001.readManufacturerID());
Serial.print("OPT3001 Device ID");
Serial.println(opt3001.readDeviceID());

configureSensor();
printResult("High-Limit", opt3001.readHighLimit());
printResult("Low-Limit", opt3001.readLowLimit());
Serial.println("----");
}

void loop()
{
OPT3001 result = opt3001.readResult();
printResult("OPT3001", result);
delay(500);
}

void configureSensor() {
OPT3001_Config newConfig;

newConfig.RangeNumber = B1100;
newConfig.ConvertionTime = B0;
newConfig.Latch = B1;
newConfig.ModeOfConversionOperation = B11;

OPT3001_ErrorCode errorConfig = opt3001.writeConfig(newConfig);
if (errorConfig != NO_ERROR)
printError("OPT3001 configuration", errorConfig);
else {
OPT3001_Config sensorConfig = opt3001.readConfig();
Serial.println("OPT3001 Current Config:");
Serial.println("------------------------------");

Serial.print("Conversion ready (R):");
Serial.println(sensorConfig.ConversionReady,HEX);

Serial.print("Conversion time (R/W):");
Serial.println(sensorConfig.ConvertionTime, HEX);

Serial.print("Fault count field (R/W):");
Serial.println(sensorConfig.FaultCount, HEX);

Serial.print("Flag high field (R-only):");
Serial.println(sensorConfig.FlagHigh, HEX);

Serial.print("Flag low field (R-only):");
Serial.println(sensorConfig.FlagLow, HEX);

Serial.print("Latch field (R/W):");
Serial.println(sensorConfig.Latch, HEX);

Serial.print("Mask exponent field (R/W):");
Serial.println(sensorConfig.MaskExponent, HEX);

Serial.print("Mode of conversion operation (R/W):");
Serial.println(sensorConfig.ModeOfConversionOperation, HEX);

Serial.print("Polarity field (R/W):");
Serial.println(sensorConfig.Polarity, HEX);

Serial.print("Overflow flag (R-only):");
Serial.println(sensorConfig.OverflowFlag, HEX);

Serial.print("Range number (R/W):");
Serial.println(sensorConfig.RangeNumber, HEX);

Serial.println("------------------------------");
}

}

void printResult(String text, OPT3001 result) {
if (result.error == NO_ERROR) {
Serial.print(text);
Serial.print(": ");
Serial.print(result.lux);
Serial.println(" lux");
}
else {
printError(text,result.error);
}
}

void printError(String text, OPT3001_ErrorCode error) {
Serial.print(text);
Serial.print(": [ERROR] Code #");
Serial.println(error);
}

文章来源: https://iotsmart.blog.csdn.net/article/details/126574612