forked from Sensirion/makecode-extension-scd41
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathSCD40.ts
128 lines (113 loc) · 4.14 KB
/
SCD40.ts
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
//% weight=80 color=#00A654 icon="\uf0c2" block="CO2-Sensor SCD40"
namespace SCD40 {
export enum SCD40_T_UNIT {
//% block="°C"
C = 0,
//% block="°F"
F = 1
}
const SCD40_I2C_ADDR = 0x62;
let co2 = 0;
let temperature = 0;
let relative_humidity = 0;
init();
function read_word(repeat = false) {
let value = pins.i2cReadNumber(SCD40_I2C_ADDR, NumberFormat.UInt16BE, repeat);
pins.i2cReadNumber(SCD40_I2C_ADDR, NumberFormat.UInt8BE, repeat);
return value
}
function read_words(number_of_words: number) {
let buffer = pins.i2cReadBuffer(SCD40_I2C_ADDR, number_of_words * 3, false);
let words:number[] = [];
for (let i = 0; i < number_of_words; i++) {
words.push(buffer.getNumber(NumberFormat.UInt16BE, 3*i));
}
return words;
}
function get_data_ready_status() {
pins.i2cWriteNumber(SCD40_I2C_ADDR, 0xE4B8, NumberFormat.UInt16BE);
basic.pause(1);
let data_ready = read_word() & 0x07FF;
return data_ready > 0;
}
function read_measurement() {
// only read measurement if data is available, else use last measurement
if (!get_data_ready_status()) {
return
}
pins.i2cWriteNumber(SCD40_I2C_ADDR, 0xEC05, NumberFormat.UInt16BE);
basic.pause(1);
let values = read_words(6);
co2 = values[0];
let adc_t = values[1];
let adc_rh = values[2];
temperature = -45 + (175 * adc_t / (1 << 16));
temperature = (Math.round(temperature * 10) / 10)
relative_humidity = 100 * adc_rh / (1 << 16);
relative_humidity = (Math.round(relative_humidity * 10) / 10)
}
/**
* perform a factory reset
*/
//% blockId="SCD40_PERFORM_FACTORY_RESET" block="factory reset"
//% block.loc.de="auf Werkseinstellung setzen"
//% weight=60 blockGap=8 advanced=true
export function perform_factory_reset() {
pins.i2cWriteNumber(SCD40_I2C_ADDR, 0x3632, NumberFormat.UInt16BE);
}
export function init() {
start_continuous_measurement();
}
/**
* start continuous measurement. Call this before reading measurements
*/
//% blockId="SCD40_START_CONTINUOUS_MEASUREMENT" block="start continuous measurement"
//% block.loc.de="starte dauerhafte Messung"
//% weight=70 blockGap=8 advanced=true
export function start_continuous_measurement() {
pins.i2cWriteNumber(SCD40_I2C_ADDR, 0x21b1, NumberFormat.UInt16BE);
}
/**
* stop continuous measurement. Call this to stop SCD40 internal measurements
*/
//% blockId="SCD40_STOP_CONTINUOUS_MEASUREMENT" block="stop continuous measurement"
//% block.loc.de="stoppe dauerhafte Messung"
//% weight=70 blockGap=8 advanced=true
export function stop_continuous_measurement() {
pins.i2cWriteNumber(SCD40_I2C_ADDR, 0x3F86, NumberFormat.UInt16BE);
basic.pause(500);
}
/**
* get CO2. Call this at most once every 5 seconds, else last measurement value will be returned
*/
//% blockId="SCD40_GET_CO2" block="CO2 %u"
//% block.loc.de="CO2 %u"
//% weight=80 blockGap=8
export function get_co2() {
read_measurement();
return co2;
}
/**
* get temperature. Call this at most once every 5 seconds, else last measurement value will be returned
*/
//% blockId="SCD40_GET_TEMPERATURE" block="temperature %u"
//% block.loc.de="Temperatur %u"
//% weight=80 blockGap=8
export function get_temperature(unit: SCD40_T_UNIT = SCD40_T_UNIT.C) {
read_measurement();
if (unit == SCD40_T_UNIT.C) {
return temperature;
}
return 32 + ((temperature * 9) / 5);
}
/**
* get relative humidity. Call this at most once every 5 seconds, else last measurement value will be returned
*/
//% blockId="SCD40_GET_RELATIVE_HUMIDITY" block="relative humidity %u|%"
//% block.loc.de="relative Luftfeuchtigkeit %u|%"
//% weight=80 blockGap=8
export function get_relative_humidity() {
read_measurement();
return relative_humidity;
}
}