亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS開發的UI制作中動態和靜態單元格的基本使用教程

2020-07-26 03:30:57
字體:
來源:轉載
供稿:網友

靜態單元格的使用
一、實現效果與說明

2015121693950758.png (320×501)

說明:觀察上面的展示效果,可以發現整個界面是由一個tableview來展示的,上面的數據都是固定的,且幾乎不會改變。

要完成上面的效果,有幾種方法:

(1)可以直接利用代碼,返回三組,在判斷每組有多少行,展示些什么數據,這樣寫“死”的代碼建議絕不要使用。

(2)稍微靈活一些的,可以把plist文件一懶加載的方式,加載到程序中,動態獲取。但是觀察界面結構,很容易看出這樣需要進行模型嵌套,很麻煩。

(3)storyboard提供了靜態單元格這個功能,可以很方便的完成上面的界面展示效果。(提示:在實際的開發中很少這樣使用)

二、使用靜態單元格完成簡單界面展示的過程

在類似的開發中,如果整個界面都是tableview,那么直接讓控制器繼承自UItableviewcontroller.

修改主控制器,讓其繼承自UItableviewcontroller

2015121694025433.png (676×150)

把storyboard中默認的uiview刪掉,直接拖一個viewcontroller

2015121694049342.png (846×582)

當拖入一個viewcontroller的時候,它上面默認就會有一個cell,默認情況下,這個cell是動態的,也就是默認是看不見的。

把cell設置成靜態的,在屬性面板的content  中設置為static cell(靜態cell)所見即所得  注意必須更改這里的這個屬性。

2015121694108022.png (778×176)

讓它和主控制器關聯

2015121694126400.png (767×172)

接下來,可以依次設置顯示的圖片和文字。

設置標題有兩種方式:

1是雙擊更改

2015121694152622.png (385×107)

2是點擊子控件  lable修改

2015121694207921.png (1115×174)

按照界面需要,設置輔助視圖

2015121694224070.png (715×109)

設置有多少組,每組有多少行。
設置組:
點擊tableview   設置屬性面板的sections屬性。

2015121694243280.png (992×264)

設置每組多少行:

2015121694300303.png (1008×390)

小技巧:如果寫的單元格千年不變,那么可以先寫一組中的一行,再拷貝,稍作修改即可。
注意:靜態單元格是實際開發中,很少用到,此處只當知識點介紹。


在UITableview的應用中使用動態單元格來完成app應用程序管理界面的搭建
一、實現效果

2015121694318055.png (640×960)

說明:該示例在storyboard中使用動態單元格來完成。

二、實現

1.項目文件結構和plist文件

2015121694333357.png (732×412)

2.實現過程以及代碼

2015121694351144.png (262×141)

在tableview的屬性選擇器中選擇動態單元格。

2015121694407505.png (1085×209)

說明:在storyboard中直接使用其自帶的動態單元格完成tableviewcell的定義,并創建了一個管理該cell的類,進行了連線。

實現代碼:

數據模型部分:

YYappInfo.h文件

復制代碼 代碼如下:

//
//  YYappInfo.h
//  01-使用動態單元格來完成app應用程序管理界面的搭建
//
//  Created by 孔醫己 on 14-6-2.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import <Foundation/Foundation.h>

@interface YYappInfo : NSObject
@property(nonatomic,copy)NSString *size;
@property(nonatomic,copy)NSString *download;
@property(nonatomic,copy)NSString *icon;
@property(nonatomic,copy)NSString *name;

-(instancetype)initWithDict:(NSDictionary *)dict;
+(instancetype)appInfoWithDict:(NSDictionary *)dict;
@end


YYappInfo.m文件
復制代碼 代碼如下:

//
//  YYappInfo.m
//  01-使用動態單元格來完成app應用程序管理界面的搭建
//
//  Created by 孔醫己 on 14-6-2.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "YYappInfo.h"

@implementation YYappInfo

-(instancetype)initWithDict:(NSDictionary *)dict
{
    if (self=[super init]) {
        //使用KVC
        [self setValuesForKeysWithDictionary:dict];
    }
    return self;
}


+(instancetype)appInfoWithDict:(NSDictionary *)dict
{

    return [[self alloc]initWithDict:dict];
}
@end


視圖部分

 YYappCell.h文件

復制代碼 代碼如下:

//
//  YYappCell.h
//  01-使用動態單元格來完成app應用程序管理界面的搭建
//
//  Created by 孔醫己 on 14-6-2.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import <UIKit/UIKit.h>


@class YYappInfo,YYappCell;

@protocol YYappCellDelegate <NSObject>
-(void)btnDidClick:(YYappCell *)cell;


@end
@interface YYappCell : UITableViewCell

@property(nonatomic,strong)YYappInfo *app;
//@property(nonatomic,strong)YYViewController *controller;
@property(nonatomic,strong)id <YYappCellDelegate> delegate;

@end


YYappCell.m文件
復制代碼 代碼如下:

//
//  YYappCell.m
//  01-使用動態單元格來完成app應用程序管理界面的搭建
//
//  Created by 孔醫己 on 14-6-2.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "YYappCell.h"
#import "YYappInfo.h"

@interface YYappCell ()
@property (weak, nonatomic) IBOutlet UIImageView *appimg;

@property (weak, nonatomic) IBOutlet UILabel *apptitle;
@property (weak, nonatomic) IBOutlet UILabel *appdownload;
@property (weak, nonatomic) IBOutlet UIButton *appbtn;

@end


復制代碼 代碼如下:

@implementation YYappCell


-(void)setApp:(YYappInfo *)app
{
    _app=app;
    self.apptitle.text=_app.name;
    self.appdownload.text=[NSString stringWithFormat:@"大小 %@ | 下載量 %@次",_app.size,_app.download];
    self.appimg.image=[UIImage imageNamed:_app.icon];
   
}

#pragma mark- 完成按鈕點擊事件

- (IBAction)btnOnclick:(UIButton *)sender
{
    //按鈕被點擊后,變為不可用狀態
    sender.enabled=NO;
   
    //通知代理,完成提示下載已經完成的動畫效果
    if ([self.delegate respondsToSelector:@selector(btnDidClick:)]) {
        //一般而言,誰觸發就把誰傳過去
        [self.delegate  btnDidClick:self];
    }
}

@end


主控制器

YYViewController.m文件

復制代碼 代碼如下:

//
//  YYViewController.m
//  01-使用動態單元格來完成app應用程序管理界面的搭建
//
//  Created by 孔醫己 on 14-6-2.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "YYViewController.h"
#import "YYappInfo.h"
#import "YYappCell.h"

@interface YYViewController ()<UITableViewDataSource,YYappCellDelegate>
@property(nonatomic,strong)NSArray *apps;
@property (strong, nonatomic) IBOutlet UITableView *tableview;

@end


復制代碼 代碼如下:

@implementation YYViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
}

#pragma mark- 使用懶加載先把plist文件中得數據加載進來
-(NSArray *)apps
{
    if (_apps==Nil) {
        NSString *fullpath=[[NSBundle mainBundle]pathForResource:@"apps_full.plist" ofType:Nil];
        NSArray *arrayM=[NSArray arrayWithContentsOfFile:fullpath];
       
        NSMutableArray *modles=[NSMutableArray arrayWithCapacity:arrayM.count];
        for (NSDictionary *dict in arrayM) {
            YYappInfo *appinfo=[YYappInfo appInfoWithDict:dict];
            [modles addObject:appinfo];
        }
        _apps=[modles copy];
    }
    return _apps;
}


#pragma mark- 設置tableview的數據源方法
//組
-(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    return 1;
}
//行
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return self.apps.count;
}
//組-行-數據
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    //創建cell
    static NSString *identifier=@"app";
    YYappCell *cell=[tableView dequeueReusableCellWithIdentifier:identifier];
    //設置cell的數據
    YYappInfo *appinfo=self.apps[indexPath.row];
    //設置代理
    cell.delegate=self;
    cell.app=appinfo;
    //返回cell
    return cell;
}

#pragma mark- 設置代理
-(void)btnDidClick:(YYappCell *)cell
{
    //取出模型
    YYappInfo *app=cell.app;
    NSLog(@"daili");
    UILabel *lab=[[UILabel alloc]init];
    //提示的顯示位置
    lab.frame=CGRectMake(60, 300, 200, 20);
    //設置提示文本
    lab.text=[NSString stringWithFormat:@"%@已經下載完成",app.name];
    //設置文本背景顏色
    [lab setBackgroundColor:[UIColor grayColor]];
    [self.view addSubview:lab];
    lab.alpha=1.0;
   
    //設置動畫效果
    [UIView animateWithDuration:2.0 animations:^{
        lab.alpha=0.0;
    } completion:^(BOOL finished) {
        //把彈出的提示信息從父視圖中刪除
        [lab removeFromSuperview];
    }];
}

#pragma mark-隱藏狀態欄
-(BOOL)prefersStatusBarHidden
{
    return YES;
}

@end


補充說明

  在程序中通過標示符取出對應的cell,是因為在storyboard中已經對cell打上了標示符(app)的標簽。

復制代碼 代碼如下:

//組-行-數據
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    //創建cell
    static NSString *identifier=@"app";
    YYappCell *cell=[tableView dequeueReusableCellWithIdentifier:identifier];
    //設置cell的數據
    YYappInfo *appinfo=self.apps[indexPath.row];
    //設置代理
    cell.delegate=self;
    cell.app=appinfo;
    //返回cell
    return cell;
}

