代码地址如下:
http://www.demodashi.com/demo/11246.html

一、准备工作

1.先用时ps工具制作好图片

2.然后计算好每张图片通过滑动视图的偏移量来改变图片的位置

3.理顺该demo将需要的一些逻辑顺序

二、程序实现

项目中不需要配置任何东西,全都是逻辑方面的东西,只要思维逻辑清楚,我们就开始干



由上面可以知道,其实该demo的代码不是很大。

1、所有的图片的初始位置进行定义

-(void)createUI
{
//1
pageoneImage1 = [[UIImageView alloc]initWithFrame:CGRectMake(0, 40, ScreenWidth, 30)];
pageoneImage1.image = [UIImage imageNamed:@"1_01"];
[imageView1 addSubview:pageoneImage1]; pageoneImage2 = [[UIImageView alloc]initWithFrame:CGRectMake(0, 100, ScreenWidth, ScreenWidth)];
pageoneImage2.image = [UIImage imageNamed:@"1_02"];
[imageView1 addSubview:pageoneImage2]; pageoneImage3 = [[UIImageView alloc]initWithFrame:CGRectMake(0, 120, ScreenWidth, ScreenWidth/4)];
pageoneImage3.image = [UIImage imageNamed:@"1_03"];
[imageView1 addSubview:pageoneImage3]; pageoneImage4 = [[UIImageView alloc]initWithFrame:CGRectMake(ScreenWidth/6, CGRectGetMaxY(pageoneImage2.frame)+10, ScreenWidth*2/3, 50)];
pageoneImage4.image = [UIImage imageNamed:@"1_04"];
[imageView1 addSubview:pageoneImage4]; pageoneImage5 = [[UIImageView alloc]initWithFrame:CGRectMake(40, CGRectGetMaxY(pageoneImage4.frame)+10, ScreenWidth-80, 40)];
pageoneImage5.image = [UIImage imageNamed:@"1_05"];
[imageView1 addSubview:pageoneImage5]; //2
pageoneImage1 = [[UIImageView alloc]initWithFrame:CGRectMake(0, 40, ScreenWidth, 30)];
pageoneImage1.image = [UIImage imageNamed:@"1_01"];
[imageView2 addSubview:pageoneImage1]; pagetwoImage1 = [[UIImageView alloc]initWithFrame:CGRectMake(-ScreenWidth/2, 100-ScreenWidth/2, ScreenWidth*2, ScreenWidth*2)];
pagetwoImage1.image = [UIImage imageNamed:@"2_01"];
[imageView2 addSubview:pagetwoImage1]; pagetwoImage2 = [[UIImageView alloc]initWithFrame:CGRectMake(0, CGRectGetMaxY(pagetwoImage1.frame)+10, ScreenWidth, 60)];
pagetwoImage2.image = [UIImage imageNamed:@"2_02"];
[imageView2 addSubview:pagetwoImage2]; pagetwoImage3 = [[UIImageView alloc]initWithFrame:CGRectMake(0, CGRectGetMaxY(pagetwoImage2.frame)+10, ScreenWidth, 30)];
pagetwoImage3.image = [UIImage imageNamed:@"2_03"];
[imageView2 addSubview:pagetwoImage3]; //3
pageoneImage1 = [[UIImageView alloc]initWithFrame:CGRectMake(0, 40, ScreenWidth, 30)];
pageoneImage1.image = [UIImage imageNamed:@"1_01"];
[imageView3 addSubview:pageoneImage1]; pagethreeImage1 = [[UIImageView alloc]initWithFrame:CGRectMake(0, 100, ScreenWidth, ScreenWidth*31/36)];
pagethreeImage1.image = [UIImage imageNamed:@"3_01"];
[imageView3 addSubview:pagethreeImage1]; pagethreeImage2 = [[UIImageView alloc]initWithFrame:CGRectMake(ScreenWidth, 100, ScreenWidth, ScreenWidth*31/36)];
pagethreeImage2.image = [UIImage imageNamed:@"3_02"];
[imageView3 addSubview:pagethreeImage2]; pagethreeImage3 = [[UIImageView alloc]initWithFrame:CGRectMake(ScreenWidth/2, 100, ScreenWidth, ScreenWidth*31/36)];
pagethreeImage3.image = [UIImage imageNamed:@"3_03"];
[imageView3 addSubview:pagethreeImage3]; pagethreeImage4 = [[UIImageView alloc]initWithFrame:CGRectMake(10, ScreenHeight, ScreenWidth-20, 60)];
pagethreeImage4.image = [UIImage imageNamed:@"3_04"];
pagethreeImage4.alpha = 0;
[imageView3 addSubview:pagethreeImage4]; pagethreeImage5 = [[UIImageView alloc]initWithFrame:CGRectMake(0, CGRectGetMaxY(pagethreeImage4.frame)+15, ScreenWidth, 40)];
pagethreeImage5.image = [UIImage imageNamed:@"3_05"];
pagethreeImage5.alpha = 0;
[imageView3 addSubview:pagethreeImage5]; //5
pagefiveImage1 = [[UIImageView alloc]initWithFrame:CGRectMake(15, 50-300, ScreenWidth-30, 70)];
pagefiveImage1.image = [UIImage imageNamed:@"5_01"];
[imageView5 addSubview:pagefiveImage1]; pagefiveImage2 = [[UIImageView alloc]initWithFrame:CGRectMake(55, CGRectGetMaxY(pagefiveImage1.frame)+10-300, ScreenWidth-110, 10)];
pagefiveImage2.image = [UIImage imageNamed:@"5_02"];
pagefiveImage2.alpha = 0;
[imageView5 addSubview:pagefiveImage2]; pagefiveImage3 = [[UIImageView alloc]initWithFrame:CGRectMake(ScreenWidth/4, ScreenHeight-ScreenWidth/2-60+300, ScreenWidth/2, ScreenWidth/4)];
pagefiveImage3.image = [UIImage imageNamed:@"5_03"];
pagefiveImage3.alpha = 0;
[imageView5 addSubview:pagefiveImage3]; pagefiveImage4 = [[UIImageView alloc]initWithFrame:CGRectMake(-ScreenWidth/2, ScreenHeight-ScreenWidth*5/4, ScreenWidth*4, ScreenWidth*4)];
pagefiveImage4.image = [UIImage imageNamed:@"5_05"];
pagefiveImage4.alpha = 0;
[self rotate360DegreeWithImageView:pagefiveImage4];
[imageView5 addSubview:pagefiveImage4]; imgView = [[UIImageView alloc]initWithFrame:CGRectMake(50, ScreenHeight-ScreenWidth*4/5, 30-30, 30-30)];
[self tomAnimationWithName:@"run" count:9];
imgView.alpha = 0;
[imageView5 addSubview:imgView];
}

