[iOS基礎控制項 - 4.3] xib的使用

來源:互聯網
上載者:User

標籤:style   blog   io   ar   color   os   使用   sp   for   

A.storyboard和xib1.storyboard: 相對xib較重量級,控制整個應用的所有介面2.xib: 輕量級,一般用來描述局部介面 B.使用1.建立xib檔案New File ==> User Interface ==> Empty 2.開啟建立的xib檔案,出現可視化視窗(1)拖入一個UIView (不是UIViewController)(2)設定大小:開啟可自訂尺寸 ==> 定義尺寸(3)拖入表徵圖圖片、名字、下載按鈕,調整設定 3.在代碼中擷取xib中的view,並設定資料(1)從xib擷取viewa.方法1:
1         // 1.擷取xib中的view, xib中可以同時定義多個view,注意名字不帶副檔名2         NSArray *viewArray = [[NSBundle mainBundle] loadNibNamed:@"app" owner:nil options:nil];3         UIView *appView = [viewArray lastObject];
 b.方法2:
1         UINib *nib = [UINib nibWithNibName:@"app" bundle:[NSBundle mainBundle]];2         NSArray *viewArray = [nib instantiateWithOwner:nil options:nil];3         UIView *appView = [viewArray lastObject];
 (2)取出View中的元素,設定圖片a.方法1,使用SubView數組:
1         // 3.設定圖片2         UIImageView *iconView = appView.subviews[2];3         iconView.image = [UIImage imageNamed:appData.icon];
 注意:按照教程是按照的順序排列數組元素(imageView應該是subviews[0],但是實際編程發現卻不是,所以此方法並不穩定) b.方法2,使用tag:
1         // 3.設定圖片2         UIImageView *iconView = [appView viewWithTag:1];3         iconView.image = [UIImage imageNamed:appData.icon];
 (3)設定名字
1         // 4.設定名字2         UILabel *nameLabel = [appView viewWithTag:2];3         nameLabel.text = appData.name;
 (4)下載按鈕已經在xib中定義好,不必使用代碼  C.實現代碼
  1 #import "ViewController.h"  2 #import "App.h"  3   4 #define ICON_KEY @"icon"  5 #define NAME_KEY @"name"  6 #define APP_WIDTH 85  7 #define APP_HEIGHT 90  8 #define MARGIN_HEAD 20  9 #define ICON_WIDTH 50 10 #define ICON_HEIGHT 50 11 #define NAME_WIDTH APP_WIDTH 12 #define NAME_HEIGHT 20 13 #define DOWNLOAD_WIDTH (APP_WIDTH - 20) 14 #define DOWNLOAD_HEIGHT 20 15  16 @interface ViewController () 17  18 /** 存放應用資訊 */ 19 @property(nonatomic, strong) NSArray *apps; // 應用列表 20  21 @end 22  23 @implementation ViewController 24  25 - (void)viewDidLoad { 26     [super viewDidLoad]; 27     // Do any additional setup after loading the view, typically from a nib. 28      29     [self loadApps]; 30 } 31  32 - (void)didReceiveMemoryWarning { 33     [super didReceiveMemoryWarning]; 34     // Dispose of any resources that can be recreated. 35 } 36  37 #pragma mark 取得應用列表 38 - (NSArray *) apps { 39     if (nil == _apps) { 40         // 1.獲得plist的全路徑 41         NSString *path = [[NSBundle mainBundle] pathForResource:@"app.plist" ofType:nil]; 42          43         // 2.載入資料 44         NSArray *dictArray  = [NSArray arrayWithContentsOfFile:path]; 45          46         // 3.將dictArray裡面的所有字典轉成模型,放到新數組中 47         NSMutableArray *appArray = [NSMutableArray array]; 48         for (NSDictionary *dict in dictArray) { 49             // 3.1建立模型對象 50             App *app = [App appWithDictionary:dict]; 51              52             // 3.2 添加到app數組中 53             [appArray addObject:app]; 54         } 55          56         _apps = appArray; 57     } 58  59     return _apps; 60 } 61  62 #pragma mark 載入全部應用列表 63 - (void) loadApps { 64     int appColumnCount = [self appColumnCount]; 65     int appRowCount = [self appRowCount]; 66      67     CGFloat marginX = (self.view.frame.size.width - APP_WIDTH * appColumnCount) / (appColumnCount + 1); 68     CGFloat marginY = (self.view.frame.size.height - APP_HEIGHT * appRowCount) / (appRowCount + 1) + MARGIN_HEAD; 69      70     int column = 0; 71     int row = 0; 72     for (int index=0; index<self.apps.count; index++) { 73         App *appData = self.apps[index]; 74  75         // 1.擷取xib中的view, xib中可以同時定義多個view,注意名字不帶副檔名 76 //        NSArray *viewArray = [[NSBundle mainBundle] loadNibNamed:@"app" owner:nil options:nil]; 77 //        UIView *appView = [viewArray lastObject]; 78          79         UINib *nib = [UINib nibWithNibName:@"app" bundle:[NSBundle mainBundle]]; 80         NSArray *viewArray = [nib instantiateWithOwner:nil options:nil]; 81         UIView *appView = [viewArray lastObject]; 82          83         // 2.定義每個app的位置、尺寸 84         CGFloat appX = marginX + column * (marginX + APP_WIDTH); 85         CGFloat appY = marginY + row * (marginY + APP_HEIGHT); 86         appView.frame = CGRectMake(appX, appY, APP_WIDTH, APP_HEIGHT); 87          88         // 3.設定圖片 89         UIImageView *iconView = [appView viewWithTag:1]; 90         iconView.image = [UIImage imageNamed:appData.icon]; 91          92         // 4.設定名字 93         UILabel *nameLabel = [appView viewWithTag:2]; 94         nameLabel.text = appData.name; 95          96         // 5.加入此app資訊到總view 97         [self.view addSubview:appView]; 98          99         column++;100         if (column == appColumnCount) {101             column = 0;102             row++;103         }104     }105 }106 107 108 #pragma mark 計算資料行數109 - (int) appColumnCount {110     int count = 0;111     count = self.view.frame.size.width / APP_WIDTH;112     113     if ((int)self.view.frame.size.width % (int)APP_WIDTH == 0) {114         count--;115     }116     117     return count;118 }119 120 #pragma mark 計算行數121 - (int) appRowCount {122     int count = 0;123     count = (self.view.frame.size.height - MARGIN_HEAD) / APP_HEIGHT;124     125     if ((int)(self.view.frame.size.height - MARGIN_HEAD) % (int)APP_HEIGHT == 0) {126         count--;127     }128     129     return count;130 }131 132 @end

 

  

[iOS基礎控制項 - 4.3] xib的使用

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.