黑马程序员_iOS 的基础控件之深入UIButton、UIImageView

iOS,Android,Java培训,期待与您的交流
iOS应用开发的一项内容就是用户界面的开发。不管应用程序实际包含的逻辑有多复杂,如果这个应用程序没有提供友好的图形用户界面,將很难吸引用户。作为一个程序设计者,必须优先考虑用户的感受,一定要让用户感到爽,这个应用程序才有价值。
1    UIButton和UIImageView的区别
1.显示图片
       1>UIImageView只能一种图片(图片默认会填充整个UIImageView) image\setImage:
       2> UIButton能显示2种图片
          * 背景 (背景会填充整个UIButton) setBackroungImage:forState:
          * 前置(覆盖在背景上面的图片,按照之前的尺寸显示) setImage:forState:
          * 还能显示文字
2.点击事件
       1> UIImageView默认是不能响应点击事件
       2> UIButton能响应点击事件 : addTarget:action:forControlEvents:
3.使用场合
       1> UIImageView : 只显示图片,不监听点击,点击了图片后不做任何反应
       2> UIButton : 既显示图片,又监听点击,点击了图片后做一些其他事情
4.继承结构
       1> UIButton之所以能添加监听器来监听事件,是因为它继承自UIControl
       2> UIImagevIew之所以不能添加监听器来监听事件,是因为它直接继承自UIView
    
- (void)viewDidLoad
{
    [super viewDidLoad];
    
    // 1.添加ImageView
    UIImageView *imageView = [[UIImageView alloc] init];
    imageView.image = [UIImage imageNamed:@"014.png"];
    imageView.frame = CGRectMake(0, 0, 150, 150);
    [self.view addSubview:imageView];
    
    // 2.UIButton
    UIButton *btn = [[UIButton alloc] init];
    // 设置背景图片
    [btn setBackgroundImage:[UIImage imageNamed:@"bg.png"] forState:UIControlStateNormal];
    // 设置前置图片
    [btn setImage:[UIImage imageNamed:@"016.png"] forState:UIControlStateNormal];
    btn.frame = CGRectMake(0, 100, 150, 150);
    
    [btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
    
    [btn setTitle:@"我是按钮" forState:UIControlStateNormal];
    [self.view addSubview:btn];

}

2    UIImageView的动画显示
UIImageView动画显示的原理是不断地切换图片,就形成了动画。步骤如下:
1、设置动画图片,animationImages:方法,需要传入一个NSArray,该集合保存的是多张图片
2、设置播放次数,animationRepeatCount属性
3、设置动画持续时间,animationDuration属性
4、开始动画,startAnimating
3    Tom猫实例
使用UIButton和UIImageView控件,实现一个简单的Tom实例,其UI界面如下所示。点击图中的任何一个按钮,Tom猫开始做动作。这些动作包括放屁,喝牛奶、吃小鸟等。
黑马程序员_iOS 的基础控件之深入UIButton、UIImageView_第1张图片
Tom猫的每个动作都需要很多图片,所以建立一个plist文件,保存每个动作的名字和图片张数。初始阶段,解析该文件,將所有信息保存到成员变量_dict,它是一个NSDictionary。
   
    
- (void)viewDidLoad
{
    [super viewDidLoad];
    
    // 1.获得tom.plist的全路径
    NSBundle *bundle = [NSBundle mainBundle];
    NSString *path = [bundle pathForResource:@"tom" ofType:@"plist"];
    
    // 2.根据文件路径加载字典
    _dict = [NSDictionary dictionaryWithContentsOfFile:path];
}



六个按钮的监听方法btnClick:,该方法调用了playAnim:filename:方法,它是执行动画的方法。
   
#pragma mark 监听所有的按钮点击
- (IBAction)btnClick:(UIButton *)sender {
    // 1.如果tom正在播放动画,直接返回,_tom是播放动画的UIImageView
    if (_tom.isAnimating) return;
    
    // 2.取出按钮文字
    NSString *title = [sender titleForState:UIControlStateNormal];
    
    // 3.获得图片数量
    int count = [_dict[title] intValue];
    
    // 4.播放动画
    [self playAnim:count fliename:title];
}

- (void)playAnim:(int)count fliename:(NSString *)filename
{
    // 1.创建可变数组
    NSMutableArray *images = [NSMutableArray array];
    
    // 2.添加图片
    for (int i = 0; i
iOS,Android,Java培训,期待与您的交流

你可能感兴趣的:(iOS)