README.md 7.7 KB
Newer Older
1

L
LiZhuoyuan 已提交
2
# flutter_screenutil
L
LiZhuoyuan 已提交
3
[![pub package](https://img.shields.io/pub/v/flutter_screenutil.svg)](https://pub.dartlang.org/packages/flutter_screenutil)
L
LiZhuoyuan 已提交
4

李卓原 已提交
5
**A flutter plugin for adapting screen and font size.Let your UI display a reasonable layout on different screen sizes!**
6

L
LiZhuoyuan 已提交
7
[中文文档](https://github.com/OpenFlutter/flutter_screenutil/blob/master/README_CN.md)
李卓原 已提交
8

L
LiZhuoyuan 已提交
9
github: https://github.com/OpenFlutter/flutter_screenutil
10

L
LiZhuoyuan 已提交
11
[Update log](/CHANGELOG.md)
12

readme  
李卓原 已提交
13
## Usage:
14

readme  
李卓原 已提交
15 16
### Add dependency:
Please check the latest version before installation.
17 18 19 20
```
dependencies:
  flutter:
    sdk: flutter
readme  
李卓原 已提交
21
  # add flutter_ScreenUtil
卓原 已提交
22
  flutter_screenutil: ^0.4.2
23 24
```

readme  
李卓原 已提交
25
### Add the following imports to your Dart code:
26 27 28 29
```
import 'package:flutter_screenutil/flutter_screenutil.dart';
```

readme  
李卓原 已提交
30 31
### Initialize the setup size
Please set the width and height of the design draft before use, the width and height of the design draft (unit px).
李卓原 已提交
32
Be sure to set the page in the MaterialApp's home(ie the entry file, just set it once) to ensure that the fit size is set before each use:
33 34

```
readme  
李卓原 已提交
35 36 37
//Set the fit size (fill in the screen size of the device in the design)
//If the design is based on the size of the iPhone6 ​​(iPhone6 ​​750*1334)
ScreenUtil.instance = ScreenUtil(width: 750, height: 1334)..init(context);
38 39
```

readme  
李卓原 已提交
40
### Use:
41

L
LiZhuoyuan 已提交
42 43
#### Adapt screen size:

readme  
李卓原 已提交
44 45
Pass the px size of the design draft:

L
LiZhuoyuan 已提交
46 47 48 49 50 51 52
Adapted to screen width: ScreenUtil().setWidth(540),

Adapted to screen height: ScreenUtil().setHeight(200),

**Note** 

Height is also adapted according to setWidth to ensure no deformation (when you want a square) 
53

L
LiZhuoyuan 已提交
54 55 56
setHeight method is mainly adapted in height, you want to control the height and actuality of a screen on the UIUsed when the same is displayed.

```
readme  
李卓原 已提交
57
//for example:
L
LiZhuoyuan 已提交
58
//rectangle
59 60 61
Container(
           width: ScreenUtil().setWidth(375),
           height: ScreenUtil().setHeight(200),
readme  
李卓原 已提交
62
           ...
63
            ),
L
LiZhuoyuan 已提交
64 65 66 67 68 69 70
            
////If you want to display a square:
Container(
           width: ScreenUtil().setWidth(300),
           height: ScreenUtil().setWidth(300),
            ),
            
71 72
```

L
LiZhuoyuan 已提交
73
#### Adapter font:
李卓原 已提交
74
``` 
75 76
      ScreenUtil().setSp(28)         //Incoming font size,the unit is pixel, fonts will not scale to respect Text Size accessibility settings
      ScreenUtil().setSp(28,true)  //Incoming font size,the unit is pixel,fonts will scale to respect Text Size accessibility settings
李卓原 已提交
77 78 79 80 81 82 83 84 85 86 87 88

for example:
        Text(
             'My font size is 28px and will not change with the system.',
                 style: TextStyle(
                   color: Colors.black,
                   fontSize: ScreenUtil().setSp(28, false) 
                 )
             ),

```

L
LiZhuoyuan 已提交
89
#### Other related apis:
90
```
readme  
李卓原 已提交
91 92 93 94 95
    ScreenUtil.pixelRatio       //Device pixel density
    ScreenUtil.screenWidth      //Device width
    ScreenUtil.screenHeight     //Device height
    ScreenUtil.bottomBarHeight  //Bottom safe zone distance, suitable for buttons with full screen
    ScreenUtil.statusBarHeight  //Status bar height , Notch will be higher Unit px
李卓原 已提交
96
    ScreenUtil.textScaleFactory //System font scaling factor
97

李卓原 已提交
98 99
    ScreenUtil().scaleWidth //Ratio of actual width dp to design draft px
    ScreenUtil().scaleHeight //Ratio of actual height dp to design draft px
100 101 102 103

```

```
readme  
李卓原 已提交
104
//import
105 106 107 108
import 'package:flutter_screenutil/flutter_screenutil.dart';

...

李卓原 已提交
109
  @override
110
  Widget build(BuildContext context) {
李卓原 已提交
111
    ///Set the fit size (fill in the screen size of the device in the design) If the design is based on the size of the iPhone6 ​​(iPhone6 ​​750*1334)
112
    ScreenUtil.instance = ScreenUtil(width: 750, height: 1334)..init(context);
readme  
李卓原 已提交
113 114
    print('Device width:${ScreenUtil.screenWidth}'); //Device width
    print('Device height:${ScreenUtil.screenHeight}'); //Device height
李卓原 已提交
115 116 117 118 119 120 121
    print(
        'Device pixel density:${ScreenUtil.pixelRatio}'); //Device pixel density
    print(
        'Bottom safe zone distance:${ScreenUtil.bottomBarHeight}'); //Bottom safe zone distance,suitable for buttons with full screen
    print(
        'Status bar height:${ScreenUtil.statusBarHeight}px'); //Status bar height , Notch will be higher Unit px
    print(
李卓原 已提交
122
        'Ratio of actual width dp to design draft px:${ScreenUtil().scaleWidth}'); 
李卓原 已提交
123
    print(
李卓原 已提交
124 125 126 127 128
        'Ratio of actual height dp to design draft px:${ScreenUtil().scaleHeight}'); 
    print(
        'The ratio of font and width to the size of the design:${ScreenUtil().scaleWidth * ScreenUtil.pixelRatio}');
    print(
        'The ratio of  height width to the size of the design:${ScreenUtil().scaleHeight * ScreenUtil.pixelRatio}');
129 130 131 132 133 134
    return new Scaffold(
      appBar: new AppBar(
        title: new Text(widget.title),
      ),
      body: new Center(
        child: Column(
李卓原 已提交
135
          crossAxisAlignment: CrossAxisAlignment.center,
136 137 138 139 140 141 142 143
          children: <Widget>[
            Row(
              children: <Widget>[
                Container(
                  width: ScreenUtil().setWidth(375),
                  height: ScreenUtil().setHeight(200),
                  color: Colors.red,
                  child: Text(
readme  
李卓原 已提交
144
                    'My width:${ScreenUtil().setWidth(375)}dp',
李卓原 已提交
145 146
                    style: TextStyle(
                        color: Colors.white,
李卓原 已提交
147
                        fontSize: ScreenUtil().setSp(12, false)),
148 149 150 151 152 153
                  ),
                ),
                Container(
                  width: ScreenUtil().setWidth(375),
                  height: ScreenUtil().setHeight(200),
                  color: Colors.blue,
readme  
李卓原 已提交
154
                  child: Text('My width:${ScreenUtil().setWidth(375)}dp',
李卓原 已提交
155 156
                      style: TextStyle(
                          color: Colors.white,
李卓原 已提交
157
                          fontSize: ScreenUtil().setSp(12, false))),
158 159 160
                ),
              ],
            ),
李卓原 已提交
161
            Text('Device width:${ScreenUtil.screenWidth}px'),
readme  
李卓原 已提交
162 163 164 165
            Text('Device height:${ScreenUtil.screenHeight}px'),
            Text('Device pixel density:${ScreenUtil.pixelRatio}'),
            Text('Bottom safe zone distance:${ScreenUtil.bottomBarHeight}px'),
            Text('Status bar height:${ScreenUtil.statusBarHeight}px'),
李卓原 已提交
166 167 168 169 170 171 172 173
            Text(
              'Ratio of actual width dp to design draft px:${ScreenUtil().scaleWidth}',
              textAlign: TextAlign.center,
            ),
            Text(
              'Ratio of actual height dp to design draft px:${ScreenUtil().scaleHeight}',
              textAlign: TextAlign.center,
            ),
李卓原 已提交
174
            Text(
李卓原 已提交
175
              'The ratio of font and width to the size of the design:${ScreenUtil().scaleWidth * ScreenUtil.pixelRatio}',
李卓原 已提交
176 177 178
              textAlign: TextAlign.center,
            ),
            Text(
李卓原 已提交
179
              'The ratio of  height width to the size of the design:${ScreenUtil().scaleHeight * ScreenUtil.pixelRatio}',
李卓原 已提交
180 181 182
              textAlign: TextAlign.center,
            ),
            SizedBox(
李卓原 已提交
183
              height: ScreenUtil().setHeight(100),
李卓原 已提交
184
            ),
李卓原 已提交
185
            Text('System font scaling factor:${ScreenUtil.textScaleFactory}'),
李卓原 已提交
186 187 188 189
            Column(
              crossAxisAlignment: CrossAxisAlignment.start,
              children: <Widget>[
                Text(
李卓原 已提交
190
                    'My font size is 14px on the design draft and will not change with the system.',
李卓原 已提交
191
                    style: TextStyle(
李卓原 已提交
192 193 194 195 196
                      color: Colors.black,
                      fontSize: ScreenUtil().setSp(14, false),
                    )),
                Text(
                    'My font size is 14px on the design draft and will change with the system.',
李卓原 已提交
197
                    style: TextStyle(
李卓原 已提交
198 199 200
                      color: Colors.black,
                      fontSize: ScreenUtil().setSp(14),
                    )),
李卓原 已提交
201 202
              ],
            )
203 204 205 206 207 208 209
          ],
        ),
      ),
    );
  }
```

readme  
李卓原 已提交
210
### example:
211

李卓原 已提交
212
[example demo](/example/lib/main_zh.dart)
213
 
readme  
李卓原 已提交
214
effect:
215

李卓原 已提交
216
![效果](demo_en.png)
217