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

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

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

【 tulaoshi.com - 编程语言 】

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

怎么办?

对! 就是使用UIControl。

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

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

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

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

(本文来源于图老师网站,更多请访问https://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

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

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

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

延伸阅读
标签: Web开发
应用背景 1.用户需要填写表单时。 2.页面采用服务器验证控件。 3.由用户来选择是否填写更多项,更多项的显示与隐藏用Display控制,如下图。 点击“增加服务内容”,显示新增表单项,如下图。 点击“取消增加”,隐藏新增表单项。 问题:用户点击下一步时,不对Display=none的新增区域表单进行验证,需要在用户点击“取消增加时”,...
直接上代码,就不多废话了 //// ViewController.m// QRCode//// Created by chenchen on 15/7/30.// Copyright (c) 2015年 BSY. All rights reserved.//#import AVFoundation/AVFoundation.h#import "ViewController.h"@interface ViewController ()AVCaptureMetadataOutputObjectsDelegate @end @implementation ViewController - (void)view...
验证码倒计时按钮的应用是非常普遍的,该Blog就和你一起来写一个IDCountDownButton来实现验证码倒计时的效果。你可以想使用普通的UIButton类型按钮一样,只需要设置其倒计时时长(若未设置,默认为60秒),就可以轻松的实现点击countDownButton开始倒计时,倒计时结束方可重新点击。 一、实现效果 如图 二、实现思路 1、自定义一个IDCou...
豆瓣小组如何点赞   1)首先打开豆瓣小组,在界面点击一个话题,在界面一直往下拉便能查看他人的留言,在他人头像的右边点击。   2)弹出窗口点击即可对他人的留言点赞。  
来往扎堆怎么点赞?   1)打开来往后点击。 2)第二步、在界面点击。 3)进入心情签到,可以看到左上角的扎堆点赞赢集分宝,点击进入。 4)进入后,会看见中间两个橙子围着去点赞三个字,点击去点赞。 5)进入后,会看见很多来往扎堆,看你爱好,选择其中一个加入。 6)加入后,点击扎堆里面的话题下...

经验教程

672

收藏

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