调整以适应esp32
This commit is contained in:
53
app/lora/lora_interface.py
Normal file
53
app/lora/lora_interface.py
Normal file
@@ -0,0 +1,53 @@
|
||||
#!/usr/bin/env python
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
"""
|
||||
LoRa通信模块的抽象接口定义 (契约)
|
||||
|
||||
这个文件定义了一个LoRa处理器应该具备哪些功能,
|
||||
但不包含任何具体的实现代码。任何具体的LoRa处理器,
|
||||
无论是UART的还是SPI的,都必须实现这里定义的所有方法。
|
||||
"""
|
||||
|
||||
# abc (Abstract Base Class) 是Python定义接口的标准方式
|
||||
from abc import ABC, abstractmethod
|
||||
|
||||
class ILoraManager(ABC):
|
||||
"""
|
||||
LoRa处理器接口。
|
||||
它规定了所有LoRa处理器实现类必须提供的功能。
|
||||
"""
|
||||
|
||||
@abstractmethod
|
||||
def receive_packet(self):
|
||||
"""
|
||||
【契约】非阻塞地检查并接收一个数据包。
|
||||
|
||||
一个符合本接口的实现必须:
|
||||
- 检查是否有新的数据包。
|
||||
- 如果有,读取、解析并返回负载数据。
|
||||
- 如果没有,必须立刻返回None,不得阻塞。
|
||||
|
||||
Returns:
|
||||
bytes: 如果成功接收到一个数据包,返回该数据包的字节。
|
||||
None: 如果当前没有可读的数据包。
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def send_packet(self, data_bytes: bytes) -> bool:
|
||||
"""
|
||||
【契约】发送一个数据包。
|
||||
|
||||
一个符合本接口的实现必须:
|
||||
- 接收一个bytes类型的参数。
|
||||
- 将这些数据通过LoRa模块发送出去。
|
||||
- 返回一个布尔值表示发送指令是否成功提交。
|
||||
|
||||
Args:
|
||||
data_bytes (bytes): 需要发送的字节数据。
|
||||
|
||||
Returns:
|
||||
bool: True表示发送指令已成功提交,False表示因任何原因失败。
|
||||
"""
|
||||
pass
|
||||
Reference in New Issue
Block a user