app-starlock/lib/talk/startChart/handle/impl/udp_talk_data_handler.dart

111 lines
3.3 KiB
Dart
Raw Normal View History

import 'dart:convert';
2024-12-09 15:57:41 +08:00
import 'dart:typed_data';
import 'package:flutter_easyloading/flutter_easyloading.dart';
import 'package:get/get.dart';
import 'package:star_lock/talk/call/g711.dart';
import 'package:star_lock/talk/startChart/constant/message_type_constant.dart';
import 'package:star_lock/talk/startChart/entity/scp_message.dart';
import 'package:star_lock/talk/startChart/handle/scp_message_base_handle.dart';
import 'package:star_lock/talk/startChart/handle/scp_message_handle.dart';
import 'package:star_lock/talk/startChart/proto/gateway_reset.pb.dart';
import 'package:star_lock/talk/startChart/proto/generic.pb.dart';
2024-12-09 15:57:41 +08:00
import 'package:star_lock/talk/startChart/proto/talk_data.pb.dart';
import 'package:star_lock/talk/startChart/proto/talk_data.pbserver.dart';
class UdpTalkDataHandler extends ScpMessageBaseHandle
implements ScpMessageHandler {
@override
2024-12-09 13:44:57 +08:00
void handleReq(ScpMessage scpMessage) {}
@override
2024-12-09 13:44:57 +08:00
void handleResp(ScpMessage scpMessage) {}
@override
2024-12-09 13:44:57 +08:00
void handleInvalidReq(ScpMessage scpMessage) {}
@override
void handleRealTimeData(ScpMessage scpMessage) {
// 收到数据后调用更新,防止定时器超时
talkDataOverTimeTimerManager.receiveMessage();
2024-12-09 15:57:41 +08:00
if (scpMessage.Payload != null) {
final TalkData talkData = scpMessage.Payload;
// 处理音视频数据
2024-12-13 14:30:33 +08:00
_handleTalkData(talkData: talkData);
2024-12-09 15:57:41 +08:00
}
}
void _handleTalkData({required TalkData talkData}) {
if (talkData == null) return;
final contentType = talkData.contentType;
switch (contentType) {
case TalkData_ContentTypeE.H264:
_handleVideoH264(talkData);
break;
case TalkData_ContentTypeE.Image:
_handleVideoImage(talkData);
break;
case TalkData_ContentTypeE.G711:
_handleVideoG711(talkData);
break;
default:
print('❌未知的TalkData--->contentType类型');
break;
}
}
/// 处理h264协议的数据
2024-12-09 15:57:41 +08:00
void _handleVideoH264(TalkData talkData) {
// talkDataRepository.addTalkData(talkData);
2024-12-09 15:57:41 +08:00
}
/// 处理图片数据
2024-12-09 15:57:41 +08:00
void _handleVideoImage(TalkData talkData) {}
/// 处理g711音频数据
void _handleVideoG711(TalkData talkData) {
try {
final g711Data = talkData.content;
// 转pcm数据
List<int> pcmBytes = G711().convertList(g711Data);
talkData.content = pcmBytes;
talkDataRepository.addTalkData(talkData);
} catch (e) {
print('Error decoding G.711 to PCM: $e');
}
}
@override
deserializePayload(
{required int payloadType,
required int messageType,
required Uint8List byte,
int? offset,
int? PayloadLength,
int? spTotal,
int? spIndex,
int? messageId}) {
2024-12-24 15:38:36 +08:00
if (messageType == MessageTypeConstant.RealTimeData) {
// 回声测试
if (spTotal != null &&
spTotal > 1 &&
messageId != null &&
spIndex != null) {
// 分包处理
return handleFragmentedPayload(
messageId: messageId,
spTotal: spTotal,
spIndex: spIndex,
byte: byte,
payloadType: payloadType,
);
} else {
// 没有分包直接解析
final TalkData talkData = TalkData();
talkData.mergeFromBuffer(byte);
return talkData;
}
}
}
}