README.md 9.0 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';
```

L
LiZhuoyuan 已提交
30
### Property
李卓原 已提交
31 32 33 34 35 36 37 38
   
|Property|Type|Default Value|Description|
|:---|:---|:---|:---| 
|width|int|1080px|The width of the device in the design draft, in px|
|height|int|1920px|The height of the device in the design draft, in px|
|allowFontScaling|bool|false|Sets whether the font size is scaled according to the system's "font size" assist option|

### Initialize and set the fit size and font size to scale according to the system's "font size" accessibility option
readme  
李卓原 已提交
39
Please set the width and height of the design draft before use, the width and height of the design draft (unit px).
李卓原 已提交
40
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:
41 42

```
李卓原 已提交
43 44 45

//fill in the screen size of the device in the design

李卓原 已提交
46 47 48
//default value : width : 1080px , height:1920px , allowFontScaling:false
ScreenUtil.instance = ScreenUtil()..init(context);

readme  
李卓原 已提交
49 50
//If the design is based on the size of the iPhone6 ​​(iPhone6 ​​750*1334)
ScreenUtil.instance = ScreenUtil(width: 750, height: 1334)..init(context);
李卓原 已提交
51 52 53 54

//If you wang to set the font size is scaled according to the system's "font size" assist option
ScreenUtil.instance = ScreenUtil(width: 750, height: 1334, allowFontScaling: true)..init(context);

55 56
```

readme  
李卓原 已提交
57
### Use:
58

L
LiZhuoyuan 已提交
59 60
#### Adapt screen size:

readme  
李卓原 已提交
61 62
Pass the px size of the design draft:

L
LiZhuoyuan 已提交
63 64 65 66 67 68 69
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) 
70

L
LiZhuoyuan 已提交
71 72 73
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  
李卓原 已提交
74
//for example:
L
LiZhuoyuan 已提交
75
//rectangle
76 77 78
Container(
           width: ScreenUtil().setWidth(375),
           height: ScreenUtil().setHeight(200),
readme  
李卓原 已提交
79
           ...
80
            ),
L
LiZhuoyuan 已提交
81 82 83 84 85 86 87
            
////If you want to display a square:
Container(
           width: ScreenUtil().setWidth(300),
           height: ScreenUtil().setWidth(300),
            ),
            
88 89
```

L
LiZhuoyuan 已提交
90
#### Adapter font:
李卓原 已提交
91
``` 
李卓原 已提交
92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
//Incoming font size,the unit is pixel, fonts will not scale to respect Text Size accessibility settings
//(AllowallowFontScaling when initializing ScreenUtil)
ScreenUtil().setSp(28)    
     
//Incoming font size,the unit is pixel,fonts will scale to respect Text Size accessibility settings
//(If somewhere does not follow the global allowFontScaling setting)
ScreenUtil(allowFontScaling: true).setSp(28)  

//for example:

Column(
              crossAxisAlignment: CrossAxisAlignment.start,
              children: <Widget>[
                Text(
                    'My font size is 24px on the design draft and will not change with the system.',
                    style: TextStyle(
                      color: Colors.black,
                      fontSize: ScreenUtil().setSp(24),
                    )),
                Text(
                    'My font size is 24px on the design draft and will change with the system.',
                    style: TextStyle(
                      color: Colors.black,
                      fontSize: ScreenUtil(allowFontScaling: true).setSp(24),
                    )),
              ],
            )

李卓原 已提交
120 121 122

```

L
LiZhuoyuan 已提交
123
#### Other related apis:
124
```
readme  
李卓原 已提交
125 126 127 128 129
    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
李卓原 已提交
130
    ScreenUtil.textScaleFactory //System font scaling factor
131

李卓原 已提交
132 133
    ScreenUtil().scaleWidth //Ratio of actual width dp to design draft px
    ScreenUtil().scaleHeight //Ratio of actual height dp to design draft px
134 135 136 137

```

