반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 자료구조공부
- 스프링부트공부
- JPA예제
- 플러터 공부
- JPA공부
- querydsl
- 기술면접공부
- nestjs공부
- JPA 공부
- 코테공부
- nestjs
- 자바공부
- 기술공부
- 프로그래머스
- 플러터 개발
- JPA
- 스프링
- 알고리즘공부
- DDD
- Kafka
- nestjs스터디
- 코테준비
- 스프링공부
- Flutter
- 카프카
- 스프링부트
- JPA스터디
- K8S
- 스프링 공부
- Axon framework
Archives
- Today
- Total
DevBoi
[Flutter] StreamBuilder State redraw 이슈 본문
반응형
최근에 채팅 관련 모듈을 개발하면서, StreamBuilder를 사용했다.
해당 사용할때 이슈가있었는데 해당 부분에 대해서는 아래와 같다.
* 채팅 입력
* 채팅 내용
위와 같이 두개의 State를 가지는 위젯들이 있었다.
해당 채팅 내용을 입력할때, 키보드가 위로 올라가면서 화면을 가리는 이슈때문에,
해당 키보드 때문에 화면이 밀리면 다시 그려주게끔 개발을 해놨다.
해당 부분 때문에 StreamBuilder에서 계속 값을 재 connection을 시키려고했다.
해당 이슈로 인해, 조금만 클릭해서 progressbar가 돌았고, 나도 돌았다.
해결 방법은 생각보다 간단하다.
아래와 같이 stream으로 받아오는 변수를 밖으로 빼면 된다.
소스코드는 아래와 같다.
import 'package:flutter/material.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:get/get.dart';
import 'package:myvalue/view/chat/widget/chat-bubble2.dart';
import 'package:myvalue/view/provider/User/global-provider.dart';
import 'package:myvalue/view/util/provider-util.dart';
final GlobalProvider globalProvider = Get.find();
class Messages2 extends StatefulWidget {
//const Messages2({Key key,String roomId});
final String roomId;
const Messages2(this.roomId);
//const Messages2({required Key key, required this.roomId}) : super(key: key);
@override
State<Messages2> createState() => _Messages2State();
}
class _Messages2State extends State<Messages2> {
late Stream<QuerySnapshot<Map<String, dynamic>>> chatStream;
@override
void initState() {
chatStream = FirebaseFirestore.instance.collection(widget.roomId.toString())
.orderBy('time',descending: true)
.snapshots();
super.initState();
}
@override
Widget build(BuildContext context) {
// 나갈때 해당 인덱스를 늘려주기
// FirebaseFirestore.instance.collection(roomId.toString()).snapshots().length;
return Expanded(
child: StreamBuilder(
//key: UniqueKey(),
stream: chatStream,
builder: (context, AsyncSnapshot<QuerySnapshot<Map<String,dynamic>>> snapshot) {
if(snapshot.connectionState == ConnectionState.waiting){
return context.widget;
}
final chatDoc = snapshot.data!.docs;
return ListView.builder(
reverse: true,
itemCount: chatDoc.length,
itemBuilder: (context,index){
bool changeDateYn = true;
if(index == chatDoc.length-1){
changeDateYn =true;
}
else{
Timestamp now = chatDoc[index]['time'];
Timestamp past = chatDoc[index+1]['time'];
DateTime time = DateTime.parse(now.toDate().toString());
DateTime yesterday = DateTime.parse(past.toDate().toString());
if(time.day != yesterday.day){
changeDateYn = true;
}
else{
changeDateYn = false;
}
}
return ChatBubbles2(
chatDoc[index]['content'],
chatDoc[index]['userId'] == userProvider.userInfo.id.toString(),
chatDoc[index]['userName'],
chatDoc[index]['time'],
changeDateYn
);
});
}
),
);
}
}
initstate를 통해서 밖의 변수에 값을 세팅해주고
해당 세팅된 값을 참조하게끔 변경하니, 해당 이슈는 발생하지않았다.
간단하고 생각을 해보면 되지만 좀 처럼 해결방법이 떠오르지않았던 문제이다.
반응형
'[Mobile] > [Flutter]' 카테고리의 다른 글
[Flutter] textformfield 클릭시 화면이 리스트를 가리는 현상 (0) | 2024.01.17 |
---|---|
[flutter] 앱에 광고 달기 (1) | 2023.12.30 |
[Flutter] Icon launcher 사용하기 (0) | 2023.12.19 |
[Flutter] IOS 애플 로그인, 회원탈퇴 (0) | 2023.12.16 |
[Flutter] Rendering Object 오류 (0) | 2023.11.27 |