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

时间:2023-02-20 20:35:38

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

原创文章。欢迎转载。转载请注明:翟乃玉的博客

地址:

viewmode=contents">http://blog.csdn.net/u013357243?viewmode=contents

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

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

点击变换

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

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

事实上就是按钮的几个状态:

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),未知。

次。

猫猫学IOS(二)UI之button操作 点击变换 移动 放大缩小 旋转的更多相关文章

  1. AJ学IOS(02)UI之按钮操作 点击变换 移动 放大缩小 旋转

    不多说,先上图片看效果,AJ分享,必须精品 这个小程序主要实现点击方向键可以让图标上下左右动还有放大缩小以及旋转的功能,点击图片会显示另一张图片. 点击变换 其实用到了按钮的两个状态,再State C ...

  2. (素材源代码)猫猫学IOS(四)UI之半小时搞定Tom猫

    下载地址:http://download.csdn.net/detail/u013357243/8514915 以下是执行图片展示 制作思路以及代码解析 猫猫学IOS(四)UI之半小时搞定Tom猫这里 ...

  3. (素材源代码) 猫猫学IOS(五)UI之360等下载管理器九宫格UI

    猫猫分享,必须精品 先看效果 代码学习地址: 猫猫学IOS(五)UI之360等下载管理器九宫格UI 猫猫学IOS(五)UI之360等下载管理器九宫格UI http://blog.csdn.net/u0 ...

  4. iOS开发UI篇—Button基础

    iOS开发UI篇—Button基础 一.简单说明 一般情况下,点击某个控件后,会做出相应反应的都是按钮 按钮的功能比较多,既能显示文字,又能显示图片,还能随时调整内部图片和文字的位置 二.按钮的三种状 ...

  5. 猫猫学iOS 之微博项目实战(2)微博主框架-自己定义导航控制器NavigationController

    猫猫分享,必须精品 原创文章,欢迎转载.转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243?viewmode=contents 一:加入导航控制器 上一篇博 ...

  6. 猫猫学iOS 之微博项目实战(5)微博自己定义搜索框searchBar

    猫猫分享.必须精品 原创文章.欢迎转载. 转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243 一:效果 用UITextField简单定义一个搜索框 二:调用 ...

  7. 猫猫学iOS 之第一次打开Xcode_git配置,git简单学习

    猫猫分享,必须精品 原创文章,欢迎转载.转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243 一:错误 当第一次打开Xcode我们进行commit操作的时候会 ...

  8. iOS开发UI篇——Button基础

    一.简单说明 一般情况下,点击某个控件后,会做出相应反应的都是按钮 按钮的功能比较多,既能显示文字,又能显示图片,还能随时调整内部图片和文字的位置 二.按钮的三种状态 1. normal(普通状态) ...

  9. (素材源代码) 猫猫学iOS 之UIDynamic重力、弹性碰撞吸附等现象牛逼Demo

    猫猫分享,必须精品 原创文章,欢迎转载. 转载请注明:翟乃玉的博客 地址:http://blog.csdn.net/u013357243 一:效果 二:代码 #import "ViewCon ...

随机推荐

  1. Release时error c1083 无法打开包括文件

    Release时error c1083 无法打开包括文件, 但Debug时没事. 项目里面包含了其实项目的头文件, 头文件目录就放在项目下面, 这个头文件里面调用其它头文件, 采用的是<xx/y ...

  2. Makefile 如何轻松搞定

    最近在学习Linux下的C编程,买了一本叫<Linux环境下的C编程指南>读到makefile就越看越迷糊,可能是我的理解能不行. 于是google到了以下这篇文章.通俗易懂.然后把它贴出 ...

  3. Mysql 修改列的顺序

    alter table 表名 modify 字段名 字段类型 after 字段举例alter table user_info modify user_name varchar(10) after us ...

  4. 【良心noip膜你赛】总结

    一点都不良心!!!! AK 快乐爆零快乐!!! 1. A. value512mb 1s规定一个区间的价值为这个区间中所有数 and 起来的值与这个区间所有数 or 起来的值的乘积.例如 3 个数 2, ...

  5. c&plus;&plus;中的迭代器 iterator

    迭代器iterator的作用类似于指针. iterator只有针对制定<类型>的容器才有效.例如: vector<int> vec; vector<int>::it ...

  6. android 破解九宫格

    将目录切换到D:/adb目录下,命令如下 敲入命令 adb shell 然后回车,可以见到如下结果 再敲入命令cd /data/system然后回车, 再执行 rm gesture.key 回车,搞定 ...

  7. jQuery选择器,用逗号分隔的时候需要注意范围问题

    jQuery选择器,用逗号分隔的时候需要注意范围问题: <%@ page language="java" import="java.util.*" pag ...

  8. 初次接触java中的递归算法

    一道关于兔子繁衍的编程题: 有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 自己考虑了挺久,思路出现了问题,甚至连 ...

  9. LINUX配置过程记录

    http://blog.csdn.net/Houchaoqun_XMU/article/details/78869052 64 sudo apt-get update 0 打开终端的快捷键是Ctrl+ ...

  10. linux的cd命令

    面试时被问到了一个命令是什么意思 cd - 还真是一脸懵逼.... 回来试了下 发现真的是一个神奇的命令~ 会跳到之前目录下并输出, 比如