iOS scrollview实现三屏复用循环广告

发布时间 - 2026-01-10 22:32:10    点击率:

循环广告我们在开发中已经是熟得不能再熟了,今天整理这篇scrollview三屏复用广告。

原理使用scrollview里的三个imageview分别去加载不同的图片,用少量的资源来显示大量或不确定的广告数量,不然如果用普通方法实现广告,难道10个广告用12个scrollview的contentsize去做,岂不是太浪费资源了

代码如下,实现所有数量的循环广告,当广告只有一个时,仅采用单图显示,>=2个广告时,自动采用三屏复用

这里添加图片的方式是通过网络请求,更新服务器上的广告,如果仅使用本地广告,可以将.m文件里的全部图片的添加方式

如:

self.endImageView.image = self.imageArray[endImageCount];

修改为

self.endImageView.image = [UIImage imageNamed:self.imageArray[endImageCount]];

然后在使用该类时,直接将本地图片的名字用数组传过去就行了,如
cview.imageArray = [[NSMutableArray alloc]initWithObjects:@"图片1",@"图片2",@"图片3", nil];

或者不改则使用方法如

NSArray *imageArr = [[NSArray alloc]initWithObjects:@"banner_理财.jpg",@"banner_惠普",@"banner_炒股", nil];

  for (int i=0; i<3; i++) {

    UIImage *cirImage1 = [UIImage imageNamed:imageArr[i]];

    [cirScrollView.imageArray addObject:cirImage1];

  }

如果图片给的是地址那可以用imageWithURL这个方法来获取图片。

下面讲从服务器获取的广告方式,请求服务器图片及解析这里就不讲了,仅从获取到的data数据后开始。

先新建一个类继承UIView。

.h文件

#import <UIKit/UIKit.h>

@interface CirculateScrollview : UIView

@property (nonatomic,strong)NSMutableArray *imageArray;//图片数组
@property (nonatomic,strong)UIScrollView *circulateScrollView;//广告

/*
 三屏复用广告
 适用范围:网络请求或固定本地的广告图片
    适用所有数量广告,广告>=2时自动采用三屏复用技术
 使用方法:例
 在需要添加广告的控制器里面
 
 CirculateScrollview *cview = [[CirculateScrollview alloc]initWithFrame:CGRectMake(0, 20, 320, 200)];
 for (int i=0; i<3; i++) {
 UIImage *image = [UIImage imageNamed:@"旅行图1"];//传进图片名字方式
 //UIImage *image = UIImage imageWithData:data];//传进data数据图片方式将服务器请求到的data数据图片转换成image形式再传输
 [cview.imageArray addObject:image];
 }
 [self.view addSubview:cview];
 
 */


/*
 图片转换NSData方法
 测试可用
 NSData * data = UIImageJPEGRepresentation(image, 1);
 */

@end

.m文件

实现方法是这三个成员变量,用来读取传输过来的图片在数组中的位置,三屏复用里,我们显示的位置是scrollview的中间位置,左边广告是全部广告的最后一个,中间显示第一个,右边的显示第二个,然后根据左滑成员变量递增,当变量递增到超过广告总数时,重新赋值第一个广告,而右滑递减,递减至-1时,即不在数组范围时,重新赋值广告数组的最后一个
#import "CirculateScrollview.h"

#define ViewWidth self.frame.size.width
#define ViewHeight self.frame.size.height
#define AllImageCount self.imageArray.count-1

@interface CirculateScrollview()<UIScrollViewDelegate>
{
  NSInteger endImageCount;//左边图片
  NSInteger oneImageCount;//中间图片[当前看到的图片]
  NSInteger secondImageCount;//右边图片
}
@property (nonatomic,strong)UIImageView *endImageView;
@property (nonatomic,strong)UIImageView *oneImageView;
@property (nonatomic,strong)UIImageView *secondImageView;
@property (nonatomic,strong)UIPageControl *pageCtl;

@end

@implementation CirculateScrollview


-(id)initWithFrame:(CGRect)frame
{
  self = [super initWithFrame:frame];
  if (self) {
    
  }
  return self;
}

-(NSMutableArray *)imageArray
{
  if (!_imageArray) {
    _imageArray = [[NSMutableArray alloc]init];
  }
  return _imageArray;
}

