国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 系統 > iOS > 正文

iOS開發教程之微博新特性頁面

2019-10-21 18:57:55
字體:
來源:轉載
供稿:網友
本文是IOS開發教程系列的第三篇,主要是分享了微博新特性頁面的制作源碼,希望對大家有所幫助
 

BeyondAppDelegate.m

//// BeyondAppDelegate.m// 20_帥哥no微博//// Created by beyond on 14-8-3.// Copyright (c) 2014年 com.beyond. All rights reserved.//#import "BeyondAppDelegate.h"#import "BeyondViewController.h"#import "NewFeatureViewController.h"#import "OauthViewController.h"#define kVersionCodeKey (NSString *)kCFBundleVersionKey@implementation BeyondAppDelegate// 應用最先執行的方法- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{  // 1,創建窗口  self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];  // 2,設置窗口的背景色  self.window.backgroundColor = [UIColor whiteColor];  // 3,調用自定義方法,判斷是不是第一次使用本版本的app,如果是第一次使用,則將窗口的根控制器設為了NewFeature控制器,否則 就直接讓主控制器成為了窗口的根控制器  [self versionCodeCheck];  // 4,讓窗口可見  [self.window makeKeyAndVisible];  return YES;}// 自定義方法,判斷是不是第一次使用本版本的app,如果是第一次使用,則將窗口的根控制器設為了NewFeature控制器,否則 就直接讓主控制器成為了窗口的根控制器- (void)versionCodeCheck{  // 1,使用用戶偏好,從沙盒中取出舊的版本號  NSString *oldVersionCode = [[NSUserDefaults standardUserDefaults] objectForKey:kVersionCodeKey];  NSString *currentVersionCode = [[[NSBundle mainBundle]infoDictionary] objectForKey:kVersionCodeKey];   // 根據版本號的比較結果 進入不同的控制器  //[self stepIntoViewController:currentVersionCode oldVersion:oldVersionCode];  //return;  #warning block test -===============以下內容,和其中調用的方法,僅用于block調用測試  if ([currentVersionCode isEqualToString:oldVersionCode]) {  //if(0){    [self enterBeyondVC];  } else {    // 關鍵 ,并且保存版本號    [[NSUserDefaults standardUserDefaults]setObject:currentVersionCode forKey:kVersionCodeKey];        // 進入新特性控制器    NewFeatureViewController *newVC = [[NewFeatureViewController alloc]init];    newVC.startBlock = ^(BOOL isSelected){      log(@"%d",isSelected);      [self enterBeyondVC];    };    self.window.rootViewController = newVC;  }}#warning block test- (void) enterBeyondVC{  // 1,如果進行過Oauth授權,則直接進入主控制器,否則 進行Oauth授權控制器  if (1) {    OauthViewController *oauthVC = [[OauthViewController alloc]init];    self.window.rootViewController = oauthVC;    return;  }      // 進入主控制器  BeyondViewController *vc =[[BeyondViewController alloc]init];  self.window.rootViewController = vc;}- (void)stepIntoViewController:(NSString *)curVersion oldVersion:(NSString *)oldVersion{  // 比較新舊版本號  UIViewController *rootViewController = nil;#warning 測試新特性的view  if ([curVersion isEqualToString:oldVersion]) {   //  if (0){    // 說明不是第一次運行,直接實例化主控制器,將主控制器設置為窗口的根控制器    // 進入主控制器(主界面之前 先把狀態欄,恢復) ios 7 無效    // [[UIApplication sharedApplication] setStatusBarHidden:NO withAnimation:UIStatusBarAnimationFade];    rootViewController = [[BeyondViewController alloc]init];  } else {    // 說明是第一次運行,進入新特性控制器,將新特性控制器設置為窗口的根控制器,并且保存版本號    // 進入新特性控制器(新特性界面之前 先把狀態欄,隱藏) ios 7 無效    // [UIApplication sharedApplication].statusBarHidden = YES;    // [[UIApplication sharedApplication]setStatusBarHidden:YES withAnimation:UIStatusBarAnimationSlide];    rootViewController = [[NewFeatureViewController alloc]init];    // 關鍵 ,并且保存版本號    [[NSUserDefaults standardUserDefaults]setObject:curVersion forKey:kVersionCodeKey];  }  // 設置窗口的根控制器,為相應的控制器  self.window.rootViewController = rootViewController;}@end

