===== Эксперимент 46. Подключаем TFT дисплей ===== В комплектацию конструктора в версии MAXI входит TFT дисплей. Thin Film Transistor (TFT) – это система производства жидкокристаллических дисплеев, в основе которой лежит активная матрица из тонкопленочных транзисторов. При подаче напряжения на такую матрицу, кристаллы поворачиваются друг к другу, что приводит к образованию черного цвета. Отключение электричества дает противоположный результат — кристаллы образовывают белый цвет. Изменения подаваемого напряжения позволяет формировать любой цвет на каждом отдельно взятом пикселе. Дисплей имеет сложное многослойное строение и чтобы понять его принцип действия потребуются некоторые знания физики, поэтому здесь мы не будем рассказывать это. [[https://ru.wikipedia.org/wiki/Жидкокристаллический_дисплей|Подробнее об устройстве жидко- кристаллических дисплеев]] Управление матрицей кристаллов берет на себя встроенный в дисплей контроллер. А мы будем управлять этим контроллером. Для этого нам потребуется специальная библиотека. Установите библиотеку "Adafruit ST7735 and ST7789" как мы уже делали ранее. После нажатия кнопки "Установка" появится окно "Установите зависимости библиотек" с предложением установить необходимые зависимости. Нужно нажать "Установить все". {{ :products:laboratory_iot_c:arduino_ide_exp46_1.png?nolink |}} Для обмена данными с дисплеем используется шина SPI. SPI (англ. Serial Peripheral Interface, SPI bus — последовательный периферийный интерфейс, шина SPI) — последовательный синхронный стандарт передачи данных в режиме полного дуплекса, предназначенный для обеспечения простого и недорогого высокоскоростного сопряжения микроконтроллеров и периферии. SPI также иногда называют четырёхпроводным (англ. four-wire) интерфейсом. Для работы с SPI требуется специальная библиотека, но она уже встроена, поэтому дополнительно загружать ее не потребуется. [[https://ru.wikipedia.org/wiki/Serial_Peripheral_Interface|Подробнее о шине SPI]] В разных партиях конструктора версии MAXI может лежать дисплей одного из двух видов − либо с 8 выводами, либо с 11. В дальнейшем мы будем приводить монтажную схему для обоих дисплеев, но вам необходимо руководствоваться схемой для своего типа дисплея. ==== Схема эксперимента ==== {{ :products:esp-iot:exp21_mont.png?direct&600 |}} //Рисунок 1. Монтажная схема эксперимента для дисплея с 8 выводами// {{ :products:esp-iot:exp21_mont_11pin.png?direct&600 |}} //Рисунок 2. Монтажная схема эксперимента для дисплея с 11 выводами// ==== Программный код эксперимента ==== Напишем приветственную надпись на дисплее. #include #include #define PIN_CS 2 #define PIN_DC 4 #define PIN_RST 5 Adafruit_ST7735 tft = Adafruit_ST7735(PIN_CS, PIN_DC, PIN_RST); void setup() { tft.initR(INITR_BLACKTAB); tft.setRotation(2); tft.fillScreen(ST77XX_BLACK); tft.setCursor(0, 0); tft.setTextColor(ST77XX_WHITE); tft.print("Hello world!"); } void loop() { } Подключаем библиотеки для работы в портами ввода-вывода, шиной SPI, дисплеем и шрифт. #include #include TFT дисплей не имеет встроенного знакогенератора, он ничего не знает о буквах и о том как они выглядят. Дисплей — это просто большой массив точек, которые могут светиться различным цветом. . Настраиваем выводы, используемые для дисплея #define PIN_CS 2 #define PIN_DC 4 #define PIN_RST 5 Создаем объект дисплея и задаем какие выводы микроконтроллера используются для управления. Adafruit_ST7735 tft = Adafruit_ST7735(PIN_CS, PIN_DC, PIN_RST); Вызываем функцию инициализации дисплея. Прежде чем мы сможем работать с дисплеем, мы должны настроить встроенный в него контроллер. Это делает функция инициализации. tft.initR(INITR_BLACKTAB); Переворачиваем изображение. Если этого не сделать, изображение на дисплее для нас буде "верх ногами". tft.setRotation(2); Когда дисплей инициализирован мы можем управлять изображением на нем. Сначала закрасим его черным цветом, установим курсор в координаты 0,0, зададим цвет текста — белый, и выведем текст. tft.fillScreen(ST77XX_BLACK); tft.setCursor(0, 0); tft.setTextColor(ST77XX_WHITE); tft.print("Hello world!"); Координата 0,0 находится в верхнем левом углу. Максимальная — в нижнем правом. {{ :products:esp-iot:exp21_coords.png?nolink |}} //Рисунок 3. Отсчет координат на дисплее// ==== Дополнительное задание ==== - Выведи другой текст по середине дисплея - Выведи несколько строк разными цветами друг под другом