暫無描述

thl 48094537ec up readme 6 年之前
android c4ed87b1c8 first commit 7 年之前
doc 25ad5f2615 up readme 6 年之前
example 25ad5f2615 up readme 6 年之前
ios c4ed87b1c8 first commit 7 年之前
lib c6179c2b66 v0.2.5 6 年之前
.gitignore c920d1102b version 0.0.5 7 年之前
CHANGELOG.md c6179c2b66 v0.2.5 6 年之前
LICENSE 62e02ca145 Initial commit 7 年之前
README.md 48094537ec up readme 6 年之前
analysis_options.yaml a458f68766 v1.0.6 7 年之前
flustars.iml c4ed87b1c8 first commit 7 年之前
flustars_android.iml c4ed87b1c8 first commit 7 年之前
pubspec.yaml c6179c2b66 v0.2.5 6 年之前
uploadMaster c4ed87b1c8 first commit 7 年之前

README.md

flustars(Flutter常用工具类库)

Pub

[flustars] Flutter常用工具类库。主要对第三方库封装,以便于使用。如果你有好的工具类欢迎PR.

关于使用本开源库

如果您是用于公司项目,请随意使用~
如果您是用于开源项目,未经本人许可,请勿copy源码到您的项目使用!

使用方式:

dependencies:
  flustars: ^0.2.5

更新说明

v0.2.5 (2019.03.07)
WidgetUtil 新增获取图片尺寸。
/// get image width height,load error return Rect.zero.(unit px)
/// 获取图片宽高,加载错误情况返回 Rect.zero.(单位 px)
Future getImageWH({Image image, String url, String localUrl, String package});

/// get image width height, load error throw exception.(unit px)
/// 获取图片宽高,加载错误会抛出异常.(单位 px)
Future getImageWHE({Image image, String url, String localUrl, String package});

/// 获取CachedNetworkImage下的图片尺寸
Image image = new Image(image: new CachedNetworkImageProvider("Url"));
Rect rect1 = await WidgetUtil.getImageWH(image: image);  

/// 其他image
Image imageAsset = new Image.asset("");
Image imageFile = new Image.file(File("path"));
Image imageNetwork = new Image.network("url");
Image imageMemory = new Image.memory(null);

/// 获取网络图片尺寸
Rect rect2 = await WidgetUtil.getImageWH(url: "Url");

/// 获取本地图片尺寸 localUrl 需要全路径
Rect rect3 = await WidgetUtil.getImageWH(localUrl: "assets/images/3.0x/ali_connors.png");

