swift 自定义UIPageControl

本文介绍了两种在Swift中自定义UIPageControl的方法。第一种利用运行时访问私有属性,可能存在审核风险。第二种通过创建自定义视图FangPageControl,允许灵活设置形状和颜色,但需要提供相应切图。文中详细展示了如何设置数量、当前页、点的大小和间距以及图片资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第一种。利用运行时,容易奔溃,审核被拒。

// 初始化一个属性列表数组

        var ivarName_pageControl: [String] = []

 

        var count: uint = 0

        // 获取属性列表

        let list = class_copyIvarList(UIPageControl.classForCoder(), &count)

 

        for index in 0 ... count-1 {

            // 获取属性名称,ivar_getTypeEncoding 可获取属性类型

            let ivarName = ivar_getName( list![Int(index)] )

            let name = String.init(cString: ivarName!)

            ivarName_pageControl.append(name)

        }

 

        // 判断是否包含这两个属性

        if ivarName_pageControl.contains("_pageImage") && ivarName_pageControl.contains("_currentPageImage")

        {

            pageControl.setValue(UIImage.init(named: "lunbo_dian_gray"), forKey: "_pageImage")

            pageControl.setValue(UIImage.init(named: "lunbo_dian_white"), forKey: "_currentPageImage")

        }

 

 

第二种(推荐)可随意更改形状和颜色,但需要设计切图给你

class FangPageControl: UIView {

 

    var numberOfPages:Int!//数量

    var currentPage:Int!//当前

    var PointSize:CGFloat!//大小

    var distanceOfPoint:CGFloat! //间距

    var inactiveImage:String!//激活状态图片

    var activeImage:String! //未激活状态图片

    

    

    override init(frame: CGRect) {

        super.init(frame: frame)

        

    }

    

    required init?(coder aDecoder: NSCoder) {

        fatalError("init(coder:) has not been implemented")

    }

    func sizeForNumberOfPages(pages:NSInteger)->CGFloat

    {

        return distanceOfPoint*CGFloat(pages + 1)+CGFloat(PointSize*CGFloat(pages))

        

    }

    func setNumberOfPages(pages:NSInteger)

    {

 

        for i in 0..<pages {

            let  pointImageView = UIImageView.init(frame: CGRect.init(x: (frame.size.width - CGFloat(pages)*(PointSize+distanceOfPoint))/2  + CGFloat((distanceOfPoint+PointSize)*CGFloat(i)), y: (self.frame.size.height-PointSize)/2, width: PointSize, height: PointSize))

            pointImageView.image = UIImage.init(named: self.activeImage)

            pointImageView.tag =  5555 + i

            self.addSubview(pointImageView)

        }

        

    }

    

    func setCurrentPage(page:NSInteger)

    {

 

        let countOfPages = self.subviews.count

        for i in 0..<countOfPages {

            

            

           let subview = self.subviews[i]as!UIImageView

           

            if i == page

            {

                subview.image = UIImage.init(named: self.inactiveImage)

            }else

            {

                subview.image = UIImage.init(named: self.activeImage)

                

            }

 

        }

    }

}

最新SWIFT 4.0版自定义PageControl,椭圆,空心圆,图片点 刚开始做swift项目,可用资源少而且每个swift版本变化太大,以前的都不能拿来直接用,现在我参考一个object-C的PageControl自己做了一个swift版的, 参考OC资源链接:https://github.com/hackxhj/EllipsePageControl, 非常感谢原作者。 本项目在原OC的功能基础上进行的改进,增加了自定义点的宽度,点的layer,不是当前点的图片等功能 基本能满足大部分的需求,写的很简单,大家一看就懂,欢迎大家使用 由于水平有限,项目中有改进之处忘各位大神给与指点,以求不断完善 本人联系方式:wei287030375@sina.com 如果觉得还可以的话给个star吧,也是对以后进行创作的一种鼓励,谢谢 效果图: image 以下是部分代码: class WEIPageControl: UIControl { var localNumberOfPages = NSInteger()//分页数量 var localCurrentPage = NSInteger()//当前点所在下标 var localPointSize = CGSize()//点的大小 var localPointSpace = CGFloat()//点之间的间距 var localOtherColor = UIColor()//未选中点的颜色 var localCurrentColor = UIColor()//当前点的颜色 var localOtherImage: UIImage?//未选中点的图片 var localCurrentImage: UIImage?//当前点的图片 var localIsSquare = Bool()//是否是方形点 var localCurrentWidthMultiple = CGFloat()//当前选中点宽度与未选中点的宽度的倍数 var localOtherBorderColor: UIColor?//未选中点的layerColor var localOtherBorderWidth: CGFloat?//未选中点的layer宽度 var localCurrentBorderColor: UIColor?//未选中点的layerColor var localCurrentBorderWidth: CGFloat?//未选中点的layer宽度 var clickIndex: ((_ result: NSInteger?) -> ())? 在ViewController中使用 //方形点举例 class ViewController: UIViewController, UIScrollViewDelegate { pageC pageControl3.frame = CGRect.init(x: left, y: scrollView3.frame.maxY, width: width, height: 20) pageControl3.numberOfPages = pageCount//总页数 pageControl3.isSquare = true//设置为方型点 pageControl3.currentWidthMultiple = 2.5//当前点的宽度为其他点的2.5倍 pageControl3.currentColor = UIColor.red pageControl3.otherColor = UIColor.blue pageControl3.pointSize = CGSize.init(width: 14, height: 6)//方点的size pageControl3.clickPoint { (index) in//方点的点击事件 self.scrollView3.setContentOffset(CGPoint.init(x: width * CGFloat(index!), y: 0), animated: true) } self.view.addSubview(pageControl3) 代码用起来就是这么简单,欢迎大家使用, 本项目github地址:https://github.com/wei287030375/WEIPageControl
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值