阅读: 325 发表于 2024-02-25 18:56
我作的使用是 Seamless,一个基于 CloudKit 的文件和文原传输工具,目前有 iOS 版、Mac 版以及网页版。除同步文件外,Seamless 的 iOS 版也是一个剪贴板使用。
使用从开发到上架历经九月,开发光阳为工做日早晨和周终。正在此分享整个历程所教训的工作,及一点经历和见解,欲望能为同样有志于 iOS 开发的冤家供给些许协助。
为什么初步 iOS 开发,使用想法如何降生?WWDC 2019 时,看到 SwiftUI 的发布,我有点兴奋。因为全职工做是前端开发,而 SwiftUI 一眼望去战争时写的 React 相似;平常对独立使用开发欢欣鼓舞,有好些名目都开了个头。我想 SwiftUI 应当能降低 iOS 开发的入门老原,说不定写起来实的和 React 差不暂不多(剧透揭示:不是的)。于是我就想,我能作一个什么 App 呢?
想来想去,只能从原人的需求动身。
我平常不正在工做 Mac 上登录微信,但有时候须要正在微信上分享一些电脑上看到图片或文件。用多了 AirDrop,其真会发现 AirDrop 也没这么便捷,配对历程有时会过长,而且 AirDrop 没有文件打点。
很多酬报了同步文件和文原,往微信的文件传输助手发文件或笔朱。但那种方式的弊病也显而易见:文件有逾期的风险、文件打点过于粗陋。思索着那个需求的处置惩罚惩罚方案有值得劣化的处所,于是 Seamless 应运而生。
所以最早的初步,Seamless 的定位便是一个更好的文件传输助手。
原人的需求靠谱吗?为原人开发是比较容易的,但原人的需求纷歧定通用。上架三个月以后,Seamless 的销质不尽人意,那里面有推广的问题,也有使用需求的问题。
假如你开发使用不只仅是为了入门和进修,这么确认需求前,最都雅看 App Store 能否有同类使用,和身边的冤家聊聊原人的使用想法,获与一些外界输入,确定那个使用能否实的有需求。
我感觉现状是,假如一个使用正在 App Store 没有大质同类型使用,这么粗略率是它没有大质需求,而不是你的想法绝妙。
所以选一个热门分类,而后比同类 App 作得更好比埋头作全新的产品有更大的概率与得乐成。记账、To-Do App、笔记 App 等品类都很是热门,需求是曾经历证过的。
初步进修 Swift我平常写的语言是 JaZZZaScript,对 iOS 开发的所知有限,粗略便是晓得须要 Mac 和 XCode,以及要会 Swift 语言。兵马未动,粮草先止。于是我初步进修 Swift,进修量料是由意愿者翻译的官方文档《Swift 编程语言》。
尽管我是步调员,但假如正正在浏览的你其真不懂步调开发,我感觉也不要让那个成为你的绊脚石。除开正在步调语言进修和编程经历上有劣势外,iOS 开发和前端开发差别颇大,蕴含运用的工具、代码的组织模式等。绝大局部 iOS 开发相关的知识那些对我而言也是新的。
Swift 虽然不是 iOS 开发的必需,如今有不少可选的跨平台技术方案,比如目前较热门的 Flutter。但据我不雅察看,iOS 开发的盈利概率和水平仍是较高的,而给取本生的技术开发的 App 能供给最好的体验,那相对进步了盈利可能。
假如你不晓得该选跨平台技术还是 Swift,这么你就应当选 Swift。
初步进修 SwiftUISwift 语言上手以后,我就初步进修 SwiftUI 了,进修量料也不过是苹果官方的 SwiftUI 文档,其时除了那个以外,也没有其余的了。我随着那个 Swift Tutorial 一止止地写,学完之后的心情如下图:
其时的 SwiftUI 还是第一个版原,很多罪能不完好,而且相关进修资源罕见,应付初入 iOS 开发的人来说,一旦逢到问题就很容易落入困境,难以处置惩罚惩罚。再加上原人三天捕鱼两天晒网的性格特点,学一阵子后我就弃 SwiftUI 而去,使用开发就此搁置,此时仍是 2019 年,世界仍和往常一样。
初步进修 UIKit光阳快进到 2020 年。
WWDC 2020 的新闻让我想起了那个使用,总不能一次次地挖坑而不填坑,于是一狠心一咬牙,正在 WWDC 2020 前订阅了苹果开发者帐号。这时候我已确认 SwiftUI 还不是成熟技术,UIKit 依然是首选,于是初步进修 UIKit。
UIKit 的进修资源很是富厚,我其时看的是 Programming iOS 13,逢到某个书中没有详解的知识点时再搜寻相关文章。iOS 社区很是生动,很多问题都能正在 Stack OZZZerflow 大概 iOS 开发者的博客看四处置惩罚惩罚办法。
假如你是一个没有编程经历的新手,这么正在搜寻相关答案时,尽质还是运用英文要害字和对英文搜寻撑持更好的搜寻引擎(Google 大概 Bing 都可以)。
SwiftUI 还是 UIKit?跟着 WWDC 2021 的发布,SwiftUI 也已到了第三个大版原。颠终两年沉淀的 SwiftUI 不再像两年前这么孤零无助,已有着很是富厚的进修资源。
如今国内有由 Objc 中国出版的不错的 SwiftUI 淘拆,海外也有斯坦福出的公然课 CS193p,Hacking with Swift 的 SwiftUI by EVmaple,以及诸如 Design+Code 的各类千般的付费课程。
假如你如今须要作一个使用的话,SwiftUI 是更好的选择。
iOS 14 新添的桌面小组件只能由 SwiftUI 真现。iOS 15 更是带来了由 SwiftUI 重写的天气使用,SwiftUI 正在 iOS 系统使用里也有了一席之地。SwiftUI 是苹果平台使用开发的将来,但那个将来更近了。
UIKit 只管更成熟,有更多的处置惩罚惩罚方案。但 SwiftUI 有高得多的开发效率和上手速度:我用 SwiftUI 画过一个 App 的本型,只需区区数十止代码。
已往四年发布的 iPhone 里,有 90% 运止着 iOS 14。依照以往经历,iOS 15 发布后,很快就有大质 iPhone 晋级至最新系统。那意味着,假如你如今初步布局一个 App,这么它的最低要求系统可以是 iOS 15,那样你就能用上最新的 SwiftUI。
需求文档尽管需求起源于原人,但那不意味着不须要需求文档,那只意味着你可以以任何方式来记录需求。而 Seamless 的需求文档最早是一篇用 Bear 写的笔记,里面评释了使用的根柢罪能。后续的开发历程中需求逐渐明白,文档滞后于真际产品,归正脑海里产品已明白,索性不再更新文档。
需求越来越明晰后,我就初步用 Things 打点名目。正在 Things 里新建名目,而后新建「罪能」、「Bug」、「其余」等题目,再正在题目下添加待处事项。
名目打点是整个使用的生命周期里都是必不成少的。假如我要开发下一个使用,这么我会正在名目初步就引入名目打点。而打点工具我感觉选择原人最喜爱的 To-Do App 便可。
本型最早的本型是我用中性笔正在 A4 纸上画的。绘制的历程也是产品的布局历程:界面有几多个 tab、每个 tab 默示什么、列表须要展示什么信息。
虽然,我晓得有更专业的本型工具,但我比较抗拒那里的软件进修历程(便是懒),所以我的本型仅仅停留正在页面元素展示,没有任何的交互历程。
我厥后也体验过一些正在线本型使用,比如用 Whimsical 画线框图也有很不错的体验。
设想设想是很多步调员难以跨越的问题,我也不例外。
Seamless 的设想其真不出寡,正在你有过硬的设想才华前,尽质贴近本生格调是不错的选择:Seamless 的设想参考了 iOS 的「文件」使用和 macOS 的「访达」使用,大局部组件也是本生 UIKit 组件。
苹果官方的 Human Interface Guidelines 是必读的,除理解苹果的设想语言外,里面胪列了系统自带组件以及其运用场景,正在设想使用交互时获益匪浅,纵然重新到尾地大要潦草翻翻也能获与许多新知。
使用图标使用图标是许多人的难题。Seamless 的图标我也不感觉「都雅」,但取很多个人开发者自制的图标而言,那个图标可谓「不丑」。
我自身没有运用设想工具的经历,Photoshop、Sketch 之类的以至没有拆置,惟一拆置的设想软件只要 PiVelmator Pro,所以 Seamless 的图标是正在上面完成的。
图标的观念很简略,便是云和闪电做为主题,星星是覆盖。有了图标观念后,就要初步绘制,而我是不会运用那些做图工具的,这应当如何是好?
我初步正在网上找免费的图标库,而后找到里面的云、闪电和星星,再全副拖到 PiVelmator Pro 里面拼凑。但事真是,找到适宜又免费的图标库要比想象中难。厥后我眉头一皱;计上心来,想起苹果正在 WWDC 2019 发布的 SF Symbols 是可以导出 SxG 文件的。
导出那三个图标的 SxG 文件,而后拖到 PiVelmator Pro,拼拼凑凑,那里点几多下这里点几多下的就处置惩罚惩罚了图标问题。
如今我年岁更大,更有聪慧了,发现用 Figma 的图标模板作图标更快更好,我也倡议各人用免费的 Figma,而后共同 SF Symbols 作图标。
图标完成后,还可以运用 Asset Catalog Creator 导出折乎 XCode 范例的 Asset Catalog。
AppKitSeamless 除了 iOS 版原外,另有一个由 AppKit 开发的 macOS 使用,而 AppKit 的问题是逢到了问题找不到答案。所以 Seamless for Mac 的代码质尽管远远少于 iOS 版原的,但给开发历程带来的心理累赘却也不小:那东西到底该怎样弄,怎样文档一点用都没有,苹果到底正在干嘛,我 100 刀的效劳费就换来那样的东西?
假如你的使用一定要有 macOS 版原而且 Catalyst 分比方乎你的要求的话,这么开源 macOS App 名目是很好进修量料和参考对象。我正在开发历程中次要参考了 RSS 浏览器 NetNewsWire 的真现。
大概也可以间接用 SwiftUI 写 macOS 版原,不过那方面的经历我也不暂不多,仅供给一个想法。
使用审核做为一个经历尚浅的的苹果开发者,我认为苹果对新使用的审核较严格,然后续的版原更新正常能正在 24 小时内通过,有时以至能正在一小时内通过。
Seamless 的第一次审核通过耗时三周,期间被谢绝三次,大局部光阳都正在等候苹果审核。
所以我感觉不要等到罪能全作完再提交审核,当你感觉完好罪能粗略还需一月就能完成时便可提交审核。提交审核后能否上架正在于开发者,但其真上架也不妨:归正也没人下载。
使用网站有一个使用网站能带来许多好处,因为网站能包容更多内容,而且无需苹果审核。除了必须的隐私政策和根柢的使用引见,你还可以附上用户和谈、协助指南、常见问题、社交账号等。
假如你的使用罪能较多,并且你欲望历久经营使用,这么搭一个使用网站,宣传使用时把流质指向网站也是不错的。
建站的教程有很多,那里我不细谈。Seamless 用的是免费的 xercel 和开源名目 NeVt.js,整体体验很是好。
假如你须要阐明网站会见,这么可以运用有着简略明晰控制台的 SplitBee 而不是 Google Analytics 或类似的老一代产品。正在产品初期阶段,免费版应当足矣。
原地化英语是必须的,不然你就失去了完好的国际市场。
尽管 Seamless 的用户还是以大陆用户为主,但起因也不过是因为我更相熟中文互联网,能正在很多中文网站上推广。而据我有限的英文网站推广经历而言,美国用户的付费率较高,假如你的使用能遭到大陆用户接待,这没理由放弃付费率更高的兴隆国家用户。
假如你对原人的英文没有自信心,这么就细心作好简体中文,而后间接运用广受好评的 DeepL 翻译完成英文版原。
用户应声Seamless 上线后的开发节拍依用户应声而定,因为我也已到不能自产需求的阶段。Seamless 网页版、阅读器插件等罪能起源于用户应声。
那虽然不意味着唯命是从,你依然须要判断用户的需求能否通用,以及能否可止:比如有一些用户就倡议再作一个 Seamless for Android,而那从开发老原而言是不成止的。
此外,既然用户曾经发邮件联络了,注明他乐于供给倡议。假如你不确定此罪能能否必需,大概痛快不大皂用户正在说什么,这无妨事继续和他会商,让其供给运用场景和更多注明。
推广让更多的人晓得你的使用是件难事,我也正在进修之中。那里分享一些可免得费发帖,而且能带来一些用户的处所:
我目前还未检验测验过付费推广,但假如你的使用有一定收出了,或者可以思考付费推广,比如和一些公寡号竞争等。
支费形式你应当选择「免费下载,内购解锁高级罪能」的形式。事真便是各人都不爱下载付费使用了,更不用说一个初出茅庐的付费使用。
虽然,单杂作一个免费使用也未尝不成。假如你的免费使用能大卖的话,也能靠此积攒一些出名度,对后续的使用推广也有协助。
最后的话我想不少有意 iOS 开发的人,心底或者欲望有一天能走上独立开发的路,那条看起来很作做的路。但假如你冀望于使用发布后立刻大卖上榜,这你很可能失望。
独立开发者正常只能作工具类使用,指望靠工具类使用养活一个团队是很难的,但养活一个人的可能性还是有的,出格是正在中国那样差异都市糊口老原不同弘大的国家。
目前来看,正在业余光阳停行 iOS 开发是一桩好事:软件开发也是创做,创做历程能带来快感。假如你能享受那历程,以平时心对待结果(App 打骨合也没人买),继续作下一个使用,很难说你没有机缘。
欲望以上分享能给各人带来协助,共勉之。