ios 引导页

作者: 整个夏天 | 来源:发表于2017-02-28 14:50 被阅读192次

目标功能

  1. 能够快速实现普通引导页功能.
  2. 提供自定义view的加载模式.
  3. 提供特定样式的加载模式,只需要配置即可.

设计思路

  1. 创建一个类SMIntroductionView,继承于UIView.
  2. 在SMIntroductionView.h中定义类型用来区分.定义协议,用来回调.定义参数,用来配置.
  3. 在SMIntroductionView.m中定义一个ScrollView容器,用来装载可以滑动的view,实现ScrollView的协议回调,用来监听滑动位置,从而做出相应的变化.

SMIntroductionView.h

定义类型

typedef NS_ENUM(NSInteger,SMIntroductionType) {
    SMIntroductionTypeByYou=0,//加载自定义view
    SMIntroductionTypeAutoFir//自动填充内容模式1,该模式下就不要再设置isNeedBgColor的值了,需要为YES,格式为IntroductionViewFir,只需要替换imgFir文件夹中的图片即可,图片名字需要保持相同
};

定义SMIntroductionDelegate协议

@protocol SMIntroductionDelegate<NSObject>
@optional
-(NSInteger)SMIntroductionGetTotalNum:(SMIntroductionView*)view;//得到总共的引导页页数,自定义模式下必须实现

-(UIView*)SMIntroduction:(SMIntroductionView*)view getView:(NSInteger)index;//根据下标获取对应的view,自定义模式下必须实现

-(UIColor*)SMIntroduction:(SMIntroductionView*)view getColorWithIndex:(NSInteger)index;//根据下标获取对应的背景颜色,自定义模式下如果需要背景颜色渐变,必须实现

-(void)SMIntroductionGo:(SMIntroductionView*)view;//当SMIntroductionTypeAutoFir模式时,点击开始体验的回调

-(void)SMIntroduction:(SMIntroductionView*)view selectIndex:(NSInteger)index;//滑动到某一个界面时候的回调

@end

定义参数

@property(nonatomic,weak)id<SMIntroductionDelegate> delegate;

@property(nonatomic,assign)SMIntroductionType typeModel;//设置类型,默认为SMIntroductionTypeByYou自定义模式

@property(nonatomic,assign)BOOL isNeedBgColor;//是否需要背景颜色的渐变效果,如果需要显示在控件中的view背景必须为透明颜色

@property(nonatomic,strong)UIPageControl * pageControl;//指示器,自定义模式可以自己设置指示器颜色,固定模式就不要设置了

@property(nonatomic,assign)int totalNum;

@property (assign, nonatomic) BOOL needPassButton;//是否需要跳过按钮

提供开始方法

-(void)load;

SMIntroductionView.m

初始化

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

-(void)awakeFromNib{
    [super awakeFromNib];
    [self SMIntroductionInit];
}

-(void)SMIntroductionInit{
    //scrollView初始化
    self.scrollView=[[UIScrollView alloc]init];
    self.scrollView.pagingEnabled=YES;
    self.scrollView.delegate=self;
    self.scrollView.showsHorizontalScrollIndicator=NO;
    self.scrollView.showsVerticalScrollIndicator=NO;
    self.scrollView.bounces=NO;
    [self addSubview:self.scrollView];
    
    self.pageControl=[[UIPageControl alloc]init];
    self.bgColors=[[NSMutableArray alloc]init];
    self.childViews=[[NSMutableArray alloc]init];
    [self addSubview:self.pageControl];
    
    [self.endBtn addTarget:self action:@selector(passBtn:) forControlEvents:UIControlEventTouchUpInside];
    [self bringSubviewToFront:_endBtn];
}

布局scrollView

-(void)layoutSubviews{
    self.w=self.frame.size.width;
    self.h=self.frame.size.height;
    self.scrollView.frame=CGRectMake(0, 0, self.w, self.h);
    for (int i=0; i<self.childViews.count; i++) {
        UIView * view=self.childViews[i];
        view.frame=CGRectMake(i*self.w, 0, self.w, self.h);
    }
    [self.scrollView setContentSize:CGSizeMake(self.w*self.childViews.count, self.h)];
    self.pageControl.frame=CGRectMake(0, self.h-40, self.w, 20);
    self.pageControl.currentPageIndicatorTintColor=[UIColor whiteColor];
    self.pageControl.userInteractionEnabled = 0;
}

