如何在Flutter中进行可滚动的拖放?

时间:2019-06-24 16:59:13

标签: flutter flutter-layout

我正在尝试使用SingleChildScrollView创建可滚动和缩放的堆栈,以实现画布编辑器。

当我将Dragabble项目放到初始视图中时,但当我向下滚动视图并试图将容器放回初始视图中时,拖放操作完美工作。

我是Flutter开发的新手,所以也许我在实现这样的事情时被误解了。

这是我当前拥有的代码。

void main() => runApp(new MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        body: App(),
      ),
    );
  }
}

class App extends StatefulWidget {
  @override
  AppState createState() => AppState();
}

class AppState extends State<App> {
  Color caughtColor = Colors.grey;

  @override
  Widget build(BuildContext context) {
    return SingleChildScrollView(
      child: Stack(
        children: <Widget>[
          Container(
            height: 2000,
          ),
          DragBox(Offset(0.0, 0.0), 'Box One', Colors.blueAccent),
        ],
      ),
    );

  }
}

class DragBox extends StatefulWidget {
  final Offset initPos;
  final String label;
  final Color itemColor;

  DragBox(this.initPos, this.label, this.itemColor);

  @override
  DragBoxState createState() => DragBoxState();
}

class DragBoxState extends State<DragBox> {
  Offset position = Offset(0.0, 0.0);

  @override
  void initState() {
    super.initState();
    position = widget.initPos;
  }

  @override
  Widget build(BuildContext context) {
    return Positioned(
        left: position.dx,
        top: position.dy,
        child: Draggable(
          data: widget.itemColor,
          child: Container(
            width: 100.0,
            height: 100.0,
            color: widget.itemColor,
            child: Center(
              child: Text(
                widget.label,
                style: TextStyle(
                  color: Colors.white,
                  decoration: TextDecoration.none,
                  fontSize: 20.0,
                ),
              ),
            ),
          ),
          onDraggableCanceled: (velocity, offset) {
            setState(() {
              position = offset;
            });
          },
          feedback: Container(
            width: 120.0,
            height: 120.0,
            color: widget.itemColor.withOpacity(0.5),
            child: Center(
              child: Text(
                widget.label,
                style: TextStyle(
                  color: Colors.white,
                  decoration: TextDecoration.none,
                  fontSize: 18.0,
                ),
              ),
            ),
          ),
        ));
  }
}

任何建议或代码示例都会对我有帮助。

1 个答案:

答案 0 :(得分:1)

我解决了这样的问题,用侦听器将您的可拖动对象包装起来。

Listener listenableDraggable = Listener(
  child: draggable,
  onPointerMove: (PointerMoveEvent event) {
    if (event.position.dy > MediaQuery.of(context).size.height) {
      // 120 is height of your draggable.
      scrollController.scrollTo(scrollcontroller.offset + 120);
    }
  },
);