UIControl的使用

在开发当中,可能很多时候都需要做个点赞的需求,如果用按钮实现,按钮作为一个系统复合控件,外部是一个 View--》UIControl的容器,

内部包含了UILabel和UIImage,以及一些排版规则。用UIButton就很难去做一些在“赞”和“取消赞”切换时的效果。

可是我们又很需要UIButton似的事件响应机制。

怎么办?

对! 就是使用UIControl。

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

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

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

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

参考代码如下:

  1. #import <UIKit/UIKit.h>
  2. typedef NS_ENUM(NSInteger, UIControlFlagMode) {
  3. FlagModelNO,
  4. FlagModelYES,
  5. FlagModelDefalt
  6. };
  7. @interface UIControlFlagView : UIControl
  8. @property (nonatomic, strong) UIImage*noStateImg;
  9. @property (nonatomic, strong) UIImage*yesStateImg;
  10. @property (nonatomic, strong) UIImage*defaultStateImg;
  11. @property (nonatomic, assign) UIControlFlagMode flag;
  12. - (void)setFlag:(UIControlFlagMode)flag withAnimation:(BOOL)animation;
  13. @end

m文件:

  1. #import "UIControlFlagView.h"
  2. @interface UIControlFlagView()
  3. @property (nonatomic, strong) UIImageView*noStateImgV;
  4. @property (nonatomic, strong) UIImageView*yesStateImgV;
  5. @property (nonatomic, strong) UIImageView*defaultStateImgV;
  6. @end
  7. @implementation UIControlFlagView
  8. - (id)initWithFrame:(CGRect)frame
  9. {
  10. self = [super initWithFrame:frame];
  11. if (self) {
  12. // Initialization code
  13. }
  14. return self;
  15. }
  16. - (void)setNoStateImg:(UIImage *)noStateImg
  17. {
  18. if (!self.noStateImgV)
  19. {
  20. self.noStateImgV = [[UIImageView alloc] initWithFrame:self.bounds];
  21. self.noStateImgV.contentMode = UIViewContentModeCenter;
  22. [self addSubview:self.noStateImgV];
  23. self.flag = FlagModelNO;//default style
  24. }
  25. self.noStateImgV.image = noStateImg;
  26. _noStateImg = noStateImg;
  27. }
  28. - (void)setYesStateImg:(UIImage *)yesStateImg
  29. {
  30. if (!self.yesStateImgV)
  31. {
  32. self.yesStateImgV = [[UIImageView alloc] initWithFrame:self.bounds];
  33. self.yesStateImgV.contentMode = UIViewContentModeCenter;
  34. [self addSubview:self.yesStateImgV];
  35. self.yesStateImgV.alpha = 0.0;
  36. }
  37. self.yesStateImgV.image = yesStateImg;
  38. _yesStateImg = yesStateImg;
  39. }
  40. - (void)setDefaultStateImg:(UIImage *)defaultStateImg
  41. {
  42. if (!self.defaultStateImgV)
  43. {
  44. self.defaultStateImgV = [[UIImageView alloc] initWithFrame:self.bounds];
  45. self.defaultStateImgV.contentMode = UIViewContentModeCenter;
  46. [self addSubview:self.defaultStateImgV];
  47. }
  48. self.defaultStateImgV.image = defaultStateImg;
  49. _defaultStateImg = defaultStateImg;
  50. }
  51. - (void)setFlag:(UIControlFlagMode)flag withAnimation:(BOOL)animation
  52. {
  53. if (animation)
  54. {
  55. //no-->yes
  56. if (_flag == FlagModelNO && flag == FlagModelYES)
  57. {
  58. self.yesStateImgV.transform = CGAffineTransformMakeScale(0.1f, 0.1f);
  59. [UIView animateWithDuration:0.3 animations:^{
  60. self.noStateImgV.alpha = 0.0;
  61. self.yesStateImgV.alpha = 1.0;
  62. self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  63. self.noStateImgV.transform = CGAffineTransformMakeScale(2.0f, 2.0f);
  64. }
  65. completion:^(BOOL finished)
  66. {
  67. self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  68. self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  69. }];
  70. }
  71. //yes-->no
  72. else if(_flag == FlagModelYES && flag == FlagModelNO)
  73. {
  74. self.noStateImgV.transform = CGAffineTransformMakeScale(0.1f, 0.1f);
  75. [UIView animateWithDuration:0.3 animations:^{
  76. self.noStateImgV.alpha = 1.0;
  77. self.yesStateImgV.alpha = 0.0;
  78. self.yesStateImgV.transform = CGAffineTransformMakeScale(2.0f, 2.0f);
  79. self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  80. }
  81. completion:^(BOOL finished)
  82. {
  83. self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  84. self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  85. }];
  86. }
  87. }
  88. else
  89. {
  90. //no-->yes
  91. if (_flag == FlagModelNO && flag == FlagModelYES)
  92. {
  93. self.noStateImgV.alpha = 0.0;
  94. self.yesStateImgV.alpha = 1.0;
  95. self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  96. self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  97. }
  98. //yes-->no
  99. else if(_flag == FlagModelYES && flag == FlagModelNO)
  100. {
  101. self.noStateImgV.alpha = 1.0;
  102. self.yesStateImgV.alpha = 0.0;
  103. self.yesStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  104. self.noStateImgV.transform = CGAffineTransformMakeScale(1.0f, 1.0f);
  105. }
  106. }
  107. _flag = flag;
  108. }
  109. @end

这是一个简单的实现,最大的优势,也是这篇文章的目的,就是在切换效果上的自定义和*度!

抛砖引玉,希望大家都能做出复合自己心中所想的点赞按钮!

上一篇:js获取url查询参数


下一篇:hibernate注解(二)mappedBy