NewFeatureViewController.h

//// NewFeatureViewController.h// 20_帥哥no微博//// Created by beyond on 14-8-3.// Copyright (c) 2014年 com.beyond. All rights reserved.// 只使用一次,版本新特性控制器,在第一次運行本版本時啟用#import <UIKit/UIKit.h>@interface NewFeatureViewController : UIViewController// 定義一個block作為成員變量,點擊開始按鈕時,初始化主控制器,讓其成為窗口的根控制器// block用copy@property (nonatomic,copy) void(^startBlock)(BOOL isShare);@end

NewFeatureViewController.m

//// NewFeatureViewController.m// 20_帥哥no微博//// Created by beyond on 14-8-3.// Copyright (c) 2014年 com.beyond. All rights reserved.// 只使用一次,版本新特性控制器,在第一次運行本版本時啟用/* 寫在前面: 當一個控件不顯示 的時候,檢查下面三個屬性: 沒有寬度和高度 x y 坐標不正確 沒有添加到父控件中 當一個控制不能點擊的時候,檢查下面個屬性: 自己的userinteraction = no 父控件的userinteraction = no 控件本身已經超出了它所在的控制器范圍 pageController的高度不能更改,那么就可以置高度為0,其他控件同理  4,居中顯示 的標準步驟:先設置center,再設置bounds  5,切換按鈕圖片可以通過切換按鈕的狀態來完成  normal:普通 highlighted : 高亮(人為長按的時候) disabled :失效(通過代碼控制) selected : 選中 (通過代碼控制)  */#import "NewFeatureViewController.h"#define kPicNum 4#warning viewSize 要改成kWinSize#define viewSize self.view.bounds.size@interface NewFeatureViewController ()<UIScrollViewDelegate>{  // 頁面指示控制器  UIPageControl *_pageControl;    // 因為開啟按鈕的點擊事件中需要分享按鈕的選中狀態  UIButton *_shareBtn;}@end@implementation NewFeatureViewController- (BOOL)prefersStatusBarHidden{  // 在LoadView之前 還要先  NSLog(@"prefers bar hidden");  return YES;  }- (void)loadView{  NSLog(@"load view");  // 新特性,讓imageView成為控制器的view,然后才再ImageView上面添加一層scrollView  UIImageView *imgView = [[UIImageView alloc]init];  // 設置控制器view(即imgView)的尺寸為全屏  imgView.frame = [UIScreen mainScreen].bounds;  NSLog(@"%@",NSStringFromCGRect(imgView.frame));  // 使用分類中的方法,如果是iphone5,加載 -568h的圖片  imgView.image = [UIImage fullScrennImageNamed:@"new_feature_background.png"];    // 讓控制器的view可以與用戶交互  imgView.userInteractionEnabled = YES;  // 直接讓imgeView成為控制器的view  self.view = imgView;}- (void)viewDidLoad{  [super viewDidLoad];  NSLog(@"view did load ");  // 1,調用自定義方法,加載UIScrollView,并且批量添加UIImageView,每個ImageView中放一張圖片  [self addUIScrollView];    // 2,調用自定義方法,加載UIPageControl  [self addUIPageControl];}// 自定義方法,加載UIScrollView,并且批量添加UIImageView,每個ImageView中放一張圖片- (void) addUIScrollView{  // 1.加載UIScrollView,并且批量添加UIImageView,每個ImageView中放一張圖片  UIScrollView *scrollView = [[UIScrollView alloc] init];  // 顯示的可視區域大小  scrollView.frame = self.view.bounds;  // 水平滾動條  scrollView.showsHorizontalScrollIndicator = NO;  // 按可視區域進行分頁  scrollView.pagingEnabled = YES;  // 滾動的范圍  scrollView.contentSize = CGSizeMake(kPicNum * viewSize.width, 0);  // 代理 可以監聽滾動的各類事件  scrollView.delegate = self;  // 添加到self.view即ImageView  [self.view addSubview:scrollView];    // 2,根據索引添加kPicNum張圖片排列而成的kPicNum個imageView到scrollView里面  for (int i = 0; i<kPicNum; i++) {    [self addImageViewToScrollView:scrollView atIndex:i];  }}// 自定義方法,加載UIPageControl- (void) addUIPageControl{  // 1,加載UIPageControl  _pageControl = [[UIPageControl alloc] init];  // 居中最好是先設置center,再設置bounds  _pageControl.center = CGPointMake(viewSize.width * 0.5, viewSize.height * 0.95);  _pageControl.bounds = CGRectMake(0, 0, 100, 0);  // 設置總頁數  _pageControl.numberOfPages = kPicNum;  // 重點~從圖片中加載顏色 默認顏色和當前頁的顏色  _pageControl.pageIndicatorTintColor = [UIColor colorWithPatternImage:[UIImage imageNamed:@"new_feature_pagecontrol_point.png"]];  _pageControl.currentPageIndicatorTintColor = [UIColor colorWithPatternImage:[UIImage imageNamed:@"new_feature_pagecontrol_checked_point.png"]];  // 禁止默認的交互事件  _pageControl.userInteractionEnabled = NO;  // 添加到self.view即ImageView  [self.view addSubview:_pageControl];}// scrollView的代理方法,用于動態控制PageControl的當前圓點,滾動減速完畢就會調用(即scrollview靜止)- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{  // 當前的第幾頁就是偏移的x除以單張寬度  _pageControl.currentPage = scrollView.contentOffset.x / scrollView.frame.size.width;}// 自定義方法,根據索引添加kPicNum張圖片排列而成的kPicNum個imageView到scrollView里面- (void)addImageViewToScrollView:(UIScrollView *)scrollView atIndex:(int)i{  // 1.創建imageview  UIImageView *imageView = [[UIImageView alloc] init];  // 因為是一張張水平排列,所以根據索引計算 frame ,通過結構體必須強轉為CGRect  imageView.frame = (CGRect){{i * viewSize.width, 0} , viewSize};      // 2.設置圖片  NSString *name = [NSString stringWithFormat:@"new_feature_%d.png", i + 1];  // 使用分類中的方法,如果是iphone5,加載 -568h的圖片  imageView.image = [UIImage fullScrennImageNamed:name];    // 3.添加  [scrollView addSubview:imageView];    // 4.如果是最后一張圖片,添加2個按鈕(分享、開始)  if (i == kPicNum - 1) {    // 必須讓最后一張imageView可以進行點擊,這樣它里面的2個按鈕才可以點擊    imageView.userInteractionEnabled = YES;            // 最后一張圖片頁面,有兩個按鈕,一個是開始    [self addStartBtnInImageView:imageView];    // 最后一張圖片頁面,有兩個按鈕,另一個是分享微博按鈕,默認是選中狀態    [self addShareBtnInImageView:imageView];  }}// 最后一張圖片頁面,有兩個按鈕,一個是分享- (void) addShareBtnInImageView:(UIImageView *)imageView{    // 2.1.創建自定義樣式的按鈕  _shareBtn = [UIButton buttonWithType:UIButtonTypeCustom];  // 添加到最后一張imageView里面  [imageView addSubview:_shareBtn];    // 2.2.設置按鈕背景圖片  // 調用自己寫的分類方法,設置按鈕正常和高亮狀態的背景圖片,并且返回 圖片的尺寸  CGSize shareBtnNormalBgImgSize = [_shareBtn setBtnBgImgForNormalAndSelectedWithName:@"new_feature_share_false.png" selectedName:@"new_feature_share_true.png"];    // 2.3.邊框(居中,先center,后bounds)  _shareBtn.center = CGPointMake(viewSize.width * 0.5, viewSize.height * 0.75);  // 按鈕寬高,就按背景圖片寬高  _shareBtn.bounds = (CGRect){CGPointZero, shareBtnNormalBgImgSize};    // 2.4.監聽  [_shareBtn addTarget:self action:@selector(shareBtnClick:) forControlEvents:UIControlEventTouchUpInside];  // 2.5.高亮狀態下不要改變圖片顏色  _shareBtn.adjustsImageWhenHighlighted = NO;  // 2.6.默認選中  _shareBtn.selected = YES;  }// 分享按鈕點擊事件,只要切換不同的選中狀態,就可以顯示不同的兩張圖片(正常圖片是不勾選,選中狀態的圖片是勾選)- (void)shareBtnClick:(UIButton *)shareBtn{  shareBtn.selected = !shareBtn.isSelected;}// 最后一張圖片頁面,有兩個按鈕,一個是開始- (void) addStartBtnInImageView:(UIImageView *)imageView{      // 1.1.創建開啟按鈕  // 使用自定義樣式  UIButton *startBtn = [UIButton buttonWithType:UIButtonTypeCustom];  // 添加到最后一張imageView里面  [imageView addSubview:startBtn];      // 1.2.設置背景圖片等個性樣式  // 調用自己寫的分類方法,設置按鈕正常和高亮狀態的背景圖片,并且返回 圖片的尺寸  CGSize startBtnBgImgSize = [startBtn setBtnBgImgForNormalAndHighightedWithName:@"new_feature_finish_button.png"];  // 1.3.邊框  startBtn.center = CGPointMake(viewSize.width * 0.5, viewSize.height * 0.85);  // 按鈕的寬高 與 背景圖片的寬高一樣大  startBtn.bounds = (CGRect){CGPointZero, startBtnBgImgSize};    // 1.4.監聽  [startBtn addTarget:self action:@selector(startBtnClick) forControlEvents:UIControlEventTouchUpInside];  }// 點擊開始按鈕時,調用block完成,以下功能:初始化主控制器,讓其成為窗口的根控制器- (void)startBtnClick{  // 直接調用block (即另外一個類里面的一段代碼來執行)  if (_startBlock) {    _startBlock(_shareBtn.isSelected);  }}@end


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
福利视频网站导航| 精品全国在线一区二区| 最近免费中文字幕大全免费第三页| 在线国产91| 在线观看的av网站| 欧美精品另类| 五月婷婷导航| 国产美女av在线| 国产免费黄网站| 国产羞羞视频在线观看| 中文字幕在线视频免费观看| 国产一区精品| 亚洲字幕成人中文在线观看| 日本国产在线| 国产偷激情在线| аⅴ成人天堂中文在线| 国产丝袜在线| 欧美性xxxx交| 国产精品178页| 欧美日韩亚洲国内综合网| 五月综合激情在线| 亚洲精品aaaa| 懂色av一区| 999在线视频| 国产裸舞福利在线视频合集 | 天堂在线免费av| 精品乱码一区二区三四区视频| 麻豆精品永久免费视频| 国产福利小视频在线| 超碰免费在线播放| 在线国产1区| 国产jizz| 中文一区在线观看| 国产精品777一区二区| 女同一区二区免费aⅴ| 国产香蕉视频在线观看| 久草在线视频网| sm国产在线调教视频| 在线一区二区三区精品| 国产网站观看9久| 国产美女高潮| 国产精品臀控福利在线观看| 久草在线视频网| 久草网在线视频| 欧美精品se| 男人天堂v视频| 久久精品视频免费看| 久久久久国产精品嫩草影院| 福利视频网站导航| 丁香综合在线| 黄色av网站在线| 久久99精品久久久久久野外| 九九热免费在线视频| 国产乱精品一区二区三区| 国产麻豆视频网站| 7777在线| 黄色电影网站在线观看| 天堂资源在线中文| 自拍亚洲国产| 97福利电影| 久热国产视频| 91啦中文在线| 欧美人成在线观看网站高清| 国产在线激情视频| 开心婷婷激情五月| 国产一级黄色大片| 天堂网中文在线| 中文字幕av中文字幕| 精品美女调教视频| 久久久久久日本一区99| 国产不卡一卡2卡三卡4卡5卡在线| 在线国产小视频| 国产乱精品一区二区三区| 国产精品久久久久久久牛牛| 樱花草在线观看www| 国产自产视频| 国产videos| 国产女呦网站| 亚洲精品影视在线| 最新天堂资源在线资源| 2018狠狠干| 国产精品一区二三区| 在线免费观看污| 国产精品人人| 国产美女在线免费观看| 999精品网| 国产aa视频| 国产精品视频流白浆免费视频 | 99综合精品久久| 导航福利在线| www.av在线视频| 在线播放www| 69av二区| 国产一卡2卡3卡四卡网站 | 黄色av网址在线免费观看| 2021av天天| 国产成人午夜精品| 最好2018中文免费视频| 国产在线拍揄自揄拍视频| 日本国产在线| 亚洲尤物在线视频| 亚洲精品成人a| 午夜亚洲成人| www.狠狠| 免费影视观看网站入口| 在线激情网站| 日本福利午夜视频在线| 永久免费网站在线| 亚洲精品xxxxx| 不卡av免费观看| 成年网在线观看免费观看网址| 欧美亚洲天堂| 天堂在线看视频| 国产色a在线| 国产精品剧情一区二区三区| 国产精品亚洲色图| 国产精品视频福利一区二区| 国产精品欧美色图| 性网站在线看| 福利视频在线看| 国产精品久久久久久福利| 国产91在线视频蝌蚪| 亚洲国产精品区| 国产精品一品| 一本大道久久精品| 国产卡二和卡三的视频| 国产一二三视频| 伊人国产在线看一| 九九在线免费视频| 国产对白在线| h网址在线观看| 国产美女av| 亚洲成av人影片在线观看| 超碰在线影院| 国产不卡精品一区二区三区| www.操.com| 精品推荐国产麻豆剧传媒| 久草国产视频| 天天干天天操天天爽| 国产精品入口麻豆免费观看| 日本动漫理论片在线观看网站| 国产精品入口麻豆免费观看| 麻豆电影传媒二区| 伊人影院蕉久影院在线播放| 最新中文字幕av专区| 亚洲男人的天堂成人| 国产精品18久久久久网站| 国产尤物视频在线| 亚洲精品aaaa精品| 999福利在线视频| 尤物网站在线| 国内自拍视频在线观看| heisi视频网在线观看| 中文字幕4区| 国产成a人亚洲精v品| 国产乱视频在线观看播放| 日本不卡1区2区3区| 亚洲成a人v欧美综合天堂麻豆| 91精选福利| 7777在线| 91欧美在线视频| 国产精品冒白浆免费视频| 国产精品一区在线看| 狠狠狠综合7777久夜色撩人| 超碰免费在线观看| 日本久久网站| 免费a级毛片在线播放| 日本亚洲欧美| 九九在线视频| 国产一级片在线播放| 中文字幕乱在线伦视频乱在线伦视频| 国产麻豆视频网站| 1区2区3区在线| 国产极品美女到高潮| 国产区高清在线| 国产欧美在线观看视频| 国产黄色免费网站| 永久免费av网站| h网站免费在线观看| 久久综合第一页| 国产网红在线| 一级黄色av| 国产美女高潮| 精品女厕厕露p撒尿| 欧美aaa一级片| 国产色视频网站| 日本国产在线| 国产探花视频在线观看| 99久久99热久久精品免费看| 欧美黑人乱大交| 日本中文字幕视频在线| 国产激情在线视频| 轻轻色免费在线视频| 国产精品69xx| 美女国产在线| 国产成a人亚洲精v品| 精品资源在线看| 在线视频二区| 国产一级黄色片免费| 超碰免费在线|