参加Google Compose挑战赛的趣事

688 阅读8分钟

之前参加了Google的 Compose 大赛,发生了不少趣事,分享给大家。

三月底Google发布了Jetpack Compose的beta版,预示着Compose框架趋于稳定亟待正式公开。同时,为了让开发者们尽早上手和测试这个框架,Google搞了个大动作,宣布启动历时4周,每周提交一个Compose作品的设计大赛。

大赛进入第2周的时候,Google官推显示首周全球有近1000位开发者提交了作品。可以感受到开发者们对于Compose的开发热情,第一波气氛看来是“躁”起来了。

在这里插入图片描述 接下来我将回顾参加第1周大赛期间发生的趣事。

缘起

我很早就在Google的官方公众号里收到了大赛的消息。

Android 开发挑战赛: Jetpack Compose 助您起飞!

第1周的设计任务是提交一个 宠物领养 应用,包含宠物列表和宠物详情两个页面即可。看起来开发难度不大,再加上前五百个完成挑战的人便可获得Google和乐高联名的 Jetpack喷气人积木 ,我瞬间就产生了兴趣,下班到家就开干。

在这里插入图片描述

开干

依照规则采用Compose项目模板创建了我的作品LovePet。可能是英文还不够好亦或是急于求成,对于部分参赛规则的描述的没有看明白就开始敲代码了。这也为后面发生的故事买下了伏笔。

Compse大赛项目模板

应用的要求比较简单,涉及到主题,布局和跳转这三块知识。但因为是第一次使用Compose这种声明式的UI框架,学习是免不了的,Google友好的开发文档着实帮上了忙。

主题指导

布局指导

导航指导

一番探索下来应用的基本思路就定下来了。

  • LazyColumn实现列表
  • Row实现列表item
  • Navigation实现画面跳转
  • Card实现详情页面

料想到简单的开发需求必将导致提交的设计大同小异。所以在基本要求以外加了些自己的设计想法。

  • 找了可爱的小狗的图标精心设计了应用的logo
  • 将列表item错位布局,而不都是顶格排布,显得有层次感
  • 在详情card里添加like图标和adopt的按钮,以完善UI交互
  • 整体采用亮黄色填充背景,紫绀色展示内容的风格

上一下最终效果。

在这里插入图片描述 感兴趣的朋友可以参考和star。

github.com/ellisonchan…

提交

代码提交之后Github上的check徽章始终显示failing,这时候我才意识到什么地方有问题,转而逐字逐句地查看模板上的详细说明。

其中这条说明,我在第一次看到的时候就没能完全理解并未重视,看来大概率是这个地方不合规范。

在这里插入图片描述 查阅了Workflow的资料之后终于明白,Github项目支持设置Workflow,每次代码变动后将自动执行预设的Workflow,项目的Actions视图也可查看其执行的日志方便回溯。

Compose的项目模板预设的Workflow则是Spotless检查和编译测试。

github.com/android/and…

Spotless工具可以检查和调整代码的格式,像通配符*的粗暴import是不被允许的。执行了格式检查后check workflow便可以通过了,项目的徽章如愿显示了passing

在这里插入图片描述 对于Spotless这类工具是否有存在的必要难以做出公允的评价。一方面它确实高效;另一方面自动调整格式甚至可能改变代码顺序则会留下隐患。尤其对于大型项目,未知地方的代码被改动是件很恐怖的事情,因为谁也无法保证代码的逻辑和布局的结构不受其影响。

所以面对demo级程序或不熟悉的语言,可以采用这类工具协助学习和适应代码规范。而对于熟知的语言或成熟的项目,最好在编码阶段就按语法规范去coding。

插曲

workflow passing之后,我以为万事大吉,便把这事给忘了。两天后(距离第1场大赛截止还有不到两天)我在网上搜索Croutines资料的时候,无意看到了有篇在讲Compose大赛的文章。

