用Swift封装图片折叠效果

本文介绍了如何使用Swift封装图片折叠效果,从使用者角度出发,只需传入图片名和frame即可实现。通过在UIView上放置两张相同图片并添加手势识别,控制图层形变来达到复杂的UI动画,提供了一种比继承UIControl更简便的方法。
摘要由CSDN通过智能技术生成

用Swift封装图片折叠效果

这里写图片描述

谈到封装,那么就要从使用者的角度出发,提供外界使用的方法

  • 1.新建一个类继承UIView
class XWFoldImageView: UIView {}
  • 2.外界想实现这个效果只需要给我图片名和控件显示的frame就够了,那么提供使用者遍历构造方法
convenience init(imageName:String ,frame:CGRect){
        self.init()
        self.frame = frame
        //1.在初始化做的操作
        self.setupDoubleImageViewLayer(imageName)
        self.setupGestureRecognizer()
    }
  • 3那么外界使用就是非常方便,如:
 override func viewDidLoad() {
        super.viewDidLoad()
        let foldImageView = XWFoldImageView(imageName: "image", frame: CGRectMake(50, 100, 300, 200))
        self.view.addSubview(foldImageView)
    }

谈谈如何具体实现

  • 大体思想
1.利用两张一模一样的图片,放在同一个UIView上面分了顶部和底部

这里写图片描述
具体代码


   //MARK: 成员属性

    private var imageTopView:UIImageView!
    private var imageBottomView:UIImageView!
    private var gradientLayer:CAGradientLayer = CAGradientLayer()


    //MARK: 便利构造

    convenience init(imageName:String ,frame:CGRect){
        self.init()
        self.frame = frame
        self.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值