Arduino:Примеры/Esplora TFT Graph

Материал из Онлайн справочника
Версия от 09:28, 14 декабря 2016; Myagkij (обсуждение | вклад) (Замена текста — «<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS">» на «<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS" enclose="div">»)
(разн.) ← Предыдущая версия | Текущая версия (разн.) | Следующая версия → (разн.)
Перейти к навигацииПерейти к поиску

Перевод: Максим Кузьмин
Проверка/Оформление/Редактирование: Мякишев Е.А.


Построение графика на TFT-экране Esplora [1]

Этот пример для Esplora (и подключенного к ней TFT-экрана Arduino) считывает данные о яркости, исходящие от встроенного светового датчика, а затем в графическом виде отображает их на экране. То есть этот пример аналогичен примеру «График», использующему последовательную передачу данных.

Необходимое оборудование

  • Плата Arduino Esplora;
  • TFT-экран Arduino;

Цепь

Подключите TFT-экран к сокету на Esplora, но так, чтобы надпись «SD Card» была вверху.

Код

Чтобы использовать экран, вам надо подключить библиотеки SPI и TFT. Также не забудьте о библиотеке Esplora.

#include <Esplora.h>
#include <TFT.h>
#include <SPI.h>

Создаем переменную, которая будет хранить информацию о Х-оси графика. Мы будем увеличивать это значение при каждом проходе через цикл loop(). В блоке setup() инициализируем экран и окрашиваем фон в приятный цвет.

int xPos = 0;

void setup(){
  EsploraTFT.begin();
  EsploraTFT.background(250,16,200); 
}

В блоке loop() считываем данные от светового датчика, а затем приспосабливаем их к высоте экрана.

void loop(){
  int sensor = Esplora.readLightSensor();
  int graphHeight = map(sensor,0,1023,0,EsploraTFT.height());

Задаем цвет строки – он должен быть таким, чтобы контрастировать и (желательно) приятно сочетаться с фоновым цветом, который мы задали чуть ранее. Далее рисуем линию от нижней части экрана – ее длина будет зависеть от данных, считанных со светового датчика.

EsploraTFT.stroke(250,180,10);
  EsploraTFT.line(xPos, EsploraTFT.height() - graphHeight, xPos, EsploraTFT.height());

Перед закрытием loop() проверяем, не заскочил ли наш график за край экрана. Если да, стираем все и начинаем с нуля по оси X.

if (xPos >= 160) {
    xPos = 0;
    EsploraTFT.background(250,16,200); 
  } 
  else {
    xPos++;
  }
  delay(16);
}

Весь скетч полностью – ниже:

/*
Построение графика на TFT-экране, подключенном к Esplora

Этот пример использует плату Esplora и TFT-экран Arduino.
Он считывает данные, идущие от светового датчика,
а затем в графическом виде выводит их на экран.

Этот код не защищен авторским правом.

Создан 15 апреля 2013 Скоттом Фитцджеральдом (Scott Fitzgerald)

http://www.arduino.cc/en/Tutorial/EsploraTFTGraph
*/

#include <Esplora.h>
#include <TFT.h>  // библиотека LCD-экрана Arduino
#include <SPI.h>

// Позиция линии на экране:
int xPos = 0;

void setup() {

  // Инициализируем экран:
  EsploraTFT.begin();

  // Очищаем экран, «заливая» его приятным цветом:
  EsploraTFT.background(250, 16, 200);
}

void loop() {

  // Считываем значение от светового датчика:
  int sensor = Esplora.readLightSensor();
  // Приспосабливаем данные от датчика к высоте экрана:
  int graphHeight = map(sensor, 0, 1023, 0, EsploraTFT.height());

  // Рисуем линию контрастирующего цвета:
  EsploraTFT.stroke(250, 180, 10);
  EsploraTFT.line(xPos, EsploraTFT.height() - graphHeight, xPos, EsploraTFT.height());

  // Если график достигает края экрана, стираем его,
  // а затем заново начинаем с другой стороны:
  if (xPos >= 160) {
    xPos = 0;
    EsploraTFT.background(250, 16, 200);
  } else {
    // Увеличиваем позицию по горизонтали:
    xPos++;
  }

  delay(16);
}

См.также

Внешние ссылки