实现UIScrollView的协议方法

-(void)scrollViewDidScroll:(UIScrollView *)scrollView{
    CGPoint  offPoint=scrollView.contentOffset;
    int pointX=offPoint.x;
    self.indexPage=pointX/self.w;
    if (pointX%self.w>=0.5*self.w) {
        self.indexPage+=1;
    }
    self.pageControl.currentPage=self.indexPage;
    
    if (self.isNeedBgColor&&self.bgColors.count>2) {
        [self setEndStartColor:pointX];
        
        
        NSDictionary *colorDicFir= [self getRGBDictionaryByColor:self.firColor];
        float r_f = [colorDicFir[@"R"] floatValue] * 255;
        float g_f = [colorDicFir[@"G"] floatValue] * 255;
        float b_f = [colorDicFir[@"B"] floatValue] * 255;
        
        NSDictionary *colorDicSec= [self getRGBDictionaryByColor:self.secColor];
        float r_s = [colorDicSec[@"R"] floatValue] * 255;
        float g_s = [colorDicSec[@"G"] floatValue] * 255;
        float b_s = [colorDicSec[@"B"] floatValue] * 255;
        
        
        
        float pointRela=offPoint.x-pointX/self.w*self.w;
        float percent=pointRela/self.w;
        
        float r_r=(r_f+(r_s-r_f)*percent)/255.0;
        float g_r=(g_f+(g_s-g_f)*percent)/255.0;
        float b_r=(b_f+(b_s-b_f)*percent)/255.0;
        
        self.nowColor=[UIColor colorWithRed:r_r green:g_r blue:b_r alpha:1];
        self.scrollView.backgroundColor=self.nowColor;
    }
}

-(void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{
    if (self.delegate&&[self.delegate respondsToSelector:@selector(SMIntroduction:selectIndex:)]) {
        [self.delegate SMIntroduction:self selectIndex:self.indexPage];
        
    }
    if (scrollView.contentOffset.x == 4 * SCREEN_W) {
        [self.passButton removeFromSuperview];
    }
    else{
        [self addSubview:_passButton];
    }
    if (scrollView == self.scrollView) {
        NSLog(@"%f",scrollView.contentOffset.x);

    }
}

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
    if (self.delegate&&[self.delegate respondsToSelector:@selector(SMIntroduction:selectIndex:)]) {
        [self.delegate SMIntroduction:self selectIndex:self.indexPage];
        NSLog(@"%d",self.indexPage);
        if (self.indexPage == self.childViews.count - 1) {
            self.passButton.hidden = 1;
        }
        else
        {
            self.passButton.hidden = 0;
        }
    }
    
}

一些颜色渐变辅助性的方法

#pragma mark 获取rgb值
- (NSDictionary *)getRGBDictionaryByColor:(UIColor *)originColor
{
    CGFloat r=0,g=0,b=0,a=0;
    if ([self respondsToSelector:@selector(getRed:green:blue:alpha:)]) {
        [originColor getRed:&r green:&g blue:&b alpha:&a];
    }else {
        const CGFloat *components = CGColorGetComponents(originColor.CGColor);
        r = components[0];
        g = components[1];
        b = components[2];
        a = components[3];
    }
    return @{@"R":@(r),@"G":@(g),@"B":@(b),@"A":@(a)};
}

#pragma mark 设置滑动首尾颜色值
-(void)setEndStartColor:(int)pointX{
    
    int index=pointX/self.w;
    if (index==self.childViews.count-1) {
        self.firColor=self.bgColors[index];
    }else{
        self.firColor=self.bgColors[index];
        self.secColor=self.bgColors[index+1];
    }
    
//    if (pointX<self.w) {
//        self.firColor=self.bgColors[0];
//        self.secColor=self.bgColors[1];
//    }else if (self.w<=pointX&&pointX<self.w*2){
//        self.firColor=self.bgColors[1];
//        self.secColor=self.bgColors[2];
//    }else if (self.w*2<=pointX&&pointX<self.w*3){
//        self.firColor=self.bgColors[2];
//        self.secColor=self.bgColors[3];
//    }else if (pointX==self.w*3){
//        self.firColor=self.bgColors[3];
//    }
}

