• iOS开发UI篇—UIScrollView控件实现图片轮播


    iOS开发UI篇—UIScrollView控件实现图片轮播

    一、实现效果

    实现图片的自动轮播

              

    二、实现代码

    storyboard中布局

    代码:

     1 #import "TXViewController.h"
      2 
      3 @interface TXViewController () <UIScrollViewDelegate>
      4 @property (weak, nonatomic) IBOutlet UIScrollView *scrollview;
      5 /**
      6  *  页码
      7  */
      8 @property (weak, nonatomic) IBOutlet UIPageControl *pageControl;
      9 
     10 @property (nonatomic, strong) NSTimer *timer;
     11 @end
     12 
     13 @implementation TXViewController
     14 
     15 - (void)viewDidLoad
     16 {
     17     [super viewDidLoad];
     18     
     19 //    图片的宽
     20     CGFloat imageW = self.scrollview.frame.size.width;
     21 //    CGFloat imageW = 300;
     22 //    图片高
     23     CGFloat imageH = self.scrollview.frame.size.height;
     24 //    图片的Y
     25     CGFloat imageY = 0;
     26 //    图片中数
     27     NSInteger totalCount = 5;
     28 //   1.添加5张图片
     29     for (int i = 0; i < totalCount; i++) {
     30         UIImageView *imageView = [[UIImageView alloc] init];
     31 //        图片X
     32         CGFloat imageX = i * imageW;
     33 //        设置frame
     34         imageView.frame = CGRectMake(imageX, imageY, imageW, imageH);
     35 //        设置图片
     36         NSString *name = [NSString stringWithFormat:@"img_0%d", i + 1];
     37         imageView.image = [UIImage imageNamed:name];
     38 //        隐藏指示条
     39         self.scrollview.showsHorizontalScrollIndicator = NO;
     40         
     41         [self.scrollview addSubview:imageView];
     42     }
     43     
     44 //    2.设置scrollview的滚动范围
     45     CGFloat contentW = totalCount *imageW;
     46     //不允许在垂直方向上进行滚动
     47     self.scrollview.contentSize = CGSizeMake(contentW, 0);
     48     
     49 //    3.设置分页
     50     self.scrollview.pagingEnabled = YES;
     51     
     52 //    4.监听scrollview的滚动
     53     self.scrollview.delegate = self;
     54     
     55     [self addTimer];
     56 }
     57 
     58 - (void)nextImage
     59 {
     60     int page = (int)self.pageControl.currentPage;
     61     if (page == 4) {
     62         page = 0;
     63     }else
     64     {
     65         page++;
     66     }
     67     
     68 //  滚动scrollview
     69     CGFloat x = page * self.scrollview.frame.size.width;
     70     self.scrollview.contentOffset = CGPointMake(x, 0);
     71 }
     72 
     73 // scrollview滚动的时候调用
     74 - (void)scrollViewDidScroll:(UIScrollView *)scrollView
     75 {
     76     NSLog(@"滚动中");
     77 //    计算页码
     78 //    页码 = (contentoffset.x + scrollView一半宽度)/scrollView宽度
     79     CGFloat scrollviewW =  scrollView.frame.size.width;
     80     CGFloat x = scrollView.contentOffset.x;
     81     int page = (x + scrollviewW / 2) /  scrollviewW;
     82     self.pageControl.currentPage = page;
     83 }
     84 
     85 // 开始拖拽的时候调用
     86 - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
     87 {
     88 //    关闭定时器(注意点; 定时器一旦被关闭,无法再开启)
     89 //    [self.timer invalidate];
     90     [self removeTimer];
     91 }
     92 
     93 - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
     94 {
     95 //    开启定时器
     96     [self addTimer];
     97 }
     98 
     99 /**
    100  *  开启定时器
    101  */
    102 - (void)addTimer{
    103     
    104     self.timer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(nextImage) userInfo:nil repeats:YES];
    105     [[NSRunLoop currentRunLoop] addTimer:self.timer forMode:NSRunLoopCommonModes];
    106 }
    107 /**
    108  *  关闭定时器
    109  */
    110 - (void)removeTimer
    111 {
    112     [self.timer invalidate];
    113 }
    114 @end

    提示:以下两个属性已经和storyboard中的控件进行了连线。

    @property (weak, nonatomic) IBOutletUIScrollView *scrollview;

    @property (weak, nonatomic) IBOutletUIPageControl *pageControl;

    补充:定时器NSTimer

       定时器 适合用来隔一段时间做一些间隔比较长的操作

     NSTimeInterval:多长多件操作一次

     target :操作谁

     selector : 要操作的方法

     userInfo: 传递参数

     repeats: 是否重复

      self.timer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(nextImage) userInfo:nil repeats:YES];

  • 相关阅读:
    (二)juc线程高级特性——CountDownLatch / Callable / Lock
    (一)juc线程高级特性——volatile / CAS算法 / ConcurrentHashMap
    配置tomcat的session共享
    elastic不错的官方文档(中文)
    elasticsearch java客户端api使用(一)
    Tomcat 没有自动解压webapp下的war项目文件问题
    Spring+Quartz实现定时任务
    注意的问题
    JMS之——ActiveMQ 高可用与负载均衡集群安装、配置(ZooKeeper + LevelDB + Static discovery)
    activemq持久化配置,设置为主从模式(带复制的主从模式,应用mysql数据库)
  • 原文地址:https://www.cnblogs.com/asd5551680/p/4069506.html
Copyright © 2020-2023  润新知