Create a movable stack widget function using flutter

Create a movable stack widget function using flutter

This post focuses on a super secret Flutter project I designed for desktop and web that uses a canvas and draggable node interface. This tutorial will show how I use stacks to accomplish draggable functionality with widgets.

As shown below.

Draggable widget example shake

We will dynamically add items to the stack and to distinguish them, I will use the RandomColor typer. So we have to add that package.

random_color:

We can then create the HomeView that contains our stack

class HomeView extends StatefulWidget {
  @override
  _HomeViewState createState() => _HomeViewState();
}

class _HomeViewState extends State<HomeView> {
  List<Widget> movableItems = [];

  @override
  Widget build(BuildContext context) {
    return Scaffold(
        body: Stack(
          children: movableItems,
        ));
  }
}

The functionality is very simple. We will have a MoveableStackItem stateful widget. It keeps track of its own position and color. The color is set on initialization and the position is updated via GestureDetector .

class _MoveableStackItemState extends State<MoveableStackItem> {
  double xPosition = 0;
  double yPosition = 0;
  Color color;

  @override
  void initState() {
    color = RandomColor().randomColor();
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return Positioned(
      top: yPosition,
      left: xPosition,
      child: GestureDetector(
        onPanUpdate: (tapInfo) {
          setState(() {
            xPosition += tapInfo.delta.dx;
            yPosition += tapInfo.delta.dy;
          });
        },
        child:Container(
          width: 150,
          height: 150,
          color: color,
        ),
      ),
    );
  }
}

The last thing to do is to add a new MoveableStackItem view. We will do this via a floating action button in HomeView.

 return Scaffold(
  floatingActionButton:FloatingActionButton(
    onPressed: () {
      setState(() {
        movableItems.add(MoveableStackItem());
      });
    },
  ),
  body: Stack(
    children: movableItems,
  ));

That's it. Now you have a movable Stack on your view.

This is the end of this article about creating a movable stack widget in flutter. For more related flutter stack widget content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Over 1 million StackOverflow Flutter 20 questions (recommended)

<<:  In-depth explanation of Mysql deadlock viewing and deadlock removal

>>:  Detailed explanation of mysql deadlock checking and deadlock removal examples

Recommend

Using HTML to implement a voting website cheating scheme that restricts IP

This is a cheating scheme for voting websites wit...

MySQL not null constraint case explanation

Table of contents Set a not null constraint when ...

Example code for implementing card waterfall layout with css3 column

This article introduces the sample code of CSS3 c...

Solution to JS out-of-precision number problem

The most understandable explanation of the accura...

Example of implementing grouping and deduplication in MySQL table join query

Table of contents Business Logic Data table struc...

Detailed explanation of using Nginx reverse proxy to solve cross-domain problems

question In the previous article about cross-doma...

Vue echarts realizes horizontal bar chart

This article shares the specific code of vue echa...

Sample code for seamless scrolling with flex layout

This article mainly introduces the sample code of...

Vue implements interface sliding effect

This article example shares the specific code of ...

What is ZFS? Reasons to use ZFS and its features

History of ZFS The Z File System (ZFS) was develo...

Discussion on the problem of iframe node initialization

Today I suddenly thought of reviewing the producti...

Vue3 implements CSS infinite seamless scrolling effect

This article example shares the specific code of ...