解决收到视频数据后加载刷新白屏问题

This commit is contained in:
Daisy 2023-12-20 16:52:18 +08:00
parent c87d2f96b0
commit 962c7cfded
7 changed files with 132 additions and 100 deletions

View File

@ -1,6 +1,7 @@
import 'dart:async'; import 'dart:async';
import 'package:flutter/services.dart';
import '../../../../tools/baseGetXController.dart'; import '../../../../tools/baseGetXController.dart';
import '../../../../tools/eventBusEventManage.dart'; import '../../../../tools/eventBusEventManage.dart';
import 'lockMonitoring_state.dart'; import 'lockMonitoring_state.dart';
@ -12,8 +13,14 @@ class LockMonitoringLogic extends BaseGetXController {
StreamSubscription? _getTVDataRefreshUIEvent; StreamSubscription? _getTVDataRefreshUIEvent;
void _getTVDataRefreshUIAction() { void _getTVDataRefreshUIAction() {
// eventBus // eventBus
_getTVDataRefreshUIEvent = eventBus.on<GetTVDataRefreshUI>().listen((event) { _getTVDataRefreshUIEvent =
state.listData.value = event.tvList; eventBus.on<GetTVDataRefreshUI>().listen((event) {
if (event.tvList.isNotEmpty) {
//
Uint8List imageData = Uint8List.fromList(event.tvList);
//
state.listData.value = imageData;
}
}); });
} }
@ -30,7 +37,6 @@ class LockMonitoringLogic extends BaseGetXController {
void onInit() { void onInit() {
// TODO: implement onInit // TODO: implement onInit
super.onInit(); super.onInit();
} }
@override @override
@ -39,5 +45,4 @@ class LockMonitoringLogic extends BaseGetXController {
print("锁详情界面销毁了"); print("锁详情界面销毁了");
_getTVDataRefreshUIEvent!.cancel(); _getTVDataRefreshUIEvent!.cancel();
} }
} }

View File