2、初始化scrollView

- (void)setupScrollView
{
// 添加scrollView
UIScrollView *scrollView = [[UIScrollView alloc] init];
scrollView.frame = self.view.bounds;
CGFloat contentW = scrollView.bounds.size.width * XXNewfeatureImageCount;
[self.view addSubview:scrollView]; scrollView.contentSize = CGSizeMake(contentW, 0);
scrollView.pagingEnabled = YES;
scrollView.bounces = NO;
scrollView.showsHorizontalScrollIndicator = NO;
scrollView.delegate = self; // 添加图片
CGFloat imageW = scrollView.bounds.size.width;
CGFloat imageH = scrollView.bounds.size.height; imageView1 = [[UIImageView alloc] init];
imageView1.frame = CGRectMake(0 * imageW, 0, imageW, imageH);
[scrollView addSubview:imageView1]; imageView2 = [[UIImageView alloc] init];
imageView2.frame = CGRectMake(1 * imageW, 0, imageW, imageH);
imageView2.alpha = 0;
[scrollView addSubview:imageView2]; imageView3 = [[UIImageView alloc] init];
imageView3.frame = CGRectMake(2 * imageW, 0, imageW, imageH);
[scrollView addSubview:imageView3]; imageView5 = [[UIImageView alloc] init];
imageView5.frame = CGRectMake(3 * imageW, 0, imageW, imageH);
imageView5.userInteractionEnabled = YES;
imageView5.alpha = 0;
[scrollView addSubview:imageView5]; // 添加跳转按钮
UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
button.frame = CGRectMake(0, 0, 150, 30);
[button setTitle:@"进入APP" forState:UIControlStateNormal];
button.layer.borderWidth = 1.0;
button.layer.borderColor = [UIColor colorWithWhite:0.915 alpha:1.000].CGColor;
button.titleLabel.font = [UIFont systemFontOfSize:14.0];
[button addTarget:self action:@selector(getstart) forControlEvents:UIControlEventTouchUpInside];
CGFloat centerX = imageView5.bounds.size.width * 0.5;
CGFloat centerY = imageView5.bounds.size.height - 88;
button.center = CGPointMake(centerX, centerY);
[imageView5 addSubview:button];
}

