Flutter:具有单个子级滚动视图的自定义底部工作表

时间:2019-06-17 10:46:21

标签: flutter scrollview bottom-sheet gesturedetector

[大量修改]

嗨,我需要您的帮助以了解此小部件的行为原因:

class Bottom extends StatefulWidget {
  @override
  _Bottom createState() => _Bottom();
}

class _Bottom extends State<Bottom> with SingleTickerProviderStateMixin {
  AnimationController _controller;
  double get maxHeight => MediaQuery.of(context).size.height;
  double get headerTopMargin =>
      lerp(20, 20 + MediaQuery.of(context).padding.top);

  @override
  void initState() {
    super.initState();
    _controller = AnimationController(
      vsync: this,
      duration: Duration(milliseconds: 600),
    );
  }

  @override
  void dispose() {
    _controller.dispose();
    super.dispose();
  }

  double lerp(double min, double max) =>
      lerpDouble(min, max, _controller.value);

  Widget get _singleCard => Card(
                      color: Colors.white,
                      child: Padding(padding: EdgeInsets.all(20),),
                      );

  List<Widget> _hundredCards(){
    List<Widget> _list = [];
    for (int i = 0; i<100; i++) _list.add(_singleCard);
    return _list;
  }

  @override
  Widget build(BuildContext context) {
    return AnimatedBuilder(
      animation: _controller,
      builder: (context, child) {
        double _height = lerp(minHeight, maxHeight);
        return Positioned(
          height: _height,
          left: 0,
          right: 0,
          bottom: 0,
          child: GestureDetector(
            onTap: _toggle,
            onVerticalDragUpdate: _handleDragUpdate,
            onVerticalDragEnd: _handleDragEnd,
            child: Container(
              padding: const EdgeInsets.symmetric(horizontal: 32),
              decoration: BoxDecoration(
                color: Colors.deepPurpleAccent,
                borderRadius:
                    const BorderRadius.vertical(top: Radius.circular(32)),
              ),
              child: SingleChildScrollView(
                child: Column(
                                    children:
              // SCROLL PROPERLY 
              <Widget>[
                _singleCard,
              ],

              //==> PROBLEM HERE!!!<=== 
              // DOESN'T SCOLL, BUT THE LIST IS SCROLLABLE INSTEAD
              //_hundredCards(),  <=== here 
                ),
              ),
            ),
          ),
        );
      },
    );
  }

  void _toggle() {
    final bool isOpen = _controller.status == AnimationStatus.completed;
    _controller.fling(velocity: isOpen ? -2 : 2);
  }

  void _handleDragUpdate(DragUpdateDetails details) {
    _controller.value -= details.primaryDelta / maxHeight;
  }

  void _handleDragEnd(DragEndDetails details) {
    if (_controller.isAnimating ||
        _controller.status == AnimationStatus.completed) return;
    final double flingVelocity =
        details.velocity.pixelsPerSecond.dy / maxHeight;
    if (flingVelocity < 0.0)
      _controller.fling(velocity: math.max(2.0, -flingVelocity));
    else if (flingVelocity > 0.0)
      _controller.fling(velocity: math.min(-2.0, -flingVelocity));
    else
      _controller.fling(velocity: _controller.value < 0.5 ? -2.0 : 2.0);
  }
}

我想在已定位的位置内有一个滚动列表 包含手势检测器,容器等。

如果我将手势检测器放在容器内不满意, 有解决的主意吗?

预先感谢

0 个答案:

没有答案