@ -1,3 +1,5 @@
import 'dart:convert';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart'; import 'package:flutter_screenutil/flutter_screenutil.dart';
@ -23,16 +25,13 @@ class _LockMonitoringPageState extends State<LockMonitoringPage> {
return SizedBox( return SizedBox(
width: 1.sw, width: 1.sw,
height: 1.sh, height: 1.sh,
// color: Colors.transparent,
child: Stack( child: Stack(
// alignment: Alignment.bottomCenter,
children: [ children: [
// state.listData.value.isEmpty ? Image.asset("images/icon_test20231113.png", width: 1.sw, height: 1.sh, fit: BoxFit.cover) : Obx(() => state.listData.value.isEmpty
Obx(() => ? Container(color: Colors.transparent)
state.listData.value.isEmpty
? Container(color: Colors.red)
: Image.memory( : Image.memory(
Uint8List.fromList(state.listData.value), state.listData.value,
gaplessPlayback: true,
width: 1.sw, width: 1.sw,
height: 1.sh, height: 1.sh,
fit: BoxFit.cover, fit: BoxFit.cover,

View File

@ -5,7 +5,7 @@ import 'package:get/get.dart';
class LockMonitoringState { class LockMonitoringState {
var isOpenVoice = false.obs; var isOpenVoice = false.obs;
var listData = <int>[].obs; var listData = Uint8List(0).obs;
Uint8List imageData = Uint8List.fromList([ Uint8List imageData = Uint8List.fromList([
255, 255,

View File

@ -1,6 +1,9 @@
import 'dart:typed_data'; import 'dart:typed_data';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_sound/flutter_sound.dart'; import 'package:flutter_sound/flutter_sound.dart';
import 'package:get/get.dart';
import 'package:get/get_core/src/get_main.dart';
import 'package:star_lock/appRouters.dart';
import 'package:star_lock/main/lockDetail/monitoring/monitoring/lockMonitoring_page.dart'; import 'package:star_lock/main/lockDetail/monitoring/monitoring/lockMonitoring_page.dart';
import 'package:star_lock/talk/call/g711Decoder.dart'; import 'package:star_lock/talk/call/g711Decoder.dart';
import 'package:star_lock/talk/call/iFrameInfo.dart'; import 'package:star_lock/talk/call/iFrameInfo.dart';
@ -21,7 +24,7 @@ class CallTalk {
int status = 0; // int status = 0; //
IframeInfo? iframe; // IframeInfo? iframe; //
var growableList; var growableList;
LockMonitoringPage callOut = const LockMonitoringPage(); bool getFirstFrame = false; //
final FlutterSoundPlayer _audioPlayer = FlutterSoundPlayer(); final FlutterSoundPlayer _audioPlayer = FlutterSoundPlayer();
CallTalk._init() { CallTalk._init() {
@ -107,6 +110,13 @@ class CallTalk {
if (iframe!.bagNum == iframe!.bagReceive) { if (iframe!.bagNum == iframe!.bagReceive) {
print( print(
'播放第${iframe!.iframeIndex}帧 一帧图片的hexStringData: ${Uint8List.fromList(growableList)}'); '播放第${iframe!.iframeIndex}帧 一帧图片的hexStringData: ${Uint8List.fromList(growableList)}');
//
if (iframe!.iframeIndex == 0) {
getFirstFrame = true;
eventBus.fire(GetFirstFrameGoPush(getFirstFrame));
}
eventBus.fire(GetTVDataRefreshUI(growableList)); eventBus.fire(GetTVDataRefreshUI(growableList));
} }
} }

View File

@ -1,5 +1,3 @@
import 'dart:async'; import 'dart:async';
import 'dart:io'; import 'dart:io';
@ -11,7 +9,6 @@ import 'udp_manage.dart';
import 'udp_senderManage.dart'; import 'udp_senderManage.dart';
class UdpHelp { class UdpHelp {
openUDP() async { openUDP() async {
// ip跟端口 // ip跟端口
var entity = await ApiRepository.to.getWifiLockServiceIpAndPort(); var entity = await ApiRepository.to.getWifiLockServiceIpAndPort();
@ -30,12 +27,14 @@ class UdpHelp{
serversList.add(int.parse(element)); serversList.add(int.parse(element));
} }
} else { } else {
List<InternetAddress> addresses = await InternetAddress.lookup(item.serviceIp!); List<InternetAddress> addresses =
await InternetAddress.lookup(item.serviceIp!);
var itemList = addresses.first.address.split("."); var itemList = addresses.first.address.split(".");
for (var element in itemList) { for (var element in itemList) {
serversList.add(int.parse(element)); serversList.add(int.parse(element));
} }
print('Resolved google.com to address: ${addresses.first.address} serversList${serversList}'); print(
'Resolved google.com to address: ${addresses.first.address} serversList${serversList}');
} }
} }
@ -51,9 +50,7 @@ class UdpHelp{
Future<void> getWifiLockServiceIpAndPort() async { Future<void> getWifiLockServiceIpAndPort() async {
var entity = await ApiRepository.to.getWifiLockServiceIpAndPort(); var entity = await ApiRepository.to.getWifiLockServiceIpAndPort();
if(entity.errorCode! == 0){ if (entity.errorCode! == 0) {}
}
} }
} }

View File

@ -1,9 +1,9 @@
import 'dart:async'; import 'dart:async';
import 'package:fast_gbk/fast_gbk.dart'; import 'package:fast_gbk/fast_gbk.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:star_lock/tools/eventBusEventManage.dart';
import '../../appRouters.dart'; import '../../appRouters.dart';
import '../../main/lockDetail/monitoring/monitoring/lockMonitoring_page.dart'; import '../../main/lockDetail/monitoring/monitoring/lockMonitoring_page.dart';
@ -16,6 +16,7 @@ class UDPTalkClass{
_manager ??= UDPTalkClass._init(); _manager ??= UDPTalkClass._init();
return _manager!; return _manager!;
} }
factory UDPTalkClass() => _share(); factory UDPTalkClass() => _share();
UDPTalkClass get manager => _share(); UDPTalkClass get manager => _share();
@ -65,17 +66,31 @@ class UDPTalkClass{
data[8] = 9; data[8] = 9;
UDPManage().sendData(data); UDPManage().sendData(data);
}); });
}
Get.toNamed(Routers.lockMonitoringPage, arguments: { // _getFirstFrameGoPushAction();
"lockId": "111" Future.delayed(const Duration(seconds: 1), () {
//
Get.toNamed(Routers.lockMonitoringPage, arguments: {"lockId": "111"});
}); });
}
} else { } else {
// //
} }
} }
void _getFirstFrameGoPushAction() {
// eventBus
StreamSubscription _GetFirstFrameGoPushEvent =
eventBus.on<GetFirstFrameGoPush>().listen((event) {
if (event.isFirstFrame == true) {
Future.delayed(const Duration(seconds: 1), () {
//
Get.toNamed(Routers.lockMonitoringPage, arguments: {"lockId": "111"});
});
}
});
}
// call的本人 // call的本人
Future<bool> isCallMe(List<int>? data) async { Future<bool> isCallMe(List<int>? data) async {
final loginData = await Storage.getLoginData(); final loginData = await Storage.getLoginData();

View File

@ -61,3 +61,9 @@ class GetTVDataRefreshUI{
List<int> tvList; List<int> tvList;
GetTVDataRefreshUI(this.tvList); GetTVDataRefreshUI(this.tvList);
} }
///
class GetFirstFrameGoPush {
bool isFirstFrame;
GetFirstFrameGoPush(this.isFirstFrame);
}