2024-12-04 15:00:56 +08:00
|
|
|
|
import 'package:flutter_easyloading/flutter_easyloading.dart';
|
|
|
|
|
|
import 'package:get/get.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';
|
|
|
|
|
|
|
|
|
|
|
|
import '../../start_chart_manage.dart';
|
|
|
|
|
|
|
|
|
|
|
|
class UdpTalkAcceptHandler extends ScpMessageBaseHandle
|
|
|
|
|
|
implements ScpMessageHandler {
|
2024-12-09 09:22:58 +08:00
|
|
|
|
@override
|
|
|
|
|
|
void handleReq(ScpMessage scpMessage) {
|
2024-12-09 11:06:35 +08:00
|
|
|
|
print('收到同意接听请求');
|
|
|
|
|
|
// 回复同意接听消息
|
|
|
|
|
|
startChartManage.sendGenericRespSuccessMessage(
|
|
|
|
|
|
ToPeerId: scpMessage.FromPeerId!,
|
|
|
|
|
|
FromPeerId: scpMessage.ToPeerId!,
|
|
|
|
|
|
PayloadType: scpMessage.PayloadType!,
|
|
|
|
|
|
);
|
2024-12-09 09:22:58 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2024-12-04 15:00:56 +08:00
|
|
|
|
@override
|
2024-12-09 09:22:58 +08:00
|
|
|
|
void handleResp(ScpMessage scpMessage) {
|
2024-12-09 11:06:35 +08:00
|
|
|
|
// 收到同意接听回复
|
2024-12-04 15:00:56 +08:00
|
|
|
|
final GenericResp genericResp = scpMessage.Payload;
|
|
|
|
|
|
if (checkGenericRespSuccess(genericResp)) {
|
2024-12-09 11:06:35 +08:00
|
|
|
|
// 启动通话保持定时器
|
|
|
|
|
|
_handleStartTalkPing();
|
|
|
|
|
|
// 启动通话数据检查的定时器
|
|
|
|
|
|
_handleCheckTalkDataTimer();
|
|
|
|
|
|
// 启动发送预期数据请求
|
|
|
|
|
|
_handleStartSendTalkExpectDataRequest();
|
2024-12-09 12:05:34 +08:00
|
|
|
|
// 设置状态为接听中
|
|
|
|
|
|
talkStatus.setDuringCall();
|
2024-12-04 15:00:56 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2024-12-09 09:22:58 +08:00
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
|
void handleInvalidReq(ScpMessage scpMessage) {
|
|
|
|
|
|
// TODO: implement handleInvalidReq
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
2024-12-09 11:06:35 +08:00
|
|
|
|
void handleRealTimeData(ScpMessage scpMessage) {
|
2024-12-09 09:22:58 +08:00
|
|
|
|
// TODO: implement handleRealTimeData
|
|
|
|
|
|
}
|
2024-12-09 11:06:35 +08:00
|
|
|
|
|
|
|
|
|
|
// 启动通话保持
|
|
|
|
|
|
void _handleStartTalkPing() {
|
|
|
|
|
|
// 启动通话保持
|
|
|
|
|
|
startChartManage.startTalkPingMessageTimer();
|
|
|
|
|
|
// 启动通话保持监听定时器(用来判断如果x秒内没有收到通话保持则执行的操作)
|
|
|
|
|
|
talkePingOverTimeTimerManager.startTimer();
|
|
|
|
|
|
// 设置通话保持超时后的事件
|
|
|
|
|
|
talkePingOverTimeTimerManager.setOnTimeout(() {
|
|
|
|
|
|
EasyLoading.showToast('通话异常中断', duration: 2000.milliseconds);
|
|
|
|
|
|
// 停止发送通话保持的命令
|
|
|
|
|
|
startChartManage.stopTalkPingMessageTimer();
|
|
|
|
|
|
startChartManage.stopTalkExpectMessageTimer();
|
2024-12-09 12:05:34 +08:00
|
|
|
|
talkStatus.setNotTalkPing();
|
2024-12-09 11:06:35 +08:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// 启动通话数据的检查,判断x秒内是否收到通话数据
|
|
|
|
|
|
void _handleCheckTalkDataTimer() {
|
|
|
|
|
|
// 启动对讲数据监听定时器
|
|
|
|
|
|
talkDataOverTimeTimerManager.startTimer();
|
|
|
|
|
|
// 设置对讲数据超时后的事件
|
|
|
|
|
|
talkDataOverTimeTimerManager.setOnTimeout(() {
|
|
|
|
|
|
EasyLoading.showToast('通话连接失败', duration: 2000.milliseconds);
|
|
|
|
|
|
startChartManage.stopTalkPingMessageTimer();
|
|
|
|
|
|
startChartManage.stopTalkExpectMessageTimer();
|
2024-12-09 12:05:34 +08:00
|
|
|
|
talkStatus.setNotTalkData();
|
2024-12-09 11:06:35 +08:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// 启动发送预期数据请求
|
|
|
|
|
|
void _handleStartSendTalkExpectDataRequest() {
|
|
|
|
|
|
// 启动发送预期数据定时器
|
|
|
|
|
|
startChartManage.startTalkExpectTimer();
|
|
|
|
|
|
}
|
2024-12-04 15:00:56 +08:00
|
|
|
|
}
|