Search code examples
swiftnstableviewosx-yosemite

How to change selection color for NSTableView which use NSArrayContoller as content source?


I have an NSTableView (view Based) who show info's from an NSarrayController. All connections are made from IB. Everything works fine, but blue selection color doesn't look ok with my design idea, so I want to change this color with my own color, but until now I failed.

class MyTable: NSTableView, NSTableViewDelegate {
    override func drawBackgroundInClipRect(clipRect: NSRect) {

        if self.isRowSelected( self.selectedRow ){
            //NSColor.brownColor().colorWithAlphaComponent(0.9).setFill()
           // NSBezierPath.fillRect(clipRect)
            println("selected")

        }
    }


}

My real problem is that: I have no idea where should I start, what to subclass, NSTableView , NSTableCellView etc.

Recent I discovered a method to do that which say I should subclass NSTableRowView, and override drawSelectionInRect function. I've did that, but in IB i don't have an NSTableRowView Object.

Thanks.


Solution

  • I did that in this way. First subclass NSTableRowView as you said:

    class MyRowView: NSTableRowView {
    
        override func drawRect(dirtyRect: NSRect) {
            super.drawRect(dirtyRect)
    
            if selected == true {
                NSColor.greenColor().set()
                NSRectFill(dirtyRect)
            }
        }
    }
    

    And then just add this method:

    func tableView(tableView: NSTableView, rowViewForRow row: Int) -> NSTableRowView? {
        let myCustomView = MyRowView()
        return myCustomView
    }
    

    If I remember right, that should do it.

    Edit: I just try my example and it works. In IB i set my tableview's delegate and datasource to ViewController and named my only column to "name." Here is my whole ViewController class:

    class ViewController: NSViewController, NSTableViewDataSource, NSTableViewDelegate {
    
        var persons = [Person]()
    
        override func viewDidLoad() {
            super.viewDidLoad()
    
            // Do any additional setup after loading the view.
            populate()
        }
    
        func populate() {
            var first = Person(name: "John")
            var second = Person(name: "Jesse Pinkman")
    
            persons = [first, second]
        }
    
        func numberOfRowsInTableView(tableView: NSTableView) -> Int {
            return persons.count
        }
    
        func tableView(tableView: NSTableView, viewForTableColumn tableColumn: NSTableColumn?, row: Int) -> NSView? {
            if tableColumn?.identifier == "name" {
                let view = tableView.makeViewWithIdentifier(tableColumn!.identifier!, owner: self) as! NSTableCellView
                view.textField?.stringValue = persons[row].name
                return view
            }
            return nil
        }
    
        func tableView(tableView: NSTableView, rowViewForRow row: Int) -> NSTableRowView? {
            let myCustomView = MyRowView()
            return myCustomView
        }
    
    }