请求与返回实体类 protocol

class LoginReq {

String username;

String password;

LoginReq(this.username, this.password);

LoginReq.fromJson(Map<String, dynamic> json)
username = json[‘username’],

password = json[‘password’];

Map<String, dynamic> toJson() => {

‘username’: username,

‘password’: password,

};

@override

String toString() {

StringBuffer sb = new StringBuffer(‘{’);

sb.write(““username”:”$username"");

sb.write(“,“password”:$password”);

sb.write(‘}’);

return sb.toString();

}

}

接口请求&解析 repository

class WanRepository {

Future<List> getBanner() async {

BaseResp baseResp = await DioUtil().request(

Method.get, WanAndroidApi.getPath(path: WanAndroidApi.BANNER));

List bannerList;

if (baseResp.code != Constant.STATUS_SUCCESS) {

return new Future.error(baseResp.msg);

}

if (baseResp.data != null) {

bannerList = baseResp.data.map((value) {

return BannerModel.fromJson(value);

}).toList();

}

return bannerList;

}

}

资源文件 resources


  • |–resources
*   |-- colors.dart
*   |-- dimens.dart
*   |-- strings.dart
*   |-- styles.dart

colors.dart

class ColorT {

static const Color app_main = Color(0xFF666666);

static const Color text_dark = Color(0xFF333333);

static const Color text_normal = Color(0xFF666666);

static const Color text_gray = Color(0xFF999999);

}

dimens.dart

class Dimens {

static const double font_sp12 = 12;

static const double font_sp14 = 14;

static const double font_sp16 = 16;

static const double gap_dp5 = 5;

static const double gap_dp10 = 10;

}

strings.dart

class Ids {

static const String titleHome = ‘title_home’;

}

Map<String, Map<String, Map<String, String>>> localizedValues = {

‘en’: {

‘US’: {

Ids.titleHome: ‘Home’,

}

},

‘zh’: {

‘CN’: {

Ids.titleHome: ‘主页’,

},

‘HK’: {

Ids.titleHome: ‘主頁’,

},

‘TW’: {

Ids.titleHome: ‘主頁’,

}

}

};

styles.dart

class TextStyles {

static TextStyle listTitle = TextStyle(

fontSize: Dimens.font_sp16,

color: ColorT.text_dark,

fontWeight: FontWeight.bold,

);

static TextStyle listContent = TextStyle(

fontSize: Dimens.font_sp14,

color: ColorT.text_normal,

);

static TextStyle listExtra = TextStyle(

fontSize: Dimens.font_sp12,

color: ColorT.text_gray,

);

}

Flutter 国际化相关

fluintl 是一个为应用提供国际化的库,可快速集成实现应用多语言。该库封装了一个国际化支持类,通过提供统一方法getString(id)获取字符串。

// 在MyApp initState配置多语言资源

setLocalizedValues(localizedValues); //配置多语言资源

// 在MaterialApp指定localizationsDelegates和supportedLocales

MaterialApp(

home: MyHomePage(),

localizationsDelegates: [

GlobalMaterialLocalizations.delegate,

GlobalWidgetsLocalizations.delegate,

CustomLocalizations.delegate //设置本地化代理

],

supportedLocales: CustomLocalizations.supportedLocales,//设置支持本地化语言集合

);

// 字符串获取

IntlUtil.getString(context, Ids.titleHome);

CustomLocalizations.of(context).getString(StringIds.titleHome);

Flutter 屏幕适配 ScreenUtil

方案一、不依赖context

步骤 1

//如果设计稿尺寸默认配置一致,无需该设置。 配置设计稿尺寸 默认 360.0 / 640.0 / 3.0

setDesignWHD(_designW,_designH,_designD);

步骤 2

// 在MainPageState build 调用MediaQuery.of(context)

class MainPageState extends State {

@override

Widget build(BuildContext context) {

// 在 MainPageState build 调用 MediaQuery.of(context)

MediaQuery.of(context);

return new Scaffold(

appBar: new AppBar(),

);

}

}

