以前应objctiew-c 写项目的时候,就知道有这两个关键字,现在用swift了。用法稍作改变,基本用法还是一致的

虽然使用这个之后,有时候会报错的非常的莫名其妙----(其实还是自己技术不够牛……)

先把可能的报错,解决方法链接附上:

http://stackoverflow.com/questions/27374330/ibdesignable-error-ib-designables-failed-to-update-auto-layout-status-interf

http://www.jianshu.com/p/a5351d270ac1

这样咱们就开始啦啦……

先附上demo 的运行效果:::::

这两个视图,都是xib 创建的,绿色的是代码 init frame ,黄色边框的是 init coder……

既然demo 都做出来了,现在开始记录步骤:::::::::::::

显示 demo view 的步骤:

1.newfile 一个 继承于UIView 的class ---- DemoView

2.newfile 一个 xib view 名字改为 ---- DemoView

3.这一步很重要 贴个图给解释 ,这样应该会更直观

顺便贴上  demoview 的代码 和 viewcontroller的调用代码,好了 T T

import UIKit

class DemoView: UIView {

    @IBOutlet var contentView: UIView!

    var borderWidth :CGFloat =  {
didSet{
self.layer.borderWidth = borderWidth
}
} var borderColor :UIColor?{
didSet{
self.layer.borderColor = borderColor?.cgColor
}
} var cornerRadius :CGFloat = {
didSet{
self.layer.cornerRadius = cornerRadius
}
} override init(frame: CGRect) {
super.init(frame: frame)
initialFromXib()
} required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
} func initialFromXib(){ let bundle = Bundle(for: type(of: self))
let nib = UINib(nibName: "DemoView", bundle: bundle)
contentView = nib.instantiate(withOwner: self, options: nil)[] as! UIView
contentView.frame = bounds
addSubview(contentView)
}
}

调用方法的代码::::::

import UIKit

class ViewController: UIViewController {

    override func viewDidLoad() {
super.viewDidLoad() addDemoView()
} override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
} /*
init frame 方式加载xib view
*/
func addDemoView() { let demoview = DemoView.init(frame: CGRect(x:,y:,width:,height:))
self.view.addSubview(demoview) demoview.borderColor = UIColor.green
demoview.borderWidth =
demoview.cornerRadius =
}
}

如果做到这里,那么这个基础的xib view 就已经可以使用了,

当然,现在还没有进入这个博客的主题,现在公布,可在storyboard 实时更新的xib view(这个xib view 必须继承UIView)

xib view 的实现步骤::::

1.newfile 一个 继承于UIView 的class ----XibView

2.newfile 一个 xib view 名字改为 ---- XibView

3.同样给张图

途中都可以看到,我使用了@IBDesignable 、@IBInspectable 这两个关键字,

那么 在storyboard 中怎么看@IBInspectable修饰的属性呢

     

文字都在代码中注释看吧   666

import UIKit

/**
@IBDesignable 加入这个关键字说明:这个类(这个类必须是UIView或者NSView的子类)可以被 xib 或者 storybord 检测到
*/
@IBDesignable class XibView: UIView { @IBOutlet var contentView: UIView!
/**
@IBInspectable 加入这个属性说明:这个属性可以 被xib 或者 storybord 检测到
但是要重写这个属性的set 方法
*/
@IBInspectable var borderWidth: CGFloat = {
didSet {
layer.borderWidth = borderWidth
}
} @IBInspectable var cornerRadius :CGFloat = {
didSet{
// layer.cornerRadius = cornerRadius
self.contentView.layer.cornerRadius = cornerRadius
}
} @IBInspectable var borderColor: UIColor? {
didSet {
layer.borderColor = borderColor?.cgColor
}
} override init(frame: CGRect) {
super.init(frame: frame)
initialFromXib()
} required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
initialFromXib()
} func initialFromXib(){ let bundle = Bundle(for: type(of: self))
let nib = UINib(nibName: "XibView", bundle: bundle)
contentView = nib.instantiate(withOwner: self, options: nil)[] as! UIView
contentView.frame = bounds
addSubview(contentView)
}
}

最后 写上自己莫名其妙的一个问题,发泄自己的小抱怨

Failed to update auto layout status: The agent crashed / Failed to render instance of XXXXXXX: The agent crashed

刚刚开始写完的时候出现这个错误,把xcode 关闭,重新打开后,报错神奇般的消失了,没有给了理由--(问谁说理……)

