Установите выход элемента в TableCellView в файле .xib для пользовательского подкласса NSTableCellView - PullRequest
0 голосов
/ 28 марта 2019

Я хочу заполнить мой NSTableView контентом. В каждой ячейке таблицы 3 элемента (2 NSTextFields и 1 NSImageView). Для этого я создал пользовательский NSTableCellView, в котором я хочу установить @IBOutlets из 3 элементов, чтобы установить для них значение. Но когда я пытаюсь установить ссылочные выходы, единственный вариант - создать действие.

Когда я пытаюсь написать @IBOutlet weak var personName: NSTextfield и затем установить ссылки, я не могу, потому что "xcode не может найти класс в текущем рабочем пространстве"

Когда я создаю NSTableView внутри main.storyboard, я могу установить ссылки на розетки. Так в чем же различие между .storyboard и .xib?

Когда я пытаюсь соединить @IBOutlet с пунктом «Персона» Troubleshoot

Мой NSViewController (владелец .xib)

class ViewController: NSViewController, NSTableViewDataSource, NSTableViewDelegate {

    @IBOutlet weak var tableView: NSTableView! //ref to tableView in xib
    var persons:[Person] = [] //content to fill tableview

    override func viewDidLoad() {
        super.viewDidLoad()

        persons.append(Person(name: "John", age: 23, piRef: "/Users/xy/Desktop/profilePic.png"))
        persons.append(Person(name: "Marie", age: 26, piRef: "/Users/xy/Desktop/profilePic.png"))


        tableView.delegate = self
        tableView.dataSource = self
    }


    func numberOfRows(in tableView: NSTableView) -> Int {        
        return persons.count        
    }

    func tableView(_ tableView: NSTableView, viewFor tableColumn: NSTableColumn?, row: Int) -> NSView? {

        let tableCellView:personTableCell = tableView.makeView(withIdentifier: NSUserInterfaceItemIdentifier(rawValue: "defaultRow"), owner: self) as! personTableCell
//NSTableColumn in xib has id "defaulRow"

        if let person:Person = persons[row] {

            tableCellView.setPerson(person: person) //call method inside NSTableCellView-subclass to set item values
        }

        return tableCellView        
    }    
}


Пользовательский подкласс NSTableCellView ( "personTableCell" )

class personTableCell: NSTableCellView {

    var person:Person! = nil

    //here should be:
    //@IBOutlet weak var personName: NSTextField!
    //@IBOutlet weak var personAge: NSTextField!
    //@IBOutlet weak var personImg: NSImageView!

    func setPerson(person: Person) {

        self.person = person

        self.personName = person.name
        self.personAge = person.age
        self.personImg = NSImage(byReferencingFile: person.profileImgRef)

    }

}

Я хочу иметь возможность добавлять ссылки на выпуск товаров в мой NSTableCellView-подкласс .

1 Ответ

1 голос
/ 28 марта 2019

Мне кажется, ты делаешь это сложнее, чем нужно.makeView дает вам ссылку на ячейку.Поэтому вы можете получить доступ к его членам напрямую.Нет необходимости в розетках (именно поэтому XCode не сделает их для вас.)

Я не могу прочитать ваши скриншоты достаточно хорошо, чтобы сказать, как определяются текстовые поля (старые глаза), поэтому я могу дать толькоВы можете привести пример из рабочей демонстрации пользовательского класса ячеек:

class DIYTableViewDelegate: NSObject, NSTableViewDelegate {
    var count = 0   // counts the number of views actually created

    func tableView(_ tableView: NSTableView, viewFor tableColumn: NSTableColumn?, row: Int) -> NSView? {
        let id = tableColumn!.identifier
        var view = tableView.makeView(withIdentifier: id, owner: nil) as? CustomTableCellView
        if view == nil {
            view = createCell(id)
            count += 1
        }
        view!.textField!.stringValue = "\(id.rawValue) \(row) \(view!.count) \(count)"
        view!.count += 1

        return view
    }
}

Кроме того, в Swift принято использовать заглавные буквы первых типов (классы, структуры, перечисления, протоколы) и строчные методы и свойства,Не влияет на то, как ваш код компилируется, но помогает другим Swifties его прочитать.

Вот еще один пример, который может помочь:

    func tableView(_ tableView: NSTableView, viewFor tableColumn: NSTableColumn?, row: Int) -> NSView? {

        guard let vw = tableView.makeView(withIdentifier: tableColumn!.identifier, owner: self) as? CustomTableCellView else { return nil }

        vw.textField?.stringValue = String(pictures[row].dropLast(4))
        vw.imageView?.image = NSImage(named: pictures[row])

        return vw
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...