初始化提交
This commit is contained in:
134
arduino-cli/libraries/RF24/examples_linux/pingpair_dyn.py
Normal file
134
arduino-cli/libraries/RF24/examples_linux/pingpair_dyn.py
Normal file
@@ -0,0 +1,134 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
#
|
||||
# Example using Dynamic Payloads
|
||||
#
|
||||
# This is an example of how to use payloads of a varying (dynamic) size.
|
||||
#
|
||||
|
||||
from __future__ import print_function
|
||||
import time
|
||||
from RF24 import *
|
||||
import RPi.GPIO as GPIO
|
||||
|
||||
irq_gpio_pin = None
|
||||
|
||||
########### USER CONFIGURATION ###########
|
||||
# See https://github.com/TMRh20/RF24/blob/master/pyRF24/readme.md
|
||||
# Radio CE Pin, CSN Pin, SPI Speed
|
||||
# CE Pin uses GPIO number with BCM and SPIDEV drivers, other platforms use their own pin numbering
|
||||
# CS Pin addresses the SPI bus number at /dev/spidev<a>.<b>
|
||||
# ie: RF24 radio(<ce_pin>, <a>*10+<b>); spidev1.0 is 10, spidev1.1 is 11 etc..
|
||||
|
||||
# Generic:
|
||||
radio = RF24(22,0);
|
||||
|
||||
# RPi Alternate, with SPIDEV - Note: Edit RF24/arch/BBB/spi.cpp and set 'this->device = "/dev/spidev0.0";;' or as listed in /dev
|
||||
#radio = RF24(22, 0);
|
||||
|
||||
|
||||
# Setup for connected IRQ pin, GPIO 24 on RPi B+; uncomment to activate
|
||||
# irq_gpio_pin = 24
|
||||
|
||||
##########################################
|
||||
def try_read_data(channel=0):
|
||||
if radio.available():
|
||||
while radio.available():
|
||||
len = radio.getDynamicPayloadSize()
|
||||
receive_payload = radio.read(len)
|
||||
print('Got payload size={} value="{}"'.format(len, receive_payload.decode('utf-8')))
|
||||
# First, stop listening so we can talk
|
||||
radio.stopListening()
|
||||
|
||||
# Send the final one back.
|
||||
radio.write(receive_payload)
|
||||
print('Sent response.')
|
||||
|
||||
# Now, resume listening so we catch the next packets.
|
||||
radio.startListening()
|
||||
|
||||
|
||||
pipes = [0xF0F0F0F0E1, 0xF0F0F0F0D2]
|
||||
min_payload_size = 4
|
||||
max_payload_size = 32
|
||||
payload_size_increments_by = 1
|
||||
next_payload_size = min_payload_size
|
||||
inp_role = 'none'
|
||||
send_payload = b'ABCDEFGHIJKLMNOPQRSTUVWXYZ789012'
|
||||
millis = lambda: int(round(time.time() * 1000))
|
||||
|
||||
print('pyRF24/examples/pingpair_dyn/')
|
||||
radio.begin()
|
||||
radio.enableDynamicPayloads()
|
||||
radio.setRetries(5, 15)
|
||||
radio.printDetails()
|
||||
|
||||
print(' ************ Role Setup *********** ')
|
||||
while (inp_role != '0') and (inp_role != '1'):
|
||||
inp_role = str(input('Choose a role: Enter 0 for receiver, 1 for transmitter (CTRL+C to exit) '))
|
||||
|
||||
if inp_role == '0':
|
||||
print('Role: Pong Back, awaiting transmission')
|
||||
if irq_gpio_pin is not None:
|
||||
# set up callback for irq pin
|
||||
GPIO.setmode(GPIO.BCM)
|
||||
GPIO.setup(irq_gpio_pin, GPIO.IN, pull_up_down=GPIO.PUD_UP)
|
||||
GPIO.add_event_detect(irq_gpio_pin, GPIO.FALLING, callback=try_read_data)
|
||||
|
||||
radio.openWritingPipe(pipes[1])
|
||||
radio.openReadingPipe(1, pipes[0])
|
||||
radio.startListening()
|
||||
else:
|
||||
print('Role: Ping Out, starting transmission')
|
||||
radio.openWritingPipe(pipes[0])
|
||||
radio.openReadingPipe(1, pipes[1])
|
||||
|
||||
# forever loop
|
||||
while 1:
|
||||
if inp_role == '1': # ping out
|
||||
# The payload will always be the same, what will change is how much of it we send.
|
||||
|
||||
# First, stop listening so we can talk.
|
||||
radio.stopListening()
|
||||
|
||||
# Take the time, and send it. This will block until complete
|
||||
print('Now sending length {} ... '.format(next_payload_size), end="")
|
||||
radio.write(send_payload[:next_payload_size])
|
||||
|
||||
# Now, continue listening
|
||||
radio.startListening()
|
||||
|
||||
# Wait here until we get a response, or timeout
|
||||
started_waiting_at = millis()
|
||||
timeout = False
|
||||
while (not radio.available()) and (not timeout):
|
||||
if (millis() - started_waiting_at) > 500:
|
||||
timeout = True
|
||||
|
||||
# Describe the results
|
||||
if timeout:
|
||||
print('failed, response timed out.')
|
||||
else:
|
||||
# Grab the response, compare, and send to debugging spew
|
||||
len = radio.getDynamicPayloadSize()
|
||||
receive_payload = radio.read(len)
|
||||
|
||||
# Spew it
|
||||
print('got response size={} value="{}"'.format(len, receive_payload.decode('utf-8')))
|
||||
|
||||
# Update size for next time.
|
||||
next_payload_size += payload_size_increments_by
|
||||
if next_payload_size > max_payload_size:
|
||||
next_payload_size = min_payload_size
|
||||
time.sleep(0.1)
|
||||
else:
|
||||
# Pong back role. Receive each packet, dump it out, and send it back
|
||||
|
||||
# if there is data ready
|
||||
if irq_gpio_pin is None:
|
||||
# no irq pin is set up -> poll it
|
||||
try_read_data()
|
||||
else:
|
||||
# callback routine set for irq pin takes care for reading -
|
||||
# do nothing, just sleeps in order not to burn cpu by looping
|
||||
time.sleep(1000)
|
||||
Reference in New Issue
Block a user