IOS 开发之swift中UIView的扩展使用的实例

 更新时间:2017年09月12日 14:40:43   作者:番薯大佬  
这篇文章主要介绍了IOS 开发之swift中UIView的扩展使用的实例的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下

IOS 开发之swift中UIView的扩展使用的实例

扩展类代码:

import UIKit 
 
extension UIView 
{ 
  // MARK : 坐标尺寸 
   
  var origin:CGPoint { 
    get { 
      return self.frame.origin 
    } 
    set(newValue) { 
      var rect = self.frame 
      rect.origin = newValue 
      self.frame = rect 
    } 
  } 
   
  var size:CGSize { 
    get { 
      return self.frame.size 
    } 
    set(newValue) { 
      var rect = self.frame 
      rect.size = newValue 
      self.frame = rect 
    } 
  } 
   
  var left:CGFloat { 
    get { 
      return self.frame.origin.x 
    } 
    set(newValue) { 
      var rect = self.frame 
      rect.origin.x = newValue 
      self.frame = rect 
    } 
  } 
   
  var top:CGFloat { 
    get { 
      return self.frame.origin.y 
    } 
    set(newValue) { 
      var rect = self.frame 
      rect.origin.y = newValue 
      self.frame = rect 
    } 
  } 
   
  var right:CGFloat { 
    get { 
      return (self.frame.origin.x + self.frame.size.width) 
    } 
    set(newValue) { 
      var rect = self.frame 
      rect.origin.x = (newValue - self.frame.size.width) 
      self.frame = rect 
    } 
  } 
   
  var bottom:CGFloat { 
    get { 
      return (self.frame.origin.y + self.frame.size.height) 
    } 
    set(newValue) { 
      var rect = self.frame 
      rect.origin.y = (newValue - self.frame.size.height) 
      self.frame = rect 
    } 
  } 
   
  // MARK: - 位移 
   
  // 移动到指定中心点位置 
  func moveToPoint(point:CGPoint) -> Void 
  { 
    var center = self.center 
    center.x = point.x 
    center.y = point.y 
    self.center = center 
  } 
   
  // 缩放到指定大小 
  func scaleToSize(scale:CGFloat) -> Void 
  { 
    var rect = self.frame 
    rect.size.width *= scale 
    rect.size.height *= scale 
    self.frame = rect 
  } 
   
  // MARK: - 毛玻璃效果 
   
  // 毛玻璃 
  func effectViewWithAlpha(alpha:CGFloat) -> Void 
  { 
    let effect = UIBlurEffect.init(style: UIBlurEffectStyle.Light) 
    let effectView = UIVisualEffectView.init(effect: effect) 
    effectView.frame = self.bounds 
    effectView.alpha = alpha 
     
    self.addSubview(effectView) 
  } 
   
  // MARK: - 边框属性 
   
  // 圆角边框设置 
  func layer(radius radius:CGFloat, borderWidth:CGFloat, borderColor:UIColor) -> Void 
  { 
    if (0.0 < radius) 
    { 
      self.layer.cornerRadius = radius 
      self.layer.masksToBounds = true 
      self.clipsToBounds = true 
    } 
     
    if (0.0 < borderWidth) 
    { 
      self.layer.borderColor = borderColor.CGColor 
      self.layer.borderWidth = borderWidth 
    } 
  } 
   
  // MARK: - 翻转 
   
  // 旋转 旋转180度 M_PI 
  func viewTransformWithRotation(rotation:CGFloat) -> Void 
  { 
    self.transform = CGAffineTransformMakeRotation(rotation); 
  } 
   
  // 缩放 
  func viewScaleWithSize(size:CGFloat) -> Void 
  { 
    self.transform = CGAffineTransformScale(self.transform, size, size); 
  } 
   