- (void)drawRect:(CGRect)rect {
  self.circulateScrollView = [[UIScrollView alloc]initWithFrame:CGRectMake(0, 0, ViewWidth, ViewHeight)];
  
  endImageCount = self.imageArray.count-1;
  oneImageCount = 0;
  secondImageCount = 1;
  
  self.circulateScrollView.showsHorizontalScrollIndicator = NO;
  self.circulateScrollView.pagingEnabled = YES;
  self.circulateScrollView.delegate = self;
  self.circulateScrollView.bounces = NO;
  
  self.circulateScrollView.contentOffset = CGPointMake(ViewWidth, 0);
  
  self.backgroundColor = [UIColor whiteColor];
  
  if (!self.imageArray.count) {
    NSLog(@"图片数组为空");
    return;
  }
  
  
  //若广告数量少于2张则不采用三屏复用技术
  if (self.imageArray.count<=1){
    self.circulateScrollView.contentSize = CGSizeMake(ViewWidth, ViewHeight);
    
    self.endImageView = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, ViewWidth, ViewHeight)];
    self.endImageView.image = self.imageArray[endImageCount];
    [self.circulateScrollView addSubview:self.endImageView];
    [self addSubview:self.circulateScrollView];
    
  }else{
    self.circulateScrollView.contentSize = CGSizeMake(ViewWidth*3, ViewHeight);
    
    //左
    self.endImageView = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, ViewWidth, ViewHeight)];
    self.endImageView.image = self.imageArray[endImageCount];
    [self.circulateScrollView addSubview:self.endImageView];
    //中
    self.oneImageView = [[UIImageView alloc]initWithFrame:CGRectMake(ViewWidth, 0, ViewWidth, ViewHeight)];
    self.oneImageView.image = self.imageArray[oneImageCount];
    [self.circulateScrollView addSubview:self.oneImageView];
    //右
    self.secondImageView = [[UIImageView alloc]initWithFrame:CGRectMake(ViewWidth*2, 0, ViewWidth, ViewHeight)];
    self.secondImageView.image = self.imageArray[secondImageCount];
    [self.circulateScrollView addSubview:self.secondImageView];
    
    
    [self addSubview:self.circulateScrollView];
    [self pageNumControl];
  }

}
//添加页符
-(void)pageNumControl
{
  self.pageCtl = [[UIPageControl alloc]initWithFrame:CGRectMake(0, ViewHeight-20, ViewWidth, 20)];
  self.pageCtl.backgroundColor = [UIColor lightGrayColor];
  self.pageCtl.currentPageIndicatorTintColor = [UIColor greenColor];
  self.pageCtl.pageIndicatorTintColor = [UIColor whiteColor];
  self.pageCtl.alpha = 0.7;
  self.pageCtl.numberOfPages = AllImageCount+1;
  [self addSubview:self.pageCtl];
}

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
  if (scrollView.contentOffset.x == 0) {
    endImageCount--;
    oneImageCount--;
    secondImageCount--;
    if (endImageCount<0) {
      endImageCount = AllImageCount;
    }else if (oneImageCount<0){
      oneImageCount = AllImageCount;
    }
    //适配2张图片
    if (secondImageCount<0){
      secondImageCount = AllImageCount;
    }
    //NSLog(@"endImageCount=%ld oneImageCount=%ld secondImageCount=%ld",endImageCount,oneImageCount,secondImageCount);
    
  }else if(scrollView.contentOffset.x == ViewWidth*2){
    endImageCount++;
    oneImageCount++;
    secondImageCount++;
    if (endImageCount>AllImageCount) {
      endImageCount = 0;
    }else if (oneImageCount>AllImageCount){
      oneImageCount = 0;
    }
    //适配2张图片
    if (secondImageCount>AllImageCount){
      secondImageCount = 0;
    }
  }
  //重新加载显示当前位置的图片
  scrollView.contentOffset = CGPointMake(ViewWidth, 0);
  self.endImageView.image = self.imageArray[endImageCount];
  self.oneImageView.image = self.imageArray[oneImageCount];
  self.secondImageView.image = self.imageArray[secondImageCount];
  self.pageCtl.currentPage = oneImageCount;
}

@end

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# iOS三屏复用循环广告  # iOS循环广告  # iOS服务器广告  # IOS中无限滚动Scrollview效果  # iOS中UIScrollView嵌套UITableView的实践教程  # iOS实现scrollview上拉显示Navbar下拉隐藏功能详解  # ios scrollview嵌套tableview同向滑动的示例  # iOS ScrollView实现自动布局的方法(适用Swift 3.0 )  # 复用  # 第一个  # 改则  # 的是  # 加载  # 惠普  # 就不  # 可以用  # 第二个  # 去做  # 只有一个  # 这篇  # 转换成  # 讲了  # 岂不是  # 这三个  # 能再  # 方法来  # 熟了  # 大家多多 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何在香港服务器上快速搭建免备案网站?  Laravel集合Collection怎么用_Laravel集合常用函数详解  Laravel如何处理表单验证?(Requests代码示例)  WordPress 子目录安装中正确处理脚本路径的完整指南  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  用yum安装MySQLdb模块的步骤方法  如何用AWS免费套餐快速搭建高效网站?  如何快速搭建高效WAP手机网站?  Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询  奇安信“盘古石”团队突破 iOS 26.1 提权  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  如何基于云服务器快速搭建个人网站?  使用Dockerfile构建java web环境  Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】  Laravel Blade模板引擎语法_Laravel Blade布局继承用法  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  Laravel模型事件有哪些_Laravel Model Event生命周期详解  Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】  js实现点击每个li节点,都弹出其文本值及修改  焦点电影公司作品,电影焦点结局是什么?  JavaScript模板引擎Template.js使用详解  如何用PHP快速搭建高效网站?分步指南  Laravel如何为API生成Swagger或OpenAPI文档  Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】  Laravel如何发送系统通知?(Notification渠道示例)  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】  创业网站制作流程,创业网站可靠吗?  企业网站制作这些问题要关注  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  iOS验证手机号的正则表达式  Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  香港服务器网站推广:SEO优化与外贸独立站搭建策略  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】  教学论文网站制作软件有哪些,写论文用什么软件 ?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  详解jQuery停止动画——stop()方法的使用  如何在阿里云虚拟服务器快速搭建网站?  教你用AI将一段旋律扩展成一首完整的曲子  Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】  Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧  html5如何实现懒加载图片_ intersectionobserver api用法【教程】  Win11怎样安装网易有道词典_Win11安装词典教程【步骤】