/// 其他方式
WidgetUtil.getImageWH(url: "Url").then((Rect rect) {
  print("rect: " + rect.toString();
});

WidgetUtil.getImageWHE(url: "Url").then((Rect rect) {
  print("rect: " + rect.toString();
}).catchError((error) {
  print("rect: " + error.toString();
});

Flutter工具类库 flustars

1、SpUtil : 单例"同步"SharedPreferences工具类。支持get传入默认值,支持存储对象,支持存储对象数组。 2、ScreenUtil : 屏幕适配,获取屏幕宽、高、密度,AppBar高,状态栏高度,屏幕方向.
3、WidgetUtil : 监听Widget渲染状态,获取Widget宽高,在屏幕上的坐标,获取网络/本地图片尺寸.
4、DioUtil : 单例Dio网络工具类(已迁移至此处DioUtil)。

Dart常用工具类库 common_utils

1、TimelineUtil : 时间轴.(新)
2、TimerUtil : 倒计时,定时任务.(新)
3、MoneyUtil : 精确转换,元转分,分转元,支持格式输出.(新)
4、LogUtil : 简单封装打印日志.(新)
5、DateUtil : 日期转换格式化输出.
6、RegexUtil : 正则验证手机号,身份证,邮箱等等.
7、NumUtil : 保留x位小数, 精确加、减、乘、除, 防止精度丢失.
8、ObjectUtil : 判断对象是否为空(String List Map),判断两个List是否相等.

Add dependency

dependencies:
  flustars: x.x.x  #latest version

APIs

  • SpUtil -> Example

    putObject
    getObject
    putObjectList
    getObjectList
    getString
    putString
    getBool
    putBool
    getInt
    putInt
    getDouble
    putDouble
    getStringList
    putStringList
    getDynamic
    haveKey
    getKeys
    remove
    clear
    isInitialized
    
    
    /// example.
    /// 等待Sp初始化完成。
    await SpUtil.getInstance();
    
    /// 同步存取,支持get默认参数。
    SpUtil.putString("username", "sky24");
    String userName = SpUtil.getString("username", defValue: "");
    
    /// save object example.
    /// 存储实体对象示例。
    City city = new City();
    city.name = "成都市";
    SpUtil.putObject("loc_city", city);
    
    Map dataStr = SpUtil.getObject("loc_city");
    City hisCity = dataStr == null ? null : City.fromJson(dataStr);
    print("thll Str: " + (hisCity == null ? "null" : hisCity.toString()));
    
    /// save object list example.
    /// 存储实体对象List示例。
    List<City> list = new List();
    list.add(new City(name: "成都市"));
    list.add(new City(name: "北京市"));
    SpUtil.putObjectList("loc_city_list", list);
    
    List<Map> dataList = SpUtil.getObjectList("loc_city_list");
    List<City> _cityList = dataList?.map((value) {
    return City.fromJson(value);
    })?.toList();
    
    print("thll List: " + (_cityList == null ? "null" : _cityList.toString()));
    
  • ScreenUtil -> Example

    getWidth                  : 返回根据屏幕宽适配后尺寸.
    getHeight                 : 返回根据屏幕高适配后尺寸.
    getWidthPx                : 返回根据屏幕宽适配后尺寸.
    getHeightPx               : 返回根据屏幕高适配后尺寸.
    getSp                     : 返回根据屏幕宽适配后字体尺寸.
    screenWidth               : 获取屏幕宽.
    screenHeight              : 获取屏幕高.
    screenDensity             : 获取屏幕密度.
    appBarHeight              : 获取系统AppBar高度.
    statusBarHeight           : 获取系统状态栏高度.
    getScreenW(ctx)           : 当前屏幕 宽.
    getScreenH(ctx)           : 当前屏幕 高.
    getStatusBarH(ctx)        : 当前状态栏高度.
    getBottomBarH(ctx)        : 当前BottomBar高度.
    getScaleW(ctx,size)       : 返回根据屏幕宽适配后尺寸.
    getScaleH(ctx,size)       : 返回根据屏幕高适配后尺寸.
    getScaleSp(ctx,size)      : 返回根据屏幕宽适配后字体尺寸.  
      
    一、不依赖context
    // 屏幕宽
    double screenWidth = ScreenUtil.getInstance().screenWidth;
    // 屏幕高
    double screenHeight = ScreenUtil.getInstance().screenHeight;
    // 屏幕像素密度
    double screenDensity = ScreenUtil.getInstance().screenDensity;
    // 系统状态栏高度
    double statusBarHeight = ScreenUtil.getInstance().statusBarHeight;
    // BottomBar高度 
    double bottomBarHeight = ScreenUtil.getInstance().bottomBarHeight;
    // 系统AppBar高度
    double appBarHeight = ScreenUtil.getInstance().appBarHeight;
    // 根据屏幕宽适配后尺寸
    double adapterW100 = ScreenUtil.getInstance().getWidth(100);
    // 根据屏幕高适配后尺寸
    double adapterH100 = ScreenUtil.getInstance().getHeight(100);
    // 根据屏幕宽适配后字体尺寸
    double adapterSp100 = ScreenUtil.getInstance().getSp(100);
    // 根据屏幕宽适配后尺寸(输入px)
    double adapterW100px = ScreenUtil.getInstance().getWidthPx(300);
    // 根据屏幕高适配后尺寸(输入px)
    double adapterH100px = ScreenUtil.getInstance().getHeightPx(300);
      
    二、依赖context
    // 屏幕宽
    double screenWidth = ScreenUtil.getScreenW(context);
    // 屏幕高
    double screenHeight = ScreenUtil.getScreenH(context);
    // 屏幕像素密度
    double screenDensity = ScreenUtil.getScreenDensity(context);
    // 系统状态栏高度
    double statusBarHeight = ScreenUtil.getStatusBarH(context);
    // BottomBar高度
    double bottomBarHeight = ScreenUtil.getBottomBarH(context);
    // 根据屏幕宽适配后尺寸
    double adapterW100 = ScreenUtil.getScaleW(context, 100);
    // 根据屏幕高适配后尺寸
    double adapterH100 = ScreenUtil.getScaleH(context, 100);
    // 根据屏幕宽适配后字体尺寸
    double adapterSp100 = ScreenUtil.getScaleSp(context, 100);
    // 屏幕方向
    Orientation orientation = ScreenUtil.getOrientation(context);
    
    
  • WidgetUtil -> Example1Example2

    asyncPrepare              : Widget渲染监听,监听widget宽高变化,callback返回宽高等参数.
    getWidgetBounds           : 获取widget 宽高.
    getWidgetLocalToGlobal    : 获取widget在屏幕上的坐标.
    getImageWH                : 获取图片宽高,加载错误情况返回 Rect.zero.(单位 px). 
    getImageWHE               : 获取图片宽高,加载错误会抛出异常.(单位 px). 
    
    /// widget渲染监听。
    WidgetUtil widgetUtil = new WidgetUtil();
    widgetUtil.asyncPrepare(context, true, (Rect rect) {
    // widget渲染完成。
    });
    
    /// widget宽高。
    Rect rect = WidgetUtil.getWidgetBounds(context);
    
    /// widget在屏幕上的坐标。
    Offset offset = WidgetUtil.getWidgetLocalToGlobal(context);
      
    /// 获取CachedNetworkImage下的图片尺寸
    Image image = new Image(image: new CachedNetworkImageProvider("Url"));
    Rect rect1 = await WidgetUtil.getImageWH(image: image);  
    
    /// 其他image
    Image imageAsset = new Image.asset("");
    Image imageFile = new Image.file(File("path"));
    Image imageNetwork = new Image.network("url");
    Image imageMemory = new Image.memory(null);
    
    /// 获取网络图片尺寸
    Rect rect2 = await WidgetUtil.getImageWH(url: "Url");
    
    /// 获取本地图片尺寸 localUrl 需要全路径
    Rect rect3 = await WidgetUtil.getImageWH(localUrl: "assets/images/3.0x/ali_connors.png");
    
    /// 其他方式
    WidgetUtil.getImageWH(url: "Url").then((Rect rect) {
    print("rect: " + rect.toString();
    });
    
    WidgetUtil.getImageWHE(url: "Url").then((Rect rect) {
    print("rect: " + rect.toString();
    }).catchError((error) {
    print("rect: " + error.toString();
    });
    

DioUtil (dio: ^1.0.13) 详细请求+解析请参考flutter_wanandroid项目。

// 打开debug模式.
DioUtil.openDebug(); 

// 配置网络参数.
Options options = DioUtil.getDefOptions();
options.baseUrl = "http://www.wanandroid.com/";
HttpConfig config = new HttpConfig(options: options);
DioUtil().setConfig(config);
  
// 两种单例请求方式.
DioUtil().request<List>(Method.get, "banner/json");
DioUtil.getInstance().request(Method.get, "banner/json");
  
//示例
LoginReq req = new LoginReq('username', 'password');
DioUtil().request(Method.post, "user/login",data: req.toJson());
  
//示例
FormData formData = new FormData.from({
      "username": "username",
      "password": "password",
    });
DioUtil().requestR(Method.post, "user/login",data: rformData);
  
// 网络请求日志  
I/flutter ( 5922): ----------------Http Log----------------
I/flutter ( 5922): [statusCode]:   200
I/flutter ( 5922): [request   ]:   method: GET  baseUrl: http://www.wanandroid.com/  path: lg/collect/list/0/json
I/flutter ( 5922): [reqdata   ]:   null
I/flutter ( 5922): [response  ]:   {data: {curPage: 1, datas: [], offset: 0, over: true, pageCount: 0, size: 20, total: 0}, errorCode: 0, errorMsg: }

Flutter Demos

  • |--demos
    • |-- city_select_page.dart 城市列表(索引&悬停)示例
    • |-- date_page.dart 日期格式化示例
    • |-- image_size_page.dart 获取网络/本地图片尺寸示例
    • |-- money_page.dart 金额(元转分/分转元)示例
    • |-- pinyin_page.dart 汉字转拼音示例
    • |-- regex_page.dart 正则工具类示例
    • |-- round_portrait_page.dart 圆形圆角头像示例
    • |-- timeline_page.dart 时间轴示例
    • |-- timer_page.dart 倒计时/定时任务示例
    • |-- widget_page.dart 获取Widget尺寸/屏幕坐标示例

点击下载APK : v0.1.x

扫码下载APK :

flutter_wanandroid

Screenshot



关于作者

GitHub : Sky24n
简书     : Sky24n
掘金     : Sky24n
Pub      : Sky24n
Email   : 863764940@qq.com

如果您觉得本项目不错的话,来个star支持下作者吧!