不多说,先上图片看效果,AJ分享,必须精品

这个小程序主要实现点击方向键可以让图标上下左右动还有放大缩小以及旋转的功能,点击图片会显示另一张图片。

点击变换

其实用到了按钮的两个状态,再State Config中的Default还有Highlighted的两个状态下background内容图片的设置

其实就是按钮的几个状态:
Default:默认状态
Highlighted:被点击时候的高亮状态
Selected:被选中的时候的状态
Disabled:不能使用的时候的状态

移动

- (IBAction)move:(UIButton *)button {
//获得frame
CGRect frame = self.iconButton.frame;
//根据按钮的类型来修改frame属性
switch (button.tag) {
case kMovingDirTop:/**向上移动*/
frame.origin.y -=20;
break;
case kMovingDirBottom:/**向下移动*/
frame.origin.y +=20;
break;
case kMovingDirLeft:/**向左移动*/
frame.origin.x -=20;
break;
case kMovingDirRight:/**向右移动*/
frame.origin.x +=20;
break;
}

这是实现的主要方法,实现方法其实很多,这方法也不是最好的,可以参考。
这里需要注意的是:frame
对于类UIView(UIButton等等都是继承自他,可以看成在手机上显示的所有东西都是这个)有属性在屏幕上的位置等等最重要的属性是位置和大小。
我们可以通过按住command + 鼠标左键(ctrl+command+j)进入看源代码
通过看源码,我们发现他定义了三个:

@property(nonatomic) CGRect            frame;
@property(nonatomic) CGRect bounds;
@property(nonatomic) CGPoint center;

这里有:
frame:主要管位置和大小(初始化的时候用,其他时候改变要用下下面两个)
bounds:他的圆点是0,主要管大小
center:主要是点,决定位置

他们的类型是
(结构体struct)CGRect

struct CGRect {
CGPoint origin;
CGSize size;
};

而他又包括point和size 当然这两个也是结构体,看名字就知道他们是干嘛的了例如origin是:
struct CGPoint {/*决定在屏幕上xy坐标*/
CGFloat x;
CGFloat y;
};

而你要是再看看,其实CGFloat就是double

# define CGFLOAT_TYPE double

放大缩小功能

//放大缩小
- (IBAction)zoom:(UIButton *)button{
//取出bounds
CGRect bounds = self.iconButton.bounds;
if(button.tag){
NSLog(@"放大");
bounds.size.width +=20;
bounds.size.height +=20;
}else{
bounds.size.width -=20;
bounds.size.height -=20;
NSLog(@"缩小");
}
//加动画
//动画开始
[UIView beginAnimations:nil context:nil];
//设置持续时间
[UIView setAnimationDuration:1.0];
//放大缩小了的bounds放回到原来button中
self.iconButton.bounds = bounds;
//提交动画
[UIView commitAnimations];
}

在这里我并没有用frame来修改,而是用了bounds的属性,其实本质上还是底层的CGSize而已

在这里为了学习,我又添加了一段动画代码IOS的动画很人性化,比安卓强了不止一点半点。要注意,学习起来一定要点进去看看,不会的就试试,重要的东西一般会放在代码的靠上的部位。

旋转功能

//旋转
- (IBAction)rotate:(UIButton *)button{
//旋转主要用到角度,OC中用的是弧度
CGFloat angle = (button.tag) ? M_PI_4 : -M_PI_4;
self.iconButton.transform = CGAffineTransformRotate(self.iconButton.transform, angle);
NSLog(@"%@",NSStringFromCGAffineTransform(self.iconButton.transform));
}

好了,基本功能完成了。剩下的大家可以自己尝试,完善。不过不要放慢学习的脚步哦。
PS1.需要学习资料的可以加我微信 znycat
PS2.为了学习,我一周会更新最少(%d),未知。次;

AJ学IOS(02)UI之按钮操作 点击变换 移动 放大缩小 旋转的更多相关文章

  1. 猫猫学IOS(二)UI之button操作 点击变换 移动 放大缩小 旋转

    不多说,先上图片看效果,猫猫分享.必须精品 原创文章.欢迎转载.转载请注明:翟乃玉的博客 地址:viewmode=contents">http://blog.csdn.net/u013 ...

  2. AJ学IOS(01) UI之Hello World与加法计算器

    不多说,AJ分享,必须精品 这两个一个是HelloWorld(左边) 另一个是 加法计算器(右边)的截图. 先运行第一个 程序看看效果 1.打开Xcode(没有哦mac系统的没有xcode的帮你们默哀 ...

  3. AJ学IOS(35)UI之Quartz2D仿真支付宝手势解锁_代理获得密码。

    AJ分享,必须精品 效果: 实现步骤 其实这个实现起来不难 第一步先放好主要的UI,一张背景图和一个View 第二部就是把9个button放到view中,设置好按钮的默认和选中图片. 注意:创建时候的 ...

  4. AJ学IOS(28)UI之Quartz2D简单介绍

    AJ分享,必须精品 iOS开发UI篇—Quartz2D简单介绍 什么是Quartz2D Quartz 2D是⼀个二维绘图引擎,同时支持iOS和Mac系统 Quartz 2D能完成的工作: 绘制图形 : ...

  5. AJ学IOS(16)UI之XIB自定义Cell实现团购UI

    AJ分享,必须精品 先看效果图 自定义Cell 本次主要是自定义Cell的学习 实现自定义Cell主要有三种方法:按照使用的频繁度排序: XIB > 纯代码 > StoryBoard XI ...

  6. AJ学IOS(13)UI之UITableView学习(下)汽车名牌带右侧索引

    AJ分享,必须精品 先看效果图 代码 ViewController #import "NYViewController.h" #import "NYCarGroup.h& ...

  7. AJ学IOS(19)UI之QQ好友列表

    AJ分享,必须精品 先看效果图 哈哈,这次猫猫给来个动态的图片,这个看起来带劲 实现思路 首先建立模型 这里用到的是一个双层的模型. cell的实现 这里一看其实就知道是一个tableView,我们自 ...

  8. AJ学IOS(09)UI之UIScrollView代理触摸实现_图片缩放

    AJ分享,必须精品 先看效果 代码 // // NYViewController.m // 05-放大缩小图片UIScrollView // // Created by apple on 15-3-2 ...

  9. AJ学IOS(06)UI之iOS热门游戏_超级猜图

    AJ分享,必须精品 先看效果图 思路 需求分析 1,搭建界面 1>上半部分,固定的,用Storyboard直接连线(OK) 2>下半部分,根据题目的变化,不断变化和调整,用代码方式实现比较 ...

随机推荐

  1. 大数据软件安装之Azkaban(任务调度)

    一.安装部署 1.安装前准备 1)下载地址:http://azkaban.github.io/downloads.html 2)将Azkaban Web服务器.Azkaban执行服务器.Azkaban ...

  2. rbac权限+中间件 初识

    rbac权限+中间件 1.权限组件rbac 1.什么是权限 1 项目与应用 2 什么是权限? 一个包含正则表达式url就是一个权限 who what how ---------->True or ...

  3. python爬取网站页面时,部分标签无指定属性而报错

    在写爬取页面a标签下href属性的时候,有这样一个问题,如果a标签下没有href这个属性则会报错,如下: 百度了有师傅用正则匹配的,方法感觉都不怎么好,查了BeautifulSoup的官方文档,发现一 ...

  4. 洛谷 P1891 疯狂LCM 题解

    原题链接 享受推式子的乐趣吧 数论真有趣! 庆祝:数论紫题第 \(3\) 道. \[\sum_{i=1}^n \operatorname{lcm}(i,n) \] \[= \sum_{i=1}^n \ ...

  5. 汉诺塔Java实现

    public class Hanoi { public static void main(String[] args ) { Hanoi hanoi = new Hanoi(); hanoi.hano ...

  6. 干货 | Python进阶系列之学习笔记(四)

    目录 Python条件判断 Python循环语句 Python循环控制 迭代器与生成器 异常 一.Python 条件判断 如果某些条件满足,才能做某件事情:条件不满足时,则不能做,这就是所谓的判断. ...

  7. ConcurrentHashMap(1.7版本和1.8版本)

     为什么要使用ConcurrentHashMap? ConcurrentHashMap是Java5中新增加的一个线程安全的Map集合,可以用来替代hashMap和HashTable.因为在并发编程中使 ...

  8. python3读取excel实战

    '''参数化'''import xlrd,xlwt,jsonfrom api实现.读取参数化接口说明 import TestApiclass ReadFileData: def __init__(se ...

  9. Java系列之泛型

    自从 JDK 1.5 提供了泛型概念,泛型使得开发者可以定义较为安全的类型,不至于强制类型转化时出现类型转化异常,在没有反省之前,可以通过 Object 来完成不同类型数据之间的操作,但是强制类型转换 ...

  10. JS 剑指Offer(三) 替换字符串中的空格

    请实现一个函数,把字符串 s 中的每个空格替换成"%20". 实现这个函数的方法很简单,在JS中可以直接应用正则表达式,代码如下 直接将全局中的space换成%20,一行代码搞定 ...