本想着大赛我都搞定了还看个啥,但技术人严重的好奇心和良好的学习态度还是促使我点了进去。(2分钟后我将会无比佩服这个决定,相反如果没有点进去的话事后我也将无比后悔。)

这篇文章非常详尽地阐述了大赛的各项细节,尤其提到了我当时因为科学上网的小麻烦而忽略的一个重要规则:将应用的截图发推,并提交项目地址和推文链接。

文章链接:Jetpack Compose迎来Beta版!!快来参加Android开发挑战赛!!

我好不容易代码写好了最后没提交,等于Google人家压根不知道你参赛了,岂不太冤。。。但说实在的必须要吐槽一下,Google记载这次比赛规则的地方不是很统一,公众号,github和官网分别记载了部分规则,我相信并不只有我一个人忽略了某个规则。

火急火燎地发完推文提交好信息后已是凌晨一点了。那会已处于大赛的后半段,想要闯进前五百明显有点悬了,毕竟这是在和全球开发者PK。

就在犯嘀咕的时候我无意中瞥见了文章作者的ID,有点眼熟。仔细一回想,和我以前组长的微信ID好像是一样的。他的ID是一个英文单词,不认识,有点像Coldplay乐队的名曲viva la vida的歌名,但又不完全一样,所以印象较深。

经过求证得知那果然是他的博客,真得很巧,时隔多年又以这种方式指引了我。 我翻阅了他的其他文章,意外发现早前就已经看过他好几篇文章却没能认出来,哈哈。

我在此隆重推荐他的博客,内容新颖、诚意满满,别的领域不说在android领域那是真的能够帮到你

fundroid掘金Blog

收获

参赛的过程就那么几天,编码的时间也不长,但Compose框架的优势让我印象深刻。

  • 简洁的代码
  • 便捷的视图预览等AS功能的支持
  • 专注于界面的声明式UI编程方式
  • 构建高性能的原生界面
  • 与Material design和Jetpack框架的完美搭配

每个android开发者都需要尽早了解并使用下这个框架,日后它将是你无法回避的重要技术。

感触

应用的推文发布几天后突然收到一个老外的点赞。

在这里插入图片描述 他的个人描述略长,但我注意到了几个关键字:engineer,google,compose。一细看给发现来头不小,原来是Google公司Compose框架的先驱者,能够收到他的点赞我倍感荣幸。

点进他的主页我意外发现了Compose框架背后的故事。早在2017年他便开始提议并着手Compose的开发工作,耗时四年时至近期才熬到beta版的发布。

在这里插入图片描述 我不禁地佩服Google这类大公司,为了一项新技术所愿意付出的时间,努力,财力和决心。

也由衷地为这位工程师感到开心。毕竟看到自己耗费四年心血从零开始设计的框架,能够在全球开枝散叶,诞生出成千上万个有趣app,这是一种怎样的感受,怎样的一种成就。

结语

有人可能会说你参赛拢共写了几百行代码,搞了这么多幺蛾子。(捂脸)确实,事挺多。但我始终觉得这段经历很有意思,就唠叨了这么多。也打心底里跟大家分享几句,建议也好,鸡汤也罢。

  • 遇到新事物勇敢地迈出第一步。很多担心会在尝试中迎刃而解,很多自认做不到的事情竟水道渠成

  • 如果你真的想做成一件事情,那就尽最大努力研究透这件事情相关的所有细节。不要因为一些小困难小麻烦就想着回避想着无视,后面真的会暴雷,间隔或长或久

  • 塞温失马焉知非福。若不是走错了路哪能发生后面的故事

  • (画风突变,这条是实用经验~)如果你在注册或登录推特的时候收不到验证码,试着将语言改为英文,之后就神奇地收到了。。。原因耐人寻味,改天可以在quora上向推特提问。

LovePet app有很多功能可以扩展,后面将继续使用Compose框架来增加新的界面和功能。相应的Compose开发实战也将一并出炉,尽请期待。