2017-08-17 9 views
1

私はUILabelでスタイルをテーピングすることで自分のカスタムスタイルを設定することができます。私はこのための簡単なコードがあります。iOS @IBDesignableの自動更新UILabelのパラメータ(タイトル、フォント、色)

struct Style { 
    var fontName: String! 
    var fontSize: CGFloat! 
    var color: UIColor! 
    var styleName: String! 
    var font: UIFont { 
     return UIFont(name: self.fontName, size: self.fontSize)! 
    } 

    init(styleName: String, fontName: String!, fontSize: CGFloat!, color: UIColor!) { 
     self.fontName = fontName 
     self.fontSize = fontSize 
     self.color = color 
    } 

    var desc: String { 
     return "Style: \(styleName)" 
    } 
} 



let dictStyle: [String: Style] = [ 
       "normal": Style(styleName: "normal", fontName: "HelveticaNeue-Light", fontSize: 20, color: UIColor.red), 
       "bold": Style(styleName: "bold", fontName: "HelveticaNeue-Bold", fontSize: 30, color: UIColor.black) 
      ] 

@IBDesignable class Label: UILabel { 

    @IBInspectable var style: String = "normal" { 
     didSet { 
      setNeedsDisplay() 
     } 
    } 

    override func prepareForInterfaceBuilder() { 
     super.prepareForInterfaceBuilder() 

     self.text = "\(style)" // there is normal or bold 

     if let color = dictStyle[self.style]?.color { 
      self.textColor = color 
     } 
     if let font = dictStyle[self.style]?.font { 
      self.font = font 
     } 
     if let name = dictStyle[self.style]?.styleName { 
      self.text = name 
     } 
    } 
} 

をし、それが仕事大丈夫だが、私は自動変更タイトル、フォント、Interface Builderでの色(下の赤RECTで)したいと思います。

Interface builder

私は.storyboardファイルで見てきた

<label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Label" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="9lO-cw-I2Z" customClass="Label" customModule="AutoRefresh" customModuleProvider="target"> 
          <rect key="frame" x="24" y="44" width="327" height="24"/> 
          <fontDescription key="fontDescription" name="HelveticaNeue" family="Helvetica Neue" pointSize="32"/> 
          <color key="textColor" red="0.25098040700000002" green="0.50196081400000003" blue="0.0" alpha="0.76206656679999996" colorSpace="calibratedRGB"/> 
          <nil key="highlightedColor"/> 
          <userDefinedRuntimeAttributes> 
           <userDefinedRuntimeAttribute type="string" keyPath="style" value="normal"/> 
          </userDefinedRuntimeAttributes> 
         </label> 

ので、 "テキスト" または "の、textColor" としてそこのフィールドは変更されません。

答えて

0

ここでは、スウィフト4で探しているものです:

@IBDesignable 
class Label: UILabel { 

    override func awakeFromNib() { 
     super.awakeFromNib() 
     config() 
    } 

    override func prepareForInterfaceBuilder() { 
     super.prepareForInterfaceBuilder() 
     config() 
    } 

    func config() { 
     // Setup how you please, e.g. color = UIColor.black 
    } 

} 
関連する問題