Привет стек переполнение ! У меня были проблемы с использованием pageview.builder внутри будущего сборщика. элементы, через которые он просматривает, - это карты, у меня это уже работало, но, выполняя logi c, чтобы получать заметки и тому подобное, я пошел к будущему сборщику и переместил этот NoteSet в свой класс. Я полагаю, что где-то совершил серьезное изменение, но я не уверен. Странно то, что я могу строить и видеть карты. Включающий детектор жестов работает также хорошо, но я не могу пролистать мой pageview.builder.
Любая помощь очень ценится!
class NoteSet extends StatefulWidget {
VoidCallback callback;
final Category category;
NoteSet(this.category, this.callback);
@override
_NoteSetState createState() => _NoteSetState();
}
class _NoteSetState extends State<NoteSet> {
List<NoteEntry> sortedNotes = [];
double currentPage;
bool largeCards = false;
SortMethod currentSortMethod = SortMethod.CreatedDescending;
Future<List<NoteEntry>> getNotes() async {
return await readCategoryNotes(widget.category);
}
void sortNotes(){...}
refresh() {...}
deleteCategory() async {
deleteCategoryDialog(context, widget.category, refresh);
}
void toggleModifiedSort(){
currentSortMethod == SortMethod.ModifiedDescending ? currentSortMethod = SortMethod.ModifiedAscending : currentSortMethod = SortMethod.ModifiedDescending;
refresh();
}
void toggleCreatedSort(){
currentSortMethod == SortMethod.CreatedDescending ? currentSortMethod = SortMethod.CreatedAscending : currentSortMethod = SortMethod.CreatedDescending;
refresh();
}
void toggleCardSize(){
largeCards = !largeCards;
refresh();
}
void moveThisCategoryUp() async {
await moveCategoryUp(widget.category);
refresh();
}
void moveThisCategoryDown() async {
await moveCategoryDown(widget.category);
refresh();
}
@override
Widget build(BuildContext context) {
PageController controller = PageController();
currentPage = (sortedNotes.length - 1).roundToDouble();
return Column(
children: <Widget>[
Padding(
padding: EdgeInsets.symmetric(horizontal: 10.0),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: <Widget>[
Text(widget.category.toString().split(".").last,
style: TextStyle(
color: Colors.white,
fontSize: 46.0,
fontWeight: FontWeight.bold,
letterSpacing: 1.0,
)
),
PopupMenuButton<VoidCallback>(...),
],
),
),
FutureBuilder(
future: getNotes(),
builder: (context, snapshot){
if(snapshot.hasData){
sortedNotes = snapshot.data;
sortNotes();
controller.addListener(() {
setState(() {
currentPage = controller.page;
});
});
return Column(
children: <Widget>[
Padding(
padding: const EdgeInsets.only(left: 15.0),
child: Row(
children: <Widget>[
Text("${sortedNotes.length} Entries",
style: TextStyle(color: Colors.tealAccent[200]))
],
),
),
Stack(
children: <Widget>[
CardScrollWidget(currentPage, sortedNotes, largeCards ? 0.8 : 1.2),
Positioned.fill(
child: GestureDetector(
onTap: () {
editNoteDialog(context, sortedNotes[currentPage.round()], refresh);
},
onLongPress: () {
deleteNoteDialog(context, sortedNotes[currentPage.round()], refresh);
},
child: ScrollConfiguration(
behavior: PageScrollBehavior(),
child: PageView.builder(
itemCount: sortedNotes.length,
controller: controller,
reverse: true,
itemBuilder: (context, index) {
return Container();
},
),
),
),
)
],
),
],
);
}
else{
return Padding(
padding: const EdgeInsets.all(20.0),
child: Center(
child: SpinKitPulse(
color: Colors.tealAccent,
size: 60.0,
),
),
);
}
},
),
SizedBox(height: 15,),
],
);
}
}