Skip to content

Лёгкая библиотека для драйвера термопары MAX6675

License

Notifications You must be signed in to change notification settings

GyverLibs/GyverMAX6675

Repository files navigation

latest PIO Foo Foo Foo

Foo

GyverMAX6675

Лёгкая библиотека для драйвера термопары 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, а лучше сразу пишите на почту alex@alexgyver.ru
Библиотека открыта для доработки и ваших Pull Request'ов!

При сообщении о багах или некорректной работе библиотеки нужно обязательно указывать:

  • Версия библиотеки
  • Какой используется МК
  • Версия SDK (для ESP)
  • Версия Arduino IDE
  • Корректно ли работают ли встроенные примеры, в которых используются функции и конструкции, приводящие к багу в вашем коде
  • Какой код загружался, какая работа от него ожидалась и как он работает в реальности
  • В идеале приложить минимальный код, в котором наблюдается баг. Не полотно из тысячи строк, а минимальный код

About

Лёгкая библиотека для драйвера термопары MAX6675

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages