关闭

iOS 一步一步带你实现引导页

标签: ios引导页oc
3525人阅读 评论(2) 收藏 举报
分类:

这里写图片描述
直接上代码(简简单单)
创建一个控制器

.h
@protocol selectDelegate <NSObject>
- (void)click;
@end
@interface XTGuidePagesViewController : UIViewController
@property (nonatomic, strong) UIButton *btnEnter;
// 初始化引导页
- (void)initWithXTGuideView:(NSArray *)images;
// 版本信息判断
- (BOOL)isShow;
@property (nonatomic, assign) id<selectDelegate> delegate;
// 创建单利类
+ (instancetype)shareXTGuideVC;
.m
- (void)initWithXTGuideView:(NSArray *)images
{
    UIScrollView *gui = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, s_w, s_h)];
    gui.pagingEnabled = YES;
    // 隐藏滑动条
    gui.showsHorizontalScrollIndicator = NO;
    gui.showsVerticalScrollIndicator = NO;
    // 取消反弹
    gui.bounces = NO;
    for (NSInteger i = 0; i < images.count; i ++) {
        [gui addSubview:({
            self.btnEnter = [UIButton buttonWithType:UIButtonTypeCustom];
            self.btnEnter.frame = CGRectMake(s_w * i, 0, s_w, s_h);
            [self.btnEnter setImage:[UIImage imageNamed:images[i]] forState:UIControlStateNormal];;
            self.btnEnter;
        })];

        [self.btnEnter addSubview:({
            UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
            [btn setTitle:@"点击进入" forState:UIControlStateNormal];
            btn.frame = CGRectMake(s_w * i, s_h - 60, 100, 40);
            btn.center = CGPointMake(s_w / 2, s_h - 60);
            btn.backgroundColor = [UIColor lightGrayColor];
            [btn addTarget:self action:@selector(clickEnter) forControlEvents:UIControlEventTouchUpInside];
            btn;
        })];
    }
    gui.contentSize = CGSizeMake(s_w * images.count, 0);
    [self.view addSubview:gui];

    // pageControl
    self.pageControl = [[UIPageControl alloc] initWithFrame:CGRectMake(0, 0, s_w / 2, 30)];
    self.pageControl.center = CGPointMake(s_w / 2, s_h - 95);
    [self.view addSubview:self.pageControl];
    self.pageControl.numberOfPages = images.count;
}

单利

+ (instancetype)shareXTGuideVC
{
    static XTGuidePagesViewController *x = nil;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        x = [[XTGuidePagesViewController alloc] init];
    });
    return x;
}
- (void)clickEnter
{
    if (self.delegate != nil && [self.delegate respondsToSelector:@selector(click)]) {
        [self.delegate click];
    }
}
- (BOOL)isShow
{
    // 读取版本信息
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    NSString *localVersion = [user objectForKey:VERSION_INFO_CURRENT];
    NSString *currentVersion =[[NSBundle mainBundle].infoDictionary objectForKey:@"CFBundleShortVersionString"];
    NSLog(@"L ===%@", localVersion);
    NSLog(@"C ===%@", currentVersion);
    if (localVersion == nil || ![currentVersion isEqualToString:localVersion]) {
        [self saveCurrentVersion];
        return YES;
    }else
    {
        return NO;
    }
}
// 保存版本信息
- (void)saveCurrentVersion
{
    NSString *version =[[NSBundle mainBundle].infoDictionary objectForKey:@"CFBundleShortVersionString"];
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    [user setObject:version forKey:VERSION_INFO_CURRENT];
    [user synchronize];
}
#pragma mark - ScrollerView Delegate
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
    self.pageControl.currentPage = scrollView.contentOffset.x / s_w;
}

在app delegate中调用

NSArray *images = @[@"1", @"2", @"3"];
    if ([[[XTGuidePagesViewController alloc] init] isShow]) {
        self.window.rootViewController = [XTGuidePagesViewController shareXTGuideVC];
        [[XTGuidePagesViewController shareXTGuideVC] initWithXTGuideView:images];
        [XTGuidePagesViewController shareXTGuideVC].delegate = self;
    }else{
        [self click];
    }
