UI基础UIView常见属性及方法

1.NSBundle

1> 一个NSBundle代表一个文件夹,利用NSBundle能访问对应的文件夹

2> 利用mainBundle就可以访问软件资源包中的任何资源

3> 模拟器应用程序的安装路径

/Users/aplle/资源库/Application Support/iPhone Simulator/7.1/Applications

 

2.UIImageView和UIButton

1> 使用场合

* UIImageView: 如果仅仅是显示图片,不需要监听图片的点击

* UIButton: 既要显示图片,又要监听图片的点击

 

2> 相同:能显示图片

 

3> 不同点

* UIButton能处理点击事件, UIImageView不能处理点击事件

* UIButton既能显示图片, 又能显示文字

* UIButton能同时显示两张图片

* UIButton继承自UIControl, 因此默认就能处理事件

* UIImageView继承自UIView, 因此默认就不能处理事件

 

3.Xcode文档安装路径

/Applications/Xcode.app/Contents/Developer/Documentation/DocSets

 

4.Xcode模拟器安装路径

/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs

 

5,UIView的常⻅见属性

➢ @property(nonatomic,readonly) UIView *superview;

➢ 获得⾃自⼰己的⽗父控件对象

➢ @property(nonatomic,readonly,copy) NSArray *subviews;

➢ 获得⾃自⼰己的所有⼦子控件对象

➢ @property(nonatomic) NSInteger tag;

➢ 控件的ID\标识,⽗父控件可以通过tag来找到对应的⼦子控件

➢ @property(nonatomic) CGAffineTransform transform;

➢ 控件的形变属性(可以设置旋转⾓角度、⽐比例缩放、平移等属性)

在OC中,通过transform属性可以修改对象的平移、缩放比例和旋转角度

 

常用的创建transform结构体方法分两大类

 

(1) 创建“基于控件初始位置”的形变

 

CGAffineTransformMakeTranslation(平移)

 

CGAffineTransformMakeScale(缩放)

 

CGAffineTransformMakeRotation(旋转)

 

(2) 创建“基于transform参数”的形变

 

CGAffineTransformTranslate

 

CGAffineTransformScale

 

CGAffineTransformRotate

 

 

补充:

 

在OC中,所有跟角度相关的数值,都是弧度值,180° = M_PI

 

正数表示顺时针旋转

 

负数表示逆时针旋转

 

提示:由于transform属性可以基于控件的上一次的状态进行叠加形变,例如,先旋转再平移。因此在实际动画开发中,当涉及位置、尺寸形变效果时,大多修改控件的transform属性,而不是frame、bounds、center 。

 

@property(nonatomic) CGRect frame; 控件所在矩形框在⽗父控件中的位置和尺⼨寸(以⽗父控件的左上⾓角为坐标原点)

@property(nonatomic) CGRect bounds; 控件所在矩形框的位置和尺⼨寸(以⾃自⼰己左上⾓角为坐标原点,所以bounds的x\y⼀一般

                                                   为0)

@property(nonatomic) CGPoint center;

控件中点的位置(以⽗父控件的左上⾓角为坐标原点)

 

6,UIView的常⻅见⽅方法

➢ - (void)addSubview:(UIView *)view;

➢ 添加⼀一个⼦子控件view

➢ - (void)removeFromSuperview;

➢ 从⽗父控件中移除

➢ - (UIView *)viewWithTag:(NSInteger)tag;

➢ 根据⼀一个tag标识找出对应的控件(⼀一般都是⼦子控件)

 

7,动画的两种创建方式

 1)

  //开始动画

 [UIView beginAnimations:nil context:nil];

 // 执行动画内容

 self.headImageView.bounds=bounds;

 // 设置动画时间

 [UIView setAnimationDuration:2.0];

 // 提交动画

 [UIView commitAnimations];

 2) // 一般用这种方式

  UIView animateKeyframesWithDuration:<#(NSTimeInterval)#> delay:<#(NSTimeInterval)#> options:<#(UIViewKeyframeAnimationOptions)#> animations:<#^(void)animations#> completion:<#^(BOOL finished)completion#>

8,汤姆猫中动画执行代码顺序

 // 1,设置图片数组

self.tom.animationImages = images;

 

// 2.设置播放次数(1次)

self.tom.animationRepeatCount = 1;

 

