iOS開發(fā)之引導頁的實現(xiàn)

一芒帕、App引導頁
一款App在首次安裝后打開時,會有3-5頁的介紹界面引導新用戶使用或者給用戶更新提示丰介。
根據(jù)引導頁的目的背蟆、出發(fā)點不同鉴分,可以將其分為功能介紹類、使用說明類带膀、推廣類志珍、問題解決類,一般引導頁不會超過5頁垛叨。 功能介紹類 功能介紹類引導頁主要是對產(chǎn)品的主要功能進行展示伦糯,讓用戶對產(chǎn)品主功能有一個大致的了解。
二嗽元、具體實現(xiàn)
1敛纲、本Demo是在繼承UICollectionViewController的前提下完成。
2剂癌、實現(xiàn)瀑布流
- (instancetype)init
{
UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc] init];

// 設(shè)置cell的尺寸
layout.itemSize = [UIScreen mainScreen].bounds.size;
// 清空行距
layout.minimumLineSpacing = 0;

// 設(shè)置滾動的方向
layout.scrollDirection = UICollectionViewScrollDirectionHorizontal;

return [super initWithCollectionViewLayout:layout];

}

3淤翔、實現(xiàn)collectionView布局

 //使用UICollectionViewController
//1.初始化的時候設(shè)置布局參數(shù)
//2.必須collectionView要注冊cell
// 3.自定義cell
- (void)viewDidLoad {
   [super viewDidLoad];
// 注冊cell,默認就會創(chuàng)建這個類型的cell
[self.collectionView registerClass:[ZJNewFeatureCell class] forCellWithReuseIdentifier:reuseIdentifier];

// 分頁
self.collectionView.pagingEnabled = YES;
self.collectionView.bounces = NO;
self.collectionView.showsHorizontalScrollIndicator = NO;

}

3、有關(guān)代理方法的實現(xiàn)

      mark - UICollectionView代理和數(shù)據(jù)源
 // 返回有多少組
- (NSInteger)numberOfSectionsInCollectionView:(UICollectionView *)collectionView
{
return 1;
}

// 返回第section組有多少個cell
- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section
 {
return 4;
}
// 返回cell長什么樣子
    - (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView  cellForItemAtIndexPath:(NSIndexPath *)indexPath
{

ZJNewFeatureCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:reuseIdentifier forIndexPath:indexPath];

NSString *imageName = [_picStrArr objectAtIndex:indexPath.row];

cell.image = [UIImage imageNamed:imageName];

[cell setIndexPath:indexPath count:[_picStrArr count]];

return cell;

}

注:代用中使用的宏是寫在PCH文件中佩谷,PCH文件的配置見另一篇文章有關(guān)PCH文件的設(shè)置旁壮。
4、實現(xiàn)UICollectionViewCell
懶加載最后一張引導頁的點擊按鈕
- (UIButton *)startButton
{
if (_startButton == nil) {
UIButton *startBtn = [UIButton buttonWithType:UIButtonTypeCustom];

    [startBtn setBackgroundColor:[UIColor clearColor]];
    
    [startBtn setBackgroundImage:[UIImage imageNamed:@"開啟按鈕"] forState:UIControlStateNormal];
    
    [startBtn addTarget:self action:@selector(start) forControlEvents:UIControlEventTouchUpInside];
    
    [self addSubview:startBtn];

    _startButton = startBtn;
  }
   return _startButton;
   }

5谐檀、布局ZJNewFeatureCell子控件的frame
- (UIImageView *)imageView
{
if (_imageView == nil) {

    UIImageView *imageV = [[UIImageView alloc] init];
    
    _imageView = imageV;
    
    // 注意:一定要加在contentView上
    [self.contentView addSubview:imageV];
    
}
return _imageView;
 }

  // 布局子控件的frame
  - (void)layoutSubviews
  {
[super layoutSubviews];

self.imageView.frame = CGRectMake(0, 0, ScreenWidth, ScreenHeight);

[self.startButton setFrame:CGRectMake(0, 0, 170, 40)];

self.startButton.center = CGPointMake(ScreenWidth * 0.5, ScreenHeight -90);
}

6抡谐、開始按鈕的點擊事件,切換根視圖

