构建响应式屏幕布局意味着编写一段代码,以响应设备布局的各种变化,因此应用程序会根据设备的屏幕尺寸和形状显示其UI。

在这篇文章中,我们将探讨Flutter中用于屏幕响应的扩展和灵活部件。

由于Flutter的跨平台、单一代码库的能力,了解屏幕管理以防止像柔性溢出错误或糟糕的用户界面设计这样的问题是至关重要的。

我们还将设计一个扩展和灵活部件的演示,并描述它们的属性以及如何在Flutter应用程序中使用它们。

前提条件

为了理解和跟上本教程,您应该具备以下条件。

  • 在您的本地机器上安装Flutter
  • 具有Flutter和Dart的工作知识

使用容器的问题

在Flutter中,一个容器是一个包含多个子小部件的父小部件。它通过宽度、高度、背景颜色和填充以及其他描述符来管理它们。基本上,一个容器是一个盒子,我们可以把内容传进去。

有两个原因可以说明为什么在Flutter中使用容器来创建一个响应式的屏幕布局是不可取的。

首先是RenderFlex的溢出。这是最经常遇到的Flutter框架错误之一;当它发生时,你会看到黄色和黑色的条纹,指示应用程序UI中的溢出区域,此外还有调试控制台的错误信息。

"大屏幕的内容尺寸不足 "只是一个UI错误,由于Flutters的灵活性,内容对于特定的屏幕来说太小或太大。

这两个问题都可以使用 "灵活 "或 "扩展 "小组件来解决,提供更好的UI和开发体验。

展开式小组件的介绍

扩展小组件是一个单子小组件,意味着只能给它分配一个子项。为了更好地优化,它被用在行或列中。

扩展小组件的属性包括child 小组件和flex 小组件。

child 小组件被放置在一个扩展的小组件内,它可以收进行和列。Flex 被用来不均匀地分配child 小组件的内容。

在下面的代码中,我们使用扩大的小组件,将flex 设置为1 ,并使用一个普通的容器来显示扩大的小组件的效果和它的属性。

Expanded(
 flex: 1,
 child: Container(
 color: Colors.red,
 ),
),

灵活小组件的介绍

灵活小组件与 "扩展 "小组件相当相似,但显著的区别在于其属性。灵活小组件用于调整孩子在屏幕中的内容位置。

灵活部件的属性包括fitflex

Fit 控制该属性如何填充可用空间。它有两个选项:FlexFit.Tight ,将其设置为填充可用空间,以及FlexFit.loose ,填充子小组件的剩余可用空间。

就像在 "扩展 "小组件中,flex 被用来不均匀地分配子小组件的内容。

下面的代码使用了一个Flexible widget,其flex 被设置为1 ,适合作为FlexFit.loose ,以及一个具有常规功能的子容器。

Flexible(
   flex: 1,
   fit: FlexFit.loose,
   child: Container(
   height: 100,
    decoration: BoxDecoration(
      borderRadius: BorderRadius.circular(15),
      color: Colors.deepOrange[400],
      ),
    child:Icon(Icons.backpack),
 ),
),

设置一个示例应用程序

在这个演示中,我们将创建一个Flutter示例应用程序,其布局是以行和列显示的内容。

这里有一个gif图,展示了我们将在这篇文章中建立的演示应用程序。

让我们先创建一个Flutter项目目录;在你的终端输入以下命令。

mkdir FlutterApps

接下来,创建一个Flutter项目。

flutter create sample_app

现在,在您选择的任何代码编辑器中打开Flutter项目。

代码执行

将以下代码粘贴到main.dart 文件中。我们首先创建一个名为homepage 的有状态部件。

homepage ,我们将创建两个按钮,将我们引向两个不同的屏幕,以看到在屏幕布局中使用扩展和灵活部件的区别。

Scaffold(
  body: Center(
    child:
      Column(mainAxisAlignment: MainAxisAlignment.center, children: [
 GestureDetector(
  onTap: () {
   Navigator.push(
    context,
    MaterialPageRoute(
     builder: (context) => ExpandedWidget(),
    ),
   );
  },
  child: Container(
    height: 50,
    width: 150,
    decoration: BoxDecoration(
      borderRadius: BorderRadius.circular(10), color: Colors.red),
    child: Center(child: Text("Expanded Widget"))),
 ),
 SizedBox(height: 100),
 GestureDetector(
  onTap: () {
   Navigator.push(
    context,
    MaterialPageRoute(
     builder: (context) => FlexibleWidget(),
    ),
   );
  },
  child: Container(
    height: 50,
    width: 150,
    decoration: BoxDecoration(
      borderRadius: BorderRadius.circular(10),
      color: Colors.teal[700]),
    child: Center(child: Text("Flexible Widget"))),
 )
])));

创建的按钮是简单的容器,里面有一些decorationcolortext 小部件,用一个手势检测器包裹起来,使我们能够使用onTap 属性来引导到ExpandedWidget()FlexibleWidget() 屏幕。

