zoukankan      html  css  js  c++  java
  • 可以触发点击事件并变色的UILabel

    可以触发点击事件并变色的UILabel

    谁说UILabel不能够当做button处理点击事件呢?今天,笔者就像大家提供一个改造过的,能够触发点击事件并变色的UILabel:)

    效果图:

    还能当做计时器用囧:

    源码如下:

    TapLabel.h 与 TapLabel.m

    //
    //  TapLabel.h
    //  TapLabel
    //
    //  Copyright (c) 2014年 Y.X. All rights reserved.
    //
    
    #import <UIKit/UIKit.h>
    @class TapLabel;
    
    @protocol TapLabelDelegate <NSObject>
    - (void)tapLabelEvent:(TapLabel *)label;
    @end
    
    @interface TapLabel : UILabel
    
    @property (nonatomic, assign) id<TapLabelDelegate>  delegate;         // 协议
    @property (nonatomic, strong) NSString             *notificationName; // 设置通知中心名字
    @property (nonatomic, strong) NSDictionary         *metaData;         // 元数据
    
    @end
    //
    //  TapLabel.m
    //  TapLabel
    //
    //  Copyright (c) 2014年 Y.X. All rights reserved.
    //
    
    #import "TapLabel.h"
    
    @implementation TapLabel
    
    - (id)initWithFrame:(CGRect)frame
    {
        self = [super initWithFrame:frame];
        if (self)
        {
            self.userInteractionEnabled       = YES;
            UILongPressGestureRecognizer *tap = 
            [[UILongPressGestureRecognizer alloc] initWithTarget:self
                                                          action:@selector(labelEvent:)];
            tap.minimumPressDuration          = 0.01f;
            [self addGestureRecognizer:tap];
        }
        return self;
    }
    
    - (void)labelEvent:(UILongPressGestureRecognizer *)gesture
    {
        // 获取到坐标值
        CGPoint locationPoint = [gesture locationInView:self];
        
        // 状态1
        if (gesture.state == UIGestureRecognizerStateBegan)
        {
            self.highlighted = YES;
        }
        
        // 状态2
        if(gesture.state == UIGestureRecognizerStateChanged)
        {
            if (locationPoint.x <= self.bounds.size.width && locationPoint.x >= 0 &&
                locationPoint.y <= self.bounds.size.height && locationPoint.y >= 0)
            {
                self.highlighted = YES;
            }
            else
            {
                self.highlighted = NO;
            }
        }
        
        // 状态3
        if (gesture.state == UIGestureRecognizerStateEnded)
        {
            if (locationPoint.x <= self.bounds.size.width && locationPoint.x >= 0 &&
                locationPoint.y <= self.bounds.size.height && locationPoint.y >= 0)
            {
                
                if (_delegate) {
                    [_delegate tapLabelEvent:self];
                }
                
                if (_notificationName) {
                    [[NSNotificationCenter defaultCenter] postNotificationName:_notificationName
                                                                        object:nil
                                                                      userInfo:@{@"TapLabel": self}];
                }
            }
            
            self.highlighted = NO;
        }
    }
    
    @end

    使用时的源码:

    //
    //  RootViewController.m
    //  TapLabel
    //
    //  Copyright (c) 2014年 Y.X. All rights reserved.
    //
    
    #import "RootViewController.h"
    #import "TapLabel.h"
    
    @interface RootViewController ()<TapLabelDelegate>
    
    @end
    
    @implementation RootViewController
    
    
    - (void)viewDidLoad
    {
        [super viewDidLoad];
    
        TapLabel *tap            = [[TapLabel alloc] initWithFrame:CGRectMake(0, 0, 320, 20)];
        tap.textAlignment        = NSTextAlignmentCenter;
        tap.center               = self.view.center;
        tap.text                 = @"YouXianMing";
        tap.font                 = [UIFont fontWithName:@"HelveticaNeue-Thin" size:18];
        tap.delegate             = self;
        tap.metaData             = @{@"name": @"YouXianMing"};
        
        tap.highlightedTextColor = [UIColor redColor];
        [self.view addSubview:tap];
    }
    
    - (void)tapLabelEvent:(TapLabel *)label
    {
        NSLog(@"%@", label.metaData);
    }
    
    @end

    原理解析:

    1. 在初始化的时候后添加了手势处理:

    2. 精确计算手势的3种状态

    3. UILabel自带了highlightedTextColor:)

    原理就是这么简单呢:)

     
     
  • 相关阅读:
    设计模式学习总结:(7)工厂方法模式和抽象工厂模式
    设计模式学习总结:(6)桥模式
    设计模式学习总结:(5)装饰模式
    设计模式学习总结:(4)观察者模式
    设计模式学习总结:(3)策略模式
    设计模式学习总结:(2)模板方法模式
    [算法总结]DFS(深度优先搜索)
    [总结]拓扑排序
    [总结]树与图的遍历
    [算法总结]康托展开Cantor Expansion
  • 原文地址:https://www.cnblogs.com/YouXianMing/p/3938631.html
Copyright © 2011-2022 走看看