一个iOS自定义pageControl

请添加图片描述

核心代码

@interface LBPageControl()
@property(nonatomic, strong)NSMutableArray *itemArray;
@end

@implementation LBPageControl

- (void)setPageCount:(NSInteger)pageCount
{
   _pageCount = pageCount;
   [self creatPageItemWithPageCount];
}

- (void)pageContolAnimationIndex:(NSInteger)index
{
   if (index <0) {
       index = _pageCount-1;
   }else if(index == _pageCount){
       index = 0;
   }
   self.currentPage = index;
   for (int i = 0; i<self.itemArray.count; i++) {
       LBPageItemView *item = self.itemArray[i];
       if (item.pageIndex == index) {
           item.isCurrentPage = YES;
       }else{
           item.isCurrentPage = NO;
       }
       [item scroProgressWithState:index];
   }
}

-(void)setScroProgress:(float)scroProgress {
   _scroProgress = scroProgress;
   NSInteger index =  self.currentPage;
   if (index <0) {
       index = _pageCount-1;
   }else if(index == _pageCount){
       index = 0;
   }
   self.currentPage = index;
   for (int i = 0; i<self.itemArray.count; i++) {
       LBPageItemView *item = self.itemArray[i];
       item.isLeftScro = self.isLeftScro;
       item.scroProgress = scroProgress;
       if (item.pageIndex == index) {
           item.isCurrentPage = YES;
       } else {
           item.isCurrentPage = NO;
       }
       [item scroProgressWithState:index];
   }
}

- (void)creatPageItemWithPageCount
{
   [self clearView];
   CGFloat itemWidth = 7;
   CGFloat variableWidth = 5;
   CGFloat itemHeight = 3;
   CGFloat itemMargin = 3;
   CGFloat itemWidthMu = variableWidth*(1-0);
   for (int i =0; i<_pageCount; i++) {
       CGFloat leftPadding = 0;
       CGFloat wideth  = itemWidth+itemWidthMu;
       if (i!=0) {
           leftPadding =  itemWidth*i+itemMargin*i+itemWidthMu;
           wideth = itemWidth;
       }
       
       LBPageItemView *item = [[LBPageItemView alloc]initWithFrame:CGRectMake(leftPadding, 7, wideth, itemHeight)];
       item.selectedColor = self.selectedItemColor;
       item.normalColor = self.normalItemColor;
       if (i==0) {
           item.isCurrentPage = YES;
       } else {
           item.isCurrentPage = NO;
       }
       item.pageIndex = i;
       [self addSubview:item];
       [self.itemArray addObject:item];
   }
}

-(void)clearView {
   [self.subviews makeObjectsPerformSelector:@selector(removeFromSuperview)];
}

#pragma mark - lazy load

- (NSMutableArray *)itemArray
{
   if (!_itemArray) {
       _itemArray = [NSMutableArray array];
   }
   return _itemArray;
}

@end

链接添加链接描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本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下载地址:喜欢的朋友请给个星呗! 欢迎各位一起来讨论,有问题请发邮箱[email protected]或者直接加我QQ:270452746进行讨论。谢谢!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值