scrollView封装广告轮播示例代码

本文详细介绍了一种自定义的轮播图组件PJXScrollView的实现过程,该组件使用Objective-C编写,适用于iOS平台。文章深入讲解了如何通过UIScrollView创建并管理轮播图的图片显示,包括图片的加载、切换和循环播放功能。此外,还介绍了如何添加UIPageControl来指示当前页面的位置。

#import <UIKit/UIKit.h>

 

@interface PJXScrollView : UIScrollView

-(void)setBannerImageArray:(NSArray*)imageArray;

-(void)addPageControl;

@end

 

 

#import "PJXScrollView.h"

#define SCROLL_VIEW_WIDTH  self.bounds.size.width

#define SCROLL_VIEW_HEIGHT self.bounds.size.height

#define SCROLL_VIEW_Y self.bounds.origin.y

@interface PJXScrollView()<UIScrollViewDelegate>{

    UIImageView *_leftImageView;

    UIImageView *_centerImageView;

    UIImageView *_rightImageView;

    

    NSArray *_imageArray;

    

    CGFloat willBeginContentOffsetX;

    CGFloat willEndContentOffsetX;

    CGFloat endContentOffsetX;

    

    NSInteger _currentImageIndex;

    UIPageControl *_pageControl;

}

 

@end

@implementation PJXScrollView

 

-(instancetype)initWithFrame:(CGRect)frame

{

    self = [super initWithFrame:frame];

    if (self) {

        [self _initScrollViewStyle];

        [self _createImageView];

        

    }

    return self;

}

 

 

-(void)_initScrollViewStyle{

    //反弹效果

    self.bounces = NO;

    

    //设置滚动范围

    self.contentSize = CGSizeMake(SCROLL_VIEW_WIDTH*3,SCROLL_VIEW_HEIGHT );

}

 

-(void)_createImageView

{

    _leftImageView = [[UIImageView alloc]initWithFrame:CGRectMake(SCROLL_VIEW_WIDTH*0, 0, SCROLL_VIEW_WIDTH, SCROLL_VIEW_HEIGHT)];

    [self addSubview:_leftImageView];

    

     _centerImageView = [[UIImageView alloc]initWithFrame:CGRectMake(SCROLL_VIEW_WIDTH*1, 0, SCROLL_VIEW_WIDTH, SCROLL_VIEW_HEIGHT)];

    [self addSubview:_centerImageView];

    

    _rightImageView = [[UIImageView alloc]initWithFrame:CGRectMake(SCROLL_VIEW_WIDTH*2, 0, SCROLL_VIEW_WIDTH, SCROLL_VIEW_HEIGHT)];

    [self addSubview:_rightImageView];

}

 

-(void)setBannerImageArray:(NSArray*)imageArray

{

    _imageArray = imageArray;

    _leftImageView.image = [UIImage imageNamed:_imageArray[0]];

    _centerImageView.image = [UIImage imageNamed:_imageArray[1]];

    _rightImageView.image  = [UIImage imageNamed:_imageArray[2]];

}

 

//监听滚动

//手开始拖拽的时候调用,

-(void)scrollViewWillBeginDragging:(UIScrollView *)scrollView

{

    willBeginContentOffsetX = scrollView.contentOffset.x;

    

}

-(void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset{

    willEndContentOffsetX = scrollView.contentOffset.x;

}

 

//停止滚动时调用

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView

{

    endContentOffsetX = scrollView.contentOffset.x;

    

    //实现广告的循环播放

    if(willEndContentOffsetX > endContentOffsetX &&

       willEndContentOffsetX < willBeginContentOffsetX){

        

        //画面从左往右移动

        if (_currentImageIndex > 0) {

            _currentImageIndex--;

        }else{

            _currentImageIndex = _imageArray.count -1;

        }

        

    }else if(willEndContentOffsetX < endContentOffsetX &&

             willEndContentOffsetX > willBeginContentOffsetX){

        //从右往左

        if (_currentImageIndex < _imageArray.count-1) {

            _currentImageIndex ++;

        }else{

            _currentImageIndex = 0;

        }

    }else{

        

    }

    //改变当前页码

    _pageControl.currentPage = _currentImageIndex;

    NSInteger leftPage = _currentImageIndex-1;

    if (leftPage < 0) {

        leftPage = _imageArray.count - 1;

    }

    

    NSInteger rightPage = _currentImageIndex + 1;

    if (rightPage >= _imageArray.count-1) {

        rightPage = 0;

    }

    

    //显示图片

    _leftImageView.image = [UIImage imageNamed:_imageArray[leftPage]];

    _centerImageView.image = [UIImage imageNamed:_imageArray[_currentImageIndex]];

    _rightImageView.image = [UIImage imageNamed:_imageArray[rightPage]];

    

    self.contentOffset = CGPointMake(SCROLL_VIEW_WIDTH, 0);

    

}

-(void)addPageControl{

    _pageControl = [[UIPageControl alloc] init];

    _pageControl.frame = CGRectMake(SCROLL_VIEW_WIDTH - 20*_imageArray.count, SCROLL_VIEW_Y+40, 20*_imageArray.count, 20);

    

    //设置页码数

    _pageControl.numberOfPages  = _imageArray.count;

    

    //设置当前页码数

    _pageControl.currentPage = 0;

    

    //设置能否能够点击

    _pageControl.enabled = NO;

    

    //设置颜色

    _pageControl.pageIndicatorTintColor = [UIColor redColor];

    _pageControl.currentPageIndicatorTintColor = [UIColor blueColor];

    

    //绑定页码控件

    [self performSelector:@selector(bindPageControl) withObject:nil afterDelay:0.1f];

}

 

-(void)bindPageControl{

    [[self superview] addSubview:_pageControl];

}

@end

 

转载于:https://www.cnblogs.com/PJXWang/p/5898798.html

基于径向基函数神经网络RBFNN的自适应滑模控制学习(Matlab代码实现)内容概要:本文介绍了基于径向基函数神经网络(RBFNN)的自适应滑模控制方法,并提供了相应的Matlab代码实现。该方法结合了RBF神经网络的非线性逼近能力和滑模控制的强鲁棒性,用于解决复杂系统的控制问题,尤其适用于存在不确定性和外部干扰的动态系统。文中详细阐述了控制算法的设计思路、RBFNN的结构与权重更新机制、滑模面的构建以及自适应律的推导过程,并通过Matlab仿真验证了所提方法的有效性和稳定性。此外,文档还列举了大量相关的科研方向和技术应用,涵盖智能优化算法、机器学习、电力系统、路径规划等多个领域,展示了该技术的广泛应用前景。; 适合人群:具备一定自动控制理论基础和Matlab编程能力的研究生、科研人员及工程技术人员,特别是从事智能控制、非线性系统控制及相关领域的研究人员; 使用场景及目标:①学习和掌握RBF神经网络与滑模控制相结合的自适应控制策略设计方法;②应用于电机控制、机器人轨迹跟踪、电力电子系统等存在模型不确定性或外界扰动的实际控制系统中,提升控制精度与鲁棒性; 阅读建议:建议读者结合提供的Matlab代码进行仿真实践,深入理解算法实现细节,同时可参考文中提及的相关技术方向拓展研究思路,注重理论分析与仿真验证相结合。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值