| 
 
| 本帖最后由 PY学习笔记 于 2025-1-19 21:02 编辑 
 上一次看到论坛有人发了一个远程扩音器,但是不是都是K10的,于是我基于K10官方固件实现了。
 1.行空板介绍
 行空板K10集成ESP32-S3、摄像头、2.8寸彩色LCD、麦克风、扬声器、WiFi蓝牙模块、RGB指示灯及多种传感器和扩展接口于一体;支持图像检测、语音识别、语音合成、mind+图形化编程,MicroPython编程,是一款专为信息科技课程教学需求而研发的开发板
 2.I2S介绍
 
 I2S(Inter-IC Sound)是一种广泛应用于数字音频传输的串行接口标准,最初由飞利浦公司开发。它用于在集成电路之间传输音频数据,定义了音频数据的传输格式、时序和控制信号。 I2S基本信号 I2S接口通常由三类信号线组成: 
 时钟线(SCK):提供同步音频数据传输的时钟信号,确定数据传输的速度和时序。SCK的频率=2x采样频率x位宽。左/右声道线(LRCK):指示当前传输的是左声道还是右声道的数据。LRCK的频率=采样频率。数据线(SD):用于传输实际的音频数据,位宽通常为16位或32位。TX方向为Serial Data Out(SDOUT),RX方向为Serial Data In(SDIN)。 
 主从工作模式 I2S工作模式可以是主模式(Master Mode)或从模式(Slave Mode)。在主模式下,设备提供时钟信号(SCK)和帧同步信号(LRCK);在从模式下,设备接收这些信号。 数据传输模式 I2S接口标准中存在三种数据传输模式: 飞利浦标准模式(I2S mode):LRCK为低时表示左声道数据,为高时表示右声道数据。数据在SCK下降沿发送,在SCK上升沿采样。左对齐(Left Justified)模式:LRCK为高时表示左声道数据,为低时表示右声道数据。数据在SCK下降沿发送,在SCK上升沿接收。右对齐(Right Justified)模式:LRCK为高时表示右声道数据,为低时表示左声道数据。数据在SCK下降沿发送,在SCK上升沿接收。 
 数据位宽与位深 I2S中位宽和位深由主设备决定。位宽通常为16位或32位,位深表示音频数据量化后的精度。 I2S初始化配置 I2S的初始化配置包括时钟使能和GPIO口配置、配置为I2S模式、设置I2S时钟和采样率等。 
 3.测试代码 通过反复“解剖”官方的库,发现麦克风和喇叭的I2S可以使用deinit方法进行定义I2S总线(官方代码还是改一下deinit的意思是反初始化,建议使用init),就可以直接使用定义好的I2S进行使用。 发送方: 复制代码from unihiker_k10 import mic,wifi
import network
import socket
import time
# Network Configuration
SSID = 'ssid'
PASSWORD = 'password'
SERVER_IP = 'ip'
SERVER_PORT = 12345
def main():
    wifi.connect(ssid=SSID,psd=PASSWORD,timeout=50000)
    mic.reinit()
    audio = mic.i2s
    sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
    audio_buf = bytearray(1024)
    
    print('Starting audio capture and transmission...')
    
    try:
        while True:
         # Read audio data
             num_read = audio.readinto(audio_buf)
             if num_read > 0:
             # Send data in smaller chunks to prevent packet loss
                 chunk_size = 1024
                 for i in range(0, num_read, chunk_size):
                     chunk = audio_buf[i:min(i + chunk_size, num_read)]
                     sock.sendto(chunk, (SERVER_IP, SERVER_PORT))
                 time.sleep_ms(1)
                
    except Exception as e:
        print('Error:', e)
    finally:
        audio.deinit()
        sock.close()
if __name__ == '__main__':
    main()
 接收方: 复制代码from unihiker_k10 import speaker,wifi
import network
import socket
import time
# Network Configuration
SSID = 'ssid'
PASSWORD = 'password'
SERVER_IP = 'ip'
SERVER_PORT = 12345
def main():
    wifi.connect(ssid=SSID,psd=PASSWORD,timeout=50000)
    speaker.reinit()
    audio = speaker.i2s
    sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
    
    print('Starting audio capture and transmission...')
    
    try:
 运行修改WiFi和IP见K10远程扩音器(对讲机) DF创客社区,效果相同。 
 
 
 | 
 | 
|  | 
|
|  | 
|  |  |