Лёгкая библиотека со стандартным набором инструментов для работы с аппаратным I2C
- Облегчайте свой код простой заменой Wire.h на microWire.h
- ATmega168/328p (nano,uno,mini), ATmega32u4 (leonardo,micro) , ATmega2560 (mega)
AVR ATmega168/328p (nano,uno,mini), ATmega32u4 (leonardo,micro), ATmega2560 (mega)
- Библиотеку можно найти по названию microWire и установить через менеджер библиотек в:
- 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: найти библиотеку как при установке и нажать "Обновить"
- Вручную: удалить папку со старой версией, а затем положить на её место новую. "Замену" делать нельзя: иногда в новых версиях удаляются файлы, которые останутся при замене и могут привести к ошибкам!
Нет
void begin(void); // инициализация шины
void setClock(uint32_t clock); // ручная установка частоты шины 31-900 kHz (в герцах)
void beginTransmission(uint8_t address); // открыть соединение (для записи данных)
uint8_t endTransmission(bool stop); // закрыть соединение , произвести stop или restart (по умолчанию - stop)
uint8_t endTransmission(void); // закрыть соединение , произвести stop
void write(uint8_t data); // отправить в шину байт данных , отправка производится сразу , формат - byte "unsigned char"
void requestFrom(uint8_t address , uint8_t length , bool stop); //открыть соединение и запросить данные от устройства, отпустить или удержать шину
void requestFrom(uint8_t address , uint8_t length); //открыть соединение и запросить данные от устройства, отпустить шину
uint8_t read(void); // прочитать байт , БУФЕРА НЕТ!!! , читайте сразу все запрошенные байты , stop или restart после чтения последнего байта, настраивается в requestFrom
uint8_t available(void); // вернет количество оставшихся для чтения байт
/* Пример записи и чтения данных в I2C - EEPROM "AT24C32" */
// #include <Wire.h> // заменяем Wire.h на microWire.h
#include <microWire.h>
uint8_t chipAddress = 0x57; // адрес устройства (используйте i2c scaner для определения)
uint16_t cellAddress = 3064; // адрес первой ячейки , куда будем писать и откуда читать
uint8_t data_0 = 115; // данные , которые запишем в EEPROM ( сравнивайте с этим числом при чтении )
uint8_t data_1 = 14;
void setup() {
Serial.begin(9600);
Wire.begin();
/* запись */
Wire.beginTransmission(chipAddress); // начинаем передачу с устройством , зовем по адресу
Wire.write(highByte(cellAddress)); // отправляем старший байт первой адреса ячейки
Wire.write(lowByte(cellAddress)); // отправляем младший байт первой адреса ячейки
Wire.write(data_0); // отпарвляем байт данных
Wire.write(data_1); // отпарвляем еще байт данных
Wire.endTransmission(); // завершаем передачу
delay(50); // подождем
/* чтение */
Wire.beginTransmission(chipAddress); // начинаем передачу с устройством , зовем по адресу
Wire.write(highByte(cellAddress)); // отправляем старший байт адреса первой ячейки
Wire.write(lowByte(cellAddress)); // отправляем младший байт адреса первой ячейки
Wire.endTransmission(); // завершаем передачу
Wire.requestFrom(chipAddress , 2); // запрашиваем свои 2 байта данных
while (Wire.available()) { // пока запрошенные данные не кончились
Serial.println(Wire.read()); // читаем и выводим их
}
}
void loop() {
}
- v2.1
- v2.2 от firexx - добавлены функции для полной совместимости с API Wire
При нахождении багов создавайте Issue, а лучше сразу пишите на почту alex@alexgyver.ru
Библиотека открыта для доработки и ваших Pull Request'ов!
При сообщении о багах или некорректной работе библиотеки нужно обязательно указывать:
- Версия библиотеки
- Какой используется МК
- Версия SDK (для ESP)
- Версия Arduino IDE
- Корректно ли работают ли встроенные примеры, в которых используются функции и конструкции, приводящие к багу в вашем коде
- Какой код загружался, какая работа от него ожидалась и как он работает в реальности
- В идеале приложить минимальный код, в котором наблюдается баг. Не полотно из тысячи строк, а минимальный код