首页 > 解决方案 > 如何通过不同的选项卡使一个小部件持久化?

问题描述

所以我想要做的是在我拥有的所有 3 个选项卡中保留最后一行的状态,但我不确定我会怎么做,有什么帮助吗?

如果有意义的话,我想基本上在我拥有的所有选项卡中保留滑块和持续时间等,现在它只能按预期在第一个选项卡上工作

此外,使用提供程序可能比将所有 7 个输入移动到歌曲卡更好的方法,所以如果你也能提供帮助,那就太好了

    import 'package:flutter/material.dart';
    import 'package:audioplayers/audioplayers.dart';
    import 'package:music_playerrrrr/providers/songs.dart';
    import 'package:music_playerrrrr/screens/tracks_screen.dart';
    import 'package:provider/provider.dart';
    
    void main() {
      runApp(MyApp());
    }
    
    class MyApp extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return ChangeNotifierProvider(
          create: (context) => Songs(),
          child: DefaultTabController(
            length: 3,
            child: MaterialApp(
              home: Scaffold(
                appBar: AppBar(
                  title: Text('Music Player'),
                  bottom: TabBar(
                    tabs: [
                      Tab(
                        text: 'Tracks',
                      ),
                      Tab(
                        text: 'Albums',
                      ),
                      Tab(
                        text: 'lol',
                      ),
                    ],
                  ),
                ),
                body: TabBarView(
                  children: [
                    TracksScreen(),
                    Scaffold(),
                    Scaffold(),
                  ],
                ),
              ),
            ),
          ),
        );
      }
    }

@override
  Widget build(BuildContext context) {
    return Scaffold(
      backgroundColor: Colors.black,
      body: Column(
        children: [
          Expanded(
            child: Padding(
              padding: const EdgeInsets.all(0),
              child: ListView.builder(
                itemCount: Provider.of<Songs>(context).songsList.length,
                itemBuilder: (context, i) {
                  final song = Provider.of<Songs>(context).songsList[i];
                  final durationInMs =
                      Provider.of<Songs>(context).songsList[i].duration;
                  final duration = millisecondsToMinutes(durationInMs);
                  final songId = song.id;
                  final filePath = song.filePath;
                  return SongCard(
                    song.title,
                    song.artist,
                    duration,
                    songId,
                    filePath,
                    checkIfSongClicked,
                    player,
                  );
                },
              ),
            ),
          ),
          if (isSongClickedOrNot)
            Container(
              width: MediaQuery.of(context).size.width,
              height: 70,
              color: Colors.pink,
              child: Row(
                mainAxisAlignment: MainAxisAlignment.spaceBetween,
                children: [
                  SizedBox(
                    width: 10,
                  ),
                  Text(
                      _position.inSeconds.remainder(60) < 10
                          ? '${_position.inMinutes.toString()}:0${_position.inSeconds.remainder(60).toString()}'
                          : '${_position.inMinutes.toString()}:${_position.inSeconds.remainder(60).toString()}',
                      style: TextStyle(color: Colors.white, fontSize: 20)),
                  Expanded(
                    child: Slider(
                      min: 0,
                      max: _duration.inSeconds.toDouble(),
                      value: _position.inSeconds.toDouble(),
                      onChanged: (value) {
                        setState(() {
                          seekToSecond(value.toInt());
                        });
                      },
                    ),
                  ),
                  SizedBox(
                    width: 10,
                  ),
                  IconButton(
                    iconSize: 50.0,
                    icon: isPlayingOrNot
                        ? Icon(Icons.pause)
                        : Icon(Icons.play_arrow),
                    onPressed: () {
                      if (isPlayingOrNot) {
                        player.pause();
                        setState(() {
                          isPlayingOrNot = false;
                        });
                      } else {
                        player.resume();
                        setState(() {
                          isPlayingOrNot = true;
                        });
                      }
                    },
                  )
                ],
              ),
            ),
        ],
      ),
    );
  }
}

标签: flutterdartwidget

解决方案


推荐阅读