// 3.设置播放时间

self.tom.animationDuration = images.count * 0.05;

// 4,开始动画

[self.tom startAnimating];

 性能问题

// 加载图片

// imageNamed: 有缓存(传入文件名)

//        UIImage *image = [UIImage imageNamed:filename];

 解决办法

// imageWithContentsOfFile: 没有缓存(传入文件的全路径)

NSBundle *bundle = [NSBundle mainBundle];

NSString *path = [bundle pathForResource:filename ofType:nil];

UIImage *image = [UIImage imageWithContentsOfFile:path];

 

动画放完1秒后清除内存

CGFloat delay = self.tom.animationDuration + 1.0;

[self.tom performSelector:@selector(setAnimationImages:) withObject:nil afterDelay:delay];

 

代码图片浏览器动态代码:

模型类

#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>

@interface LLPic : NSObject

// 图片地址
@property (nonatomic, copy) NSString *icon;

// 图片
@property (nonatomic, strong) UIImage *image;

// 描述
@property (nonatomic, copy) NSString *desc;

+ (instancetype)picWithDic:(NSDictionary *)dic;
- (instancetype)initWithDic:(NSDictionary *)dic;

+ (NSArray *)array;

@end
#import "LLPic.h"

@interface LLPic ()
{
    UIImage *_imageABC;
}
@end

@implementation LLPic

+ (NSArray *)array
{
    NSString *path = [[NSBundle mainBundle] pathForResource:@"images.plist" ofType:nil];
    
    NSArray *arrPic = [NSArray arrayWithContentsOfFile:path];
    NSMutableArray *arrPicMA = [[NSMutableArray alloc] initWithCapacity:arrPic.count];
    for (NSDictionary *dic in arrPic) {
        
        [arrPicMA addObject:[self picWithDic:dic]];
    }
    return arrPicMA;
}

- (UIImage *)image
{
    if (!_imageABC) {
        _imageABC = [UIImage imageNamed:self.icon];
    }
    return _imageABC;
}

- (instancetype)initWithDic:(NSDictionary *)dic
{
    if (self = [super init]) {
        
        [self setValuesForKeysWithDictionary:dic];
    }
    return self;
}

+ (instancetype)picWithDic:(NSDictionary *)dic
{
    return [[self alloc] initWithDic:dic];
}

@end

controller

#import "ViewController.h"
#import "LLPic.h"
@interface ViewController ()

// 属性值必须改为strong,如果联系IBOutLet则为week
@property (nonatomic, strong) NSArray *picView;
@property (nonatomic, strong) UILabel *headLab;
@property (nonatomic, strong) UIImageView *imageView;
@property (nonatomic, strong) UIButton *leftBtn;
@property (nonatomic, strong) UIButton *rightBtn;
@property (nonatomic, strong) UILabel *footLab;
@property (nonatomic, strong) UIButton *leftRotationBtn; // 左旋转
@property (nonatomic, strong) UIButton *rightRotationBtn; // 右旋转
// 计数器
@property (nonatomic, assign) int index;

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    self.view.backgroundColor = [UIColor purpleColor];

    [self loadPicView];
}

#pragma mark - 按钮点击事件
// 左点击
- (void)leftBtnClick
{
    self.index--;
    [self loadPicView];
}
// 右点击
- (void)rightBtnClick
{
    self.index++;
    [self loadPicView];
}


// 按钮旋转事件
- (void)rotationBtn:(UIButton *)btn
{
    [UIView animateWithDuration:0.2 animations:^{
        if (btn.tag == 20) {
            self.imageView.transform = CGAffineTransformRotate(self.imageView.transform, M_PI_4);
        } else if (btn.tag == 40){
            self.imageView.transform = CGAffineTransformRotate(self.imageView.transform, -M_PI_4);
        }
        
    }];
}

#pragma mark - 展示界面
- (void)loadPicView
{
    // 1,拿出模型对象
    
    LLPic *pic = self.picView[self.index];
    
    self.headLab.text = [NSString stringWithFormat:@"%d/%ld", self.index+1, self.picView.count];
    self.imageView.image = [UIImage imageNamed:pic.icon];
    self.footLab.text = pic.desc;
    
    self.leftBtn.enabled = (self.index != 0);
    self.rightBtn.enabled = (self.index != (self.picView.count-1));
    
    // 2,加载按钮
    [self creatRoationBtn];
    
}
#pragma mark - 懒加载控件,代码可读性强,并且提高性能
// headLab的加载
- (UILabel *)headLab
{
    if (!_headLab) {
        
        _headLab = [[UILabel alloc] initWithFrame:CGRectMake(10, 20, 300, 30)];
        _headLab.textAlignment = NSTextAlignmentCenter;
        [self.view addSubview:_headLab];
        
    }
    return _headLab;
}