UIScrollViewDelegate method

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
offsetX = scrollView.contentOffset.x;
NSLog(@"%f",offsetX);
int page = offsetX / scrollView.bounds.size.width + 0.5; #pragma mark --- 此处写动画
if (offsetX <= ScreenWidth/2) {
[self firstPage];
}
else if (offsetX > ScreenWidth/2 && offsetX <= ScreenWidth+ScreenWidth/2) {
[self secondPage];
}
else if (offsetX > ScreenWidth+ScreenWidth/2 && offsetX <= ScreenWidth*2+ScreenWidth/2) {
[self thirdPage];
}
else if (offsetX > ScreenWidth*2+ScreenWidth/2 && offsetX <= ScreenWidth*3+ScreenWidth/2) {
[self lastPage];
} self.pageControl.currentPage = page;
}

3、gif的动画和旋转动画

#pragma mark --- UIImageView显示gif动画
- (void)tomAnimationWithName:(NSString *)name count:(NSInteger)count
{
// 如果正在动画,直接退出
if ([imgView isAnimating]) return;
// 动画图片的数组
NSMutableArray *arrayM = [NSMutableArray array];
// 添加动画播放的图片
for (int i = 0; i < count; i++) {
// 图像名称
NSString *imageName = [NSString stringWithFormat:@"%@%d.png", name, i+1];
// ContentsOfFile需要全路径
NSString *path = [[NSBundle mainBundle] pathForResource:imageName ofType:nil];
UIImage *image = [UIImage imageWithContentsOfFile:path];
[arrayM addObject:image];
}
// 设置动画数组
imgView.animationImages = arrayM;
// 重复1次
imgView.animationRepeatCount = 0;
// 动画时长
imgView.animationDuration = imgView.animationImages.count * 0.05;
// 开始动画
[imgView startAnimating];
} #pragma mark --- 旋转动画
- (void)rotate360DegreeWithImageView:(UIImageView *)imageView
{
CABasicAnimation *animation = [ CABasicAnimation
animationWithKeyPath: @"transform" ];
animation.fromValue = [NSValue valueWithCATransform3D:CATransform3DIdentity];
//围绕Z轴旋转,垂直与屏幕
animation.toValue = [ NSValue valueWithCATransform3D:
CATransform3DMakeRotation(M_PI, 0.0, 0.0, 1.0) ];
animation.duration = 5;
//旋转效果累计,先转180度,接着再旋转180度,从而实现360旋转
animation.cumulative = YES;
animation.repeatCount = MAXFLOAT;
//在图片边缘添加一个像素的透明区域,去图片锯齿
CGRect imageRrect = CGRectMake(0, 0,imageView.frame.size.width, imageView.frame.size.height);
UIGraphicsBeginImageContext(imageRrect.size);
[imageView.image drawInRect:CGRectMake(1,1,imageView.frame.size.width-2,imageView.frame.size.height-2)];
imageView.image = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext(); [imageView.layer addAnimation:animation forKey:nil];
}

三、运行效果

运行效果图如下图:

IOS炫酷的引导界面

代码地址如下:
http://www.demodashi.com/demo/11246.html

注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权