```
readme  
李卓原 已提交
138
//import
139 140 141 142
import 'package:flutter_screenutil/flutter_screenutil.dart';

...

李卓原 已提交
143
  @override
144
  Widget build(BuildContext context) {
李卓原 已提交
145
    ///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)
146
    ScreenUtil.instance = ScreenUtil(width: 750, height: 1334)..init(context);
readme  
李卓原 已提交
147 148
    print('Device width:${ScreenUtil.screenWidth}'); //Device width
    print('Device height:${ScreenUtil.screenHeight}'); //Device height
李卓原 已提交
149 150 151 152 153 154 155
    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(
李卓原 已提交
156
        'Ratio of actual width dp to design draft px:${ScreenUtil().scaleWidth}'); 
李卓原 已提交
157
    print(
李卓原 已提交
158 159 160 161 162
        '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}');
163 164 165 166 167 168
    return new Scaffold(
      appBar: new AppBar(
        title: new Text(widget.title),
      ),
      body: new Center(
        child: Column(
李卓原 已提交
169
          crossAxisAlignment: CrossAxisAlignment.center,
170 171 172 173 174 175 176 177
          children: <Widget>[
            Row(
              children: <Widget>[
                Container(
                  width: ScreenUtil().setWidth(375),
                  height: ScreenUtil().setHeight(200),
                  color: Colors.red,
                  child: Text(
readme  
李卓原 已提交
178
                    'My width:${ScreenUtil().setWidth(375)}dp',
李卓原 已提交
179 180
                    style: TextStyle(
                        color: Colors.white,
李卓原 已提交
181
                        fontSize: ScreenUtil().setSp(12, false)),
182 183 184 185 186 187
                  ),
                ),
                Container(
                  width: ScreenUtil().setWidth(375),
                  height: ScreenUtil().setHeight(200),
                  color: Colors.blue,
readme  
李卓原 已提交
188
                  child: Text('My width:${ScreenUtil().setWidth(375)}dp',
李卓原 已提交
189 190
                      style: TextStyle(
                          color: Colors.white,
李卓原 已提交
191
                          fontSize: ScreenUtil().setSp(12, false))),
192 193 194
                ),
              ],
            ),
李卓原 已提交
195
            Text('Device width:${ScreenUtil.screenWidth}px'),
readme  
李卓原 已提交
196 197 198 199
            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'),
李卓原 已提交
200 201 202 203 204 205 206 207
            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,
            ),
李卓原 已提交
208
            Text(
李卓原 已提交
209
              'The ratio of font and width to the size of the design:${ScreenUtil().scaleWidth * ScreenUtil.pixelRatio}',
李卓原 已提交
210 211 212
              textAlign: TextAlign.center,
            ),
            Text(
李卓原 已提交
213
              'The ratio of  height width to the size of the design:${ScreenUtil().scaleHeight * ScreenUtil.pixelRatio}',
李卓原 已提交
214 215 216
              textAlign: TextAlign.center,
            ),
            SizedBox(
李卓原 已提交
217
              height: ScreenUtil().setHeight(100),
李卓原 已提交
218
            ),
李卓原 已提交
219
            Text('System font scaling factor:${ScreenUtil.textScaleFactory}'),
李卓原 已提交
220 221 222 223
            Column(
              crossAxisAlignment: CrossAxisAlignment.start,
              children: <Widget>[
                Text(
李卓原 已提交
224
                    'My font size is 14px on the design draft and will not change with the system.',
李卓原 已提交
225
                    style: TextStyle(
李卓原 已提交
226
                      color: Colors.black,
L
LiZhuoyuan 已提交
227
                      fontSize: ScreenUtil().setSp(14),
李卓原 已提交
228 229 230
                    )),
                Text(
                    'My font size is 14px on the design draft and will change with the system.',
李卓原 已提交
231
                    style: TextStyle(
李卓原 已提交
232
                      color: Colors.black,
李卓原 已提交
233
                      fontSize: ScreenUtil(allowFontScaling: true).setSp(24),
李卓原 已提交
234
                    )),
李卓原 已提交
235 236
              ],
            )
237 238 239 240 241 242 243
          ],
        ),
      ),
    );
  }
```

readme  
李卓原 已提交
244
### example:
245

李卓原 已提交
246
[example demo](/example/lib/main_zh.dart)
247
 
readme  
李卓原 已提交
248
effect:
249

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