<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont

简介: 1、UIImageView 是用来显示图片的控件,相当于相框,用来显示UIImage对象           //初始化UIImage对象及为其加载图片   //第一种方式//   UIImage *image = [UIImage imageNamed:@"1.
1、UIImageView  是用来显示图片的控件,相当于相框,用来显示UIImage对象           
    //初始化UIImage对象及为其加载图片
   
//第一种方式
//    UIImage *image = [UIImage imageNamed:@"1.JPG"];
    第二种方式
    通过图片的路径加载图片
    通过应用程序包找出图片 NSBundle (应用程序包类)
    获取当前应用包对象
    //pathForResource: 资源名称 ofType: 资源类型
//    NSString *filePath = [[NSBundle mainBundle]pathForResource:@"2" ofType:@"JPG"];
//    UIImage *image2 = [UIImage imageWithContentsOfFile:filePath];
两种优缺点和使用场景:
     第一种方式:如果这个图片资源被多次使用,使用第一种方式,此种方式会把图片添加到应用程序的缓存中,多次使用比较方便 ,缺点:占用内存,优点:第二次使用速度很快
        第二种方式:如果这个图片资源只被使用一次,使用第二种方式,此种方式不会把图片对象添加到缓存中,缺点:耗时
注意:本节素材下载(百度云):UIImageView素材   http://pan.baidu.com/s/1t2H2m
                                                                          动画素材       http://pan.baidu.com/s/1eQk7fN0
——————————————————————————————
    //创建UIimageView 对象
   UIImageView *imageView = [[UIImageView alloc]initWithImage:image];
   //配置属性
    //设定frame
    imageView.frame = [UIScreen mainScreen].bounds;
    //重新设置图片
    imageView.image = image2;
   [self.view addSubview:imageView];
    [imageView release];
    //UIImageView 加载动态图片
    //1.准备一组图片  使用数组存放
    NSMutableArray *imageArray = [NSMutableArray arrayWithCapacity:7];
     //使用for循环添加图片
    for (int i =1; i < 8; i ++) {
        //先确定图片的名字
        NSString *name = [NSString stringWithFormat:@"huoju_%d.tiff",i ];
        //初始化image对象
        UIImage *image = [UIImage imageNamed:name];
        //将图片添加到数组中
        [imageArray addObject:image];

    }
//     NSLog(@"%@",imageArray);//验证数组中是否添加完成
    //建立动画视图
    UIImageView  *fireImageView = [[UIImageView alloc]initWithFrame:CGRectMake(120, 100, 79, 106)];
    fireImageView.backgroundColor = [UIColor greenColor];
    //设置UIImageView 播放动态图片需要的数组
    fireImageView.animationImages  = imageArray;
    //设置播放速度
    fireImageView.animationDuration = 0.1;
    //设置播放图片重复次数
    fireImageView.animationRepeatCount = 1000;
    //启动动态图片播放 对动画的配置写在动画开始之前 VIP
    [fireImageView startAnimating];
    //添加到父视图
    [self.view addSubview:fireImageView];
    [fireImageView release];
    //等比缩放图片
    NSString *fielePath2 = [[NSBundle mainBundle]pathForResource:@"8" ofType:@"JPG"];
    UIImage *image3 = [UIImage imageWithContentsOfFile:fielePath2];
    //image3.size  中存放的是图片的宽和高
    NSLog(@"%@",NSStringFromCGSize(image3.size));
    //将UIImageView 设置为宽200,高为知,用来显示不是真的image3
    UIImageView *CFImageView = [[UIImageView alloc]initWithImage:image3];
    CGFloat h = image3.size.height * 200 / image3.size.width ;
    CFImageView.frame = CGRectMake(60, 200, 200, h);
    [self.view addSubview:CFImageView];
    [CFImageView release];
最终效果如下:
UIController子类控件 <wbr>UI_06

————————————————————————————
练习1:
//制作僵尸动态图片
       CGSize zSize = CGSizeZero;
    NSMutableArray *Zombil = [NSMutableArray arrayWithCapacity:22];
    for (int i = 1; i < 23; i ++) {
        //先确定图片的名字
        NSString *name1 = [NSString stringWithFormat:@"Zombie%d.tiff",i];
        //创建Image对象
        UIImage *image4 = [UIImage imageNamed:name1];
       //定义Size变量存储图片大小
        zSize = image4.size;
       //将图片添加到数组中
        [Zombil addObject:image4];
    }
    NSLog(@"%@",Zombil);//验证
    //建一个imageView 视图
    UIImageView *zombie1 = [[UIImageView alloc]initWithFrame:CGRectMake(10, 100, 300, zSize.height * 300 / zSize.height)];
    zombie1.backgroundColor = [UIColor redColor];
    //设置播放动画需要的数组
    zombie1.animationImages = Zombil;
    //设置播放速度
    zombie1.animationDuration = 3;
    //设置播放重复次数:给0是无限重复
    zombie1.animationRepeatCount = 100;
    //启动动画
    [zombie1 startAnimating];
    //加载到父视图
    [self.view addSubview:zombie1];
    [zombie1 release];
