OSX Swift,只需按一下按钮即可绘制一条简单的线条

时间:2017-04-24 22:19:01

标签: macos swift3 drawing nsview drawing2d

已经看了很多但没有找到匹配的东西。 真正的简单我想画一条线买一按按钮。 我有一个来自NSView的类来绘制,它监视一个var,如果它改变了重绘视图。 我可以通过更改值来点击鼠标来调用视图,它绘制得很好。但我不能让按钮工作。它调用绘图方法,但视图没有更新??? 我知道它必须简单,但我找不到它。 提前谢谢。

下面是我的View类和View Controller。

    //
//  LineDrawer.swift
//  TestDraw3
//
//  Created by Colin Wood on 21/04/17.
//  Copyright © 2017 Colin Wood. All rights reserved.
//

import Cocoa



class LineDrawer : NSView {
// Vars
    var newLinear = NSBezierPath()


    public var QQ: Int = 0 {   // every time QQ changes redraw information in QQ
        didSet{
            boom()    // drawing method
        }
    }



// Methods
    override func draw(_ dirtyRect: NSRect) {
        NSColor.red.set()
        newLinear.lineWidth = 5
        newLinear.lineCapStyle = NSLineCapStyle.roundLineCapStyle
        newLinear.stroke()
    }

    func boom(){  // draw a simple line
        Swift.print("In BooM")
        Swift.print(QQ)
        let lastPt = NSPoint(x: QQ, y: 1)
        newLinear.move(to: lastPt)
        let newPt = NSPoint(x: QQ, y: 50)
        newLinear.line(to: newPt)
        needsDisplay = true
    }

     override func mouseDown(with theEvent: NSEvent) {
        QQ = QQ + 7  // just add 7 so you can see it being drawn after didSet 
    }

}


//
//  ViewController.swift
//  TestDraw3
//
//  Created by Colin Wood on 15/04/17.
//  Copyright © 2017 Colin Wood. All rights reserved.
//

import Cocoa

class ViewController: NSViewController {
// Vars
    @IBOutlet weak var textField: NSTextField!

// Methods
    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view.

    }

    override var representedObject: Any? {
        didSet {
        // Update the view, if already loaded.

        }
    }


    @IBAction func button(_ sender: Any) {
        let v = LineDrawer()
        v.QQ = 300  // change QQ to call didSet
    }

}

1 个答案:

答案 0 :(得分:0)

您需要将LineDrawer添加为子视图。添加它的好地方是viewDidLoad方法:

private var line: LinerDrawer!

override func viewDidLoad() {
    super.viewDidLoad()
    line = LinerDrawer()
    line.frame = NSMakeRect(0, 0, 200, 200)
    line.QQ = 300
    line.isHidden = true
    view.addSubview(line)
}

然后在按下按钮时最终显示:

@IBAction func button(_ sender: Any) {
    line.isHidden = false
}

您仍然需要为frame视图制定正确的LineDrawer

相关问题