18-Swift之UIView(视图)

1、UIView 的定义?

答:UIView 是视图。视图对象是一个应用中, 用户可以看到的对象。 视图对象知道如何绘制自己, 也能够响应用户的操作. 视图对象的主要目的之一是将应用模型对象中的数据显示出来, 并允许用户编辑该数据。

2、UIView的委托

答:UIView 委托 UIResponder, NSCoding, UIAppearance, UIAppearanceContainer, UIDynamicItem, UITraitEnvironment, UICoordinateSpace, UIFocusItem, CALayerDelegate等。

3、UIView的方法和属性介绍

1、init 和 init ...frame

 /**
  创建一个UIView的实例对象
  */
var View = UIView.init()
View = UIView.init(frame: CGRect.init(x: 10, y: 10, width: 100, height: 60))

2、设置视图的大小

/**
 设置UIView视图的大小
 */
View.frame = self.view.frame
View.frame = CGRect.init(x: 10, y: 64, width: 100, height: 50)

3、设置视图的背景色

/**
 设置UIView的背景色
 设置颜色,涉及到UIColor类,我们就举例下面几个,后期再UIColor讲述中会详细解说。
 */
View.backgroundColor = UIColor.red
View.backgroundColor = UIColor.init(colorLiteralRed: 120/255, green: 120/255, blue: 20/255, alpha: 1.0)
View.backgroundColor = UIColor.init(white: 120/255, alpha: 1.0)

4、设置交互

/**
 设置UIView的交互
 UIVIew的交互默认情况下是开启的为True,然而,还是有为 false的时候。所谓的交互,就是指用户可以和UIView进行互动。
 */
View.isUserInteractionEnabled = false
View.isUserInteractionEnabled = true

5、切割

/**
 切割UIView
 */
View.layer.cornerRadius = 6.0

6、描边

/**
 描边(轮廓)
 */
View.layer.borderWidth = 1.0
View.layer.borderColor = UIColor.red.cgColor

7、获取视图大小

/**
 获取尺寸大小
 */
let rect:CGRect = View.frame
print(rect.width)
print(rect.height)

8、获取视图的位置

/**
 获取控制位置
 */
let Point :CGPoint = rect.origin
print(Point.x)
print(Point.y)

9、获取视图的中心点

/**
 获取UIView视图的中心点
 注意:可以通过center 来改变UIView的位置
 */
let center:CGPoint = View.center
print(center.x)
print(center.y)

10、视图的渲染

/**
 视图的渲染
 */
self.view.addSubview(View)

11、视图的叠加

/**
 视图的叠加
 */
let MyView:UIView  = UIView.init()
MyView.frame = CGRect.init(x: 10, y: 10, width: 50, height: 100)
MyView.backgroundColor = UIColor.yellow
//        View.addSubview(MyView)
self.view.addSubview(MyView)

12、视图的超出父视图的裁剪

/**
 视图叠加超出父视图的范围,所以我们要进行对处理
 */
View.layer.masksToBounds = true

13、视图的交换层次

/**
 视图层次交换
 */
self.view.exchangeSubview(at: 2, withSubviewAt: 3)

14、视图层的移除

/**
 图层的移除
 缺点:视图确实被移除了,但是还在内存中
 */
MyView.removeFromSuperview()
CFBridgingRetain(MyView)

15、视图添加标记

/**
 给UIView 添加标记
 */
View.tag = 250
/* 输出:<UIView: 0x7f8052508e10; frame = (10 64; 100 50); clipsToBounds = YES; tag = 250; layer = <CALayer: 0x60000003d7c0>>]*/
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • *面试心声:其实这些题本人都没怎么背,但是在上海 两周半 面了大约10家 收到差不多3个offer,总结起来就是把...
    Dove_iOS阅读 27,210评论 30 471
  • 7、不使用IB是,下面这样做有什么问题? 6、请说说Layer和View的关系,以及你是如何使用它们的。 1.首先...
    AlanGe阅读 719评论 0 1
  • Core Animation基础 Core Animation 利用了硬件加速和架构上的优化来实现快速渲染和实时动...
    独木舟的木阅读 1,560评论 0 3
  • 1.OC里用到集合类是什么? 基本类型为:NSArray,NSSet以及NSDictionary 可变类型为:NS...
    轻皱眉头浅忧思阅读 1,394评论 0 3
  • UIView与UIWindow Uiview需要一个窗口UIWindow来展示页面,而UIWindow类似于一个U...
    Tuberose阅读 3,956评论 1 20