|
pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分:
$ y, k0 w+ m! h7 G4 a, T; k$ x通用板控制见 pyb. - import pyb
( u t, ^1 ]. u
4 M k2 I: [0 ]. B) F' Z! R, G' {- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
0 g$ o# }; A, ?, J9 r' D& X - pyb.wfi() # pause CPU, waiting for interrupt0 j- z; r* z: i) b
- pyb.freq() # get CPU and bus frequencies
! } i6 @% C7 b' [8 X9 X - pyb.freq(60000000) # set CPU freq to 60MHz! I; S) S9 Z9 ^$ _" Y* x" J9 @
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码 % k9 P9 F. V; v* O; N$ W, m
: a3 z7 C4 C6 y+ _
延迟和计时使用 time模块: - import time: P" D; ]& O) S
2 P1 L4 ?! W, D+ f- time.sleep(1) # sleep for 1 second% V* x) T7 T! p
- time.sleep_ms(500) # sleep for 500 milliseconds
- h, W9 e9 V* `, G - time.sleep_us(10) # sleep for 10 microseconds
) h4 j m: A' @ n - start = time.ticks_ms() # get value of millisecond counter
5 Y6 N- n) g* ?( |2 M9 W/ x - delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 / o T7 D5 n9 w/ H' @
- w q2 e) Q7 r" s内部 LED见 pyb.LED. - from pyb import LED
7 |4 D. F# W7 ?7 E9 U$ I8 f
- k( j9 Y1 ~& K4 h5 p8 g+ @- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
" B; G# y* S' L: Y4 E - led.toggle(). X. @7 E. e8 v
- led.on()3 V( t7 E w* Z, L3 ^9 H& U$ A
- led.off()
* o6 ]& `: ]" f- C/ j8 g* R - * }0 f& _9 ?; z9 K2 \) y- M% ^' B+ \
- # LEDs 3 and 4 support PWM intensity (0-255)3 v/ p8 h% [2 y
- LED(4).intensity() # get intensity& A: s( Y6 q6 H/ ?% U0 n2 O
- LED(4).intensity(128) # set intensity to half
复制代码
: }5 `# z9 P1 {5 W6 S0 [5 l& d, `- B& Y) P3 x& Z3 G% k9 u3 _2 N
内部开关请参阅 pyb.Switch. - from pyb import Switch
0 ^2 b& P6 R1 w$ n/ w" S
0 e1 e( V t/ O" O* i- sw = Switch()
0 w* n0 ^( r$ [ \ - sw.value() # returns True or False: ~, f8 @* P. t* |. ]
- sw.callback(lambda: pyb.LED(1).toggle())
复制代码 # F2 O! Y) h2 d+ ?# T- Y' y7 K
7 P; e1 i, j5 N: q, l0 s# V, x引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin: S! i- _9 v, h! _, H2 q
- " g9 r6 ]: u/ U- _ q" m( {, [
- p_out = Pin('X1', Pin.OUT_PP)" i- O Y o# ]0 r1 I3 e) D
- p_out.high()
, B# s L+ N; D, ^ - p_out.low()
1 }& B- k& u7 V$ i; p5 V( R7 ^1 F
' D! X7 h, J* V. b- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)
0 N% \" h2 y; w - p_in.value() # get value, 0 or 1
复制代码 ( r4 s4 G3 c: c/ ]) \* Z# ^
# T' l8 |0 b1 R0 A# D( Y$ S. k
伺服控制请参阅pyb.Servo. - from pyb import Servo
/ j/ J; G3 k X7 `4 S$ { - " z# }; n5 W9 t2 A- @+ P
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
& L4 [3 [. ]5 Y: X. K - s1.angle(45) # move to 45 degrees
( p7 j4 f8 }# g Q - s1.angle(-60, 1500) # move to -60 degrees in 1500ms; _0 `: ?' e# \! {
- s1.speed(50) # for continuous rotation servos
复制代码
7 Z$ M4 O1 z/ T
0 [3 e. t9 J3 _% e- ?+ K- j/ T& S外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
: Z6 F# J6 }+ T - ~ z1 z2 J, C6 b) _. c
- callback = lambda e: print("intr")
$ N1 U. i$ w8 E7 e# Y) S - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码 ) M) e# ]0 G3 N
7 b( y8 W0 t0 ?计时器请参阅pyb.Timer. - from pyb import Timer
$ B1 s9 D+ u# z
- G% J+ x& l9 _4 B1 t- tim = Timer(1, freq=1000)' u( _0 H: g: K/ H
- tim.counter() # get counter value
3 d) p0 \$ p' t% i- v" ~$ Y - tim.freq(0.5) # 0.5 Hz
* _1 { u6 | X+ N' f5 ] - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
2 w W% w; u! n2 [( t0 T; Y3 B6 ~RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC' X1 s0 K9 ^6 y3 h. G s, T4 ^
% U* ]7 R& S) K" R4 L$ c/ F- rtc = RTC()" M, ~4 a7 p9 G( A; c/ Q
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time1 m% {/ Y% P% i# i
- rtc.datetime() # get date and time
复制代码 3 e# i1 A' z3 C: X! v; R
PWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer! E: }7 w; g6 L( ?- q
2 N, |6 }8 F# \2 b. x, O1 n- p = Pin('X1') # X1 has TIM2, CH1$ n3 w; b& H s0 H
- tim = Timer(2, freq=1000)% a3 e" W' E- J3 F# S- g
- ch = tim.channel(1, Timer.PWM, pin=p)* ]& a+ Y7 @' [; N
- ch.pulse_width_percent(50)
复制代码
! x: _& C0 p2 [6 z" MADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
0 B9 P+ \- f* d% [* N7 l
% n6 Y2 X' n$ R- adc = ADC(Pin('X19'))) a6 D- B3 P, }6 p9 a7 X) q
- adc.read() # read value, 0-4095
复制代码 ( X2 f6 U K$ H5 X- f
8 m9 ^7 h" |. h* W/ E6 c6 C5 m
DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
8 {5 J5 w. y. @+ M3 g. k
" a. u7 Y! S' q6 E$ ^- dac = DAC(Pin('X5'))
+ D! ]. N4 I: p1 T& ` - dac.write(120) # output between 0 and 255
复制代码
. K; a% ?1 ?* P/ |5 R, _
/ y8 y' e* v9 _UART(串行总线)请参阅 pyb.UART. - from pyb import UART3 p) z2 B" p* c: r4 H
- 3 S8 F! I( h1 q3 Z
- uart = UART(1, 9600)
8 t5 t8 _ ?0 Z - uart.write('hello')
6 c( z. c) {* L$ A( n# ?" {; W - uart.read(5) # read up to 5 bytes
复制代码
" e( `* A( r: E- _2 M) f3 ], m: Q4 O k
SPI总线请参阅 pyb.SPI. - from pyb import SPI: X; U" b v3 w3 U' {7 J. B
- % x, L: U) k0 ?2 S' n) u
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
- r @2 Q+ n8 f T3 D) p/ o$ w4 F - spi.send('hello')
- o4 P7 M8 i% B - spi.recv(5) # receive 5 bytes on the bus2 \5 c5 F& c, S% Z2 Y7 h: A/ |2 ~& M
- spi.send_recv('hello') # send and receive 5 bytes
复制代码 , S0 M+ k5 ]; X7 Y9 u: o
8 ]- D7 ? W, ~
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
, g! ^/ @( \9 ^$ B5 O! d8 E
7 n) u4 Y) [; T a- i2c = I2C('X', freq=400000) # create hardware I2c object5 e- v! V7 `- q
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object5 p- S8 f* f+ O( c( v8 R, H
; i) j5 }8 l; z- i2c.scan() # returns list of slave addresses
+ Q. f. E/ e' ?! | - i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x421 ?: E: d% J) K' R6 O7 f) n
- i2c.readfrom(0x42, 5) # read 5 bytes from slave7 t' `: \" B3 D' d% U
- " F5 y; O: j; U- r
- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
' ?4 C4 A# j p# b4 B: P - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
; R) n/ H4 j: t) M, U7 F
`7 v% L: ]9 ~注意:对于传统 I2C 支持,请参阅 pyb.I2C。 ! W& y# c, U6 w$ {
I2S总线参见 machine.I2S. - from machine import I2S, Pin
% y( P9 W0 C8 J# Z8 x. p
U& t7 `, r; @* i) S- 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 object5 q/ |' n% T g" e( W$ L0 j/ l$ v
- i2s.write(buf) # write buffer of audio samples to I2S device
' K# x' `# Y" q8 e4 k6 I! t0 H
0 ~6 j2 \' |8 n _- 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
. y" e: K6 q2 w4 A- ^ - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
+ ?6 i* X. Q5 L1 q P+ \2 wI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
6 x6 W9 ]0 ]7 c3 [4 ]" P d) {CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN
4 c, g# U9 M3 _- Y: H. l# ^& Z - ! P# s- ?& [+ K/ Q/ E* f: X
- can = CAN(1, CAN.LOOPBACK): l% F8 Y# B9 r# t( X# h! {. K
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))9 S2 T: Y( R7 e9 E% Q# T0 a
- can.send('message!', 123) # send a message with id 123$ c3 h6 t& F; o. Y3 K
- can.recv(0) # receive message on FIFO 0
复制代码
1 ?; a! O5 s& n+ Z2 x4 [1 R+ J9 |8 s6 r# G
内部加速度计参见pyb.Accel. - from pyb import Accel
8 X4 l5 m# P1 R/ ?/ R1 x6 T8 b
! Q7 ] b! O" n/ {- accel = Accel(). ^0 g" O& M4 y
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 8 P( E/ z8 g/ [/ Y" h& {$ s
4 ]; Q% I. E$ A) E% a( T
|