iOS UI基础-3.0图片浏览器及plist使用
2015-08-20 22:58 jiangys 阅读(910) 评论(0) 编辑 收藏 举报需求:
1.显示当前图片序号/总图片数
2.显示图片
3.上一张图片、下一张图片转换
4.显示图片描述
下面用代码来实现
// // UYViewController.m // 3.0图片查看器 // // Created by jiangys on 15/8/19. // Copyright (c) 2015年 uxiaoyuan. All rights reserved. // #import "UYViewController.h" @interface UYViewController () @property(nonatomic,strong) UILabel *noLabel; @property(nonatomic,strong) UIImageView *iconImage; @property(nonatomic,strong) UILabel *descLable; @property(nonatomic,strong) UIButton *leftButton; @property(nonatomic,strong) UIButton *rightButton; //显示当前的照片索引 @property(nonatomic,assign) int index; //图片信息的数组 @property(nonatomic,strong) NSArray *imageList; @end @implementation UYViewController -(NSArray *)imageList { if (_imageList==nil) { NSString *path=[[NSBundle mainBundle] pathForResource:@"ImageList" ofType:@"plist"]; //在OC中,通常需要完整的路径 _imageList=[NSArray arrayWithContentsOfFile:path]; } return _imageList; } - (void)viewDidLoad { [super viewDidLoad]; //1.索引 _noLabel=[[UILabel alloc] initWithFrame:CGRectMake(0, 20, self.view.frame.size.width, 40)]; _noLabel.text=@"1/5"; _noLabel.textAlignment=NSTextAlignmentCenter; [self.view addSubview:_noLabel]; //2.图片 CGFloat imageW=200; CGFloat imageH=200; CGFloat imageX=(self.view.frame.size.width-imageW)*0.5; CGFloat imageY=CGRectGetMidY(self.noLabel.frame)+20; _iconImage=[[UIImageView alloc] initWithFrame:CGRectMake(imageX, imageY, imageW, imageH)]; _iconImage.image=[UIImage imageNamed:@"biaoqingdi"]; [self.view addSubview:_iconImage]; //3.描述 _descLable=[[UILabel alloc] initWithFrame:CGRectMake(0, CGRectGetMaxY(self.iconImage.frame), self.view.frame.size.width, 100)]; _descLable.text=@"测试的拉"; _descLable.textAlignment=NSTextAlignmentCenter; //需要Label具有“足够的高度”,不限制显示的行数 _descLable.numberOfLines=0; [self.view addSubview:_descLable]; //4.左边的按钮 _leftButton=[[UIButton alloc] initWithFrame:CGRectMake(0, 0, 40, 40)]; CGFloat centerX=self.iconImage.frame.origin.x*0.5; CGFloat centerY=self.iconImage.center.y; _leftButton.center=CGPointMake(centerX, centerY); _leftButton.tag=-1; [_leftButton setBackgroundImage:[UIImage imageNamed:@"left_normal"] forState:UIControlStateNormal]; [_leftButton setBackgroundImage:[UIImage imageNamed:@"left_highlighted"] forState:UIControlStateHighlighted]; [_leftButton addTarget:self action:@selector(clickButton:) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:_leftButton]; //5.右边的按钮 _rightButton=[[UIButton alloc] initWithFrame:CGRectMake(0, 0, 40, 40)]; _rightButton.center=CGPointMake(self.view.bounds.size.width-centerX, centerY); [_rightButton setBackgroundImage:[UIImage imageNamed:@"right_normal"] forState:UIControlStateNormal]; [_rightButton setBackgroundImage:[UIImage imageNamed:@"rigth_highlighted"] forState:UIControlStateHighlighted]; [self.view addSubview:_rightButton]; _rightButton.tag=1; [_rightButton addTarget:self action:@selector(clickButton:) forControlEvents:UIControlEventTouchUpInside]; [self showPhotoInfo]; } -(void)clickButton:(UIButton *)button { //根据按钮调整当前显示图片的索引 self.index+=(int)button.tag; [self showPhotoInfo]; } -(void)showPhotoInfo { self.noLabel.text=[NSString stringWithFormat:@"%d/%d",self.index+1,5]; self.iconImage.image=[UIImage imageNamed:self.imageList[self.index][@"name"]]; self.descLable.text=self.imageList[self.index][@"desc"]; self.rightButton.enabled=(self.index!=4); self.leftButton.enabled=(self.index!=0); } @end
plist文件的使用:
1.创建一个plist
2.填写为ImageList.plist
3.填入数据
4.完成