当前位置: 移动技术网 > IT编程>移动开发>IOS > iOS UIScrollView滚动视图/无限循环滚动/自动滚动的实例代码

iOS UIScrollView滚动视图/无限循环滚动/自动滚动的实例代码

2019年07月24日  | 移动技术网IT编程  | 我要评论

姚晓峰,宣恩贡水论坛,云末加速器

我们都知道uiscrollview有一种很流畅的切换效果,结合uipagecontrol的辅助展示效果,就可以完成一个很不错的产品介绍功能页面。下面给大家分享ios uiscrollview滚动视图/无限循环滚动/自动滚动功能,具体代码如下所示;

<uiscrollviewdelegate>
#define width [[uiscreen mainscreen] bounds].size.width
#define height [[uiscreen mainscreen] bounds].size.height
@property (nonatomic, strong)nstimer *timer; //定时器
@property (nonatomic, retain)nsmutablearray *arr; //放图片的数组
@property (nonatomic, retain)uiview *headerview; //tableview的表头
@property (nonatomic, retain)uiimageview *image; //图片
@property (nonatomic, retain)uiscrollview *scrollview; 
@property (nonatomic, retain)uipagecontrol *pagec; //页码
//设置头视图
- (void)headimage{
  //图片数组
  self.arr = [nsmutablearray arraywithobjects:@"8.jpg",@"1.jpg", @"2.jpg", @"3.jpg", @"4.jpg", @"5.jpg", @"6.jpg", @"7.jpg", @"8.jpg", @"1.jpg", nil];
  self.scrollview = [[uiscrollview alloc]initwithframe:cgrectmake(0, 0, width, 200 * height/667)];
  self.scrollview.backgroundcolor = [uicolor clearcolor];
  //设置滚动量
  self.scrollview.contentsize = cgsizemake(width * self.arr.count, 0);
  //设置偏移量
  self.scrollview.contentoffset = cgpointmake(width, 0);
  //设置按页滚动
  self.scrollview.pagingenabled = yes;
  //设置是否显示水平滑动条
  self.scrollview.showshorizontalscrollindicator = no;
  //设置是否边界反弹
  self.scrollview.bounces = no;
  //把scrollview添加到tableview的表头的视图上
  [self.headerview addsubview:self.scrollview];
  [_scrollview release];
  //循环图片添加到uiimageview上
  for (int i = 0 ; i < self.arr.count; i++) {
    nsstring *name = [self.arr objectatindex:i];
    uiimage *img = [uiimage imagenamed:name];
    self.image = [[uiimageview alloc]init];
    self.image.frame = cgrectmake(i * width, 0, width, 200 * height/667);
    self.image.image = img;
    [self.scrollview addsubview:self.image];
    [_image release];
  }
  self.scrollview.delegate = self;
  //设置页面
  self.pagec = [[uipagecontrol alloc]initwithframe:cgrectmake(100 * width/375, 120 * height/667, 200* width/375, 60*height/667)];
  self.pagec.backgroundcolor = [uicolor clearcolor];
  //把页码添加到头视图上
  [self.headerview addsubview:self.pagec];
  //设置页码数
  self.pagec.numberofpages = self.arr.count;
  //设置选中页码的颜色
  self.pagec.currentpageindicatortintcolor = [uicolor browncolor];
  //设置未选中的页码颜色
  self.pagec.pageindicatortintcolor = [uicolor graycolor];
  //设置当前选中页
  self.pagec.currentpage = 0;
  //核心方法
  [self.pagec addtarget:self action:@selector(pageaction:) forcontrolevents:uicontroleventvaluechanged];
  [_pagec release];
  //自定义一个定时器方法
  [self addtimer];
}
 //定时器执行方法
- (void)change:(nstimer *)time{
  if (self.pagec.currentpage == self.pagec.numberofpages - 1) {
    self.pagec.currentpage = 0;
  } else if (self.pagec.currentpage < self.pagec.numberofpages - 1) {
    self.pagec.currentpage++;
  }
  [self.scrollview setcontentoffset:cgpointmake((self.pagec.currentpage + 1) * width, 0) animated:no];
 }

以上所述是小编给大家介绍的ios uiscrollview滚动视图/无限循环滚动/自动滚动的实例代码,希望对大家有所帮助

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • ios uicollectionview实现横向滚动

    现在使用卡片效果的app很多,之前公司让实现一种卡片效果,就写了一篇关于实现卡片的文章。文章最后附有demo实现上我选择了使用uicollectionview ... [阅读全文]
  • iOS UICollectionView实现横向滑动

    本文实例为大家分享了ios uicollectionview实现横向滑动的具体代码,供大家参考,具体内容如下uicollectionview的横向滚动,目前我使... [阅读全文]
  • iOS13适配深色模式(Dark Mode)的实现

    iOS13适配深色模式(Dark Mode)的实现

    好像大概也许是一年前, mac os系统发布了深色模式外观, 看着挺刺激, 时至今日用着也还挺爽的终于, 随着iphone11等新手机的发售, ios 13系统... [阅读全文]
  • ios 使用xcode11 新建项目工程的步骤详解

    ios 使用xcode11 新建项目工程的步骤详解

    xcode11新建项目工程,新增了scenedelegate这个类,转而将原appdelegate负责的对ui生命周期的处理担子接了过来。故此可以理解为:ios... [阅读全文]
  • iOS实现转盘效果

    本文实例为大家分享了ios实现转盘效果的具体代码,供大家参考,具体内容如下demo下载地址: ios转盘效果功能:实现了常用的ios转盘效果,轮盘抽奖效果的实现... [阅读全文]
  • iOS开发实现转盘功能

    本文实例为大家分享了ios实现转盘功能的具体代码,供大家参考,具体内容如下今天给同学们讲解一下一个转盘选号的功能,直接上代码直接看viewcontroller#... [阅读全文]
  • iOS实现轮盘动态效果

    本文实例为大家分享了ios实现轮盘动态效果的具体代码,供大家参考,具体内容如下一个常用的绘图,主要用来打分之类的动画,效果如下。主要是ios的绘图和动画,本来想... [阅读全文]
  • iOS实现九宫格连线手势解锁

    本文实例为大家分享了ios实现九宫格连线手势解锁的具体代码,供大家参考,具体内容如下demo下载地址:效果图:核心代码://// clockview.m// 手... [阅读全文]
  • iOS实现卡片堆叠效果

    本文实例为大家分享了ios实现卡片堆叠效果的具体代码,供大家参考,具体内容如下如图,这就是最终效果。去年安卓5.0发布的时候,当我看到安卓全新的material... [阅读全文]
  • iOS利用余弦函数实现卡片浏览工具

    iOS利用余弦函数实现卡片浏览工具

    本文实例为大家分享了ios利用余弦函数实现卡片浏览工具的具体代码,供大家参考,具体内容如下一、实现效果通过拖拽屏幕实现卡片移动,左右两侧的卡片随着拖动变小,中间... [阅读全文]
验证码:
移动技术网