Flutter常用第三方库及使用说明

1、permission_handler:权限处理

static const List<PermissionGroup> values = <PermissionGroup>[

    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组件。



 

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容