最终效果:
UIController子类控件 <wbr>UI_06

======================================================
2、UISwitch  开关控件 继承自 UIControl
    //创建Swictch对象
    UISwitch *aSwitch1 = [[UISwitch alloc]initWithFrame:CGRectMake(30, 50, 0, 0)];
    //配置Switch边框的渲染颜色
    aSwitch1.tintColor = [UIColor redColor];
   //配置控件内部的颜色
    aSwitch1.onTintColor = [UIColor blueColor];
    //设置按钮的颜色
    aSwitch1.thumbTintColor = [UIColor cyanColor];
   //给Switch 添加事件
    //self 指视图控制器对象
    [aSwitch1 addTarget:self action:@selector(handleSwitch:) forControlEvents:UIControlEventValueChanged];//当状态代表的数值改变的时候事件触发
    [self.view addSubview:aSwitch1];
    [aSwitch1 release];
}

#pragma mark switch 的关联事件
- (void)handleSwitch: (UISwitch *)aswitch{
    //首先应该或许开关控件当前的状态
    switch ((int)aswitch.on) {
        case YES:
            NSLog(@"开了");
            break;
            case NO:
            NSLog(@"关了");
            break;
        default:
            break;
    }
}
======================================================
3、UIStepper  加减控件   继承自 UIControl
   
UIStepper *aStep = [[UIStepper alloc]initWithFrame:CGRectMake(100, 100, 0, 0)];
   
//设置边框颜色
    aStep.
tintColor = [UIColor redColor];
   
//设置背景颜色
    aStep.
backgroundColor = [UIColor cyanColor];
   
//设置step的最小值 默认最小值是0.0
    aStep.
minimumValue = 10.0;
   
//设置step的最大值  默认最大值是100.0
    aStep.
maximumValue = 30.0;
   
//长按按钮数值是否自动增加或减小,默认为YES
    aStep.
autorepeat = NO;
   
//设置控件所代表的数值当大于最大值或者小于最小值的时候,是否可以从另一头开始
//    aStep.wraps = YES;
   
//设置点击按钮时数值的变化值
    aStep.
stepValue = 10.0;
    //给aStep添加事件
    [aStep addTarget:self action:@selector(handleStepper : ) forControlEvents:(UIControlEventValueChanged)];
    [self.view addSubview:aStep];
    [aStep
release];

}
UIController子类控件 <wbr>UI_06

//实现事件方法
- (void)handleStepper : (UIStepper *)stepper{
   
//stepper.value 代表这个控件当前的数值
   
NSLog(@"%f",stepper.value);
}
=========================================================
4、UISegmentedControl  分段控制器,此控件有多个分段组成,每一个分段相当于一个button
    NSArray *titles = @[@"红色",@"绿色背景",@"蓝色",@"橙色",@"紫色"];
   //创建segmentControl 对象,并为每个分段添加title
    UISegmentedControl *aSegment = [[UISegmentedControl alloc]initWithItems:titles];
    //segmentControl 每个标题的宽度默认是等分总宽度的
    aSegment.frame = CGRectMake(20, 40, 280, 40);
    //设置segmentControl的边框颜色
    aSegment.tintColor = [UIColor magentaColor];
    //设置默认选中的分段
    aSegment.selectedSegmentIndex = 0;
    //修改分段的宽度

    [aSegment setWidth:60 forSegmentAtIndex:1];
    //给segmentControl 关联事件
    [aSegment addTarget:self action:@selector(handlSegment : ) forControlEvents:(UIControlEventValueChanged)];
    //添加父视图
    [self.view addSubview:aSegment];
    [aSegment release];
}
UIController子类控件 <wbr>UI_06
   ————————————————————
#pragma mark  segmentControl 的关联事件
- (void)handlSegment : (UISegmentedControl *)segment{
//    segment.selectedSegmentIndex   返回当前分段控制器被选中的下标
    NSLog(@"%ld",segment.selectedSegmentIndex);//验证
    self.view.backgroundColor = [UIColor blueColor];
    switch (segment.selectedSegmentIndex) {
        case 0:
            self.view.backgroundColor = [UIColor redColor];
            break;
            case 1:
            self.view.backgroundColor = [UIColor greenColor];
            break;
            case 2:
            self.view.backgroundColor = [UIColor blueColor];
            break;
            case 3:
            self.view.backgroundColor = [UIColor orangeColor];
            break;
            case 4:
            self.view.backgroundColor = [UIColor purpleColor];
            break;
        default:
            break;
    }
}
================================================
5、UISlider  滑块控件,继承自UIControl ,主要用来显示当前播放进度,控制音量或进度
(注意:必须记忆的方法)
    UISlider *aSlider = [[UISlider alloc]initWithFrame:CGRectMake(20, 100, 280, 30)];
   
//设置属性
   
//设置滑块最小值

    aSlider.
minimumValue = 0.2;
   
//设置滑块最大值
    aSlider.
maximumValue = 1.0;
   
//设置滑块当前的数值(或位置)
    aSlider.
value = 0.5;
   
//设置滑过区域的颜色
    aSlider.
minimumTrackTintColor = [UIColor redColor];
   
