iOS- UIButton/UIImageView/UISlider/UISwitch操作
如果看不到图片 可以尝试更换浏览器(推荐Safari )
一、控件的属性
1.CGRect frame
1> 表示控件的位置和尺寸(以父控件的左上角为坐标原点(0, 0))
2> 修改这个属性,可以调整控件的位置和尺寸
2.CGPoint center
1> 表示控件的中点(以父控件的左上角为坐标原点)
2> 修改这个属性,可以调整控件的位置
3.CGRect bounds
1> 表示控件的位置和尺寸(以自己的左上角位坐标原点,位置永远是(0, 0))
2> 修改这个属性,只能调整控件的尺寸
4.int tag
1> 表示控件的标识
2> 通过不同标识可以区分不同的控件
5.CGAffineTransform transform
1> 表示控件的形变状态(旋转角度、缩放比例)
2> 创建CGAffineTransform的函数
* CGAffineTransformMakeScale(CGFloat sx, CGFloat sy)
创建一个x、y方向的缩放比例分别为sx、sy的形变值 * CGAffineTransformMakeRotation(CGFloat angle)
创建一个旋转角度为angle的形变值 * CGAffineTransformScale(CGAffineTransform t, CGFloat sx, CGFloat sy)
在形变值t的基础上,再进行缩放,x、y方向的缩放比例分别为sx、sy,然后返回一个新的形变值 * CGAffineTransformRotate(CGAffineTransform t, CGFloat angle)
在形变值t的基础上,再进行旋转,旋转角度为angle,然后返回一个新的形变值 二、添加控件到控制器的view
[self.view addSubview:子控件];
二、添加控件到控制器的view
[self.view addSubview:子控件];
三、设置按钮的属性
// 1.创建按钮
// 1.1.创建
UIButton *btn = [[UIButton alloc] init]; // 1.2.设置按钮的尺寸和位置
btn.frame = CGRectMake(, , , ); // 1.3.设置按钮普通状态下的属性
// 1.3.1.设置背景图片
UIImage *normal = [UIImage imageNamed:@"btn_01.png"];
[btn setBackgroundImage:normal forState:UIControlStateNormal];
// 1.3.2.设置文字
[btn setTitle:@"你好" forState:UIControlStateNormal];
// 1.3.3.设置文字颜色
[btn setTitleColor:[UIColor greenColor] forState:UIControlStateNormal]; // 1.4.设置按钮高亮状态下的属性
// 1.4.1.设置背景图片
UIImage *high = [UIImage imageNamed:@"btn_02.png"];
[btn setBackgroundImage:high forState:UIControlStateHighlighted];
// 1.4.2.设置文字
[btn setTitle:@"Hello" forState:UIControlStateHighlighted];
// 1.4.3.设置文字颜色
[btn setTitleColor:[UIColor redColor] forState:UIControlStateHighlighted]; // 1.5.监听按钮点击
[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
四、viewDidLoad
1.这是控制器的一个方法
2.当控制器的view创建完毕的时候会调用一次
五、UISlider
1.value属性可以获得当前的进度值
2.按钮的value发生改变了,会触发UIControlEventValueChanged事件
六、Plist文件的使用
1.加载一个plist文件的时候,会返回一个plist的根节点对象(Root)
七、NSBundle的使用
1.利用NSBundle可以访问某个资源包的内容
2.如果访问软件中最主要资源包的内容,应该用mainBundle
NSBundle *bundle = [NSBundle mainBundle];
3.利用NSBundle获得文件的全路径
NSString *path = [bundle pathForResource:@"descs" ofType:@"plist"];
七、实例、按钮操作(移动/放大/旋转)
ViewController.h
#import <UIKit/UIKit.h> @interface ViewController : UIViewController
@property (weak, nonatomic) IBOutlet UIButton *btn; // 重置
- (IBAction)reset:(id)sender; // 行走
- (IBAction)run:(id)sender;
// 缩放
- (IBAction)scale:(id)sender;
// 旋转
- (IBAction)rotate:(id)sender;
@end
ViewController.m
#import "ViewController.h" #define kDelta 50
//const int delta = 50; @interface ViewController ()
//{
// CGFloat _angle;
//}
@end @implementation ViewController //- (void)begin
//{
// // 0.动画(头部-开始动画)
// [UIView beginAnimations:nil context:nil];
// // 设置动画的执行时间
// [UIView setAnimationDuration:1.0];
//}
//
//- (void)end
//{
// // 4.动画(尾部-提交动画-执行动画)
// [UIView commitAnimations];
//} - (void)btnClickWithBlock:(void (^)())block
{
// 0.动画(头部-开始动画)
[UIView beginAnimations:nil context:nil];
// 设置动画的执行时间
[UIView setAnimationDuration:1.0]; block(); // 1.动画(尾部-提交动画-执行动画)
[UIView commitAnimations];
} #pragma mark 控制按钮走动(上下左右)
- (IBAction)run:(id)sender {
[self btnClickWithBlock:^{
// 1.先取出frame
// CGRect tempFrame = _btn.frame;
CGPoint tempCenter = _btn.center; // 2.取出按钮的tag标记
int tag = [sender tag];
// CGFloat delta = 100;
switch (tag) {
case : // 上
// tempFrame.origin.y -= kDelta;
tempCenter.y -= kDelta;
break; case : // 右
// tempFrame.origin.x += kDelta;
tempCenter.x += kDelta;
break; case : // 下
// tempFrame.origin.y += kDelta;
tempCenter.y += kDelta;
break; case : // 左
// tempFrame.origin.x -= kDelta;
tempCenter.x -= kDelta;
break; default:
break;
} // 3.重新赋值按钮的frame
// _btn.frame = tempFrame;
_btn.center = tempCenter;
}];
} #pragma mark 放大\缩小
- (IBAction)scale:(id)sender {
[self btnClickWithBlock:^{
CGFloat scale = [sender tag] == ? 1.2 : 0.8;
_btn.transform = CGAffineTransformScale(_btn.transform, scale, scale);
}];
} #pragma mark 左旋转\右旋转
- (IBAction)rotate:(id)sender {
// _angle -= M_PI_4; // 弧度 3.14 - π
// 角度 180
// 向左旋转45°
// _btn.transform = CGAffineTransformMakeRotation(- M_PI_4);
// _btn.transform = CGAffineTransformRotate(_btn.transform, M_PI_4 * (10 == tag?-1:1)); [self btnClickWithBlock:^{
int tag = [sender tag];
if ( == tag) { // 左
_btn.transform = CGAffineTransformRotate(_btn.transform, M_PI_4 * -);
} else { // 右
_btn.transform = CGAffineTransformRotate(_btn.transform, M_PI_4 * );
}
}];
} #pragma mark 重置
- (IBAction)reset:(id)sender {
// 清空之前所有的形变状态(消除以前的旋转、缩放等状态)
// _btn.transform = CGAffineTransformIdentity;
[self btnClickWithBlock:^{
_btn.transform = CGAffineTransformIdentity;
}];
}
@end
八、实例、简易图片浏览器
ViewController.h
#import <UIKit/UIKit.h> @interface ViewController : UIViewController
- (IBAction)nightMode:(UISwitch *)sender;
- (IBAction)imageSizeChange:(UISlider *)sender;
- (IBAction)setting;
- (IBAction)sliderValueChange:(UISlider *)sender;
@property (weak, nonatomic) IBOutlet UIImageView *imageView;
@property (weak, nonatomic) IBOutlet UILabel *imageNo;
@property (weak, nonatomic) IBOutlet UILabel *imageDesc;
@property (weak, nonatomic) IBOutlet UIView *settingView; @end
ViewController.m
#import "ViewController.h" @interface ViewController ()
{
NSArray *_allDescs;
}
@end @implementation ViewController #pragma mark 控制器的view加载完毕后会调用一次
- (void)viewDidLoad
{
[super viewDidLoad]; // 1.获得所有的描述(通过解析plist文件来创建数组对象,比如传入文件的全路径)
// 如果要访问项目中资源包里面的所有资源。应该用mainBundle
NSBundle *bundle = [NSBundle mainBundle];
// 获得文件的全路径
NSString *path = [bundle pathForResource:@"descs" ofType:@"plist"];
// 加载path对应的文件来创建数组
_allDescs = [NSArray arrayWithContentsOfFile:path]; // 2.设置默认的描述
_imageDesc.text = _allDescs[];
} #pragma mark 夜间模式
- (IBAction)nightMode:(UISwitch *)sender {
if (sender.on) { // 开
self.view.backgroundColor = [UIColor darkGrayColor];
} else { // 关
self.view.backgroundColor = [UIColor whiteColor];
}
} #pragma mark 图片尺寸改变了
- (IBAction)imageSizeChange:(UISlider *)sender {
// // 1.取出frame
// CGRect tempFrame = _imageView.frame;
//
// // 2.修改frame
// tempFrame.size.width = sender.value * 320;
// tempFrame.size.height = sender.value * 100;
//
// // 3.重新赋值frame
// _imageView.frame = tempFrame; _imageView.transform = CGAffineTransformMakeScale(sender.value, sender.value);
} #pragma mark 点击了设置
- (IBAction)setting {
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:0.5]; // 1.取出中点
CGPoint tempCenter = _settingView.center; // 2.修改y值
// tempCenter.y -= _settingView.frame.size.height; if (_settingView.frame.origin.y == self.view.frame.size.height) { // 设置界面目前看不见
tempCenter.y -= _settingView.bounds.size.height;
} else { // 能看见设置界面
tempCenter.y += _settingView.bounds.size.height;
} // 3.重新赋值
_settingView.center = tempCenter; [UIView commitAnimations];
} #pragma mark slider值改变
- (IBAction)sliderValueChange:(UISlider *)sender {
// 1.设置中间的图片
// 获得图片名称 %.f 不保留任何小数
NSString *imageName = [NSString stringWithFormat:@"%.f.png", sender.value];
_imageView.image = [UIImage imageNamed:imageName]; // 2.设置序号(第几张)
_imageNo.text = [NSString stringWithFormat:@"%.f/16", sender.value + ]; // 3.设置描述
int no = (int)(sender.value + 0.5);
_imageDesc.text = _allDescs[no];
}
@end
Thanks! 清澈Saup
iOS- UIButton/UIImageView/UISlider/UISwitch操作的更多相关文章
- IOS UIButton用法详解
这段代码动态的创建了一个UIButton,并且把相关常用的属性都列举了.希望对大家有用. //这里创建一个圆角矩形的按钮UIButton *button1 = [UIButton buttonWi ...
- iOS UIButton 图片文字上下垂直布局 解决方案
实现如图所示效果: 这是一个UIButton,需要改变image和title相对位置. 解决如下: //设置文字偏移:向下偏移图片高度+向左偏移图片宽度 (偏移量是根据[图片]大小来的,这点是关键)b ...
- IOS学习笔记25—HTTP操作之ASIHTTPRequest
IOS学习笔记25—HTTP操作之ASIHTTPRequest 分类: iOS2012-08-12 10:04 7734人阅读 评论(3) 收藏 举报 iosios5网络wrapper框架新浪微博 A ...
- iOS UIButton文字和图片间距随意调整
代码地址如下:http://www.demodashi.com/demo/11606.html 前记 在开发中,我们经常会遇到这么一种情况,就是一个按钮上面有图片也有文字,但是往往设计并不是我们想要的 ...
- iOS——使用FMDB进行数据库操作(转载)
iOS 使用FMDB进行数据库操作 https://github.com/ccgus/fmdb [摘要]本文介绍iOS 使用FMDB进行数据库操作,并提供详细的示例代码供参考. FMDB 使用方法 A ...
- iOS学习21之UILabel, UITextField, UIButton, UIImageView
1.UILabel 1> 概述 UILabel (标签): 是显示文本的控件.在App中 UILabel 是出现频率最高的控件 UILabel 是 UIView 子类,作为子类一般是为了扩充父类 ...
- swift系统学习控件篇:UIbutton+UIlabel+UITextField+UISwitch+UISlider
工作之余,学习下swift大法.把自己的学习过程分享一下.当中的布局很乱,就表在意这些细节了.直接上代码: UIButton+UILabel // // ViewController.swift // ...
- iOS基础 - UIButton - UIImageView
封装思想:将相同的重复东西保存到方法里,不同的东西用参数代替.不相同的东西交给方法调用者,相同东西自己搞定. 一.UIButton和UIImageView的区别 1.显示图片 1> UIImag ...
- 【iOS 开发】基本 UI 控件详解 (UIButton | UITextField | UITextView | UISwitch)
博客地址 : http://blog.csdn.net/shulianghan/article/details/50051499 ; 一. UI 控件简介 1. UI 控件分类 UI 控件分类 : 活 ...
随机推荐
- 在线预览word,excel文档
Google Doc 示例:https://jsfiddle.net/7xr419yb/ Microsoft Office 示例:https://jsfiddle.net/gcuzq343/
- scala 获取当前时间的两种方式
在编写程序时,有时需要获取当前时间,这在记录异常信息.获取程序运行耗时很有用处 方式一: val time1=System.currentTimeMillis() 这种方式获取的是程序运行到此的毫秒数 ...
- Zookeeper -- 本地\完全分布式 搭建
准备工作 linux软件:Zookeeper-3.4.12.tar.gz 四台centos系统虚拟机,主机名为:s101~s104 一.本地模式搭建(s101上安装) 1.解压软件压缩包:解压到根目录 ...
- ajax重定向登录页
/** * ajax默认设置 * 包括默认提交方式为POST, * 判断后台是否是重定向 */ $.ajaxSetup( { //设置ajax请求结束后的执行动作 complete : functio ...
- Python 1.2 列表和字典基础
一. List创建.索引.遍历和内置增删函数 1.列表是Python的内置可变对象,由Array实现,支持任意类型的添加.组合和嵌套. L = [] # list declare L = [1, 1. ...
- 【blockly教程】第五章 循环结构
在这里,我们将介绍一个新游戏--Pond Tutor 在Pond Tutor(https://blockly-games.appspot.com/pond-tutor)这个游戏中,我们将扮演黄色的鸭子 ...
- java 关键字super和this
super关键字 作用:调用父类的构造器 只能出现在子类的构造其中,并且必须是第一行 super()中的参数,决定了调用父类的那个构造器 注:如果子类构造器中没有出现super,则默认加上super( ...
- 北京Uber优步司机奖励政策(3月16日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- 北京Uber优步司机奖励政策(12月2日)
用户组:人民优步(适用于12月2日)奖励政策: 滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:htt ...
- dsp6657的串口学习
1. 打算用dsp6657学习下,先用串口实验吧.找一下芯片支持库Chip support libraries,路径D:\ti\pdk_C6657_1_1_1_4\packages\ti\csl,新建 ...