IOS炫酷的引导界面的更多相关文章

  1. html5跟随鼠标炫酷网站引导页动画特效

    html5跟随鼠标炫酷网站引导页动画特效一款非常不错的引导页,文字效果渐变,鼠标跟随出绚丽的条纹.html5炫酷网站引导页,鼠标跟随出特效. 体验效果:http://hovertree.com/tex ...

  2. iOS炫酷动画图案、多种选择器、网络测速、滑动卡片效果等源码

    iOS精选源码 对网络进行测速 自实现大标题,配合原生骨架屏demo 简单方便的pickerVIew记录数据 LZPickerView 科技风绘制组件,简单快速"画"出炫酷图案 R ...

  3. 【PyQt5-Qt Designer】制作炫酷的启动界面+进度条

    QProgressBar 进度条+QSplashScreen 启动界面 知识点: 1.进度条 #将进度条的最大值.最小值设置为相同时,产生跑马灯效果 self.progressBar.setMinim ...

  4. iOS--创建炫酷的渐变色界面

    { CAGradientLayer *_layer; } //创建渐变层 _layer =[CAGradientLayer layer]; _layer.frame=self.view.frame; ...

  5. Android开发必知--WebView加载html5实现炫酷引导页面

    大多数人都知道,一个APP的引导页面还是挺重要的,不过要想通过原生的Android代码做出一个非常炫酷的引导页相对还是比较复杂的,正巧html5在制作炫酷动画网页方面比较给力,我们不妨先利用html5 ...

  6. FIR.im Weekly - 让炫酷 UI 为 APP 增色

    上周我看到一些不错的设计分享,挑选了几个比较全的 GitHub 资源推荐给大家.此外,还精选了一些实用的 iOS,Android 干货文章. iOS 炫酷动画资源 @荧星诉语 收集整理了主流炫酷动画框 ...

  7. iOS任何界面全屏炫酷倒计时,一句代码就够了

    概述 iOS全屏炫酷倒计时,任何界面只需要调用一句代码就能实现,支持定制倒计时数字.倒计时结束时显示的文本.支持倒计时播放图片.开始倒计时和结束倒计时的block和delegate回调.支持定制文本颜 ...

  8. 用javascript写Android和iOS naitve应用,实在炫酷。

    关注NativeScript有一段时间了,说好了的三月发第一个Beta版,终于发布了. // declare the extended NativeScriptActivity functionali ...

  9. iOS动画开发之五——炫酷的粒子效果

    在上几篇博客中,我们对UIView层的动画以及iOS的核心动画做了介绍,基本已经可以满足iOS应用项目中所有的动画需求,如果你觉得那些都还不够炫酷,亦或是你灵光一现,想用UIKit框架写出一款炫酷的休 ...

随机推荐

  1. SD 一轮集训 day4 圣城鼠

    非常强的构造题. 很显然的是我们要构造一个类似菊花图的东西,因为这样的话两点之间路径的点数会非常少,很容易满足第二个条件. 但是因为直接菊花图的话会不满足第一个条件,,,所以我们可以构造一个类菊花图. ...

  2. 【DFS】【贪心】Codeforces Round #411 (Div. 1) C. Ice cream coloring

    对那个树进行dfs,在动态维护那个当前的冰激凌集合的时候,显然某种冰激凌仅会进出集合各一次(因为在树上形成连通块). 于是显然可以对当前的冰激凌集合贪心染色.暴力去维护即可.具体实现看代码.map不必 ...

  3. 【SAM】BZOJ3998-弦论

    [题目大意] 给出一个字符串,求第k大的子串.(输入1表示子串可重复,0表示不可重复) [思路] 显然,k大子串是后缀自动机的经典题型,可以利用后缀自动机的性质来解决.对于字符串 [前铺1]" ...

  4. 【序列莫队】BZOJ2038- [2009国家集训队]小Z的袜子(hose)

    [题目大意]给出1-N只袜子的颜色,多次询问L-R中选出一双同色袜子的概率. [思路] 裸莫队.基本的莫队步骤:①分组(每组大小为根号sqrt(n),共sqrt(n)组)②排序(左边界分组,右边界在组 ...

  5. java 的环境搭建

    java.JDK 的搭建__本人是在360里下载的.也可以去其它的网站. java.jdk官网地址下载: https://download.oracle.com 二.也可以下载地址:http://do ...

  6. Java高级架构师(一)第31节:Nginx简介、安装和基本运行

    第一节:主要介绍Nginx和安装

  7. MYSQL复习笔记2-自带工具介绍

    Date: 20140102Auth: Jin 一.mysql 命令行客户端1)base-h host-P port--socket=path,-S path用于连接的套接字文件替换使用IP PORT ...

  8. datetimepicker只显示日期,不显示时分秒

    HTML代码<div class="input-group date form_datetime form-date" data-link-field="dtp_i ...

  9. Android 卡顿优化 4 布局优化实际技巧

    今天分享一些layout布局书写中的一些技巧,希望看过之后你也一样可以写出性价比高的布局.我个人的目标是用最少的View写出一样效果的布局.因为我相信View的数量减少伴随着的就是层级的减少.从而达到 ...

  10. JS的数组相关知识

    创建数组方法一: var a1=new Array(5); console.log(a1.length); console.log(a1); //[] ,数组是空的 var a2=new Array( ...