Лёгкая библиотека для драйвера термопары MAX6675
- Чтение температуры в градусах Цельсия
- Вывод в целых числах и float
- Определение наличия модуля и термопары на связи
- Работа через программный и аппаратный SPI (отдельный класс)
Совместима со всеми Arduino платформами (используются Arduino-функции)
- Для работы нужна GyverGFX
- Библиотеку можно найти по названию GyverMAX6675 и установить через менеджер библиотек в:
- Arduino IDE
- Arduino IDE v2
- PlatformIO
- Скачать библиотеку .zip архивом для ручной установки:
- Распаковать и положить в C:\Program Files (x86)\Arduino\libraries (Windows x64)
- Распаковать и положить в C:\Program Files\Arduino\libraries (Windows x32)
- Распаковать и положить в Документы/Arduino/libraries/
- (Arduino IDE) автоматическая установка из .zip: Скетч/Подключить библиотеку/Добавить .ZIP библиотеку… и указать скачанный архив
- Читай более подробную инструкцию по установке библиотек здесь
- Рекомендую всегда обновлять библиотеку: в новых версиях исправляются ошибки и баги, а также проводится оптимизация и добавляются новые фичи
- Через менеджер библиотек IDE: найти библиотеку как при установке и нажать "Обновить"
- Вручную: удалить папку со старой версией, а затем положить на её место новую. "Замену" делать нельзя: иногда в новых версиях удаляются файлы, которые останутся при замене и могут привести к ошибкам!
GyverMAX6675<CLK_PIN, DATA_PIN, CS_PIN> sens; // программный SPI
GyverMAX6675_SPI<CS_PIN> sens; // аппаратный SPI
bool readTemp(); // Запросить температуру (вернёт true если успешно)
float getTemp(); // Получить температуру float
int getTempInt(); // Получить температуру int
// Настройки перед подключением библиотеки
// задать задержку переключения CLK в микросекундах для улучшения связи по длинным проводам
// (для GyverMAX6675)
#define MAX6675_DELAY 10
// задать скорость SPI в Гц (умолч. 1000000 - 1 МГц) для улучшения связи по длинным проводам
// (для GyverMAX6675_SPI)
#define MAX6675_SPI_SPEED 300000
Есть два способа получения температуры с датчика:
- Вызвать
getTemp()
илиgetTempInt()
- функция прочитает и вернёт температуру с датчика. При ошибке чтения вернёт предыдущее успешно прочитанное значение. - Вызвать
readTemp()
- вернётtrue
при успешном чтении иfalse
при ошибке. Результат можно забрать изgetTemp()
илиgetTempInt()
.
Остальные примеры смотри в examples!
#include <GyverMAX6675.h>
// Пины модуля MAX6675K
#define CLK_PIN 13 // Пин SCK
#define DATA_PIN 12 // Пин SO
#define CS_PIN 10 // Пин CS
// указываем пины в порядке SCK SO CS
GyverMAX6675<CLK_PIN, DATA_PIN, CS_PIN> sens;
void setup() {
Serial.begin(9600);
}
void loop() {
if (sens.readTemp()) { // Читаем температуру
Serial.print("Temp: "); // Если чтение прошло успешно - выводим в Serial
Serial.print(sens.getTemp()); // Забираем температуру через getTemp
//Serial.print(sens.getTempInt()); // или getTempInt - целые числа (без float)
Serial.println(" *C");
} else Serial.println("Error"); // ошибка чтения или подключения - выводим лог
delay(1000); // Немного подождем
}
- v1.0 - релиз
При нахождении багов создавайте Issue, а лучше сразу пишите на почту [email protected]
Библиотека открыта для доработки и ваших Pull Request'ов!
При сообщении о багах или некорректной работе библиотеки нужно обязательно указывать:
- Версия библиотеки
- Какой используется МК
- Версия SDK (для ESP)
- Версия Arduino IDE
- Корректно ли работают ли встроенные примеры, в которых используются функции и конструкции, приводящие к багу в вашем коде
- Какой код загружался, какая работа от него ожидалась и как он работает в реальности
- В идеале приложить минимальный код, в котором наблюдается баг. Не полотно из тысячи строк, а минимальный код