//判断滑动的方向0--左;1--右
-(int)getOritation:(int)pointX{
    int oritation=0;
    if (pointX>self.lastX) {
        oritation=1;
    }
    self.lastX=pointX;
    return oritation;
}

类辅助方法

#pragma mark 点击进入
//点击最后一页开始按钮事件
-(void)goClick:(id)sender{
    if (self.delegate&&[self.delegate respondsToSelector:@selector(SMIntroductionGo:) ]) {
        [self.delegate SMIntroductionGo:self];
    }
    [self removeFromSuperview];
}

//开始加载方法
-(void)load{
    [self createPassButton];

    if (self.typeModel==SMIntroductionTypeByYou) {
        if (self.delegate&&[self.delegate respondsToSelector:@selector(SMIntroductionGetTotalNum:)]) {
            self.totalNum=(int)[self.delegate SMIntroductionGetTotalNum:self];
        }
        self.pageControl.numberOfPages=self.totalNum;
        if (self.delegate&&[self.delegate respondsToSelector:@selector(SMIntroduction:getView:)]) {
            for (int i=0; i<self.totalNum; i++) {
                UIView * view=[self.delegate SMIntroduction:self getView:i];
                [self.childViews addObject:view];
                [self.scrollView addSubview:view];
            }
        }
        
        if (self.isNeedBgColor&&self.delegate&&[self.delegate respondsToSelector:@selector(SMIntroduction:getColorWithIndex:)]) {
            self.bgColors=[[NSMutableArray alloc]init];
            for (int i=0; i<self.totalNum; i++) {
                [self.bgColors addObject:[self.delegate SMIntroduction:self getColorWithIndex:i]];
            }
            
            self.scrollView.backgroundColor=self.bgColors[0];
        }
    }else if (self.typeModel==SMIntroductionTypeAutoFir){
        self.pageControl.numberOfPages=4;
        self.isNeedBgColor=YES;
        NSArray * imgNames=@[@"second",@"first",@"third",@"four"];
        for (int i=0; i<4; i++) {
            UIView * view=[self getViewFromLib:@"IntroductionViewFir" withOwer:self];
            view.backgroundColor=[UIColor clearColor];
            [self.childViews addObject:view];
            [self.scrollView addSubview:view];
            UIImageView * imgTop=[view viewWithTag:1];
            NSString * png=[NSString stringWithFormat:@"%@%@%@",@"guide_",imgNames[i],@"_top_image.png"];
            imgTop.image=[UIImage imageNamed:png];
            UIImageView * imgCenter=[view viewWithTag:2];
            imgCenter.image=[UIImage imageNamed:[NSString stringWithFormat:@"%@%@%@",@"guide_",imgNames[i],@"_middle_image.png"]];
            UIImageView * imgBottom=[view viewWithTag:3];
            imgBottom.image=[UIImage imageNamed:[NSString stringWithFormat:@"%@%@%@",@"guide_",imgNames[i],@"_bottom_person.png"]];
            UIButton * btn=[view viewWithTag:4];
            if (i!=3) {
                btn.hidden=YES;
            }

            [btn addTarget:self action:@selector(goClick:) forControlEvents:UIControlEventTouchUpInside];
        }
        
        
        
        UIColor * firColor=[UIColor colorWithRed:0.5922 green:0.7529 blue:0.3373 alpha:1.0];
        UIColor * secColor=[UIColor colorWithRed:0.949 green:0.7059 blue:0.2941 alpha:1.0];
        UIColor * thirdColor=[UIColor colorWithRed:0.9373 green:0.5725 blue:0.6588 alpha:1.0];
        UIColor * fourthColor=[UIColor colorWithRed:0.6392 green:0.6 blue:0.8275 alpha:1.0];
        
        self.bgColors=[[NSMutableArray alloc]initWithObjects:firColor,secColor,thirdColor,fourthColor, nil];
        self.scrollView.backgroundColor=self.bgColors[0];
        
    }
    
}

