Ce que j'ai fait: Données dérivées supprimées, xcode redémarré, éditeur -> Refresh all views
J'obtiens Designables
build a échoué dans le storyboard lorsque je clique sur Editeur -> Refresh all views
.
Veuillez vérifier le code suivant. Qu'est-ce que je rate? Textfiled n'est pas mis à jour dans le storyboard lorsque je modifie la valeur @IBInspectable depuis l'inspecteur d'attributs.
import UIKit
import QuartzCore
@IBDesignable
class BorderedFloatingTF: UITextField {
required init?(coder aDecoder:NSCoder) {
super.init(coder:aDecoder)
setup()
}
override init(frame:CGRect) {
super.init(frame:frame)
setup()
}
override func textRect(forBounds bounds: CGRect) -> CGRect {
return bounds.insetBy(dx: 20, dy: 0)
}
override func editingRect(forBounds bounds: CGRect) -> CGRect {
return textRect(forBounds: bounds)
}
override func prepareForInterfaceBuilder() {
super.prepareForInterfaceBuilder()
setup()
}
// properties..
@IBInspectable var enableTitle : Bool = false
@IBInspectable var borderColor: UIColor = UIColor.white {
didSet {
layer.borderColor = borderColor.cgColor
}
}
@IBInspectable var borderWidth: Int = 1 {
didSet {
layer.borderWidth = CGFloat(borderWidth)
}
}
@IBInspectable var placeHolderColor: UIColor = UIColor.white {
didSet {
self.attributedPlaceholder = NSAttributedString(string:self.placeholder != nil ? self.placeholder! : "", attributes:[NSForegroundColorAttributeName: placeHolderColor])
}
}
fileprivate func setup() {
borderStyle = UITextBorderStyle.none
layer.borderWidth = CGFloat(borderWidth)
layer.borderColor = borderColor.cgColor
placeHolderColor = UIColor.white
}
}
Essaye ça
import QuartzCore
@IBDesignable
class BorderedFloatingTF: UITextField {
required init?(coder aDecoder:NSCoder) {
super.init(coder:aDecoder)
setup()
}
override init(frame:CGRect) {
super.init(frame:frame)
setup()
}
override func textRect(forBounds bounds: CGRect) -> CGRect {
return bounds.insetBy(dx: 20, dy: 0)
}
override func editingRect(forBounds bounds: CGRect) -> CGRect {
return textRect(forBounds: bounds)
}
// properties..
@IBInspectable var enableTitle : Bool = false
@IBInspectable var borderColor: UIColor = UIColor.white {
didSet {
layer.borderColor = borderColor.cgColor
}
}
@IBInspectable var borderWidth: Int = 1 {
didSet {
layer.borderWidth = CGFloat(borderWidth)
}
}
@IBInspectable var placeHolderColor: UIColor = UIColor.white {
didSet {
self.attributedPlaceholder = NSAttributedString(string:self.placeholder != nil ? self.placeholder! : "", attributes:[NSForegroundColorAttributeName: placeHolderColor])
}
}
func setup() {
borderStyle = UITextBorderStyle.none
layer.borderWidth = CGFloat(borderWidth)
layer.borderColor = borderColor.cgColor
placeHolderColor = UIColor.white
}
}
Votre IBDesignables
& IBInspectables
tous les deux fonctionnent bien.
J'ai eu ce problème avec un chargement de classe personnalisé à partir d'un xib. Nous sommes finalement tombés sur cette solution (il fallait utiliser le bon paquet pour la classe, plutôt que Bundle.main):
@IBDesignable
class DataEntryView: UIView {
@IBOutlet var contentView: DataEntryView!
@IBInspectable var hasError : Bool = false
required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
self.commonInit()
}
override init(frame: CGRect) {
super.init(frame: frame)
self.commonInit()
}
private func commonInit() {
let bundle = Bundle.init(for: type(of: self))
bundle.loadNibNamed("DataEntryView", owner: self, options: nil)
addSubview(contentView)
contentView.translatesAutoresizingMaskIntoConstraints = false
contentView.topAnchor.constraint(equalTo: self.topAnchor, constant: 0).isActive = true
contentView.leftAnchor.constraint(equalTo: self.leftAnchor, constant: 0).isActive = true
contentView.rightAnchor.constraint(equalTo: self.rightAnchor, constant: 0).isActive = true
contentView.bottomAnchor.constraint(equalTo: self.bottomAnchor, constant: 0).isActive = true
}
}
J'ai eu le même problème sur un projet. J'ai suivi les étapes suivantes pour résoudre le problème.
Dans la vue personnalisée IBDesignable, veillez à remplacer les deux méthodes.
required init?(coder aDecoder: NSCoder)
override init(frame: CGRect)
Ajouter ce qui suit à vos chemins de recherche Runpath dans les paramètres de construction
@loader_path/Frameworks
$(CONFIGURATION_BUILD_DIR)
Nettoyez votre projet, supprimez les données dérivées.
Cela devrait aller.
Dans mon projet, il me manquait pour définir sa valeur Type. Votre problème n'est pas à ce sujet. Mais pour les autres personnes qui ont le même problème avec moi, je voulais expliquer.
Exemple: J'écrivais comme ci-dessous:
@IBInspectable public var rowOrColoumnCount = 0
Mais cela aurait dû être comme:
@IBInspectable public var rowOrColoumnCount : Int = 0
Vérifiez si le module spécifié est correct dans le champ "Module". Il est spécifié "Template1" maintenant, est-ce correct? Essayez également de rendre toutes les propriétés @IBInspectable publiques.
Essayez de ne laisser que cette partie:
@IBDesignable
class BorderedFloatingTF: UITextField {
// properties..
@IBInspectable var enableTitle : Bool = false
@IBInspectable var borderColor: UIColor = UIColor.white {
didSet {
layer.borderColor = borderColor.cgColor
}
}
@IBInspectable var borderWidth: Int = 1 {
didSet {
layer.borderWidth = CGFloat(borderWidth)
}
}
@IBInspectable var placeHolderColor: UIColor = UIColor.white {
didSet {
self.attributedPlaceholder = NSAttributedString(string:self.placeholder != nil ? self.placeholder! : "", attributes:[NSForegroundColorAttributeName: placeHolderColor])
}
}
}