基于UIControl控件实现ios点赞功能

2016-02-19 11:20 26 1 收藏

下面这个基于UIControl控件实现ios点赞功能教程由图老师小编精心推荐选出,过程简单易学超容易上手,喜欢就要赶紧get起来哦!

【 tulaoshi.com - 编程语言 】

在开发当中,可能很多时候都需要做个点赞的需求,如果用按钮实现,按钮作为一个系统复合控件,外部是一个 View--》UIControl的容器,内部包含了UILabel和UIImage,以及一些排版规则。用UIButton就很难去做一些在“赞”和“取消赞”切换时的效果。
可是我们又很需要UIButton似的事件响应机制。

怎么办?

对! 就是使用UIControl。

UIControl在这里有两个突出的优势:

1.作为UIButton的父控件,具有UIButton一样的事件响应机制

2.作为UIView的简单子控件,具有作为容器视图的潜质

设计思路:实现一个自定义控件,继承UIControl,里面包含一些视图,包含什么视图由你的需求决定,我的是两张图片。 然后在事件响应时,两张图片进行切换。切换动画可以自定义。这样就实现了一个切换效果自由度很大的点赞按钮哦!

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

参考代码如下:

#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文件:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)
#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

这是一个简单的实现,最大的优势,也是这篇文章的目的,就是在切换效果上的自定义和自由度!
抛砖引玉,希望大家都能做出复合自己心中所想的点赞按钮!

希望大家对本文所述感兴趣。

来源:http://www.tulaoshi.com/n/20160219/1597134.html

延伸阅读
标签: 抖音 手机软件
抖音没人点赞怎么办  在抖音短视频中,你的短视频如果受到其他用户的喜欢的话,就会有许多用户为你的视频点赞,点赞数够高的话,你的视频就有机会上推荐,就会有更多的用户看到你的视频,你就会有更多的粉丝,不过想要其他用户为你的视频点赞可不是件易事。 第一、首先加关注,也就是互粉。 第二、多加关键词 抖音内容的排名是及时性...
来往扎堆怎么点赞?   1)打开来往后点击。 2)第二步、在界面点击。 3)进入心情签到,可以看到左上角的扎堆点赞赢集分宝,点击进入。 4)进入后,会看见中间两个橙子围着去点赞三个字,点击去点赞。 5)进入后,会看见很多来往扎堆,看你爱好,选择其中一个加入。 6)加入后,点击扎堆里面的话题下...
标签: Web开发
应用背景 1.用户需要填写表单时。 2.页面采用服务器验证控件。 3.由用户来选择是否填写更多项,更多项的显示与隐藏用Display控制,如下图。 点击“增加服务内容”,显示新增表单项,如下图。 点击“取消增加”,隐藏新增表单项。 问题:用户点击下一步时,不对Display=none的新增区域表单进行验证,需要在用户点击“取消增加时”,...
标签: 抖音
抖音分身视频怎么做 下载两个软件,picsart和巧影。 手机固定录一段视频、picsart是扣图用的、你要分身的照片在巧影播放时截图下来、然后去picsart抠图并保存。 打开巧影并打开要做的视频、然后在分层里第一个找照片、加入照片后你要用手慢慢拉到和原视频重叠的位置、要几个分身就重复做几次然后就ok。 抖音分身教程 ...
定位获取位置及位置编码-反编码 我们的应用程序,可以通过添加Core Location框架所包含的类,获取设备的地图位置。 添加CoreLocation.framework框架,导入#importCoreLocation/CoreLocation.h。 使用地图服务时,会消耗更多地设备电量.因此,在获取到设备的位置后,应该停止定位来节省电量。 我们通过一个demo来展示内容与效果 代码如下: // //...

经验教程

436

收藏

34
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部