【Flutter】旋转元素(Transform、RotatedBox )

这里写自定义目录标题

  • Transform旋转元素
  • [可以改变宽高约束的旋转 - RotatedBox](#可以改变宽高约束的旋转 - RotatedBox)

Transform旋转元素

说明:Transform旋转操作改变了元素的方向,但并没有改变它的布局约束。因此,虽然视觉上元素看起来是旋转了,但它仍然遵循原始的宽高约束,这可能导致它不能正确地铺满 父元素。

dart 复制代码
import 'dart:math' as math;

Stack(
  fit: StackFit.expand,
  children: [
    LayoutBuilder(
      builder: (context, constraints) {
        final double width = constraints.maxWidth;
        final double height = constraints.maxHeight;

        return Transform.rotate(
          angle: math.pi / 2, // 固定 90 度旋转
          child: Container(
            color: Colors.red,
            width: mirror ? height : width, // 根据镜像状态调整宽度
            height: mirror ? width : height, // 根据镜像状态调整高度
            child: Icon(Icons.check_box),
          ),
        );
      },
    ),
  ],
)

可以改变宽高约束的旋转 - RotatedBox

说明:RotatedBox 是一种不同的旋转方式,它实际上改变了子组件的布局方向,而不是仅仅在绘制时旋转。这意味着它会根据旋转角度重新计算子组件的尺寸和位置,可以应用于旋转后希望铺满父元素的情境。

dart 复制代码
Stack(
  fit: StackFit.expand,
  children: [
    RotatedBox(
      quarterTurns: 1, // 90 度等于 1/4 转
      child: Container(
        color: Colors.red,
        width: MediaQuery.of(context).size.width, // 使用原始宽度
        height: MediaQuery.of(context).size.height, // 使用原始高度
        child: Icon(Icons.check_box),
      ),
    ),
  ],
)
相关推荐
程序员老刘2 天前
跨平台开发地图 | 2026年6月
flutter·ai编程·客户端
悟空瞎说3 天前
Flutter 架构详解:新手必懂底层原理
flutter
SoaringHeart3 天前
Flutter最佳实践:IM聊天文字链接自动识别跳转
前端·flutter
恋猫de小郭3 天前
KMP / CMP 鸿蒙版本 Beta 发布,他有什么特别之处?
android·前端·flutter
风华圆舞4 天前
Flutter + 鸿蒙 Intents Kit:页面直达能力的完整接入方案
flutter·ui·华为·harmonyos
韩曙亮4 天前
【Flutter】Flutter 组件 ④ ( 组件渲染 的 三棵树理论 | Widget 树 → Element 树 → RenderObject 树 )
flutter·element·widget·renderobject
恋猫de小郭4 天前
Android 17 正式版发布,全新 AI 和各种破坏性更新
android·前端·flutter
kingbal4 天前
Windows:flutter环境搭建
windows·flutter
911hzh4 天前
Flutter MethodChannel 跨端通信框架 zh_native_channel:快速入门、优势分析与 Pigeon 对比
flutter
911hzh4 天前
Flutter 快速搭建新项目:用 Flutter Foundation Kit 一条命令生成带基础架构的 App 模板
flutter