mirror of
https://github.com/CopterExpress/clover.git
synced 2026-05-26 11:43:25 +00:00
Creates assets/timing_with_thumbs.png
Auto commit by GitBook Editor
This commit is contained in:
@@ -37,8 +37,9 @@
|
||||
* [Урок 13](docs/les13.md)
|
||||
* [Урок 15](docs/les15.md)
|
||||
* [Урок 16](docs/les16.md)
|
||||
* Другое
|
||||
* [Другое](drugoe.md)
|
||||
* [CopterHack-2017](docs/copterhack2017.md)
|
||||
* [Прошивка ESC контроллеров с помощью Arduino](docs/esc_firmware.md)
|
||||
* [Работа со светодиодной лентой](docs/rabota-so-svetodiodnoi-lentoi.md)
|
||||
* [Полезные ссылки](docs/links.md)
|
||||
|
||||
|
||||
BIN
assets/timing_with_thumbs.png
Normal file
BIN
assets/timing_with_thumbs.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 154 KiB |
128
docs/rabota-so-svetodiodnoi-lentoi.md
Normal file
128
docs/rabota-so-svetodiodnoi-lentoi.md
Normal file
@@ -0,0 +1,128 @@
|
||||
## Работа со светодиодной лентой на Raspberry 3
|
||||
|
||||
#### Подключение и определение типа ленты
|
||||
|
||||
Есть два основных типа адресуемых светодиодов: WS2812 и WS2812B. Принцип управления один и тот же, однако тайминги разные. Посмотрите на светодиодный модуль на ленте и определите, сколько у него ножек: 6 или 4. Если ножек 6, то это WS2812, если 4 - то WS2812B или SK2812.
|
||||
|
||||