// imageView的加载
- (UIImageView *)imageView
{
    if (!_imageView) {
        
        _imageView = [[UIImageView alloc] initWithFrame:CGRectMake(70, 70, 180, 180)];
        [self.view addSubview:_imageView];
    }
    return _imageView;
}

// leftBtn的加载
- (UIButton *)leftBtn
{
    if (!_leftBtn) {
        
        _leftBtn = [UIButton buttonWithType:UIButtonTypeCustom];
        _leftBtn.frame = CGRectMake(0,125, 40, 40);
        [_leftBtn setBackgroundImage:[UIImage imageNamed:@"left_normal"] forState:UIControlStateNormal];
        [_leftBtn setBackgroundImage:[UIImage imageNamed:@"left_highlighted"] forState:UIControlStateHighlighted];
        [_leftBtn setBackgroundImage:[UIImage imageNamed:@"left_disable"] forState:UIControlStateDisabled];
        
        // 按钮点击事件
        [_leftBtn addTarget:self action:@selector(leftBtnClick) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:_leftBtn];
    }
    return _leftBtn;
}

// rightBtn的加载
- (void)creatRoationBtn
{
    _rightRotationBtn = [UIButton buttonWithType:UIButtonTypeCustom];
    _rightRotationBtn.frame = CGRectMake(200,400,40, 40);
    [_rightRotationBtn setBackgroundImage:[UIImage imageNamed:@"right_rotate_normal"] forState:UIControlStateNormal];
    [_rightRotationBtn setBackgroundImage:[UIImage imageNamed:@"right_rotate_highlighted"] forState:UIControlStateHighlighted];
    _rightRotationBtn.tag = 20;
    [_rightRotationBtn addTarget:self action:@selector(rotationBtn:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:_rightRotationBtn];
    
    _leftRotationBtn = [UIButton buttonWithType:UIButtonTypeCustom];
    _leftRotationBtn.frame = CGRectMake(100,400,40, 40);
    [_leftRotationBtn setBackgroundImage:[UIImage imageNamed:@"left_rotate_normal"] forState:UIControlStateNormal];
    [_leftRotationBtn setBackgroundImage:[UIImage imageNamed:@"left_rotate_highlighted"] forState:UIControlStateHighlighted];
    _leftRotationBtn.tag = 40;
    [_leftRotationBtn addTarget:self action:@selector(rotationBtn:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:_leftRotationBtn];

}
- (UIButton *)rightBtn
{
    if (!_rightBtn) {
        
        _rightBtn = [UIButton buttonWithType:UIButtonTypeCustom];
        _rightBtn.frame = CGRectMake(280,125,40, 40);
        [_rightBtn setBackgroundImage:[UIImage imageNamed:@"right_normal"] forState:UIControlStateNormal];
        [_rightBtn setBackgroundImage:[UIImage imageNamed:@"right_highlighted"] forState:UIControlStateHighlighted];
        [_rightBtn setBackgroundImage:[UIImage imageNamed:@"right_disable"] forState:UIControlStateDisabled];
        
        [_rightBtn addTarget:self action:@selector(rightBtnClick) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:_rightBtn];
    }
    return _rightBtn;

}



// 描述lab
- (UILabel *)footLab
{
    if (!_footLab) {
        
        _footLab = [[UILabel alloc] initWithFrame:CGRectMake(10, 260, 300, 60)];
        _footLab.textAlignment = NSTextAlignmentCenter;
        _footLab.numberOfLines = 0;
        [self.view addSubview:_footLab];
        
    }

    return _footLab;
}

#pragma mark - 加载数据模型
- (NSArray *)picView
{
    if (!_picView) {
        
        _picView = [LLPic array];
    }
    return _picView;
}

@end

完成展示:

转载于:https://www.cnblogs.com/-boy/p/4106818.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值