12/08/2018, 16:55

How to build Custom UI elements with IBDesignable

Nội dung Giới thiệu IBInspectable IBDesignable Kết Luận Giới thiệu Từ Xcode 6 có 2 thuộc tính khai báo của interface builder mới được giới thiệu đó là IBInspectable and IBDesignable. Trong đó IBInspectable thể hiện properties của class trong interface builder Attribute Inspector và ...

Nội dung

  • Giới thiệu
  • IBInspectable
  • IBDesignable
  • Kết Luận

Giới thiệu

Từ Xcode 6 có 2 thuộc tính khai báo của interface builder mới được giới thiệu đó là IBInspectable and IBDesignable. Trong đó IBInspectable thể hiện properties của class trong interface builder Attribute Inspector và IBDesignable cập nhật view realtime. Đó quả thật là một điều tuyệt vời giúp chúng ta thiết kế, chỉnh sửa giao diện ngay trong interface builder.

Nào chúng ta cùng tìm hiểu nhé!

Step 0: IBInspectable

IBInspectable properties cung cấp một cách truy cập mới vào một tính năng cũ : user-defined runtime attributes. Hiện tại truy cập từ identity inspector, những phương thức này đã available trước khi Interface Builder được integrated vào Xcode. Họ cung cấp một cơ chế mạnh mẽ cho việc cấu hình một vài key-value mã hóa property của một instance in a NIB, XIB, or storyboard:

Dưới đây là những valid types cho IBInspectable :

Int
CGFloat
Double
String
Bool
CGPoint
CGSize
CGRect
UIColor
UIImage

Ví dụ:

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
}

Trong Attribute Inspector bạn sẽ nhìn thấy ở phần trên:

Tất cả được thêm vào một vài thuộc tính định nghĩa người dùng runtime được cài đặt giá trị khởi tạo của view khi nó load lên.

IBDesignable

Khi bạn Applied vào một UIView hoặc NSView subclass, @IBDesignable định nghĩa rõ cho Interface Builder biết rằng nó nên render view trực tiếp trên canvas. Điều này cho phép nhìn thấy những gì bạn custom view xuất hiện mà không cần build hoặc run app sau mỗi lần change.

Để đánh dấu một custom view là IBDesignable, thêm vào trước class name với prefix là @IBDesignable.

@IBDesignable
class MyCustomView: UIView {
    ...
}

Kết hợp với IBInspectable properties, người thiết kế hoặc developer có thể dễ dàng chỉnh cái render của custom control để lấy chính xác kết quả họ muốn.

Khi custome view không có đầy đủ nội dung của app khi render trong Interface Builde, bạn có thể cần sinh ra mock data để hiển thị như là: ảnh default user profile hoặc dữ liệu chung thời tiết.

Có 2 cách để thêm code cho context đặc biệt:

  • prepareForInterfaceBuilder(): Method này comply với code của bạn nhưng nó chỉ thực hiện khi chuẩn bị hiển thị trong Interface Builder.

  • TARGET_INTERFACE_BUILDER: The #if TARGET_INTERFACE_BUILDER xử lý macro sẽ làm việc 1 trong 2 là Objective-C or Swift để điều kiện compile đúng code cho tình huống

#if !TARGET_INTERFACE_BUILDER
    // this code will run in the app itself
#else
    // this code will execute only in IB
#endif

Kết Luận

IBDesignable đã giúp cho việc tạo một custome class một cách dễ dàng hơn bằng cách developer có thể dễ dàng thay đổi trong interface builder.

Nguồn:

http://nshipster.com/ibinspectable-ibdesignable/ http://www.thinkandbuild.it/building-custom-ui-element-with-ibdesignable/

0