2017工作流水账
写在前面
2017年就要过去了,最后一批90后页即将年满18岁了…
在写这篇总结之前,我翻出了去年的年终总结…看了看去年的自己对2017年做的计划,似乎又有很多都没有完成…一边总结一边尴尬…
2017.01 - 2017.03
我的2017年,有一个既懒散又颓废的开始…1月初,合租的好哥们富鑫被公司hr坑了一波,没有办成上海户口,于是离职去了杭州,在一座陌生的城市重新开始打拼。得知他这个决定以后,我的心情很低落,又一个好兄弟离开了上海,不知道我还能在这个冰冷的城市坚持多久。房子还剩2个月到期,不喜欢独居的我四处寻求合租,然而一时之间并找不到有租房需求的小伙伴。最终我搬到杨浦,蹭住在斌斌哥家里,这一蹭,就蹭到了现在。
这期间,去年的年终奖公司一拖再拖,到最后领导在例会上对“年终奖”这件事绝口不提,然后开始画大饼,表示公司调整了工作的方向,要做一个新的项目。于是一下子多了好多需求…而我在去年底就跟领导提了2月底要去日本旅游…最终跟领导据理力争,在保证了不会拖项目的进度以后,领导批了我四天调休假,凑上一个周末,这趟早就约好了的行程总算得以成行…
作为一个从没有出过国的土鳖,这趟旅行还是挺有意思的,去了很多著名的打卡景点,也认识了很多化妆品的牌子,做了一回不专业的代购哈哈哈。
2017.04 - 2017.09
可能旅行真的能治愈坏心情,从日本回来以后,心情好了很多,这时候公司的新项目也有很多活没干完,就投入到了新项目的开发工作中。然而,这个新项目进行的并不顺利,需求多次变更,后端开发已经迷失在这不停修改的需求文档里,作为一个客户端开发,我只能眼睁睁看着接口联调时间一次次延后…整个项目最终上线时间比预期时间晚了两个星期,而项目上线以后,也没有达到预期的目标,公司领导似乎也因为此事对技术部产生了诸多不满,整个公司弥漫着一股药丸的气息。6月初,我第一次产生了离职的念头。
在猎聘和拉勾更新了一波简历以后,我几乎投遍了上海所有的知名互联网公司,然而大部分都没有回应,头一次深切地感受到了移动互联网的寒冬…我只能暂缓离职的打算,一边准备面试快,一边等待9月份的求职黄金期。到了9月初,公司的项目几乎停滞,每天都流传着公司资金链出问题,工资发不出的留言(事后得知是领导故意安排人散步消息,好让大家主动离职…),公司里的很多同事都无所事事,我深感在这样下去就要废了,只能到处托同学内推面试,总算在9月初拿到了几个offer,几番权衡以后,加入了B站。
2017.10 - 2017.12
刚入职的事后,我被分配到了小视频项目组,一来就碰上了一次UI大改版,十一放假回来以后连着赶了两个礼拜工,勉勉强强完成了改版,结果在灰度包上线以后被查出来一个大bug…尴尬…过了一个月,公司业务调整,小视频不再迭代开发,整个项目组的开发都被划到了直播事业部,于是在兜兜转转一年以后,我又一次投身到了直播业务…
流水账之总结
今年经历了3月份的年终奖跳票,经历了离职最后一个月被坑社保…入职的时候,我站HR听了我的经历也是唏嘘不已…动荡不安的2017年总算要过去了…从9月底到现在,算算来大B站也有3个月了,各方面逐渐稳定了下来,我也开始慢慢接触直播的核心业务,希望2018年能够稳定的提升自己的技术能力,和直播部的大佬们一起把这一块业务做好,尽量不拖运营的后腿。在这个基础上再去研究一下android的底层知识,多写几篇技术博客。(自从搭好了博客以后,一直没有怎么写过…再次尴尬…)
P.S. 每年给自己列了一堆计划,结果各种完不成。今年就不再假惺惺的给自己列计划清单了,希望自己能从小事一点一点做起,等明年年底总结的时候,不要有什么遗憾和后悔就好。
自定义一个简单方便的LoadingLayout
写在前面
android项目中经常需要从网络服务器端获取数据并显示到页面上,由于网络速度不稳定,客户端发起请求而服务端还未返回数据时,页面需要有加载中
状态;如果请求失败,页面又需要显示为网络连接失败
状态;如果这次请求的数据为空,页面还需要显示为暂无数据
;只有服务端返回有效的数据时,页面才会正常显示。
这个需求在平时的开发过程中非常常见,因此我写了一个简单的多状态布局,包含这四种状态,方便在以后的项目中使用。这个loadingLayout的代码我全都上传到github上了,本来想发布到jCenter上,好给大家轻松通过gradle构建,后来又想了下,这个功能很简单,添加gradle依赖太重了,大家可以通过这篇文章自己实现,并配合自己的项目进行修改和扩展。
源码及demo地址:https://github.com/mavsforlife/LoadingLayoutDemo
大家可以去看看给我提意见啊,更欢迎star哈哈哈~~~
好的,啰嗦了一大堆,下面我们来正式开整,快速打造一个简单的loadingLayout。
如何实现
大家应该很容易想到FrameLayout,将loading
error
empty
content
这四种状态下的view放入一个FrameLayout
中,提供方法根据状态来显示某一层view,隐藏其他层。
首先我们新建一个LoadingLayout类继承自FrameLayout,并定义mEmptyView
mErrorView
mLoadingView
三个View对象,定义两个onclickListener用于处理重新加载的逻辑(稍后会说到)。
|
|
初始化
我们在它的构造方法中完成一些初始化的工作
|
|
上面这段代码非常的简单,初始化了这个loadingView以后,在这个viewGroup中依次添加了emptyView
errorView
loadingView
这三个子view。由于LoadingLayout是继承自FrameLayout的,因此这三个子view是叠成3层显示的。
自定义属性
大家看到了我定义了emptyView
,errorView
,loadingView
三个属性,并且设置了默认值,所以我们要先在android app的styles文件中先定义好这三个属性,并且创建empty_view
, error_view
, loading_view
三个默认的xml布局文件。
|
|
- 默认的empty_view文件
|
|
- 默认的error_view文件
|
|
- 默认的loading_view文件
|
|
重写onFinishInflate
方法
当View及其子View从xml文件中加载完成以后,会调用onFinishInflate
方法,我们先将所有子view都隐藏。
|
|
如何显示不同状态的view
接下来就是重点了,我们根据不同的业务场景显示不同的view,其实非常简单,我们将loadingLayout的某一层布局显示出来,隐藏其他子布局就好了。由于我们是按照emptyView
errorView
loadingView
contentView
这样的顺序添加的,因此可以通过view.getChildAt()
方法,显示或隐藏指定布局。
- 显示emptyView(emptyView为getChildAt(0))
|
|
- 显示errorView(errorView为getChildAt(1))
|
|
- 显示loadingView(loadingView为getChildAt(2))
|
|
- 显示contentView(contentView为getChildAt(3))
|
|
设置重试点击事件
在实际项目中,如果页面为空,可能业务上需要我们提供一个按钮点击跳转到首页?
购买页面?
其他指定页面?
;如果因为网络原因加载失败,页面上一般会有一个重新加载按钮
。这就是我在文章的开头说到的两个onclickListener的作用.
我们首先要提供两个set方法来设置onclickListener
|
|
然后再在onFinishInflate
方法中,给按钮的点击事件实现这两个接口。
|
|
一些额外提供的方法
前面的工作做完,基本已经实现了需求,只是有时候我们不方便在xml中定义emptyView,又不想使用自定义的emptyView,所以我又写了一些扩展方法。
在java类中直接设置emptyView/errorView/loadingView。
|
|
修改自定义emptyView/errorView的文字
|
|
自定义emptyView及errorView的注意事项。
我在ids.xml
文件中定义了三个id。
|
|
在自定义errorView中,一定要创建一个button并将id设置为btn_error
,创建一个textView并将id设置为tv_error
;同时在自定义emptyView时,要创建一个textView并将id设置为btn_epmty
,否则会引发nullPointerException,切记切记!
最终效果及使用方法
下图就是在activity中最终的显示效果啦,忽略丑丑的布局,仓促写的。。。
使用方法:首先在activity或fragment的布局文件中插入loadingLayout,loadingLayout中包裹的就是contentView。(只允许包裹一个子 view,因此如果有多个view,需要用ScrollView等ViewGroup再包一层)
|
|
然后在java代码中,通过findViewById方法初始化view,并实现点击重试接口。使用showContent
方法显示contView。
|
|
最后
感谢大家,撒花~~
以及,再次求star啊啊啊啊啊
My first article——记录搭建Hexo博客并发布到gitpage
第一篇文章,就记录一下怎么用hexo搭建博客并发布到gitpage吧…
准备工作
- 安装git
- 安装node
- 注册github账号
正式安装hexo
Node和git都安装好以后,首先创建一个文件夹(例如“blog”),然后进入blog文件夹下,在命令行中执行如下命令安装Hexo。
npm install -g hexo
初始化,执行init命令初始化hexo,命令:
hexo init
好啦,至此,全部安装工作已经完成!blog就是你的博客根目录,所有的操作都在里面进行。
生成静态页面
hexo generate
(hexo g
也可以)
本地启动
启动本地服务,进行文章预览调试,命令:
hexo server
(hero s
也可以)
浏览器输入http://localhost:4000
,就可以在浏览器中预览啦~~~
配置Github
建立Repository
建立与你用户名对应的仓库,仓库名必须为【your_user_name.github.io】,固定写法
然后建立关联,我的blog在本地/Users/blog/hexo,blog是我之前建的东西也全在这里面,有:
_config.yml node_modules public source
db.json package.json scaffolds themes
现在我们需要_config.yml文件,来建立关联,命令:
vi _config.yml
翻到最下面,改成我这样子的
deploy:
type: git
repo: https://github.com/your_user_name/your_user_name.github.io.git
branch: master
然后,执行配置命令:
hexo deploy
就配置成功啦~~~
撒花~~~
在浏览器中输入http://your_user_name.github.io ,就可以访问你的个人博客啦。
如果你在设置的过程中有什么不懂得,可以去hexo.io上查看~~
Hello World
Welcome to Hexo! This is your very first post. Check documentation for more info. If you get any problems when using Hexo, you can find the answer in troubleshooting or you can ask me on GitHub.
Quick Start
Create a new post
|
|
More info: Writing
Run server
|
|
More info: Server
Generate static files
|
|
More info: Generating
Deploy to remote sites
|
|
More info: Deployment