//创建跳过按钮
-(void)createPassButton
{
    _passButton = [[UIButton alloc]init];
    _passButton.frame = CGRectMake(SCREEN_W - 50 - 15, 25, 50, 25);
    _passButton.titleLabel.adjustsFontSizeToFitWidth = 1;
    [_passButton setTitle:@"跳过" forState:UIControlStateNormal];
    [_passButton setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
    [_passButton setFont:[UIFont systemFontOfSize:13]];
    _passButton.layer.cornerRadius = 3;
    _passButton.layer.masksToBounds = 1;
    _passButton.layer.borderWidth = 1;
    _passButton.layer.borderColor = [UIColor whiteColor].CGColor;
    [_passButton addTarget:self action:@selector(passBtn:) forControlEvents:UIControlEventTouchUpInside];
    [self addSubview:_passButton];
}

//跳过按钮点击事件
-(IBAction)passBtn:(id)sender
{
    if (self.delegate&&[self.delegate respondsToSelector:@selector(SMIntroductionGo:) ]) {
        [self.delegate SMIntroductionGo:self];
    }
    [self removeFromSuperview];
}

//从xib加载view
-(UIView*)getViewFromLib:(NSString*)libName withOwer:(id)owner{
    return [[[NSBundle mainBundle] loadNibNamed:libName owner:owner options:nil] lastObject];
}

使用方法

xib中设置好布局,并将Class改为SMIntroductionView

xib设置.png

关联到你的Controller中

@property (weak, nonatomic) IBOutlet SMIntroductionView *introductionView;

实现各种协议

//固定模式1下点击开始按钮回调
-(void)SMIntroductionGo:(SMIntroductionView *)view{
    [self topMoreClick];
}
//当前选中的页面
-(void)SMIntroduction:(SMIntroductionView *)view selectIndex:(NSInteger)index{
    
}
//自定义模式下得到页面总数,自定义模式必须实现
-(NSInteger)SMIntroductionGetTotalNum:(SMIntroductionView *)view{
    return 4;
}

//自定义模式下得到每页的view
-(UIView*)SMIntroduction:(SMIntroductionView *)view getView:(NSInteger)index{
    UILabel * label=[[UILabel alloc]init];
    label.text=[NSString stringWithFormat:@"这是第%ld页",(long)index];
    
    return label;
}
//自定义模式下,需要背景渐变功能的情况下必须实现
-(UIColor*)SMIntroduction:(SMIntroductionView *)view getColorWithIndex:(NSInteger)index{
    if (index==0) {
        return [UIColor redColor];
    }else if (index==1){
        return [UIColor greenColor];
    }else if (index==2){
        return [UIColor blueColor];
    }else {
        return [UIColor brownColor];
    }
}

进行简单的设置并开始加载

self.introductionView.delegate=self;//设置协议
    self.introductionView.typeModel=SMIntroductionTypeAutoFir;//设置展示类型
//    self.introductionView.typeModel=SMIntroductionTypeByYou;
//    self.introductionView.isNeedBgColor=YES;//设置是否需要背景颜色渐变
    [self.introductionView load];//开始加载

效果图

自定义界面 样式1

源码地址

https://github.com/StoneMover/SMLeadPage.git

相关文章

  • ios引导页

    首先修改 App Transport Security SettingsAllow Arbitrary Loads...

  • iOS 引导页

    在AppDelegate.m中:我们需要两个Viewcongtroller来实现;myViewController...

  • ios 引导页

    目标功能 能够快速实现普通引导页功能. 提供自定义view的加载模式. 提供特定样式的加载模式,只需要配置即可. ...

  • iOS引导页

    在我们项目中经常会用到引导页,引导页主要功能就是向用户展示你的产品。 这是我写的一个例子的效果图(图片是随便找的):

  • iOS引导页

    引导页是App中的基本功能,指导用户理解某些操作或版本变化等等。 引导页可能出现在任何时候,页面内容会根据可交互度...

  • iOS引导页、启动页

    前言 这里使用 launchScreen 、.storyboard 文件创建启动图和引导页。首次打开项目或者更新后...

  • iOS 引导页适配

    1,图片适配,最早以前是自己命名规范,例如@1x,@2x,@3x等,3套图基本上就够用了 2,在iPhone X之...

  • ios开发,引导页

    在viewController.m里面 @interface ViewController () { UISc...

  • iOS 引导页 --LaunchIntroduction

    一、前言 引导页,一个酷炫的页面,基本上每个应用程序刚安装后启动的时候都会有一个引导页,用于引导用户使用APP,怎...

  • ios 引导页 新闻

    首先修改 App Transport Security Settings Allow Arbitrary Load...

网友评论

    本文标题:ios 引导页

    本文链接:https://www.haomeiwen.com/subject/grlxgttx.html