扩展的小部件例子

首先,创建一个名为expanded.dart 的文件。

touch expanded.dart

接下来,将以下代码粘贴到文件中。在代码中,我们创建了一个无状态的小部件,以使用flex 属性编写我们的例子。

class ExpandedWidget extends StatelessWidget {
 const ExpandedWidget({Key? key}) : super(key: key);
 @override
 Widget build(BuildContext context) {
  return Scaffold(
    appBar: AppBar(
     leading: GestureDetector(
       onTap: () {
        Navigator.pop(context);
       },
       child: Icon(Icons.arrow_back_ios_new)),
    ),
    body: Padding(
     padding: const EdgeInsets.symmetric(horizontal: 15),
     child: Column(
      mainAxisAlignment: MainAxisAlignment.spaceAround,
      children: [
       Column(
        children: [
         Text("With Flex"),
         Container(
          height: 100,
          child: Row(
           children: [
            Expanded(
             flex: 1,
             child: Container(
              color: Colors.red,
             ),
            ),
            Expanded(
             flex: 2,
             child: Container(
              color: Colors.deepOrange[400],
             ),
            ),
            Expanded(
             flex: 3,
             child: Container(
              color: Colors.purpleAccent,
             ),
            )
           ],
          ),
         ),
        ],
       ),
       Column(
        children: [
         Text("Without Flex"),
         Container(
          height: 100,
          child: Row(
           children: [
            Expanded(
             child: Container(
              color: Colors.red,
             ),
            ),
            Expanded(
             child: Container(
              color: Colors.deepOrange[400],
             ),
            ),
            Expanded(
             child: Container(
              color: Colors.purpleAccent,
             ),
            )
           ],
          ),
         ),
        ],
       ),
      ],
     ),
    ));
 }
}

首先,我们返回一个脚手架,以便我们可以使用appbarbody 属性。接下来,在appbar ,我们创建了一个返回按钮,这样我们就可以返回到前一个屏幕。

接着是正文,我们使用了两列,一列在顶部,另一列在按钮处将它们间隔开来;在每一列中,我们有一段文字描述它是有还是没有flex 。在它下面,我们使用三个有或没有flex 的扩展部件和一个分配不同颜色的容器创建了一个行。

下面的图片显示了应用和不应用flex 的布局。

灵活部件的例子

首先,创建一个名为flexible.dart 的文件。

touch flexible.dart

接下来,将以下代码粘贴到文件中。

class FlexibleWidget extends StatelessWidget {
 const FlexibleWidget({Key? key}) : super(key: key);
 @override
 Widget build(BuildContext context) {
  return Scaffold(
   appBar: AppBar(
    leading: GestureDetector(
      onTap: () {
       Navigator.pop(context);
      },
      child: Icon(Icons.arrow_back_ios_new)),
   ),
   body: Padding(
    padding: const EdgeInsets.symmetric(horizontal: 10),
    child: Column(
     mainAxisAlignment: MainAxisAlignment.spaceAround,
     children: [
      Column(
       children: [
        Text("Flexfit.loose"),
        Row(
         mainAxisAlignment:MainAxisAlignment.center,
         children: [
          Flexible(
           flex: 1,
           fit: FlexFit.loose,
           child: Container(
            height: 100,
            decoration: BoxDecoration(
             borderRadius: BorderRadius.circular(15),
             color: Colors.deepOrange[400],
            ),
            child:Icon(Icons.backpack),
           ),
          ),
          SizedBox(
           width: 10,
          ),
          Flexible(
           flex: 1,
           fit: FlexFit.loose,
           child: Container(
            height: 100,
            decoration: BoxDecoration(
             borderRadius: BorderRadius.circular(15),
             color: Colors.deepOrange[400],
            ),
            child:Icon(Icons.backpack),
           ),
          )
         ],
        )
       ],
      ),
      Column(
       children: [
        Text("Flexfit.tight"),
        Row(
         children: [
          Flexible(
           flex: 1,
           fit: FlexFit.tight,
           child: Container(
             height: 100,
           decoration: BoxDecoration(
            borderRadius: BorderRadius.circular(15),
              color: Colors.purpleAccent,
           ),
           child:Icon(Icons.backpack),
           ),
          ),
          SizedBox(
           width: 10,
          ),
          Flexible(
           flex: 1,
           fit: FlexFit.tight,
           child: Container(
             height: 100,
            decoration: BoxDecoration(
             borderRadius: BorderRadius.circular(15),
             color: Colors.purpleAccent,
            ),
            child:Icon(Icons.backpack),
           ),
          )
         ],
        )
       ],
      )
     ],
    ),
   ),
  );
 }
}