  // 水平,或垂直翻转 
  func viewFlip(isHorizontal:Bool) -> Void 
  { 
    if (isHorizontal) 
    { 
      // 水平 
      self.transform = CGAffineTransformScale(self.transform, -1.0, 1.0); 
    } 
    else 
    { 
      // 垂直 
      self.transform = CGAffineTransformScale(self.transform, 1.0, -1.0); 
    } 
  } 
} 

使用效果图:

使用示例:

let imageView = UIImageView.init(frame: CGRectMake(10.0, 10.0, 60.0, 60.0)) 
self.view.addSubview(imageView) 
     
imageView.image = UIImage(named: "header") 
     
imageView.backgroundColor = UIColor.colorRandom() 
     
imageView.left = 100.0 
imageView.top = 100.0 
imageView.size = CGSizeMake(100.0, 100.0) 
 
imageView.moveToPoint(CGPointMake(100.0, 100.0)) 
imageView.scaleToSize(2.0) 
 
imageView.effectViewWithAlpha(0.6) 
     
imageView.layer(radius: 3.0, borderWidth: 1.0, borderColor: UIColor.redColor()) 
     
imageView.viewFlip(false) 
     
imageView.viewTransformWithRotation(5.0) 

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本的支持!

相关文章

  • iOS中UITextField实现过滤选中状态拼音的代码

    iOS中UITextField实现过滤选中状态拼音的代码

    这篇文章主要介绍了iOS中UITextField实现过滤选中状态拼音的代码,需要的朋友可以参考下
    2018-01-01
  • iOS 断点上传文件的实现方法

    iOS 断点上传文件的实现方法

    这项目开发中,有时候我们需要将本地的文件上传到服务器,简单的几张图片还好,但是针对iPhone里面的视频文件进行上传,为了用户体验,我们有必要实现断点上传。这篇文章主要介绍了iOS 断点上传文件的实现方法,需要的朋友可以参考下
    2017-12-12
  • iOS如何封装带复制功能的UILabel示例代码

    iOS如何封装带复制功能的UILabel示例代码

    如果是在IOS的应用方面,很多时候我们需要封装UILabel,下面这篇文章主要给大家介绍了关于iOS如何封装带复制功能的UILabel的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-08-08
  • 关于iOS GangSDK的使用 为App快速集成社群公会模块

    关于iOS GangSDK的使用 为App快速集成社群公会模块

    这篇文章主要介绍了iOS GangSDK的使用为App快速集成社群公会模块功能的实现过程。
    2017-11-11
  • IOS 静态库和Framework区别

    IOS 静态库和Framework区别

    这篇文章主要介绍了IOS 静态库和Framework区别的相关资料,这里对动态库与静态库做比较,选择什么时候使用库文件,需要的朋友可以参考下
    2016-12-12
  • iOS省市二级联动的数据组织PHP版

    iOS省市二级联动的数据组织PHP版

    这篇文章主要为大家详细介绍了iOS开发之"省市"二级联动的数据组织PHP版,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • IOS 开发之PickerView文字和随机数的使用

    IOS 开发之PickerView文字和随机数的使用

    这篇文章主要介绍了IOS 开发之PickerView文字和随机数的使用的相关资料,这里提供实例帮助大家理解掌握这部分内容,需要的朋友可以参考下
    2017-08-08
  • IOS之构造方法与自定义构造方法的区别与实现

    IOS之构造方法与自定义构造方法的区别与实现

    本篇文章主要介绍了构造方法以及自定义构造方法的实现,需要的朋友可以参考下
    2015-07-07
  • iOS中Label实现显示不同颜色与字体的方法

    iOS中Label实现显示不同颜色与字体的方法

    这篇文章主要给大家介绍了关于在iOS中Label实现显示不同颜色与字体的相关资料,文中分别介绍了利用range或者文字两种实现的方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-11-11
  • iOS button响应流程图文详解

    iOS button响应流程图文详解

    这篇文章主要为大家介绍了iOS button响应流程图文详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11

最新评论