swift 第十四课 可视化view: @IBDesignable 、@IBInspectable的更多相关文章

  1. Kali Linux Web 渗透测试视频教程—第十四课-arp欺骗、嗅探、dns欺骗、session劫持

    Kali Linux Web 渗透测试视频教程—第十四课-arp欺骗.嗅探.dns欺骗.session劫持 文/玄魂 目录 Kali Linux Web 渗透测试—第十四课-arp欺骗.嗅探.dns欺 ...

  2. NeHe OpenGL教程 第四十四课:3D光晕

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  3. NeHe OpenGL教程 第三十四课:地形

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  4. NeHe OpenGL教程 第二十四课:扩展

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  5. NeHe OpenGL教程 第十四课:图形字体

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  6. webgl(three.js)实现室内三维定位,3D定位,3D楼宇bim、实时定位三维可视化解决方案——第十四课(定位升级版)

    序: 还是要抽出时间看书的,迷上了豆豆的作品,最近在看<天幕红尘>,书中主人公的人生价值观以及修为都是让我惊为叹止.很想成为那样的人,但是再看看自己每天干的事,与时间的支配情况,真是十分的 ...

  7. 斯坦福第十四课:降维(Dimensionality Reduction)

    14.1  动机一:数据压缩 14.2  动机二:数据可视化 14.3  主成分分析问题 14.4  主成分分析算法 14.5  选择主成分的数量 14.6  重建的压缩表示 14.7  主成分分析法 ...

  8. 第四十四课:jQuery UI和jQuery easy UI

    jQuery UI是jQuery官方提供的功能效果和UI样式.作为官方出的东西,它一直没有被人们看重,一是它没有datagrid,tree等UI库必备的东西,二是它修改太过频繁,体积庞大.其实它所有以 ...

  9. 第三十四课:jQuery Deferred详解2

    上一课主要分析了jQuery1.51版本的jQuery Deferred.在jQuery1.6中,jQuery Deferred添加了两个方法,always,pipe. always用来添加回调,无论 ...

随机推荐

  1. JS 日期格式化,留作参考

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. JSP基础语法总结

    任何语言都有自己的语法,Java中有.JSP虽然是在Java上的一种应用,但是依然有其自己扩充的语法,而且在Jsp中,所有Java语句都可以使用. 一.Jsp的模板元素 Jsp页面中的HTML内容称为 ...

  3. 如何查看float在内存中存储方式

    float fla = -1000; unsigned int *pfla = (unsigned int*)&fla; printf("fla=%X\n",*pfla); ...

  4. BZOJ 2400: Spoj 839 Optimal Marks (按位最小割)

    题面 一个无向图,一些点有固定权值,另外的点权值由你来定. 边的值为两点的异或值,一个无向图的值定义为所有边的值之和. 求无向图的最小值 分析 每一位都互不干扰,按位处理. 用最小割算最小值 保留原图 ...

  5. [ES2019] Represent Collision-free String Constants as Symbols in JavaScript

    ES2019 introduces the Symbol.prototype.description property. In this lesson, we'll learn why this pr ...

  6. HR#4 题解

    既然考这么差就来写题啦OTZ T1 猜结论?猜nm! 一直到考试结束都没猜出来=.=我就好奇别人如何猜出来的 我们来说DP(from ZBK) 设\(dp[i][j]\)表示胜or负 那我们来看一下代 ...

  7. http 内容协商返回最适合的内容

    内容协商返回最命适的内容AcceptAccept-CharsetAccept-EncodingAccept-LanguageContent-Language内容协商技术有以下 3 种类型.服务器驱动协 ...

  8. Ubuntu下dpkg安装软件遇到包依赖问题的处理方法

    造冰箱的大熊猫@cnblogs 2019/9/10 向灵魂工程师致敬! 在Ubuntu环境下通过dpkg命令安装deb包时,如果遇到包依赖问题,如 $sudo dpkg -i xxx.deb (Rea ...

  9. _cdecl与_stdcall区别

    _cdecl与_stdcall是最常用的的两种函数调用修饰,区别在于函数返回时,清理栈(恢复栈平衡)是caller做还是被调函数做. : _cdecl int add1(int a, int b) : ...

  10. 五、SSD原理(Single Shot MultiBox Detector)

    主流的算法主要分为两个类型: (1)tow-stage R-CNN系列算法,其主要思路是先通过启发式方法(selective search)或者CNN网络(RPN)产生一些列稀疏的候选框,然后对这些候 ...