iOS JXPageControl-(最全的自定义UIPageControl框架)

JXPageControl是一款适用于iOS的页面指示器动画框架,支持多种动画变换,包括跳跃、变换、填充等,同时支持内容布局变换和Xib布局。此框架在Xcode7环境下开发,兼容iOS8.0及以上版本,通过CocoaPods轻松集成。

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

https://blog.youkuaiyun.com/TanJiaXiang/article/details/95796616

github https://github.com/Coder-TanJX/JXPageControl

 

2019-07-13 21:43:22 Code_TanJX 阅读数 105更多

分类专栏: iOSUI框架 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 

本文链接:https://blog.youkuaiyun.com/TanJiaXiang/article/details/95796616

(JXPageControl 支持多种动画变换, 支持内容布局变换, 支持Xib布局)


    1. 开发环境: Xcode 7
    1. 运行条件: iOS(8.0+)
  • 开源框架:github地址

 

(如果使用有什么问题,可以留言,欢迎一起学习,欢迎star)


Installation [安装]

安装,只需将以下面代码添加到您的Podfile:


platform :ios, '8.0'

target 'TargetName' do
pod 'JXPageControl'
end

  •  

UI效果

  • JXPageControlChameleon

    在这里插入图片描述


  • JXPageControlExchange

    在这里插入图片描述


  • JXPageControlFill

    在这里插入图片描述


  • JXPageControlJump

    在这里插入图片描述


  • JXPageControlScale

    在这里插入图片描述


Frame set [框架集合]

  • Common 框架公用类文件
  • Jump 跳跃式动画效果类文件
  • Transform 转变式动画类文件


JXPageControl 介绍

 

  • JXPageControlBase - 所有pageControl的基类
  • JXPageControlType - 所有pageControl的准守的协议, 它提供了很多自定义API供给开发者使用

 

JXPageControlType - 提供的 - API。

 

  • numberOfPages —> 指示器个数。
  • currentPage —> 当前指示器页码。
  • progress —> 当前指示器页码进程。
  • hidesForSinglePage —>只有一个指示器时,是否隐藏。
  • inactiveColor —> 不活跃指示器颜色
  • activeColor —> 活跃指示器颜色
  • inactiveSize —> 不活跃指示器大小
  • activeSize —> 活跃指示器大小
  • indicatorSize —> 所有指示器大小
  • columnSpacing —> 指示器水平间距
  • contentAlignment —> 内容布局位置 (注意这个属性很好用!!!)
  • contentMode —> 内容布局位置,并且支持在Xib中变换,实时查看位置变化 (注意这个属性很好用!!!)
  • isInactiveHollow —> 不活跃指示器是否是空心图形
  • isActiveHollow —> 活跃指示器是否是空心图形
  • reload() —> 刷新数据/UI

注意 :

JXPageControl 还提供了一些非 JXPageControlType 的 API。可以在具体使用的类中查看

 


[JXPageControl 使用] :

 

Example 1

  • 在 xib, storyboard中使用 ( xib, storyboard 中可以完成属性和布局设置 !!! )

  • 注意 module要选择 JXPageControl, 否则会显示不出来, 调用会报错

  • View 中可以设置 contentMode , 变换内容位置

 

在这里插入图片描述

在这里插入图片描述

Example 2

  • 使用纯代码编写

import JXPageControl

class ChamelonVC: UIViewController {

    lazy var codePageControl: JXPageControlJump = {
        let pageControl = JXPageControlJump(frame: CGRect(x: 0,
                                                          y: 0,
                                                          width: UIScreen.main.bounds.width,
                                                          height: 30))
        pageControl.numberOfPages = 4
        
        // JXPageControlType: default property
//        pageControl.currentPage = 0
//        pageControl.progress = 0.0
//        pageControl.hidesForSinglePage = false
//        pageControl.inactiveColor = UIColor.white.withAlphaComponent(0.5)
//        pageControl.activeColor = UIColor.white
//        pageControl.inactiveSize = CGSize(width: 10, height: 10)
//        pageControl.activeSize = CGSize(width: 10, height: 10)
//        pageControl.inactiveSize = CGSize(width: 10, height: 10)
//        pageControl.columnSpacing = 10
//        pageControl.contentAlignment = JXPageControlAlignment(.center,
//                                                              .center)
//        pageControl.contentMode = .center
//        pageControl.isInactiveHollow = false
//        pageControl.isActiveHollow = false
        
        // JXPageControlJump: default "custom property"
        pageControl.isAnimation  = true
        pageControl.isFlexible = true
        
        return pageControl
    }()
    
    override func viewDidLoad() {
        super.viewDidLoad()
        view.addSubview(codePageControl)
    }
    
}

extension ChamelonVC: UIScrollViewDelegate {
    func scrollViewDidScroll(_ scrollView: UIScrollView) {
        let progress = scrollView.contentOffset.x / scrollView.bounds.width
        let currentPage = Int(round(progress))
        
        // 方式一
        codePageControl.progress = progress
        
        // 方式二
//        codePageControl.currentPagev = currentPage

    }
    
}

Example 2 and so on …


import JXPageControl
...

Demo地址

 

 

最新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
本Demo使用UICollectionView实现自动无限轮播功能。 主要功能: 1.实现自动轮播,可修改轮播的时间 2.轮播图片可以来自本地,也可来自网络,通过单独的方法进行设置即可。对于加载网络图片时,Demo中使用了YYWebImage,也可自行替换成SDWebImage。 3.重写了和系统UIPageControl一样的功能,可用图片代替PageControl上的点点,也可自定义其颜色以及切换动画。 使用方法:使用方法比较简单。 /** * 加载本地图片Banner */ - (void)setupLocalBannerImageView { NSArray *array = @[@"1.png", @"2.png", @"3.png", @"4.png", @"5.png"]; FFBannerView *bannerVew = [FFBannerView bannerViewWithFrame:CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, 200) locationImageArray:array]; bannerVew.timeInterval = 2.0; [self.view addSubview:bannerVew]; } /** * 加载网络图片Banner */ - (void)setupNetWorkBannerImageView { NSArray *array = @[@"http://i3.download.fd.pchome.net/t_960x600/g1/M00/07/09/oYYBAFMv8q2IQHunACi90oB0OHIAABbUQAAXO4AKL3q706.jpg", @"http://images.weiphone.net/attachments/photo/Day_120308/118871_91f6133116504086ed1b82e0eb951.jpg", @"http://benyouhuifile.it168.com/forum/macos/attachments/month_1104/110425215921926a173e0f728e.jpg", @"http://benyouhuifile.it168.com/forum/macos/attachments/month_1104/1104241737046031b3a754f783.jpg"]; FFBannerView *bannerVew = [FFBannerView bannerViewWithFrame:CGRectMake(0, 250, [UIScreen mainScreen].bounds.size.width, 200) netWorkImageArray:array placeHolderImage:nil]; bannerVew.timeInterval = 2.0; bannerVew.pageControlStyle = FFPageControlStyleMiddle; bannerVew.delegate = self; [self.view addSubview:bannerVew]; } 以上方式即可简单使用,如需自定义PageControl也可继承FFAbstractDotView,做些基本的设置即可。 gitHub下载地址:喜欢的朋友请给个星呗! 欢迎各位一起来讨论,有问题请发邮箱270452746@qq.com或者直接加我QQ:270452746进行讨论。谢谢!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sundaysme

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值