zoukankan      html  css  js  c++  java
  • iOS开发UI篇—UIScrollView控件实现图片轮播

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

    一、实现效果

    实现图片的自动轮播

              

    二、实现代码

    storyboard中布局

    代码:

    复制代码

    #import "YYViewController.h"

    @interface YYViewController () <UIScrollViewDelegate>
    @property (weak, nonatomic) IBOutlet UIScrollView *scrollview;
    /**
    * 页码
    */
    @property (weak, nonatomic) IBOutlet UIPageControl *pageControl;

    @property (nonatomic, strong) NSTimer *timer;
    @end

    @implementation YYViewController

    - (void)viewDidLoad
    {
    [super viewDidLoad];

    // 图片的宽
    CGFloat imageW = self.scrollview.frame.size.width;
    // CGFloat imageW = 300;
    // 图片高
    CGFloat imageH = self.scrollview.frame.size.height;
    // 图片的Y
    CGFloat imageY = 0;
    // 图片中数
    NSInteger totalCount = 5;
    // 1.添加5张图片
    for (int i = 0; i < totalCount; i++) {
    UIImageView *imageView = [[UIImageView alloc] init];
    // 图片X
    CGFloat imageX = i * imageW;
    // 设置frame
    imageView.frame = CGRectMake(imageX, imageY, imageW, imageH);
    // 设置图片
    NSString *name = [NSString stringWithFormat:@"img_0%d", i + 1];
    imageView.image = [UIImage imageNamed:name];
    // 隐藏指示条
    self.scrollview.showsHorizontalScrollIndicator = NO;

    [self.scrollview addSubview:imageView];
    }

    // 2.设置scrollview的滚动范围
    CGFloat contentW = totalCount *imageW;
    //不允许在垂直方向上进行滚动
    self.scrollview.contentSize = CGSizeMake(contentW, 0);

    // 3.设置分页
    self.scrollview.pagingEnabled = YES;

    // 4.监听scrollview的滚动
    self.scrollview.delegate = self;

    [self addTimer];
    }

    - (void)nextImage
    {
    int page = (int)self.pageControl.currentPage;
    if (page == 4) {
    page = 0;
    }else
    {
    page++;
    }

    // 滚动scrollview
    CGFloat x = page * self.scrollview.frame.size.width;
    self.scrollview.contentOffset = CGPointMake(x, 0);
    }

    // scrollview滚动的时候调用
    - (void)scrollViewDidScroll:(UIScrollView *)scrollView
    {
    NSLog(@"滚动中");
    // 计算页码
    // 页码 = (contentoffset.x + scrollView一半宽度)/scrollView宽度
    CGFloat scrollviewW = scrollView.frame.size.width;
    CGFloat x = scrollView.contentOffset.x;
    int page = (x + scrollviewW / 2) / scrollviewW;
    self.pageControl.currentPage = page;
    }

    // 开始拖拽的时候调用
    - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
    {
    // 关闭定时器(注意点; 定时器一旦被关闭,无法再开启)
    // [self.timer invalidate];
    [self removeTimer];
    }

    - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
    {
    // 开启定时器
    [self addTimer];
    }

    /**
    * 开启定时器
    */
    - (void)addTimer{

    self.timer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(nextImage) userInfo:nil repeats:YES];
    106 }
    /**
    * 关闭定时器
    */
    - (void)removeTimer
    {
    [self.timer invalidate];
    }
    @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];

  • 相关阅读:
    如何在android studio上加入OpenCV库
    c++ overload 、override、overwrite
    学习笔记:linux之文件空洞
    windows 编译安装PROJ.4
    RDD:基于内存的集群计算容错抽象
    用Scala语言轻松开发多线程、分布式以及集群式程序
    scala 读雷达数据文件,生成png
    linux下virtualBox挂载物理磁盘,启动第二块硬盘中的系统
    shell检查网络出现异常、僵尸进程、内存过低后,自动重启
    cordova 5.0版本说明
  • 原文地址:https://www.cnblogs.com/LifeTechnologySupporter/p/9686142.html
Copyright © 2011-2022 走看看