//设置未滑过区域的颜色
    aSlider.
maximumTrackTintColor = [UIColor whiteColor];
   
//设置滑块上的图片
    [aSlider
setThumbImage:[UIImage imageNamed:@"slider"] forState:UIControlStateNormal];
 
//关联时间
    [aSlider addTarget:self action:@selector(handleSlinder : ) forControlEvents:(UIControlEventValueChanged)];
    [self.view addSubview:aSlider];
    [aSlider release];
}
效果图:

UIController子类控件 <wbr>UI_06 —————— ————————————————————————
#pragma mark slider的关联时间
- (void)handleSlinder :  (UISlider *)aSlider{
   
//通过滑块控制视图的透明度
   
self.view.alpha = aSlider.value;
    //value 返回的是当前滑块所在位置代表的数值
   //NSLog(@"%.2f",aSlider.value);//验证使用,用过要注掉
}

=========================================================
总结:UIControll 是控制控件的基类,凡是继承自该类的子类都可以通过addTarget: action: forControlEvents : 这个方法添加响应时间,UIontrol类的实现类似我们学过的target ... action 设计模式, 所以如果你想自定义一个视图,而且还是能够响应事件的,那就让它继承自UIControl;

欢迎学习本文,未经博主许可,禁止转载!
目录
相关文章
|
SQL Web App开发 前端开发
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
在运行一个group by的sql时,抛出以下错误信息: Task with the most failures(4):  -----Task ID:  task_201411191723_723592_m_000004URL:  http://DDS0204.
920 0
|
8天前
|
人工智能 自然语言处理 API
深入浅出LangChain与智能Agent:构建下一代AI助手
LangChain为大型语言模型提供了一种全新的搭建和集成方式,通过这个强大的框架,我们可以将复杂的技术任务简化,让创意和创新更加易于实现。本文从LangChain是什么到LangChain的实际案例到智能体的快速发展做了全面的讲解。
279543 52
深入浅出LangChain与智能Agent:构建下一代AI助手
|
9天前
|
设计模式 人工智能 JSON
一文掌握大模型提示词技巧:从战略到战术
本文将用通俗易懂的语言,带你从战略(宏观)和战术(微观)两个层次掌握大模型提示词的常见技巧,真正做到理论和实践相结合,占领 AI 运用的先机。
237785 4
|
9天前
|
NoSQL Cloud Native Redis
Redis核心开发者的新征程:阿里云与Valkey社区的技术融合与创新
阿里云瑶池数据库团队后续将持续参与Valkey社区,如过往在Redis社区一样耕耘,为开源社区作出持续贡献。
Redis核心开发者的新征程:阿里云与Valkey社区的技术融合与创新
|
9天前
|
关系型数据库 分布式数据库 数据库
PolarDB闪电助攻,《香肠派对》百亿好友关系实现毫秒级查询
PolarDB分布式版助力《香肠派对》实现百亿好友关系20万QPS的毫秒级查询。
PolarDB闪电助攻,《香肠派对》百亿好友关系实现毫秒级查询
|
3天前
|
机器人 Linux API
基于Ollama+AnythingLLM轻松打造本地大模型知识库
Ollama是开源工具,简化了在本地运行大型语言模型(ile优化模型运行,支持GPU使用和热加载。它轻量、易用,可在Mac和Linux上通过Docker快速部署。AnythingLLM是Mintplex Labs的文档聊天机器人,支持多用户、多种文档格式,提供对话和查询模式,内置向量数据库,可高效管理大模型和文档。它也是开源的,能与Ollama结合使用,提供安全、低成本的LLM体验。这两款工具旨在促进本地高效利用和管理LLMs。
81077 19
|
10天前
|
消息中间件 Cloud Native Serverless
RocketMQ 事件驱动:云时代的事件驱动有啥不同?
本文深入探讨了云时代 EDA 的新内涵及它在云时代再次流行的主要驱动力,包括技术驱动力和商业驱动力,随后重点介绍了 RocketMQ 5.0 推出的子产品 EventBridge,并通过几个云时代事件驱动的典型案例,进一步叙述了云时代事件驱动的常见场景和最佳实践。
246779 2
|
7天前
|
物联网 PyTorch 测试技术
手把手教你捏一个自己的Agent
Modelscope AgentFabric是一个基于ModelScope-Agent的交互式智能体应用,用于方便地创建针对各种现实应用量身定制智能体,目前已经在生产级别落地。
|
11天前
|
弹性计算 安全 API
访问控制(RAM)|云上安全使用AccessKey的最佳实践
集中管控AK/SK的生命周期,可以极大降低AK/SK管理和使用成本,同时通过加密和轮转的方式,保证AK/SK的安全使用,本次分享为您介绍产品原理,以及具体的使用步骤。
101885 3
|
10天前
|
自然语言处理 Cloud Native Serverless
通义灵码牵手阿里云函数计算 FC ,打造智能编码新体验
近日,通义灵码正式进驻函数计算 FC WebIDE,让使用函数计算产品的开发者在其熟悉的云端集成开发环境中,无需再次登录即可使用通义灵码的智能编程能力,实现开发效率与代码质量的双重提升。
95465 4