如何添加xib视图以查看控制器swift 3

时间:2018-01-05 23:30:53

标签: ios swift xib

我正在尝试将此XIB视图添加到我的viewcontroller:

import UIKit

class TranslateView: UIView {
    @IBOutlet var TranslateView: UIView!

    override init(frame: CGRect){
        super.init(frame: frame)
        commonInit()
    }

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        commonInit()
    }

    private func commonInit(){
        Bundle.main.loadNibNamed("TranslateView", owner: self, options: nil)
        addSubview(TranslateView)
        TranslateView.frame = self.bounds
        TranslateView.autoresizingMask = [.flexibleHeight, .flexibleWidth]
    }
}

我将它加载到我的视图控制器中:

import UIKit
import AVFoundation
import Vision

class ViewController: UIViewController, AVCaptureVideoDataOutputSampleBufferDelegate {
    let captureSession = AVCaptureSession()

    let button: UIButton = {
        let button = UIButton()

        button.addTarget(self, action: #selector(ViewController.pressed(sender:)),for: .touchUpInside)
        button.backgroundColor = UIColor.clear
        button.setTitle("Translate", for: .normal)
        button.translatesAutoresizingMaskIntoConstraints = false
        return button
    }()

    override func viewDidLoad() {
        super.viewDidLoad()

        setupCaptureSession()
        view.addSubview(button)
    }

    @objc func pressed(sender: UIButton!) {
        //add label
        button.removeFromSuperview()

        let headerView = Bundle.main.loadNibNamed("TranslateView", owner:
            self, options: nil)?.first as? TranslateView
        self.view.addSubview(headerView!)
        headerView?.frame = CGRect(x:0, y: 0, width: view.frame.width, height: 50.0)
    }

我删除了大部分代码以保持此问题的简短。我没有使用故事板,因为我想使用live cameraview作为我的应用程序的背景。通过这种方式这样做是最简单的。我想要发生的是,当我按下按钮时,整个屏幕应该被替换为TranslateView.xib的新视图。

希望有人可以提供帮助。或者,如果有一个更好的简单方法,那么使用XIB来实现相同的结果让我知道。

请在Swift 3中给出一个代码示例,而不只是解释该怎么做,因为我已经知道我需要做什么而不是如何编码。

2 个答案:

答案 0 :(得分:1)

尝试更改此代码

<span class="v-vaadin-version">version: </span>

到此

let headerView = Bundle.main.loadNibNamed("TranslateView", owner:
    self, options: nil)?.first as? TranslateView

答案 1 :(得分:0)

我认为将TranslationView转换为UIViewController会更好。这不会是一个很大的变化,但随后将TranslationView添加到ViewController将会更加简单。例如:

class TranslateView: UIViewController {
    override init(nibName nibNameOrNil: String?, bundle nibBundleOrNil: Bundle?) {
        super.init(nibName: "TranslationView", bundle: nil)
    }
}

然后您可以将此控制器加载到ViewController类中,如下所示:

let headerView = TranslationView()
self.addChildViewController(headerView)
self.view.addSubview(headerView.view)
headerView.didMoveToParentViewController(self)
headerView.view.frame = CGRect(x:0, y: 0, width: view.frame.width, height: 50.0)