【Flutter&Dart】 拖动边界线改变列宽类似 vscode 那种拖动改变编辑框窗口大小(11 /100)

【Flutter&Dart】 拖动改变 widget 的窗口尺寸大小GestureDetector~简单实现(10 /100)
【Flutter&Dart】 拖动边界线改变列宽并且有边界高亮和鼠标效果(12 /100)

上效果:

这个在知乎里找到的效果,感觉很不错就给抄过来实现一下。

上代码:

dart 复制代码
import 'package:flutter/material.dart';

class MyDraggableViewDemo2 extends StatelessWidget {
  const MyDraggableViewDemo2({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('MyDraggableViewDemo2'),
        ),
        body: DraggableDemo(),
      ),
    );
  }
}

class DraggableDemo extends StatefulWidget {
  const DraggableDemo({super.key});

  @override
  State<StatefulWidget> createState() {
    return _DraggableDemoState();
  }
}

class _DraggableDemoState extends State<DraggableDemo> {
  double leftWidth = 100.0;
  double height = 200.0;
  bool isResizing = false;

  @override
  Widget build(BuildContext context) {
    return Row(children: [
      // 使用 SizedBox 组件来指定左边的组件的宽度
      SizedBox(
        width: leftWidth,
        child: Container(
          color: Colors.blue,
          child: Center(child: Text('左侧菜单')),
        ),
      ),

// 使用 GestureDetector 组件来包裹分割线
      GestureDetector(
        // 监听水平方向的拖拽操作
        onHorizontalDragUpdate: (details) {
          // 获取拖拽的距离
          double delta = details.delta.dx;
          // 更新左边的组件的宽度
          leftWidth += delta;
          // 限制左边的组件的宽度在 0 到屏幕宽度之间
          leftWidth = leftWidth.clamp(0.0, MediaQuery.of(context).size.width);
          // 重绘组件
          setState(() {});
        },
        child: VerticalDivider(
          width: 16,
          thickness: 4,
          color: Colors.black,
        ),
      ),
      // 使用 Expanded 组件来包裹右边的组件
      Expanded(
        child: Container(
          color: Colors.red,
          child: Center(child: Text('右侧工作区')),
        ),
      ),
    ]);
  }
}

功能上符合要求了,但是交互效果上还是需要在进行细微调整的

比如鼠标停留后的高亮分割线,感觉是停留超过两秒才出现的,滑过不会出现

还有左右可拖动的鼠标剪头等等

===========END

相关推荐
kirk_wang8 分钟前
Flutter share_plus 库鸿蒙端适配实践:打通跨平台分享功能
flutter·移动开发·跨平台·arkts·鸿蒙
行者9613 分钟前
Flutter适配OpenHarmony:手势交互的深度优化与实战应用
flutter·交互·harmonyos·鸿蒙
行者9615 分钟前
Flutter与OpenHarmony深度融合:跨平台日历组件性能优化与适配实践
flutter·harmonyos·鸿蒙
One_Piece_Fu20 分钟前
2026年node.js最新版下载(24.12.0LTS)安装教程(详细)
vscode·学习·node.js
行者9622 分钟前
Flutter适配鸿蒙:SnackBar组件实践与优化策略
flutter·harmonyos·鸿蒙
2501_9159184125 分钟前
介绍如何在电脑上查看 iPhone 和 iPad 的完整设备信息
android·ios·小程序·uni-app·电脑·iphone·ipad
TheNextByte128 分钟前
如何通过蓝牙将照片从 iPhone 分享到Android ?
android·gitee·iphone
wxl78122731 分钟前
零基础10分钟部署MinerU:Docker Compose一键搭建指南
api·gradio·docker compose·vllm·mineru2.7.1
kirk_wang34 分钟前
Flutter艺术探索-ListView与GridView列表组件完全指南
flutter·移动开发·flutter教程·移动开发教程
2501_9160088935 分钟前
没有 Mac 如何在 Windows 上创建 iOS 应用描述文件
android·macos·ios·小程序·uni-app·iphone·webview