自定义App首次启动引导页
#import"ZBGuidePageView.h" @interfaceZBGuidePageView()<UIScrollViewDelegate> @property(nonatomic,strong)UIScrollView*scrollView;
@property(nonatomic,strong)UIPageControl*pageControl; @end @implementationZBGuidePageView NSString*key =@"CFBundleShortVersionString"; - (void)show { NSString*key =@"CFBundleShortVersionString"; //获得当前软件的版本号
NSString*currentVersion = [NSBundlemainBundle].infoDictionary[key]; //获得沙盒中存储的版本号
NSString*sanboxVersion = [[NSUserDefaultsstandardUserDefaults]stringForKey:key]; if(![currentVersionisEqualToString:sanboxVersion]) { //自定义引导界面
[selfpushGuideView]; //存储版本号
[[NSUserDefaultsstandardUserDefaults]setObject:currentVersionforKey:key]; //立即存储
[[NSUserDefaultsstandardUserDefaults]synchronize]; } } //加载视图
- (void)pushGuideView {
UIWindow*window = [UIApplicationsharedApplication].keyWindow;
self.frame= window.bounds;
[windowaddSubview:self];
//创建引导的滑动视图
_scrollView= [[UIScrollViewalloc]initWithFrame:CGRectMake(,,SCREEN_WIDTH,SCREEN_HEIGHT)];
[selfaddSubview:_scrollView];
_scrollView.backgroundColor= [UIColorwhiteColor];
//设置属性
//设置滑动视图内容的大小
_scrollView.contentSize=CGSizeMake(SCREEN_WIDTH*,SCREEN_HEIGHT);
//分页设置
_scrollView.pagingEnabled=YES;
//设置滚动条的显示与隐藏
_scrollView.showsHorizontalScrollIndicator=NO;
_scrollView.showsVerticalScrollIndicator=NO; //循环添加图片
for(NSIntegeri =; i <; i++) {
UIImageView*imageView = [[UIImageViewalloc]initWithFrame:CGRectMake(SCREEN_WIDTH* i,,SCREEN_WIDTH,SCREEN_HEIGHT)];
//设置属性
NSString*imageName = [NSStringstringWithFormat:@"guide%@.jpg",@(i +)];
imageView.image= [UIImageimageNamed:imageName];
imageView.userInteractionEnabled=YES; if(i ==) { UIButton*button = [[UIButtonalloc]initWithFrame:CGRectMake(,SCREEN_HEIGHT*0.85,SCREEN_WIDTH-,SCREEN_HEIGHT*0.07)];
[buttonsetTitle:@"立即体验"forState:UIControlStateNormal];
button.titleLabel.font= [UIFontfontWithName:@"Helvetica-Bold"size:];
[buttonaddTarget:selfaction:@selector(didExperButton)forControlEvents:UIControlEventTouchUpInside];
UIColor*color =UICOLOR_FROM_HEX(0x008aff);
[buttonsetBackgroundColor:color];
[imageViewaddSubview:button]; } [_scrollViewaddSubview:imageView];
}
} - (void)didExperButton
{
[UIViewbeginAnimations:@"animation"context:nil];
[UIViewsetAnimationDuration:1.0f];
[UIViewsetAnimationCurve:UIViewAnimationCurveEaseInOut];
[UIViewsetAnimationTransition:UIViewAnimationTransitionCurlUpforView:self.windowcache:YES];
[UIViewcommitAnimations];
[selfremoveFromSuperview];
} @end
自定义App首次启动引导页的更多相关文章
- ionic之应用首次启动引导页
用户首次启动app先进入引导页,localstroge记录状态,下次启动应用不再显示引导页. HTML: <html> <head> <meta charset=&quo ...
- IOS 一句代码搞定启动引导页
前言引导页,一个酷炫的页面,自从微博用了之后一下就火起来了,对于现在来说一个app如果没有引导页似乎总显那么不接地气,那么为了让我们的app也“高大上”一次,我写了一个demo来实现启动引导页的实现, ...
- HybridApp启动引导页的实现
有一种帅叫做长话短说,@孙红雷,--这可以叫做“短帅”吗,^_^ 首先说下思路,既然是Hybrid APP, 那就是可以用html的方式实现,启动引导页比较常见的展示方式是滑动,那么我们就可以使用图片 ...
- 安卓第一次启动引导页使用ViewPager实现
我们在安装某个APP的时候,基本都会有一个引导页的提示,他们可以打广告,或者介绍新功能的加入和使用说明等.一般都支持滑动并且下面有几个点,显示共有多少页和当前图片的位置,在IOS上这个实现起来比较简单 ...
- Android:启动引导页实现
前言 基本上现在所有的应用都会有一个欢迎界面,在欢迎界面对应用做一个整体的介绍,然后在跳入到主界面,这次要说的这个引导页就是带翻页的引导页.效果如下所示
- 使用Webview实现app启动引导页
效果如下: 首先需要一个html页面及相应的js和css支持放在assets目录下(如果没有这个目录请项目上右键-new-folder-assets) 配置权限: <uses-permissio ...
- iOS-王云鹤 APP首次启动显示用户指导
这个功能的重点就是在如何判断应用是第一次启动的. 其实很简单 我们只需要在一个类里面写好用户引导页面 基本上都是使用UIScrollView 来实现, 新建一个继承于UIViewController ...
- 应用app首次进入导航页动画
import android.content.Intent; import android.os.Bundle; import android.support.v7.app.AppCompatActi ...
- 怎样做一个iOS App的启动分层引导动画?
一. 为什么要写这篇文章? 这是一个很古老的话题,从两年前新浪微博开始使用多层动画制作iOS App的启动引导页让人眼前一亮(当然,微博是不是历史第一个这个问题值得商榷)之后,各种类型的引导页层出不穷 ...
随机推荐
- opencv2.4.10+VS2012配置问题
opencv2.4.10+VS2012配置 作为opencv的初学者,第一个难题想必都一样,如何配置opencv+VS的环境呢?在网上的教程,铺天盖地,但我仍然是尝试了十几次才找到属于自己的那套配置方 ...
- 多结果集IMultipleResult接口
在某些任务中,需要执行多条sql语句,这样一次会返回多个结果集,在应用程序就需要处理多个结果集,在OLEDB中支持多结果集的接口是IMultipleResult. 查询数据源是否支持多结果集 并不是所 ...
- 使用Anaconda管理环境
Anaconda指的是一个开源的python发行版本,其包含了conda.Python等180多个科学包及其依赖项. Anaconda是一个开源的包.环境管理器,可以用于在同一个机器上安装不同版本的软 ...
- 在windows环境下运行compass文件出现的错误提示解决方案
在windows环境下运行compass文件出现的错误提示解决方案 例如:经常在项目中运行grunt命令编译scss文件的时候,会出现下面的错误提示 (Encoding::CompatibilityE ...
- 创建Python数据分析的Docker镜像+Docker自定义镜像commit,Dockerfile方式解析+pull,push,rmi操作
实例解析Docker如何通过commit,Dockerfile两种方式自定义Dcoker镜像,对自定义镜像的pull,push,rmi等常用操作,通过实例创建一个Python数据分析开发环境的Dock ...
- Eclipse equinox implementation of OSGi
Bundle package org.osgi.framework; public interface Bundle extends Comparable<Bundle> { int UN ...
- (转)Android新的menu实现——ActionMode
Android的menu有多种实现方式,以前写过一篇Android中五种常用的menu(菜单),这里介绍一种新的menu实现方式:ActionMode.ActionMode是Android 3.0以后 ...
- matlab练习程序(全景图到穹顶图)
这个程序我最初是用FreeImage写的,这两天改成了matlab,再不贴上来,我就要忘了. 看到一篇文章有这样的变换,挺有意思的,就拿来试了一下,文章点此. 全景图到穹顶图变换,通俗的说就是将全景图 ...
- HQL(Hibernate Query Language)
1. NativeSQL > HQL > EJB QL(JP QL 1.0) > QBC(Query By Criteria) > QBE(Query By Example)2 ...
- 路由 vue-router
vue-router官方文档 1.router跳转页面 编程式的导航 this.$router.push('/index'); 2.mode Router构造配置 const router = new ...