UIControl的使用
在开发当中,可能很多时候都需要做个点赞的需求,如果用按钮实现,按钮作为一个系统复合控件,外部是一个 View--》UIControl的容器,
内部包含了UILabel和UIImage,以及一些排版规则。用UIButton就很难去做一些在“赞”和“取消赞”切换时的效果。
可是我们又很需要UIButton似的事件响应机制。
怎么办?
对! 就是使用UIControl。
UIControl在这里有两个突出的优势:
1.作为UIButton的父控件,具有UIButton一样的事件响应机制
2.作为UIView的简单子控件,具有作为容器视图的潜质
设计思路:实现一个自定义控件,继承UIControl,里面包含一些视图,包含什么视图由你的需求决定,我的是两张图片。 然后在事件响应时,两张图片进行切换。切换动画可以自定义。这样就实现了一个切换效果自由度很大的点赞按钮哦!
参考代码如下:
- #import <UIKit/UIKit.h>
- typedef NS_ENUM(NSInteger, UIControlFlagMode) {
- FlagModelNO,
- FlagModelYES,
- FlagModelDefalt
- };
- @interface UIControlFlagView : UIControl
- @property (nonatomic, strong) UIImage*noStateImg;
- @property (nonatomic, strong) UIImage*yesStateImg;
- @property (nonatomic, strong) UIImage*defaultStateImg;
- @property (nonatomic, assign) UIControlFlagMode flag;
- - (void)setFlag:(UIControlFlagMode)flag withAnimation:(BOOL)animation;
- @end
m文件:
- #import "UIControlFlagView.h"
- @interface UIControlFlagView()
- @property (nonatomic, strong) UIImageView*noStateImgV;
- @property (nonatomic, strong) UIImageView*yesStateImgV;
- @property (nonatomic, strong) UIImageView*defaultStateImgV;
- @end
- @implementation UIControlFlagView
- - (id)initWithFrame:(CGRect)frame
- {
- self = [super initWithFrame:frame];
- if (self) {
- // Initialization code
- }
- return self;
- }
- - (void)setNoStateImg:(UIImage *)noStateImg
- {
- if (!self.noStateImgV)
- {
- self.noStateImgV = [[UIImageView alloc] initWithFrame:self.bounds];
- self.noStateImgV.contentMode = UIViewContentModeCenter;
- [self addSubview:self.noStateImgV];
- self.flag = FlagModelNO;//default style
- }
- self.noStateImgV.image = noStateImg;
- _noStateImg = noStateImg;
- }
- - (void)setYesStateImg:(UIImage *)yesStateImg
- {
- if (!self.yesStateImgV)
- {
- self.yesStateImgV = [[UIImageView alloc] initWithFrame:self.bounds];
- self.yesStateImgV.contentMode = UIViewContentModeCenter;
- [self addSubview:self.yesStateImgV];
- self.yesStateImgV.alpha = 0.0;
- }
- self.yesStateImgV.image = yesStateImg;
- _yesStateImg = yesStateImg;
- }
- - (void)setDefaultStateImg:(UIImage *)defaultStateImg
- {
- if (!self.defaultStateImgV)
- {
- self.defaultStateImgV = [[UIImageView alloc] initWithFrame:self.bounds];
- self.defaultStateImgV.contentMode = UIViewContentModeCenter;
- [self addSubview:self.defaultStateImgV];
- }
- self.defaultStateImgV.image = defaultStateImg;
- _defaultStateImg = defaultStateImg;
- }
- - (void)setFlag:(UIControlFlagMode)flag withAnimation:(BOOL)animation
- {
- if (animation)
- {
- //no-->yes
- if (_flag == FlagModelNO && flag == FlagModelYES)
- {
- self.yesStateImgV.transform = CGAffineTransformMakeScale(0.1f, 0.1f);
- [UIView animateWithDuration:0.3 animations:^{
- self.noStateImgV.alpha = 0.0;
- self.yesStateImgV.alpha = 1.0;
- self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- self.noStateImgV.transform = CGAffineTransformMakeScale(2.0f, 2.0f);
- }
- completion:^(BOOL finished)
- {
- self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- }];
- }
- //yes-->no
- else if(_flag == FlagModelYES && flag == FlagModelNO)
- {
- self.noStateImgV.transform = CGAffineTransformMakeScale(0.1f, 0.1f);
- [UIView animateWithDuration:0.3 animations:^{
- self.noStateImgV.alpha = 1.0;
- self.yesStateImgV.alpha = 0.0;
- self.yesStateImgV.transform = CGAffineTransformMakeScale(2.0f, 2.0f);
- self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- }
- completion:^(BOOL finished)
- {
- self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- }];
- }
- }
- else
- {
- //no-->yes
- if (_flag == FlagModelNO && flag == FlagModelYES)
- {
- self.noStateImgV.alpha = 0.0;
- self.yesStateImgV.alpha = 1.0;
- self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- }
- //yes-->no
- else if(_flag == FlagModelYES && flag == FlagModelNO)
- {
- self.noStateImgV.alpha = 1.0;
- self.yesStateImgV.alpha = 0.0;
- self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
- }
- }
- _flag = flag;
- }
- @end
这是一个简单的实现,最大的优势,也是这篇文章的目的,就是在切换效果上的自定义和自由度!
抛砖引玉,希望大家都能做出复合自己心中所想的点赞按钮!
UIControl的使用的更多相关文章
- 你真的了解UIControl吗?
一:首先查看一下关于UIControl的定义 NS_CLASS_AVAILABLE_IOS(2_0) @interface UIControl : UIView //控件默认是启用的YES.是否要禁用 ...
- iOS UIControl 详解
UIControl是UIView的子类,当然也是UIResponder的子类.UIControl是诸如UIButton,UISwitch,UItextField等控件的父类,它本身包含了一些属性和方法 ...
- iOS学习24之UIControl及其子类
1. UIControl初识 1> 概述 UIControl是有控制功能的视图( 如UIButton.UISlider.UISegmentedControl等)的父类 只要跟控制有关的控件都是继 ...
- IOS开发UI基础UIControl事件
UIControl事件1.UIControlEventTouchDown单点触摸按下事件:用户点触屏幕,或者又有新手指落下的时候. 2.UIControlEventTouchDownRepeat多点触 ...
- iOS - UIControl
前言 NS_CLASS_AVAILABLE_IOS(2_0) @interface UIControl : UIView @available(iOS 2.0, *) public class UIC ...
- iOS学习之UIControl
一.UIControl初识 1.UIControl是有控制功能的视图(比如UIButton.UISlider.UISegmentedControl等)的父类. 只要跟控制有关的控件都是继承于 ...
- iOS开发~视图(UIView)与控件(UIControl)
1.UIView类 1.什么是视图 看得见的都是视图 2.什么是控件 一种特殊的视图,都是UIControl的子类,不仅具有一定的显示外观,还能响应高级事件,与用户交互.严格意义上UILabel不是控 ...
- MATLAB中为控件(uicontrol)绑定Callback函数(回调函数)
笔者走了许多弯路,终于找到这个方法,分享给大家. 'callback',@(~,~)colormapeditor(h) 如果版本老不支持“~”这种写法,那就改成: 'callback',@(x,y)c ...
- ##DAY5 UIControl及其子类
##DAY5 UIControl及其子类 #pragma mark ———————UIControl——————————— UIControl初识: 1)UIControl是有控制功能的视图(比如UI ...
随机推荐
- Shell基础:变量类型 & 运算符
Shell变量 Shell支持三种类型的变量 用户自定义变量:用户自定义的变量,变量名以英文字母或下划线开头,区分大小写. 位置变量:根据位置传递参数给脚本的变量,默认支持9个位置变量 $1,$2,$ ...
- uva--1339 - Ancient Cipher(模拟水体系列)
1339 - Ancient Cipher Ancient Roman empire had a strong government system with various departments, ...
- SQL Sever 2008 安装
http://jingyan.baidu.com/article/4b07be3c1daf1248b380f33b.html 大致出错信息如下:RebootRequiredCheck 检查是否需要挂起 ...
- 推荐cms
推荐cms : 国外:drupal joomla wordpress 国内:phpcms
- Introduction to Windows 8: The Definitive Guide for Developer
<Windows 8应用开发权威指南>介绍 Introduction to Windows 8: The Definitive Guide for Developer 一.封面设计要求及文 ...
- jQuery修改后代、兄弟样式
<div> <div >1</div> <div class="one"> 2 <div>2_1 <div> ...
- [转]CentOS更改yum源与更新系统
[1] 首先备份/etc/yum.repos.d/CentOS-Base.repo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/Cent ...
- C#基础学习文章导航
第一部分:入个门 C#入门篇-1:HelloWorld的类 C#入门篇-2:什么是变量 C#入门篇-3:数据类型及转换 C#入门篇-4:使用运算符 第二部分:流程控制语句 C#入门篇5-1:流程控制语 ...
- 尽量少用Include
当我们使用EF写查询,尤其是关联到多个表的时候,我们一般习惯使用include关联,但是过多地使用include会带来性能问题.作为替代方法,可以使用多个toList来代替. 改造前:
- 使用Zen coding高效编写html代码
zen-Coding是一款快速编写HTML,CSS(或其他格式化语言)代码的编辑器插件,这个插件可以用缩写方式完成大量重复的编码工作,是web前端从业者的利器. zen-Coding插件支持多种编辑器 ...