使用flutter创建可移动的stack小部件功能

作者:Lucklyの博客 时间:2023-06-21 12:28:25 

本文主要介绍我为桌面和 Web 设计的一个超级秘密 Flutter 项目使用了画布和可拖动节点界面。本教程将展示我如何使用堆栈来使用小部件完成可拖动功能

如下所示。

使用flutter创建可移动的stack小部件功能

我们将动态地将项目添加到堆栈中并区分它们,我将使用 RandomColor 类型器。所以我们必须添加那个包。

random_color:

然后我们可以创建包含我们的堆栈的 HomeView


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,
       ));
 }
}

功能非常简单。我们将有一个MoveableStackItem有状态的小部件。它会跟踪自己的位置和颜色。颜色在初始化时设置,位置通过 更新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,
       ),
     ),
   );
 }
}

最后要做的是向MoveableStackItem视图添加一个新的。我们将通过 HomeView 中的浮动操作按钮来实现。


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

就是这样。现在您的视图上有一个可移动的Stack。

来源:https://blog.csdn.net/qq_39132095/article/details/120615912

标签:flutter,stack,小部件
0
投稿

猜你喜欢

  • Java如何实现压缩文件与解压缩zip文件

    2022-01-28 09:14:00
  • C#实现json的序列化和反序列化实例代码

    2022-07-18 01:50:34
  • mybatis注解与xml常用语句汇总

    2022-05-17 18:39:47
  • Kotlin使用静态变量与静态方法详解

    2021-10-11 07:03:40
  • JavaSE的逻辑控制你了解吗

    2023-01-07 01:32:22
  • Android中获取资源 id 及资源 id 的动态获取

    2023-06-30 04:38:06
  • Java设计模式之抽象工厂模式浅析讲解

    2022-08-08 18:26:47
  • Spring Boot2深入分析解决java.lang.ArrayStoreException异常

    2021-10-20 12:10:24
  • 通过spring boot 设置tomcat解决 post参数限制问题

    2022-09-26 23:38:31
  • java微信企业号开发之开发模式的开启

    2022-03-20 10:58:02
  • mybatis-plus配置控制台打印完整带参数SQL语句的实现

    2023-11-24 22:43:58
  • EventBus与Spring Event区别详解(EventBus 事件机制,Spring Event事件机制)

    2023-12-06 00:23:05
  • Android百度地图定位后获取周边位置的实现代码

    2021-11-30 08:21:07
  • android.enableD8.desugaring = false引发问题解决

    2023-11-03 16:06:15
  • 详解C#设置Excel数据自适应行高、列宽的2种情况

    2022-10-21 23:46:29
  • Activiti常用类简介

    2021-07-02 21:58:13
  • 使用java的HttpClient实现多线程并发

    2022-09-19 20:35:55
  • jpa EntityManager 复杂查询实例

    2023-08-31 01:03:01
  • Android集成Flutter

    2023-07-06 13:07:33
  • SpringMVC HttpMessageConverter消息转换器

    2023-01-13 04:57:45
  • asp之家 软件编程 m.aspxhome.com