pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: 7 X. x4 W4 N; m( v c" J# p" E
通用板控制见 pyb. - import pyb6 c) r$ @8 \5 Y) C# r [: X4 ~
- ' } z, F) w" p. O1 b9 A& Q0 D2 e
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
& o6 g# O& ~# l - pyb.wfi() # pause CPU, waiting for interrupt) m# \8 h8 J1 Z
- pyb.freq() # get CPU and bus frequencies/ w) O: G" \. e# b3 [
- pyb.freq(60000000) # set CPU freq to 60MHz0 I% m! h3 I( [7 t/ B* G
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码
7 G0 Z6 u, |5 v% C
* E+ j+ J3 r6 m- {' O H* {/ d延迟和计时使用 time模块: - import time
8 H' y+ ?: j- s0 T/ D
+ `/ w" P' N. F& K( j4 O k. f. N3 o$ E& ]- time.sleep(1) # sleep for 1 second# w7 n; C2 A- i! Y8 h/ I
- time.sleep_ms(500) # sleep for 500 milliseconds- A! W2 ^* N2 S0 e! d7 Q7 u4 Q
- time.sleep_us(10) # sleep for 10 microseconds
4 w2 g0 ~* ^3 h( e - start = time.ticks_ms() # get value of millisecond counter7 S+ Z, q6 Z& s1 c
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 * j" {% Y4 s( R8 M
$ @' j6 `8 c& N" | Z内部 LED见 pyb.LED. - from pyb import LED
- w" Y: w* r4 v# W - , m! g* C, i5 Y4 `' U# w1 X
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue+ X6 P9 ]& j3 b+ W }
- led.toggle()
) K9 G1 P0 O0 p$ L7 Y - led.on()/ ]) R* ?1 M& E) w1 I1 w
- led.off()' B M8 i) s+ N6 N1 J' x' L
- / Q; a* l; l& a
- # LEDs 3 and 4 support PWM intensity (0-255)" T& l* T% R: q0 U: g# N: f. i
- LED(4).intensity() # get intensity- u3 h: u6 X& ?6 c
- LED(4).intensity(128) # set intensity to half
复制代码 u0 _1 S6 L% p! i) j
; Z+ e$ q, u5 Z. {) U
内部开关请参阅 pyb.Switch. - from pyb import Switch% f4 v; d2 G# o2 A( P/ i. D
3 _, U& |, b* s: y* h4 ~8 p' ]- sw = Switch()
0 ]" L# t5 H% ~8 }, f - sw.value() # returns True or False
N4 g/ m1 n2 ~6 X$ `' O - sw.callback(lambda: pyb.LED(1).toggle())
复制代码
; N) P4 V3 i8 ^
8 z! T; C6 m4 u z3 `引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin$ P. s. L; H0 I) G2 Y" U
- ( O6 ~% E+ I6 P. }' x+ b* V5 X6 u& o
- p_out = Pin('X1', Pin.OUT_PP), X5 j! t2 j# l+ y
- p_out.high()
/ C- ]3 t2 ~. S( N2 a - p_out.low()1 M0 D- z* e- `, Y% d+ a
! P( ?& i: G! o- B2 d K! z; F- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)# `0 f( w; \$ W' I, k
- p_in.value() # get value, 0 or 1
复制代码
3 b3 z6 C1 o6 M" x& ~7 d2 Z8 h
/ j1 ~- y) v) [7 m* _. x( {% ?伺服控制请参阅pyb.Servo. - from pyb import Servo: @1 Q* U" j6 k% [& `1 u
z, e9 Z; H. M. D: y" d( C- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)1 G, C4 I5 b2 M# K# f2 Q4 P
- s1.angle(45) # move to 45 degrees2 v' r; [; }$ m/ t
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms: n/ B& I0 Z9 h/ Z
- s1.speed(50) # for continuous rotation servos
复制代码 % N# V* ?* d! V6 |/ n3 v0 M* ]
; Q3 D+ R. q. }9 N2 k! m" }( g6 s* X外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt" ?1 E2 s# \" ?" a% s m9 K6 W1 f
# q* h" }$ Y* F- y- X- callback = lambda e: print("intr")
5 [( V7 t1 f- N8 A5 P+ ^ - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码 0 [7 H R$ s3 L6 {0 P4 j
k2 I0 K7 q& b* L& D
计时器请参阅pyb.Timer. - from pyb import Timer% f$ f6 F9 [2 V: r G, m1 _" i4 W; e8 D* J
- 0 ]0 k: L* {& h! l$ W$ ]9 ^( j6 l
- tim = Timer(1, freq=1000)6 g! l6 H7 n+ g' f' ]
- tim.counter() # get counter value! x( _: M! `; I4 W0 [5 o, A) v' l. w
- tim.freq(0.5) # 0.5 Hz
. N8 b5 g. @- ^ - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
7 Q w+ n- ?: W! iRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
% S5 H6 `; r+ K! \ - & Y) f; [2 Z6 m1 B
- rtc = RTC()
" ?# S9 f" b' T, V% F' s0 s - rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time/ K g9 d1 P: z+ h( Z
- rtc.datetime() # get date and time
复制代码
, y* A% _& X, P- ZPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer
H. I. n+ [. q0 p - & V/ M) Y3 d: J9 j3 M
- p = Pin('X1') # X1 has TIM2, CH17 K4 z7 k8 [7 G) C% _" j5 v U* V
- tim = Timer(2, freq=1000)
9 x8 d& i, l/ J R. j+ s2 j2 Z - ch = tim.channel(1, Timer.PWM, pin=p)/ R9 A0 Y( D2 v% B( l
- ch.pulse_width_percent(50)
复制代码
% f/ F, C0 J# w0 ^1 R: }& ~ADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
& K. b: W1 s, G+ b
- [3 q7 m* J E! t3 [( M4 ~- adc = ADC(Pin('X19'))
! f" E, x5 Z3 h - adc.read() # read value, 0-4095
复制代码 1 `' R+ N7 P) F9 s
6 f( v( B- Q; f' v) S! @$ y1 U
DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
0 T: m: D. b# ~; b; z6 M - $ Y. t% T; i% T* Z
- dac = DAC(Pin('X5'))$ T9 W& }; k+ {3 z6 z' C' ^
- dac.write(120) # output between 0 and 255
复制代码 , o1 P% b9 T+ U" ~3 J- n
9 N( y' P( P* Z6 h aUART(串行总线)请参阅 pyb.UART. - from pyb import UART
+ i* v. D# V' Z - - \; t1 \) ?, a5 ]/ _
- uart = UART(1, 9600)
$ d" v) Y! `2 J n' F2 I6 p7 X0 U - uart.write('hello')* E# d+ [' `) Y( V" U p& G
- uart.read(5) # read up to 5 bytes
复制代码 2 H; c0 z8 }. _, _2 a- l3 ^( |
# o5 G3 C) e0 Z. T
SPI总线请参阅 pyb.SPI. - from pyb import SPI
4 D0 Y& s8 C! H: p
7 O( f3 \; ~/ L7 r2 F! \" o# }8 X- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)1 n" y; a$ @) i. G2 k. k
- spi.send('hello')
# P7 c! N' D% m, s9 J( g! A8 i - spi.recv(5) # receive 5 bytes on the bus
+ l; I' B U% g5 j6 {% I - spi.send_recv('hello') # send and receive 5 bytes
复制代码 3 D+ z! L4 ]6 c" h% k
- k) f Y! I: @( jI2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
; T3 Y% @0 o& s8 L v - ) u K8 R: b& ~( ~, ^ `7 Z
- i2c = I2C('X', freq=400000) # create hardware I2c object
) d7 G7 G! m! L, f/ S - i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object( ]8 y0 h. P' |* i
* W) N* Z6 e* F% F: V. X2 x- i2c.scan() # returns list of slave addresses
1 o8 Y0 E# j/ ]$ ~/ S - i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42; d6 n2 @3 z# o$ O9 ^4 F
- i2c.readfrom(0x42, 5) # read 5 bytes from slave3 H; w" s5 f8 o+ M
, c" i8 h% n0 r$ F1 N1 {+ Z- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x101 n& f* I B0 b* }' Q0 v% a
- i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
1 w# O9 X/ g: h" E2 D
* u# H# a, E) H5 K注意:对于传统 I2C 支持,请参阅 pyb.I2C。
7 v6 S2 L9 Y9 O' @* m6 p% [I2S总线参见 machine.I2S. - from machine import I2S, Pin
6 @( b! N- M- U4 v3 o" H/ ?
0 e, D" n# F, k% c0 }# m) a- i2s = I2S(2, sck=Pin('Y6'), ws=Pin('Y5'), sd=Pin('Y8'), mode=I2S.TX, bits=16, format=I2S.STEREO, rate=44100, ibuf=40000) # create I2S object2 T6 ^% K* ^0 R; B" w' a$ U; [+ |
- i2s.write(buf) # write buffer of audio samples to I2S device
0 Q3 Z8 g, l* P& m1 j6 P0 w' D
C$ w6 {1 S0 b: `. D- i2s = I2S(1, sck=Pin('X5'), ws=Pin('X6'), sd=Pin('Y4'), mode=I2S.RX, bits=16, format=I2S.MONO, rate=22050, ibuf=40000) # create I2S object
+ p$ @, J( R, n2 h1 h) M - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
; s; M3 h/ o5 C- i% G9 @, M1 pI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
* d/ ^3 f) m0 o6 M- KCAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN" s# J# I! B% C+ ]5 G0 {
% D# R6 ~' U$ ?/ _; J' O- can = CAN(1, CAN.LOOPBACK)6 @, g5 l; g5 v/ L
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
: B) f4 [$ n; B _ - can.send('message!', 123) # send a message with id 123
4 q( n, [) i0 z2 C( G/ J3 q& I - can.recv(0) # receive message on FIFO 0
复制代码
5 u" \+ s5 c6 R. D2 v
9 w5 X* S4 D3 O7 S( i' s! m内部加速度计参见pyb.Accel. - from pyb import Accel7 A- \) C- A2 o) b0 n
" {, U2 s6 }% J; I$ ] K% Y( w2 l5 z- accel = Accel()5 h- C! V, E/ R( G8 k# d
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
+ Z! f# B3 i* K# U$ y* M, O" J1 h+ U; q: }
|