|
||||
|
||||
Т.к. принцип управления одинаковый, то и ленты подключаются одинаково:
|
||||
|
||||
| Лента | Raspberry Pi |
|
||||
| :---: | :---: |
|
||||
| GND | GND |
|
||||
| 5V | 5V |
|
||||
| DIN | GPIO21 или GPIO31 |
|
||||
|
||||
Типы лент для обозначения ленты в коде описаны в файле [https://github.com/jgarff/rpi\_ws281x/blob/master/ws2811.h](https://github.com/jgarff/rpi_ws281x/blob/master/ws2811.h)
|
||||
|
||||
Основные типы лент - это WS2812\_STRIP \(для WS2812\) и SK6812\_STRIP \(для WS2812B или SK6812\).
|
||||
|
||||
#### Установка библиотеки для работы со светодиодной лентой
|
||||
|
||||
Определите папку, в которой будут находиться файлы библиотеки, и открыть путь к этой папке в терминале. По-умолчанию можно использовать домашнюю папку, для перехода в неё нужно выполнить команду
|
||||
|
||||
```
|
||||
cd ~
|
||||
```
|
||||
|
||||
Склонируйте репозиторий библиотеки для работы с led лентами на Raspberry Pi
|
||||
|
||||
```
|
||||
git clone https://github.com/jgarff/rpi_ws281x.git
|
||||
```
|
||||
|
||||
Установите Scons \([что это?](https://ru.wikipedia.org/wiki/SCons)\) и Swig \([что это?](https://ru.wikipedia.org/wiki/SWIG)\)
|
||||
|
||||
```
|
||||
sudo apt-get install scons python-dev swig
|
||||
```
|
||||
|
||||
Соберите библиотеку с помощью Scons \(команда выполняется внутри папки с исходным кодом библиотеки\)
|
||||
|
||||
```
|
||||
cd rpi_ws281x
|
||||
scons
|
||||
```
|
||||
|
||||
Соберите python обёртку библиотеки с помощью Swig и установите её для возможности использования в своих python скриптах.
|
||||
|
||||
```
|
||||
cd python
|
||||
python ./setup.py build
|
||||
python ./setup.py install
|
||||
```
|
||||
|
||||
#### Пример программы для светодиодной ленты на RPI3
|
||||
|
||||
Откройте в текстовом редакторе файл strandtest.py из папки python/examples \(находится в папке с библиотекой\)
|
||||
|
||||
```
|
||||
nano strandtest.py
|
||||
```
|
||||
|
||||
Найдите участок кода с настройками ленты
|
||||
|
||||
```
|
||||
# LED strip configuration:
|
||||
LED_COUNT = 16 # Number of LED pixels.
|
||||
LED_PIN = 18 # GPIO pin connected to the pixels (18 uses PWM!).
|
||||
#LED_PIN = 10 # GPIO pin connected to the pixels (10 uses SPI /dev/spidev0.0).
|
||||
LED_FREQ_HZ = 800000 # LED signal frequency in hertz (usually 800khz)
|
||||
LED_DMA = 10 # DMA channel to use for generating signal (try 10)
|
||||
LED_BRIGHTNESS = 255 # Set to 0 for darkest and 255 for brightest
|
||||
LED_INVERT = False # True to invert the signal (when using NPN transistor level shift)
|
||||
LED_CHANNEL = 0 # set to '1' for GPIOs 13, 19, 41, 45 or 53
|
||||
LED_STRIP = ws.WS2811_STRIP_GRB # Strip type and colour ordering
|
||||
```
|
||||
|
||||
Поправьте настройки для работы с лентой и сохраните файл. Чтобы использование ленты не мешало работе других устройств на Raspberry Pi, рекомендуется использовать следующие настройки \(настройки подходят для ленты в комплекте с Клевер 3\):
|
||||
|
||||
```
|
||||
# LED strip configuration:
|
||||
LED_COUNT = 30 # Number of LED pixels.
|
||||
LED_PIN = 21 # GPIO pin connected to the pixels.
|
||||
LED_FREQ_HZ = 800000 # LED signal frequency in hertz (usually 800khz)
|
||||
LED_DMA = 10 # DMA channel to use for generating signal (try 10)
|
||||
LED_BRIGHTNESS = 255 # Set to 0 for darkest and 255 for brightest
|
||||
LED_INVERT = False # True to invert the signal (when using NPN transistor level shift)
|
||||
LED_CHANNEL = 0 # set to '1' for GPIOs 13, 19, 41, 45 or 53
|
||||
LED_STRIP = ws.SK6812_STRIP # Strip type and colour ordering
|
||||
```
|
||||
|
||||
Запустите тестовую программу, используя права администратора
|
||||
|
||||
```
|
||||
sudo python strandtest.py
|
||||
```
|
||||
|
||||
Права администратора необходимы для выполнения скрипта, т.к. без них нет доступа к функциям прерывания, которые использует библиотека для работы с лентой.
|
||||
|
||||
#### Почему именно так и можно ли по-другому
|
||||
|
||||
Основные типы лент, которые используются для Clever3, это WS2812, WS2812B и SK6812 \(аналог WS2812B\). Они управляются по одному и тому же принципу: для массива светодиодов в ленте отправляется пакет данных по 24 бита на светодиод; каждый светодиод считывает первые 24 бита из пришедших к нему данных и устанавливает соответствующий цвет, остальные данные он отправляет следующему светодиоду в ленте. Нули и единицы задаются разными сочетаниями длительностей высокого и низкого уровня в импульсе.
|
||||
|
||||
Все эти ленты поддерживаются для управления библиотекой
|
||||
|
||||
[https://github.com/jgarff/rpi\_ws281x](https://github.com/jgarff/rpi_ws281x)
|
||||
|
||||
, при этом для управления используется модуль DMA \(direct memory access\) процессора распберри и один из каналов передачи данных: PWM, PCM или SPI, что гарантирует отсутствие задержек в управлении \(а управляется всё на многозадачной операционке, это важно\).
|
||||
|
||||
Есть некоторые особенности работы с каналами, например при передаче данных с помощью PWM \(ШИМ\) перестаёт работать встроенная аудиосистема распберри, при передаче данных по PCM блокируется использование подключенных цифровых аудиоустройств \(при этом встроенная система работает\), а при использовании SPI \(кстати, требуется специальная настройка размера буфера и частоты GPU распберри для правильной работы\) лед лента блокирует все остальные устройства, подключенные по этому каналу.
|
||||
|
||||
Есть некоторые особенности выбора канала DMA для управления лентой: некоторые каналы используются системой, поэтому их использование может привести к неприятным последствиям, например использование 5 канала рушит файловую систему распберри, т.к. этот канал используется при чтении-записи на SD карту. Безопасный канал - 10 \(другие не проверял\), он же установлен по-умолчанию в приведённой выше библиотеке.
|
||||
|
||||
Поэтому сценарии использования лед ленты следующие:
|
||||
|
||||
1\) Если нам не важна работоспособность встроенного аудио на распберри \(и мы его не используем, т.к. аудио и лента будут выдавать билиберду в этом случае\), то можно использовать PWM канал \(для этого требуется подключить вход ленты к одному из следующих GPIO портов распберри: 12, 18, 40, или 52 для PWM0 канала и 13, 19, 41, 45 или 53 для PWM1 канала\)
|
||||
|
||||
2\) Если нам не важно наличие на шине SPI других устройств, то можно управлять лентой по каналу SPI \(GPIO на распберри 10 или 38\). Здесь требуется произвести следующие настройки \(только для распберри 3\):
|
||||
|
||||
\* увеличить размер буфера передачи данных для поддержки длинных лент, добавив стройку spidev.bufsiz=32768 в файле /boot/cmdline.txt
|
||||
|
||||
\* установить частоту GPU для правильной частоты работы SPI, добавив строку core\_freq=250 в файл /boot/config.txt
|
||||
|
||||
3\) Если нам важна и работа аудио, и подключение к SPI устройств кроме лед ленты, то можно управлять лентой по каналу PCM \(GPIO 21 или 31\). При этом никаких дополнительных манипуляций с распберри не требуется.
|
||||
|
||||
Исходя из вышеперечисленных способов управления лентой, наилучшим вариантом, позволяющим управлять лентой, сохранить работоспособность встроенной аудиосистемы и возможность подключения всяческих устройств и датчиков по SPI, является управление по каналу PCM \(GPIO 21\) с использованием 10 канала DMA.
|
||||
|
||||
Reference in New Issue
Block a user