新浪微博客户端(42)-完善表情键盘的工具条

 

DJEmotionTabBar.m

复制代码
//
//  DJEmotionTabBar.m
//  微博
//
//  Created by 海月高 on 16/11/26.
//  Copyright © 2016年 yongdaimi. All rights reserved.
//

#import "DJEmotionTabBar.h"
#import "DJEmotionTabBarButton.h"

@interface DJEmotionTabBar()

@property (nonatomic,weak) UIButton *selectedBtn;

@end

@implementation DJEmotionTabBar


- (instancetype)initWithFrame:(CGRect)frame
{
    self = [super initWithFrame:frame];
    if (self) {
    
        // 添加选项btn
        [self setupBtnTitle:@"最近" type:DJEmotionTabBarButtonTypeRecent];
        DJEmotionTabBarButton *defaultBtn = [self setupBtnTitle:@"默认" type:DJEmotionTabBarButtonTypeDefault];
        [self setupBtnTitle:@"Emoji" type:DJEmotionTabBarButtonTypeEmoji];
        [self setupBtnTitle:@"浪小花" type:DJEmotionTabBarButtonTypeLxh];
        
        
        // 设置“默认”选项的btn为选中状态
        [self btnClick:defaultBtn];
        
    }
    return self;
}



- (DJEmotionTabBarButton *)setupBtnTitle:(NSString *)title type:(DJEmotionTabBarButtonType)buttonType{

    
    DJEmotionTabBarButton *btn = [[DJEmotionTabBarButton alloc] init];
    [btn setTitle:title forState:UIControlStateNormal];
    
    [btn setTitleColor:DJColor(140,140,140) forState:UIControlStateNormal];
    [btn setTitleColor:DJColor(86, 86, 86) forState:UIControlStateSelected];
    
    
    [btn setBackgroundImage:[UIImage imageNamed:@"compose_emotion_table_normal"] forState:UIControlStateNormal];
    [btn setBackgroundImage:[UIImage imageNamed:@"compose_emotion_table_selected"] forState:UIControlStateSelected];
    [btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchDown];

    btn.titleLabel.font = [UIFont systemFontOfSize:13];
    
    [btn setTag:buttonType];
    
    [self addSubview:btn];
    
    return btn;

}



- (void)layoutSubviews {

    [super layoutSubviews];
    NSUInteger count =  self.subviews.count;
    CGFloat btnY = 0;
    CGFloat btnH = self.height;
    CGFloat btnW = self.width / count;
    for (int i = 0; i < count; i++) {
        UIButton *btn = self.subviews[i];
        btn.x = i * btnW;
        btn.y = btnY;
        btn.width = btnW;
        btn.height = btnH;
    }
    
}



- (void)btnClick:(DJEmotionTabBarButton *)btn {

    self.selectedBtn.selected = NO;
    btn.selected = YES;
    self.selectedBtn = btn;
    
    // 传递点击消息
    if ([self.delegate respondsToSelector:@selector(emotionTabBar:didSelectedButtonType:)]) {
        DJEmotionTabBarButtonType type =  (DJEmotionTabBarButtonType)btn.tag;
        [self.delegate emotionTabBar:self didSelectedButtonType:type];
    }
    
}


@end
复制代码

最终效果:

 



如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
posted @   夜行过客  阅读(405)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示