2015121694429191.png (730×145)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品久久久久久久久| 国产69精品久久久久99| 97国产真实伦对白精彩视频8| 日韩精品小视频| 亚洲色图17p| 欧美人交a欧美精品| 92福利视频午夜1000合集在线观看| 日韩av免费在线看| 欧美视频第一页| 国产精品色悠悠| 国产精品一香蕉国产线看观看| 91精品免费看| 成人黄色av网站| 国产一区二区三区在线观看视频| 亚洲乱码一区二区| 欧美日韩国产二区| 久久影视电视剧免费网站| 波霸ol色综合久久| 欧美激情视频一区二区三区不卡| 久久影视免费观看| 91色p视频在线| 久久国产精品免费视频| 久久久天堂国产精品女人| 国产精品第三页| 欧美一区第一页| 日本91av在线播放| 欧美一级大片在线观看| 国产在线视频欧美| 久久精品电影网站| 久久久久久国产精品久久| 欧美激情高清视频| 欧美裸身视频免费观看| 欧美日韩国产丝袜美女| 日韩电影在线观看永久视频免费网站| 亚洲国产精品久久精品怡红院| 国模极品一区二区三区| 欧美激情三级免费| 久久精品视频在线观看| 亚洲国产私拍精品国模在线观看| 96sao精品视频在线观看| 午夜精品久久久久久久久久久久| 一区二区亚洲欧洲国产日韩| 精品国产户外野外| 少妇高潮久久77777| 国产精品视频免费观看www| 热久久这里只有精品| 国产97在线视频| 国产精品高潮粉嫩av| 日韩影视在线观看| 久久九九热免费视频| 亚洲成人激情小说| 精品视频久久久久久| 欧美在线观看日本一区| 日韩av一卡二卡| 亚洲人成在线电影| 8x海外华人永久免费日韩内陆视频| 久久精品91久久香蕉加勒比| 欧美日本啪啪无遮挡网站| 日韩成人av在线播放| 91精品国产91久久久久久不卡| 欧美又大又硬又粗bbbbb| 亚洲视频自拍偷拍| 国内久久久精品| **欧美日韩vr在线| 俺也去精品视频在线观看| 亚洲精品suv精品一区二区| 日韩美女视频免费看| 91亚洲精品久久久久久久久久久久| 国产成人精品免费久久久久| 国产精品jvid在线观看蜜臀| 欧美大片网站在线观看| 狠狠色香婷婷久久亚洲精品| 韩日欧美一区二区| 性欧美暴力猛交69hd| 国产精品激情av电影在线观看| 欧美国产日韩视频| 韩国国内大量揄拍精品视频| xxxxxxxxx欧美| 欧美视频13p| 日韩成人av网址| 91精品久久久久久久久不口人| 中文字幕亚洲欧美在线| 成人激情视频在线观看| 日韩欧美在线视频日韩欧美在线视频| 国产一区二区香蕉| 91av网站在线播放| 国产精品av电影| 久久好看免费视频| 91丝袜美腿美女视频网站| 久久久女女女女999久久| 欧美极品美女视频网站在线观看免费| 亚洲久久久久久久久久| 青草青草久热精品视频在线观看| 九九精品视频在线| 日韩在线精品视频| 国产精品亚洲欧美导航| 欧美一区二区视频97| 最好看的2019年中文视频| 亚洲成人精品久久| 精品成人国产在线观看男人呻吟| 久久久久久亚洲| 精品网站999www| 久久综合九色九九| 国产91精品黑色丝袜高跟鞋| 国产精品一二区| 亚洲自拍小视频| 亚洲精品久久久久久久久久久久久| 91精品久久久久久综合乱菊| 欧美高清不卡在线| 成人黄色中文字幕| 国产精品尤物福利片在线观看| 色七七影院综合| 66m—66摸成人免费视频| 91精品久久久久| 午夜欧美大片免费观看| 欧美午夜精品伦理| 成人精品福利视频| 久久国产精品电影| 亚洲美女在线观看| 国产成人精品在线播放| 国产精品成人品| 国产亚洲欧洲高清一区| 亚洲男人第一网站| 国产在线精品成人一区二区三区| 亚洲欧洲免费视频| 日韩精品中文字幕在线| 亚洲欧美第一页| 欧美日韩成人在线视频| 日韩黄色在线免费观看| 青青草99啪国产免费| 国产成人av网| 亚洲www永久成人夜色| 久色乳综合思思在线视频| 亚洲区一区二区| 欧美亚洲日本网站| 91久久嫩草影院一区二区| 911国产网站尤物在线观看| 日韩免费在线播放| 97人人模人人爽人人喊中文字| 亚洲第一av网站| 久久99久久久久久久噜噜| 欧美激情国内偷拍| 欧美日韩在线免费| 亚洲精品久久久久久下一站| 亚洲精选一区二区| 国产午夜精品全部视频播放| 欧洲美女7788成人免费视频| 中文国产亚洲喷潮| 国产男人精品视频| 国产精品久久久久999| 日韩天堂在线视频| 国产91精品久久久久久久| 国产精品入口免费视频一| 啪一啪鲁一鲁2019在线视频| 伊人亚洲福利一区二区三区| 久久久久久久久久久久av| 国产亚洲精品一区二555| 久久99久久99精品免观看粉嫩| 日韩精品高清视频| 欧美福利在线观看| 在线精品视频视频中文字幕| 美女性感视频久久久| 日韩精品中文字幕有码专区| 中文字幕视频在线免费欧美日韩综合在线看|