MicroPython:Платы/WiPy/Краткое руководство по плате WiPy
Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску
Перевод: Максим Кузьмин
Проверка/Оформление/Редактирование: Мякишев Е.А.
Краткое руководство по плате WiPy[1]
Материалы ниже – краткое руководство по CC3200/WiPy. Если вы только начали работать с этой платой, советуем сначала ознакомиться с этими статьями:
Общее управление платой (включая режимы сна)
См. модуль machine.
import machine
help(machine) # показываем все элементы модуля «machine»
machine.freq() # считываем частоту процессора
machine.unique_id() # возвращаем уникальный 6-байтный ID платы
# (MAC-адрес WiPy)
machine.idle() # средняя сила тока снижается примерно до 12 мА,
# любое прерывание пробудит плату
machine.lightsleep() # все, кроме «WLAN», будет выключено
# (средняя сила тока ~950 мкА);
# пробуждается от «Pin», «RTC» или «WLAN»
machine.deepsleep() # режим глубокого сна,
# микроконтроллер будет запускаться от сброса;
# пробуждается от «Pin» и «RTC»
Контакты и GPIO
См. класс machine.Pin.
from machine import Pin
# инициализируем GP2 в режиме GPIO (alt=0)
# и делаем его выходным контактом:
p_out = Pin('GP2', mode=Pin.OUT)
p_out.value(1)
p_out.value(0)
p_out.toggle()
p_out(True)
# делаем GP1 входным контактом с включенным подтягивающим резистором:
p_in = Pin('GP1', mode=Pin.IN, pull=Pin.PULL_UP)
p_in() # считываем значение, «0» или «1»
Таймеры
См. класс machine.TimerWiPy и класс machine.Pin. ID таймера может быть значение от «0» до «3».
from machine import Timer
from machine import Pin
tim = Timer(0, mode=Timer.PERIODIC)
tim_a = tim.channel(Timer.A, freq=1000)
tim_a.freq(5) # 5 Гц
p_out = Pin('GP2', mode=Pin.OUT)
tim_a.irq(trigger=Timer.TIMEOUT, handler=lambda t: p_out.toggle())
ШИМ (широтно-импульсная модуляция)
См. machine.Pin и machine.Timer.
from machine import Timer
# таймер 1 в ШИМ-режиме, и разрядность должна быть 16 бит:
tim = Timer(1, mode=Timer.PWM, width=16)
# включаем канал А на 1 КГц с коэффициентом заполнения 50.55%:
tim_a = tim.channel(Timer.A, freq=1000, duty_cycle=5055)
АЦП (аналогово-цифровое преобразование)
См. machine.ADCWiPy.
from machine import ADC
adc = ADC()
apin = adc.channel(pin='GP3')
apin() # считываем значение (0-4095)
UART (последовательная шина)
См. machine.UART.
from machine import UART
uart = UART(0, baudrate=9600)
uart.write('привет')
uart.read(5) # считываем до 5 байтов
Шина SPI
См. machine.SPI.
from machine import SPI
# настраиваем ведущее SPI-устройство на 2 МГц:
spi = SPI(0, SPI.MASTER, baudrate=200000, polarity=0, phase=0)
spi.write('привет')
spi.read(5) # получаем 5 байтов на шину
rbuf = bytearray(5)
spi.write_readinto('привет', rbuf) # отправляем и получаем 5 байтов
Шина I2C
См. machine.I2C.
from machine import I2C
# configure the I2C bus
i2c = I2C(baudrate=100000)
i2c.scan() # возвращаем список адресов
# ведомых устройств
i2c.writeto(0x42, 'привет') # отправляем 5 байтов
# ведомому устройству
# с адресом «0x42»
i2c.readfrom(0x42, 5) # получаем 5 байтов
# от ведомого устройства
i2c.readfrom_mem(0x42, 0x10, 2) # считываем два байта
# с ведомого устройства
# с адресом «0x42»,
# с адреса в памяти «0x10»
i2c.writeto_mem(0x42, 0x10, 'xy') # записываем 2 байта
# на ведомое устройство
# с адресом «0x42»
# в адрес в памяти «0x10»
Сторожевой таймер (WDT)
См. machine.WDT.
from machine import WDT
# включаем WDT-таймер с таймаутом 5 секунд (минимум – 1 секунда):
wdt = WDT(timeout=5000)
wdt.feed()
Часы реального времени (RTC)
См. machine.RTC.
from machine import RTC
# инициализируем с датой и временем по умолчанию:
rtc = RTC()
# инициализируем со своими датой и временем:
rtc = RTC(datetime=(2015, 8, 29, 9, 0, 0, 0, None))
print(rtc.now())
def alarm_handler (rtc_o):
pass
# выполняем неблокирующие операции;
# печать предупреждающих сообщений
# во время прерывания через Telnet невозможна,
# только через UART
# создаем RTC-будильник, который сработает через 5 секунд:
rtc.alarm(time=5000, repeat=False)
# включаем RTC-прерывания:
rtc_i = rtc.irq(trigger=RTC.ALARM0, handler=alarm_handler, wake=machine.SLEEP)
# переходим в экономичный режим
# в ожидании срабатывания будильника и пробуждения
machine.lightsleep()
SD-карта
См. machine.SD.
from machine import SD
import os
# задаем контакты для тактовой частоты, CMD и передачи данных:
sd = SD(pins=('GP10', 'GP11', 'GP15'))
# или используем настройки для платы расширения по умолчанию:
sd = SD()
os.mount(sd, '/sd')
WLAN (WiFi)
См. network.WLAN и machine.
import machine
from network import WLAN
# настраиваем WLAN-подсистему в режим станции
# (по умолчанию она работает в режиме точки доступа):
wlan = WLAN(mode=WLAN.STA)
# задаем фиксированные IP-настройки:
wlan.ifconfig(config=('192.168.0.107', '255.255.255.0', '192.168.0.1', '8.8.8.8'))
wlan.scan() # сканируем доступные сети
wlan.connect(ssid='mynetwork', auth=(WLAN.WPA2, 'mynetworkkey'))
while not wlan.isconnected():
pass
print(wlan.ifconfig())
# настраиваем пробуждение WLAN:
wlan.irq(trigger=WLAN.ANY_EVENT, wake=machine.SLEEP)
# переводим плату в режим сна:
machine.lightsleep()
# теперь подключаемся к FTP- или Telnet-серверу, и это разбудит WiPy
Telnet- и FTP-сервер
См. network.Server.
from network import Server
# инициализируем сервер с новым пользователем,
# паролем и таймаутом (в секундах):
server = Server(login=('user', 'password'), timeout=60)
server.timeout(300) # меняем таймаут
server.timeout() # считываем таймаут
server.isrunning() # проверяем, запущен ли сервер или нет
Светодиод сердцебиения
См. модуль wipy.
import wipy
wipy.heartbeat(False) # отключаем светодиод сердцебиения
wipy.heartbeat(True) # включаем светодиод сердцебиения
wipy.heartbeat() # считываем состояние светодиода сердцебиения