UIPickerView的“重用视图"总是零 [英] UIPickerView's "reusing view" always nil

查看:36
本文介绍了UIPickerView的“重用视图"总是零的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

在我的程序中,我在UIPickerView的每一行中都附加了自定义视图.但是重用视图总是无效的.因此,每次创建新的自定义视图对象时.如何使用重用视图"?

In my program I have custom view attached with each row of UIPickerView. But reusing view always comes nil. Hence every time new Custom View Object is creating. How can I use "reusing view"?

func pickerView(_ pickerView: UIPickerView, viewForRow row: Int, forComponent component: Int, reusing view: UIView?) -> UIView {
        if let vv = view {
            return vv    // This will never getting called
        }

        let rowSize = pickerView.rowSize(forComponent: component)
        let pickerContentView = PickerContentView(frame: CGRect(x: 0, y: 0, width: rowSize.width, height: rowSize.height))
        pickerContentView.titleText = (items[Array(items.keys)[component]]! as [String])[row] as String + (component == 0 ? (row == 0 ? " MB" : " GB") : " vCPU")
        return pickerContentView
    }

UIView子类

class PickerContentView: UIView {

    // FIXME: - properties
    var titleText: String? {
        didSet {
            if let titleText = self.titleText {
                title.text = titleText
            }
        }
    }

    // FIXME: - initializer
    override init(frame: CGRect) {
        super.init(frame: frame)

        setupViews()
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    // FIXME: - create views
    private let title: Label = {
        let label = Label()
        label.textAlignment = .center
        label.numberOfLines = 1
        label.font = UIFont.systemFont(ofSize: 17, weight: .regular)
        label.textColor = UIColor(hex: 0x212121, alpha: 1)
        label.fontSize = 17
        label.frameHeight = 44
        label.clipsToBounds = true
        return label
    }()

    // FIXME: - define constraints
    private func setupViews() {
        addSubview(title)

        // x, y, width, height => title
        addConstraints(format: "H:|-8-[v0]-8-|", views: title)
        addConstraints(format: "V:|[v0]|", views: title)

        layoutIfNeeded()
    }
}

推荐答案

尝试一下:

  func pickerView(_ pickerView: UIPickerView, viewForRow row: Int, forComponent component: Int, reusing view: UIView?) -> UIView {
    if let vv = view {
        return vv    // This will never getting called
    }

    let rowSize = pickerView.rowSize(forComponent: component)
    let pickerContentView = PickerContentView(frame: CGRect(x: 0, y: 0, width: rowSize.width, height: rowSize.height))
    pickerContentView.titleText = (items[Array(items.keys)[component]]! as [String])[row] as String + (component == 0 ? (row == 0 ? " MB" : " GB") : " vCPU")
    view?.addSubview(pickerContentView)
    return view!
}

这篇关于UIPickerView的“重用视图"总是零的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