1、permission_handler:权限处理
static const List
calendar,
camera,
contacts,
location,
locationAlways,
locationWhenInUse,
mediaLibrary,
microphone,
phone,
photos,
reminders,
sensors,
sms,
speech,
storage,
ignoreBatteryOptimizations,
notification,
access_media_location,
unknown,
];
例:
Future requestPermission() async {
PermissionUtil.requestLocationPermission();
bool hasLocationPermission =
await PermissionUtil.requestLocationPermission();
if (hasLocationPermission) {
print("定位权限申请通过");
} else {
print("定位权限申请不通过");
}
}
2、webview
webview_flutter
WebView({
Key key,
this.onWebViewCreated, //WebView创建完成之后的回调
this.initialUrl, // 初始化 URL
this.javascriptMode = JavascriptMode.disabled, //JS执行模式,默认是不调用
this.javascriptChannels, // JS可以调用Flutter 的通道
this.navigationDelegate, // 路由委托,可以使用它执行拦截操作
this.gestureRecognizers, // 手势相关
this.onPageStarted, //开始加载页面回调
this.onPageFinished, // 页面加载完成的回调
this.onWebResourceError, //资源加载失败回调
this.debuggingEnabled = false,
this.gestureNavigationEnabled = false,
this.userAgent,
this.initialMediaPlaybackPolicy =
AutoMediaPlaybackPolicy.require_user_action_for_all_media_types,
})
3、dio:网络请求,这块一般都需要自己项目中封装
yhPost(url, {data, options, cancelToken}) async {
Response response;
try {
response = await _yhHttp.post(url,
data: data, options: options, cancelToken: cancelToken);
closeAllDialiog();
} on DioError catch (e) {
if (e.response != null) {
// toastUtil(e.response.statusMessage);
}
showLog('code ${e.response?.statusCode}');
var errorcode = e.response?.statusCode;
switch (errorcode) {
case UNAUTH:
Store.value().logout();
break;
}
showLog('postHttp exception: $e');
closeAllDialiog();
}
return response;
}
4、pull_to_refresh:下拉刷新,上拉加载库,可定制性高
SmartRefresher(
controller: model.refreshController,
onRefresh: model.refresh,
onLoading: model.loadMore,
enablePullUp: true,
enablePullDown: true,
child: ListView.separated(
padding: EdgeInsets.all(Dimens.margin_normal),
separatorBuilder: (context, index) {
return Divider(
height: 10,
color: Colors.transparent,
);
},
itemCount: model.list.length,
itemBuilder: (ctx, index) {
OrderBean data = model.list[index];
return _buildItem(data);
}),
);
6、shared_preferences: ^0.5.3+4 (缓存数据)
SharedPreferences prefs = await SharedPreferences.getInstance();
String counter = "1";
await prefs.setString('counter', counter);
6、path_provider:
用于获取路径,并没有操作文件和目录的功能,因此,需要搭配Director和File等进行操作
7、Provider:状态管理,很有用,多看看,简化了监听回调,实际是内部自动注册监听了
8、flutter_swiper: 多种布局方式,无限轮播,Android和IOS双端适配
9、fl_chart:折线图
10、flutter_picker: 条件选择,时间选择
11、sprintf: 字符串
12、url_launcher:打电话,ulr、超链接等
13、contact_picker: 联系人选择
14、logger:打印
logger.v("Verbose log")
logger.d("Debug log");
logger.i("Info log");
logger.w("Warning log");
logger.e("Error log");
logger.wtf("What a terrible failure log");
1. image_picker
一个可以从图库选择图片,并可以用相机拍摄新照片的flutter插件
2. flutter_image
使用NetworkImageWithRetry 代替Image.network 加载网络图片可获得重试能力。
3. barcode_scan
一个可以扫描二维码和条形码的flutter插件。
4. intl
该插件提供国际化和本地化设施,包括消息翻译,复数和性别,日期/数字格式和解析以及双向文本。
5. sqflite
sqlite插件,同时支持ios和andriod
6. connectivity
这个插件允许Flutter应用程序发现网络连接并相应地进行自我配置。它可以区分蜂窝与WiFi连接。这个插件适用于iOS和Android。
7. cupertino_icons
Cupertino主题图标集
8. location
这个插件能够处理Android和iOS设备的位置。它还提供位置更改时的回调。
9. contact_picker
有了这个插件,Flutter应用程序可以要求其用户从他/她的地址簿中选择一个联系人,并将与联系人相关的信息将返回给应用程序。
10. sensors
通过这个插件我们可以访问加速度计与陀螺仪。
11. convert
该插件包含用于在不同数据表示之间转换的编码器和解码器。它是dart:convert核心库的外部对象,并且包含需要更灵活版本控制的中央API和API。
12.io
dart VM的工具集,可以对文件进行读取与写入。
13.flutter_alipay
可以使用支付宝支付。
14.flutter_amap
高德地图3d flutter组件。
15.amap_location
高德地图定位flutter组件。