- (void)start
 {
     //切換根視圖
self.window.rootViewController          = [ViewController new];

//記錄是否已經(jīng)走過新特性
[[NSUserDefaults standardUserDefaults]setBool:YES forKey:[NSString stringWithFormat:@"ISNEWFEATURE%@",App_Version]];

[[NSUserDefaults standardUserDefaults]synchronize];

 }

7桐猬、deledate中判斷是否展示引導頁

  - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

self.window                             = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
self.window.backgroundColor             = [UIColor clearColor];

self.window.rootViewController = [[ViewController alloc]init];

NSArray *picStrArr = [NSArray arrayWithObjects:@"1242x2208_01",@"1242x2208_02", @"1242x2208_03", @"1242x2208_04", nil];

[NewFeatureManager shareManagerWithDelegate:self picStrArr:picStrArr];

return YES;

}
保存值的時候帶著版本號麦撵,是讓版本升級后首次打開也能展示引導頁。
demo地址下載:https://github.com/zhengju/GuidePageDemo

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末课幕,一起剝皮案震驚了整個濱河市厦坛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌乍惊,老刑警劉巖杜秸,帶你破解...
    沈念sama閱讀 222,590評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異润绎,居然都是意外死亡撬碟,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評論 3 399
  • 文/潘曉璐 我一進店門莉撇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來呢蛤,“玉大人,你說我怎么就攤上這事棍郎∑湔希” “怎么了?”我有些...
    開封第一講書人閱讀 169,301評論 0 362
  • 文/不壞的土叔 我叫張陵涂佃,是天一觀的道長励翼。 經(jīng)常有香客問我蜈敢,道長,這世上最難降的妖魔是什么汽抚? 我笑而不...
    開封第一講書人閱讀 60,078評論 1 300
  • 正文 為了忘掉前任抓狭,我火速辦了婚禮,結(jié)果婚禮上造烁,老公的妹妹穿的比我還像新娘否过。我一直安慰自己,他們只是感情好惭蟋,可當我...
    茶點故事閱讀 69,082評論 6 398
  • 文/花漫 我一把揭開白布苗桂。 她就那樣靜靜地躺著,像睡著了一般敞葛。 火紅的嫁衣襯著肌膚如雪誉察。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,682評論 1 312
  • 那天惹谐,我揣著相機與錄音持偏,去河邊找鬼。 笑死氨肌,一個胖子當著我的面吹牛鸿秆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播怎囚,決...
    沈念sama閱讀 41,155評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼卿叽,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了恳守?” 一聲冷哼從身側(cè)響起考婴,我...
    開封第一講書人閱讀 40,098評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎催烘,沒想到半個月后沥阱,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,638評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡伊群,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,701評論 3 342
  • 正文 我和宋清朗相戀三年考杉,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片舰始。...
    茶點故事閱讀 40,852評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡崇棠,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出丸卷,到底是詐尸還是另有隱情枕稀,我是刑警寧澤,帶...
    沈念sama閱讀 36,520評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站抽莱,受9級特大地震影響范抓,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜食铐,卻給世界環(huán)境...
    茶點故事閱讀 42,181評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望僧鲁。 院中可真熱鬧虐呻,春花似錦、人聲如沸寞秃。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽春寿。三九已至朗涩,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間绑改,已是汗流浹背谢床。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留厘线,地道東北人识腿。 一個月前我還...
    沈念sama閱讀 49,279評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像造壮,于是被迫代替她去往敵國和親渡讼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,851評論 2 361

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,322評論 25 707
  • 錢人人都有,但人人都不一定能稱得上是有錢人旨枯。有錢的人應該是買得起一線城市的房蹬昌,開得了寶馬路虎一類的豪車,用得上國際...
    性感有才的郭郭閱讀 394評論 0 4
  • 親愛的Wendy: 今天放學回家的時候召廷,你超級開心凳厢。 原因有兩: 1、你英語期中考試得了滿分竞慢,老師獎勵你一顆棒棒糖...
    C呀么CJ閱讀 123評論 0 0
  • 今天做的發(fā)卷很好先紫。面發(fā)的不錯,很松軟筹煮,可能是小麥粉的緣故遮精,不夠白,但是麥香味濃。比以前改進的地方是排氣足本冲,開蒸前二...
    何麗珍閱讀 211評論 0 0
  • 文章作者:Tyan博客:noahsnail.com | CSDN | 簡書 本文主要是關(guān)于numpy的一些基本運算...
    SnailTyan閱讀 505評論 0 0