1. init project
这是一个系列的文章,用来记录我的相册应用的开发过程,内容可能会比较枯燥,还请读者见谅。
我使用 NextCloud 作为我的存储中心,但是当我备份相册的时候,我感到了莫名的蛋疼,实在是太难用了,不支持相册,不支持标记,不支持各种视图,所以我决定自己写一个新的客户端,只提供相册功能。
技术选型
我用的是 iPhone 12,理所当然我会选择 iOS 客户端开发,在我面前有这么几种方案可以选择:
- object-c
- swift
- swiftui
- flutter
- qml
- react-native
本着三短一长选最长的原则,我计划使用 react-native 作为项目的技术方案。
object-c 已经很老旧了,我只是想业余时间做一个应用满足自己的需求,排除。
swfit 和 swiftui 是苹果目前主推的,特别是 swfitui,用来写界面真的很方便,但是我不想学新的,排除。
flutter 是谷歌在推的一个框架,从我的研发角度来看,flutter 和 qml 没有什么本质区别,都是自己实现了绘制,在此基础上完善控件等高级功能,既然我是一个 Qt 开发者,我肯定不会选择再去学一套类似的技术了,排除。
qml,Qt 目前主推的界面开发框架,采用 JSON like 的方式描述界面,并且可以运行一部分的标准 js 语法,配合 C++ 在 native 端提供本地功能,Qt 自己是一套平台一样的框架,用起来很爽,但是我不想写 qml,排除。
最终就只能用 react native 了,我个人想学一下前端开发,使用相关的技术栈对我来说性价比最高,选择。
为了写 js 而找了这么多借口(
功能设计
确定了技术方案,就需要考虑实现哪些功能了,作为一个相册 App,它最基本的功能肯定是 能启动,嗯,看图。
- 浏览服务器和本地的图片
- 上传和下载图片
- 相册分类
- 标记信息
- 查看文件详情
一开始先不考虑那么多,做一个基本的 TimeLine 样式就可以了。
界面设计
功能也已经确定了,先实现一个 TimeLine 的功能,那么就要确定界面的样式了,我个人比较欣赏 Google Photo 的设计,打算就按像素复制了。
初始化项目
现在可以考虑怎么写代码了,首先初始化一下项目。
npx react-native init photos --template react-native-template-typescript |
初始化一个带有 typescript 的 react native 项目,然后在 vscode 里安装一些 react 和 react native 相关的插件就可以了。
删掉初始化项目的 App.tsx 和相关的文件,新建 src 目录和 App.tsx 文件,开始写新的界面。