步骤 3

ScreenUtil.getInstance().screenWidth

ScreenUtil.getInstance().screenHeight

//屏幕适配相关

ScreenUtil.getInstance().getWidth(size); //返回根据屏幕宽适配后尺寸(单位 dp or pt)

ScreenUtil.getInstance().getHeight(size); //返回根据屏幕高适配后尺寸 (单位 dp or pt)

ScreenUtil.getInstance().getWidthPx(sizePx); //sizePx 单位px

ScreenUtil.getInstance().getHeightPx(sizePx); //sizePx 单位px

ScreenUtil.getInstance().getSp(fontSize); //返回根据屏幕宽适配后字体尺寸

方案二、依赖context

//如果设计稿尺寸默认配置一致,无需该设置。 配置设计稿尺寸 默认 360.0 / 640.0 / 3.0

setDesignWHD(_designW,_designH,_designD);

ScreenUtil.getScreenW(context); //屏幕 宽

ScreenUtil.getScreenH(context); //屏幕 高

//屏幕适配相关

ScreenUtil.getScaleW(context, size); //返回根据屏幕宽适配后尺寸(单位 dp or pt)

ScreenUtil.getScaleH(context, size); //返回根据屏幕高适配后尺寸 (单位 dp or pt)

ScreenUtil.getScaleSp(context, size) ;//返回根据屏幕宽适配后字体尺寸

Flutter 数据存储 SpUtil

SpUtil : 单例"同步" SharedPreferences 工具类。

项目中为大家提供SpHelper,方便存取实体对象类。

// 存储SplashModel实体对象

SplashModel model = new SplashModel();

SpHelper.putObject(Constant.KEY_SPLASH_MODEL, model);

// 获取SplashModel实体对象

SplashModel model = SpHelper.getSplashModel();

class SpHelper {

// 存储Obj,T 用于区分存储类型

static void putObject(String key, Object value) {

switch (T) {

case int:

SpUtil.putInt(key, value);

break;

case double:

SpUtil.putDouble(key, value);

break;

case bool:

SpUtil.putBool(key, value);

break;

case String:

SpUtil.putString(key, value);

break;

case List:

SpUtil.putStringList(key, value);

break;

default:

SpUtil.putString(key, value == null ? “” : json.encode(value));

break;

}

}

static SplashModel getSplashModel() {

String _splashModel = SpUtil.getString(Constant.KEY_SPLASH_MODEL);

if (ObjectUtil.isNotEmpty(_splashModel)) {

Map userMap = json.decode(_splashModel);

return SplashModel.fromJson(userMap);

}

return null;

}

}

Screenshot


主界面

19956127-780fcc4338bdeed4.gif

启动页
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

总结

找工作是个很辛苦的事情,而且一般周期都比较长,有时候既看个人技术,也看运气。第一次找工作,最后的结果虽然不尽如人意,不过收获远比offer大。接下来就是针对自己的不足,好好努力了。

最后为了节约大家的时间,我把我学习所用的资料和面试遇到的问题和答案都整理成了PDF文档

喜欢文章的话请关注、点赞、转发 谢谢!

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

,基本涵盖了95%以上Android开发知识点,真正体系化!**

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

总结

找工作是个很辛苦的事情,而且一般周期都比较长,有时候既看个人技术,也看运气。第一次找工作,最后的结果虽然不尽如人意,不过收获远比offer大。接下来就是针对自己的不足,好好努力了。

最后为了节约大家的时间,我把我学习所用的资料和面试遇到的问题和答案都整理成了PDF文档

喜欢文章的话请关注、点赞、转发 谢谢!

[外链图片转存中…(img-yJ82TCp4-1713362864436)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

Logo

开源鸿蒙跨平台开发社区汇聚开发者与厂商,共建“一次开发,多端部署”的开源生态,致力于降低跨端开发门槛,推动万物智联创新。

更多推荐