怎么让继承的类直接使用XIB的布局试图

最近做的一个小工具,一键替换key,就是为了解放双手,不然每次运行测试和正式的版本都要手动的替换key。

自从2013年三月进入一家外企之后,就再也没有用过xib.虽然现在苹果已经建议大家用Storyboard但是一些地方还是要用到xib.

自己几乎所有的项目都是用的全代码,但是平时demo和一些小工具还是用上可视化试图和最新语言Swift.

做到是一个mac程序,几个界面基本上的功能按钮都是一样的。就封装了一个类,用上了xib。但是拖拽一个NSView,继承与我们刚才的自定义试图,运行发现出不来我们XIB界面。

我自己分析了一下原因,虽然我们让XIB的类指向我们自己自定义试图,但是关联不起来试图。应该没有加载,我最初想到的解决在

override init(frame frameRect: NSRect)
required init?(coder: NSCoder) 

这两个方法里面读取Nib里面的试图获取到设置为自定义试图的大小。

最后对于Xib这一块不是很熟悉就没走通,后来经过搜索,解决了我的问题。大体上解决方法和我想的是一样的。

解决问题的视频地址https://www.youtube.com/watch?v=Wx7qk2oOV48

下面是怎么实现的,看不了视频的可以看我的。

新建一个OToolBarView类继承于NSView.

class OToolBarView: NSView {
}

因为Storyboard不允许直接拖拽NSView,允许我们拖拽NSViewController。但是我们的是自定义试图,用不上NSViewController。就新建一个xib来做了。

名字命名为OToolBarView.xib我们在xib里面关联刚才创建的类。

我们设置里面的View关联为OToolBarView的一个属性

@IBOutlet var view: OToolBarView!

新增一个方法来加载自定义试图

func loadNibView() {
    Bundle.main.loadNibNamed("OToolBarView", owner: self, topLevelObjects: nil)
    self.view.frame = self.bounds
    self.addSubview(self.view)
}

我有点不理解为什么执行了Bundle.main.loadNibNamed("OToolBarView", owner: self, topLevelObjects: nil)这个方法之前设置的属性View就存在值了,有点不理解。

还有这个类型AutoreleasingUnsafeMutablePointer应该像Object-C的自定义释放的类型。以后研究一下这个类型。

我们在我们必要的的两个初始化方法里面进行调用loadNibView

override init(frame frameRect: NSRect) {
    super.init(frame: frameRect)
    self.loadNibView()
}
required init?(coder: NSCoder) {
    super.init(coder: coder)
    self.loadNibView()
}

我们运行之后就可以显示出来了。