- (void)click
{
    ViewController *vc = [[ViewController alloc] init];
    self.window.rootViewController = vc;
    [self.window.layer transitionWithAnimType:TransitionAnimTypeRamdom subType:TransitionSubtypesFromRamdom curve:TransitionCurveRamdom duration:2.0f];
}

还会持续更新, 喜欢的请关注

2
1
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

iOS启动时如何添加引导页面 (更新)

相信大家都看到过手机应用在启动的时候,都会有一个很漂亮的页面,在这个页面显示之后,如果你是第一次打开该应用还会有提示图片(如程序怎么使用等等),今天自己写了一个小demo 在此分享一下,可以给新学者一...
  • yudandan10
  • yudandan10
  • 2014-12-18 20:10
  • 45543

APP首次启动引导界面和启动界面设置——iOS开发

APP首次启动引导界面和启动界面设置——iOS开发。及NSUserDefaults的使用
  • Zsk_Zane
  • Zsk_Zane
  • 2015-07-28 20:30
  • 9661

iOS开发——如何做一个漂亮的引导页

对于一款App来说,引导页是必不可少的组成元素,每当用户第一次安装应用,或者更新一次应用后,首先引入眼帘的就是引导页。一个漂亮的引导页可以增加用户体验。今天我们来实现这个功能,demo我已经集成到  ...
  • CHENYUFENG1991
  • CHENYUFENG1991
  • 2015-11-25 16:39
  • 5435

关于引导页 iOS(蒙层)

对于写引导页有两个解决方案: 1,写个UIImageView子类。通过获得appDelegate将自己加载到appDelegate.window上。[appDelegate.window add...
  • sunqiliuyang
  • sunqiliuyang
  • 2014-12-24 16:00
  • 1073

iOS引导页实现(一)

目前多数app在启动时会有引导页,今天给大家介绍一种比较直观,能够快速实现的引导页实现方法 最终效果就是有一个全屏的引导页,页面底部有UIPageControl 用来指示当前引导页为第几个页面 其...
  • lwjok2007
  • lwjok2007
  • 2015-06-16 12:20
  • 25410

iOS最好用的引导页

最近项目结束的时候又要改引导页,之前写的启动页改起来太麻烦了,所以就直接封装一个,功能可能还不是很完善,但是感觉用起来也比较方便,在这里和大家分享一下。   这是github的下载地址:http...
  • YZ18337161090
  • YZ18337161090
  • 2017-04-01 15:43
  • 343

iOS 一步一步带你实现引导页

直接上代码(简简单单) 创建一个控制器.h @protocol selectDelegate - (void)click; @end @interface XTGuidePagesViewCont...
  • sinat_30162391
  • sinat_30162391
  • 2016-05-30 23:59
  • 3525

app引导页(背景图片切换加各个页面动画效果)

前言:不知不觉中又加班到了10点半,整个启动页面做了一天多的时间,一共有三个页面,每个页面都有动画效果,动画效果调试起来麻烦,既要跟ios统一,又要匹配各种不同的手机,然后产品经理还有可能在中途改需求...
  • ysh06201418
  • ysh06201418
  • 2015-11-02 15:45
  • 5051

ios基于UIScrollView实现滑动引导页

上代码前,我们先来看下实现的效果图: WelcomeViewController.h #import @interface WelcomeViewController : UIView...
  • chenzheng8975
  • chenzheng8975
  • 2016-07-22 09:55
  • 1744

Android自定义View的实现方法,带你一步步深入了解View(四)

本文转自:http://blog.csdn.net/guolin_blog/article/details/17357967 不知不觉中,带你一步步深入了解View系列的文章已经写到第四篇了...
  • feidie436
  • feidie436
  • 2018-01-09 09:22
  • 28
    个人资料
    • 访问:246436次
    • 积分:3971
    • 等级:
    • 排名:第9188名
    • 原创:135篇
    • 转载:9篇
    • 译文:0篇
    • 评论:43条
    我的微博
    公众号
      我的微信公众号
      为你推荐最新的博文~更有惊喜等着你
    博客专栏