一个低成本的 Flutter 屏幕适配解决方案

100% 还原 UI,只需要按照设计图写的宽高写即可

先看图片,设置的标准宽度是 360

iPhone 8 ——————————- iPhone 11

iPhone 12 pro max ——————— ipad air

Android 图

768×1280-320dpi———-10801920-420dpi———-1440×2560-560dpi

Web 图

随着拉长屏幕,慢慢的宽度会大于高度,当大于的时候,会以高度为基准。

使用

引用

flutter_autosize_screen: ^{LAST_VERSION}

初始化

  1. 在 main 方法的第一行就初始化,下面的基准一般以宽度为基准,直接写 Ui 设计图的宽度尺寸,如果是横屏的状态的,下面的 360 就是以高度为基准。

void main() {
  // 设置基准 或者以苹果6,375 为标准, isAutoTextSize 表示文字是否随着系统的字体大小更改而更改,默认是 true
  AutoSizeUtil.setStandard(360,isAutoTextSize: true);

  // 使用 runAutoApp 来代替 runApp
  // import 'package:flutter_autosize_screen/binding.dart';
  runAutoApp(const MyApp());

}
  1. 替换根 MaterialApp 的 MediaQuery

MaterialApp(
      title: 'Autosize Demo',
      /// 替换,这样可以在以后 使用 MediaQuery.of(context) 得到 正确的Size
      builder: AutoSizeUtil.appBuilder,
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: Scaffold(
        body: HomePage(),
      ),
    )
  1. 获取 Size

AutoSizeUtil.getScreenSize()
//或者
MediaQuery.of(context).size
  1. 直接按照设计图的尺寸写即可

Container(
    alignment: Alignment.center,
    height: 60,
    width :60,
    color: Colors.redAccent,
    child: Text(
      "直接按照设计图写尺寸",
    ),
  )
  1. 获取真正的大小,比如 kToolbarHeight 是 56

// 一下方法获取到真正的大小,然后设置到 toolbar上
AutoSizeUtil.getRealSize(kToolbarHeight)
  1. 切记,不能使用 window 获取 size 或者是获取 MediaQuery
    window.physicalSize
    MediaQueryData.fromWindow(window)

下一个目标

因为从根修改了屏幕宽高,会引起一些系统 Widget,有可能比正常的大或者小,比如 toorbar 的高度默认是 kToolbarHeight = 56.0,这样如果把宽度标准设置成 112 的话,那这 kToolbarHeight 就会显得很高,还有 Text(bodyText2)默认的是 14,也会非常大,所以下一个计划是还原一下默认的系统 widget。大家有好的建议也可以提给我。

原理

掘进

感谢

FlutterTest

GitHub

https://github.com/niezhiyang/flutter_autosize_screen