在代码中,我们创建了一个无状态的小部件,FlexibleWidget 。在它里面,我们创建了两行灵活部件的内容。在第一行,我们使用flexfit.loose ,在第二行,我们使用flexfit.tight 。有了这个,图标将填补孩子所提供的可用空间。

下面的图片显示了这样的布局,flexfit.loose ,使用了孩子提供的最小空间,flexfit.tight ,填补了孩子提供的可用空间。

扩大的和灵活的部件之间的区别

就像我之前指出的那样,这些小组件的主要区别在于它们的属性。展开的小组件只有childflex 属性,如果误用的话,这可能是一个限制。相比之下,灵活的小组件有更多的属性;这使得使用灵活,因此而得名。

总结

在这篇文章中,我们了解了使用 "扩展 "和 "灵活 "小组件的响应式屏幕布局。我们首先介绍了使用容器创建响应式屏幕布局时必然会出现的潜在问题,然后介绍了解决方案:扩展的和灵活的部件。我们介绍了它们的属性、相似性、差异性,最重要的是,我们还介绍了一个实际操作的例子。

以上就是详解如何在Flutter中用小部件创建响应式布局的详细内容,更多关于Flutter响应式布局的资料请关注Devmax其它相关文章!

详解如何在Flutter中用小部件创建响应式布局的更多相关文章

  1. Flutter中文教程-Cookbook

    Flutter中文网的Cookbook中包含了在编写Flutter应用程序时常见问题及示例。设计基础使用主题共享颜色和字体样式Images显示来自网上的图片用占位符淡入图片使用缓存图Lists创建一个基本list创建一个水平list使用长列表创建不同类型子项的List创建一个gridList处理手势处理点击添加Material触摸水波效果实现滑动关闭导航导航到新页面并返回给新页面传值从新页面返回数据给上一个页面网络从网上获取数据进行认证请求使用WebSockets

  2. android-studio – 未配置Dart SDK

    Initializinggradle…

  3. 安卓 – 从一个扑动的应用程序拨打电话

    或者有更好的选择从我的应用程序拨打电话?

  4. android – 如何在Flutter中添加Webview?

    我知道可以将WebView添加为整页,但找不到任何示例代码.我假设你可以使用PageView作为它的基础,但不知道如何调用本机androidWebView并将其添加到PageView.谁能指出我正确的方向?

  5. android – 如何将消息从Flutter传递给Native?

    如果需要与特定的API/硬件组件进行交互,您如何将Flutter的信息传递回Android/Native代码?是否有任何事件频道可以通过其他方式发送信息或类似于回调?

  6. android – 如何在Flutter App中处理onPause / onResume?

    我是否过于复杂的事情?即使我的用例似乎不需要它,我仍然想知道:如何自己处理onPause/onResume事件?

  7. android – 如何使用Flutter构建Augment Reality应用程序?

    我对Android开发有一些基础知识.最近听说过Flutter并且非常有兴趣研究它.我想知道是否有可能使用颤振构建增强现实应用程序以及要实现此目的的方法?请帮忙.解决方法截至目前,颤振不支持3D.Flutter现在专注于2D,团队长期计划为颤振提供优化的3Dapi.你读了常见问题here.

  8. Flutter 网络请求框架封装详解

    这篇文章主要介绍了Flutter 网络请求框架封装详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  9. VUE响应式原理的实现详解

    这篇文章主要为大家详细介绍了VUE响应式原理的实现,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

  10. Flutter StreamBuilder实现局部刷新实例详解

    这篇文章主要为大家介绍了Flutter StreamBuilder实现局部刷新实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

随机推荐

  1. Flutter 网络请求框架封装详解

    这篇文章主要介绍了Flutter 网络请求框架封装详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. Android单选按钮RadioButton的使用详解

    今天小编就为大家分享一篇关于Android单选按钮RadioButton的使用详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

  3. 解决android studio 打包发现generate signed apk 消失不见问题

    这篇文章主要介绍了解决android studio 打包发现generate signed apk 消失不见问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  4. Android 实现自定义圆形listview功能的实例代码

    这篇文章主要介绍了Android 实现自定义圆形listview功能的实例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  5. 详解Android studio 动态fragment的用法

    这篇文章主要介绍了Android studio 动态fragment的用法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. Android用RecyclerView实现图标拖拽排序以及增删管理

    这篇文章主要介绍了Android用RecyclerView实现图标拖拽排序以及增删管理的方法,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下

  7. Android notifyDataSetChanged() 动态更新ListView案例详解

    这篇文章主要介绍了Android notifyDataSetChanged() 动态更新ListView案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下

  8. Android自定义View实现弹幕效果

    这篇文章主要为大家详细介绍了Android自定义View实现弹幕效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  9. Android自定义View实现跟随手指移动

    这篇文章主要为大家详细介绍了Android自定义View实现跟随手指移动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. Android实现多点触摸操作

    这篇文章主要介绍了Android实现多点触摸操作,实现图片的放大、缩小和旋转等处理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部