我的问题是我有一个自定义UIView,它代表一个弹出窗口。在这个视图中我想要一个滑块,它有一个标签,每次我拖动滑块时都会更新。滑块逻辑工作,至少在我直接在ViewController中使用它时,但不能与我的自定义视图一起使用。具体来说,addTarget中指定的方法根本不会被调用。我也尝试将滑块的backgroundColor设置为某个东西,它实际上显示出来,这意味着它有一个框架。那么,我在这里错过了什么?在自定义UIView子类中,UIButton等有很多次类似的问题。
class PriceVoteController: UIView {
var parentView: UIView = UIView()
let slider: UISlider = {
let slider = UISlider()
slider.isContinuous = true
slider.minimumValue = 1
slider.maximumValue = 3
slider.setMinimumTrackImage(#imageLiteral(resourceName: "minimumSliderTrackImage").resizableImage(withCapInsets: UIEdgeInsets(top: 0, left: 9, bottom: 0, right: 9)), for: .normal)
slider.setMaximumTrackImage(#imageLiteral(resourceName: "maximumSliderTrackImage").resizableImage(withCapInsets: UIEdgeInsets(top: 0, left: 9, bottom: 0, right: 9)), for: .normal)
let sliderThumb = #imageLiteral(resourceName: "sliderThumImage")
slider.setThumbImage(sliderThumb, for: .normal)
slider.addTarget(self, action: #selector(adjustPriceLabel), for: .valueChanged)
slider.setValue(2.0, animated: true)
return slider
}()
let priceLabel: UILabel = {
let label = UILabel()
label.textAlignment = .center
return label
}()
let blackView: UIView = {
let view = UIView()
view.backgroundColor = .black
view.alpha = 0.2
return view
}()
let popUpView: UIView = {
let view = UIView()
view.layer.backgroundColor = UIColor.white.cgColor
view.layer.cornerRadius = 10
return view
}()
@objc fileprivate func adjustPriceLabel() {
print("adjust label")
priceLabel.text = String(format: "%.1f", slider.value)
priceLabelLeftConstraint.constant = getXPositionForSliderValue()
}
fileprivate func getXPositionForSliderValue() -> CGFloat {
guard let currentThumbImage = slider.currentThumbImage else { return 0 }
let sliderRange = slider.frame.size.width - currentThumbImage.size.width;
let sliderOrigin = slider.frame.origin.x + (currentThumbImage.size.width / 2.0);
let sliderValueToPixels = ((CGFloat(slider.value - slider.minimumValue)/CGFloat(slider.maximumValue - slider.minimumValue)) * sliderRange) + sliderOrigin;
return sliderValueToPixels;
}
var priceLabelLeftConstraint: NSLayoutConstraint = NSLayoutConstraint()
override init(frame: CGRect) {
super.init(frame: frame)
self.isUserInteractionEnabled = true
}
fileprivate func setupSlider() {
self.popUpView.addSubview(slider)
slider.anchor(top: self.popUpView.topAnchor, left: self.popUpView.leftAnchor, bottom: nil, right: self.popUpView.rightAnchor, paddingTop: 10, paddingLeft: 50, paddingBottom: 0, paddingRight: 50, width: 0, height: 0)
self.popUpView.addSubview(priceLabel)
priceLabel.text = String(slider.value)
priceLabel.anchor(top: slider.bottomAnchor, left: nil, bottom: nil, right: nil, paddingTop: 10, paddingLeft: 0, paddingBottom: 0, paddingRight: 0, width: 0, height: 0)
priceLabelLeftConstraint = priceLabel.centerXAnchor.constraint(equalTo: self.popUpView.leftAnchor, constant: getXPositionForSliderValue())
priceLabelLeftConstraint.isActive = true
}
func showOn(view: UIView) {
parentView = view
parentView.addSubview(self.popUpView)
self.popUpView.anchor(top: nil, left: nil, bottom: nil, right: nil, paddingTop: 0, paddingLeft: 0, paddingBottom: 0, paddingRight: 0, width: view.frame.width - 100, height: 200)
self.popUpView.centerXAnchor.constraint(equalTo: parentView.centerXAnchor).isActive = true
self.popUpView.centerYAnchor.constraint(equalTo: parentView.centerYAnchor).isActive = true
setupSlider()
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}
我真的希望有人可以帮我解决这个问题,因为我试图在过去几个小时内解决这个问题......并且没有解决方案:/正如我所说,当一切都在ViewController中时,方法会被调用它的观点,但不是自定义的UIView。
顺便说一句,parentView属性是viewController的主视图,其中自定义UIView被初始化。我使用空构造函数初始化它,然后使用ViewController的视图调用show()。
感谢您的帮助! - 罗伯特
答案 0 :(得分:0)
所以,最后我得到了解决方案......对于面临同样问题的每个人:查看您的视图层次结构。我错过了我的popUpView和我的customView之间的链接,这就是触摸事件未被正确触发的原因。另一个错误是popUp从未正确锚定并且没有自己的框架......这就是滑块根本无法操作的原因。 我希望这有助于你们中的一些人!