如何在iOS 8中使用Swift和Xcode 6制作精美的UI组件

 我来答
约定20125
2015-08-13 · TA获得超过1.5万个赞
知道大有可为答主
回答量:1.1万
采纳率:96%
帮助的人:2932万
展开全部
 苹果在Xcode 6中加入了两个新的Interface Builder(下文用IB简称)属性声明:IBInspectable和IBDesignable。IBInspectable在IB的Attribute Inspector(属性检查器)中查看类的属性,而IBDesignable能实时更新视图,很厉害吧!
  

  IBInspectable
  以下是我发现的适用于IBInspectable的类型:
  
  下面这些数据都对IBInspectable有效:
  Int
  CGFloat
  Double
  String
  Bool
  CGPoint
  CGSize
  CGRect
  UIColor
  UIImage
  
  举个小栗子
  class OverCustomizableView : UIView {
  @IBInspectable var integer: Int = 0
  @IBInspectable var float: CGFloat = 0
  @IBInspectable var double: Double = 0
  @IBInspectable var point: CGPoint = CGPointZero
  @IBInspectable var size: CGSize = CGSizeZero
  @IBInspectable var customFrame: CGRect = CGRectZero
  @IBInspectable var color: UIColor = UIColor.clearColor()
  @IBInspectable var string: String = "We ? Swift"
  @IBInspectable var bool: Bool = false
  }
  
  在属性检查器的上面是这样:

  这一切添加了一些用户定义的运行时属性,这些属性将会在view加载时设置它的初始值。
  
  运行时属性的创建:

  IBDesignable
  来看个好玩的地方。IBDesignable告诉IB它可以加载并渲染视图。这个视图类必须在一个框架里面才能正常工作。不过这种方式也不会太麻烦,我们下面会看到方法。 我认为IB是隐式地将UIView的代码转换成NSView的代码,这样就能动态地加载框架并渲染组件。
  
  创建新工程
  打开Xcode6,创建一个新的“Single Page Application” (单页面应用)并选择Swift作为编程语言。
  
  添加新的Target
  在导航选中工程文件点击“+”按钮添加新的target

  
  选择Framework & Application Library和choose the Cocoa Touch Framework,如图

  
  命名为MyCustomView。Xcode会自动链接MyCustomView.framework到你的工程。
  
  创建自定义视图类
  创建一个新的swift文件,并添加到MyCustomView框架里。
  
  右键单击框架的目录。

  选择Cocoa Touch文件

  给它命名为CustomView,作为UIView的子视图

  CustomView.swift文件里包含:
  import UIKit
  
  class CustomView: UIView {
  
  init(frame: CGRect) {
  super.init(frame: frame)
  // Initialization code
  }
  
  /*
  // Only override drawRect: if you perform custom drawing.
  // An empty implementation adversely affects performance during animation.
  override func drawRect(rect: CGRect)
  {
  // Drawing code
  }
  */
  
  }
  
  移除生成的方法。
  import UIKit
  
  class CustomView: UIView {
  
  }
  告诉Xcode用@IBDesignable 关键字来渲染你的视图。
  
  添加三个属性:borderColor: UIColor, borderWidth: CGFloat以及cornerRadius: CGFloat。
  
  设置默认值,并让它们是可检验的:
  @IBDesignable class CustomView : UIView {
  @IBInspectable var borderColor: UIColor = UIColor.clearColor()
  @IBInspectable var borderWidth: CGFloat = 0
  @IBInspectable var cornerRadius: CGFloat = 0
  }
  
  为视图层属性添加逻辑
  为每个属性添加[property observers](观察者属性),并根据layer更新。
  class CustomView : UIView {
  @IBInspectable var borderColor: UIColor = UIColor.clearColor() {
  didSet {
  layer.borderColor = borderColor.CGColor
  }
  }
  
  @IBInspectable var borderWidth: CGFloat = 0 {
  didSet {
  layer.borderWidth = borderWidth
  }
  }
  
  @IBInspectable var cornerRadius: CGFloat = 0 {
  didSet {
  layer.cornerRadius = cornerRadius
  }
  }
  }
  
  按编译框架
  
  测试自定义视图
  打开Main.storyboard,从组件库里添加一个视图。
  
  在Identity Inspector里把视图类改成CustomView。

  调整视图,如果需要可添加自动布局约束。
  
  Tip:按住选中视图并拖动鼠标到另一个视图可以添加自动布局约束。

  
  上手玩了一下`cornerRadius`,我发现当添加一些比较大的值时会创建一个有意思的模式。
转载
usernamevalid
2015-08-12 · TA获得超过4417个赞
知道小有建树答主
回答量:2001
采纳率:71%
帮助的人:762万
展开全部
用心啊,找人来设计
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式