对比学习UIKit和AppKit -- ViewController
在iOS中ViewController的基类是UIViewController;Mac中ViewController的基类是NSViewController。
Mac中ViewController父类是NSViewController,子类很少,笔者就查到了NSPageController。如果应用中需要,可以Customize。
iOS中有好多个ViewController,在Ref2中有介绍,其父类是UIViewController,子类包括UINavigationController、UITabBarController、UIPageViewController等。也可以Customize。
在应用中如何使用ViewController呢?还有Window、WindowController之间都是什么关系呢? 下面先说说流水账。
1. 在Mac上创建一个Window,我们需要指定这个Window的File‘s Owner,这个File’s Owner需要是一个WindowController的子类;而iOS上不会创建一个Window,也不需要WindowController,因为iOS上的Window非常简单,它不需要title bars, close boxes, or any other visual adornments;
2. 不论在iOS上还是Mac上,如果我们需要在xib文件中创建一个view时,需要指定这个View的File‘s Owner,这个File’s Owner需要是一个ViewController的子类;或者时UIViewController或者时NSViewController;
3. 在Mac上,创建一个view 的xib文件后,会有一个Application的Placeholder对象出现在IB中,如同其所在的category说的一样,它是一个Placeholder,<TBD>;
4.
在Mac上创建一个Window的xib文件后,跟创建view时不一样的地方在于,Window的xib中有一个栏目时Object,和PlaceHolder时并列的,Mac和iOS上创建View的xib文件时就没有,这个源于Window与view的不同。先看Xcode给默认加入的三个对象:Main
Menu、App Delegate和Font
Manager。这个话题需要另开新帖。<TBD>;
5. 在Mac和iOS上开发的不同在于,Mac上偏重Window,View次之,而iOS上可以说时99%是View。比如我们要显示一个Image+一段文字描述,在Mac上通常可以在一个Window上拉进两个View,一个ImageView,一个TextField view,然后由WindowController来处理,当然也可以创建一个customized 的view,这个view包括一个ImageView,一个TextField view,然后配上一个custom view controller;而iOS上搞一个root view,然后像Mac上那样搞也可以,但是如果一个应用的页面多了,管理起来就麻烦了,一个页面显示Image,另外一个页面就是tab view了,难道把之前的全删掉,然后加新的,或者新搞一个window,然后替换当前的window?都不太自然,即使能实现,成本也高了很多。所以最好的方式就是创建一个自定义的view,然后加一个custom viewcontroller。
6. ViewController干了什么,什么情况下需要customize view controller? view controller是UI设计MVC模式中的C,对于iOS上的UIViewcontroller,我写过一篇博文,没深入挖掘什么,就是读了一下Apple的文档,乱写的,概括来说,有这么几个功能:View Management,rotation management等。而Mac上的NSViewController最主要的就是view management。显著的区别就是iOS需要管理view的什么周期,并把若干callback函数暴露出来,让developer来定制在什么时候干什么事,比如在ViewWillAppear中可以设置status bar的方向和样式以使status bar和要显示的view风格一致等等。什么时候需要customized viewcontroller?这个对于Mac和iOS是通用的,如果定制了View,就需要定制的viewcontroller,因为view controller需要管理这个view,对这个view中每个button如何显示,点击后反应是什么,awakeFromnib怎样实现都得提供支持。
7. 问题回到最初,为什么iOS上有那么多UIViewController的子类,而Mac上却少有NSViewController的子类呢?iOS上view的显示空间小,要高效地显示往往总要采取那几种方式,Apple提取了若干种非常常用的view,对其提供了UIViewController的子类帮助开发者直接使用,从而缩短开发时间。而Mac上有足够的空间,开发者可以随便搞,很难抽取共同的模式,即便少,但还是有NSPageController来提供显示多页时使用,如果你的应用中有这种固定模式,你可以提供一个给整个应用来用。