iOS学习之SKTagView的使用

SKTagView是一款支持自动布局的标签tag.

特性:

-流式展示标签

-可以配置标签的颜色、事件、间隔、外边距等


-支持Auto layout


-可以在UITableViewCell中良好展示


-支持横竖屏切换


-不使用UICollectionView.

// 配置

- (void)configTagView

{

    self.label = [[UILabel alloc] initWithFrame:CGRectMake(10, 90, 100, 30)];

    self.label.textColor = [UIColor blackColor];

    self.label.font = [UIFont systemFontOfSize:13];

    self.label.text = @"历史搜索";

    [self.view addSubview:self.label];

    // 先移除掉所有

    [self.tagView removeAllTags];

    // 初始化

    self.tagView = [[SKTagView alloc] init];

    // 整个tagView对应其SuperView的上左下右距离

    self.tagView.padding = UIEdgeInsetsMake(10, 10, 10, 10);

    // 上下行之间的距离

    self.tagView.lineSpacing = 10;

    // item之间的距离

    self.tagView.interitemSpacing = 20;

    // 最大宽度

    self.tagView.preferredMaxLayoutWidth = 375;

//    @property (assign, nonatomic) CGFloat regularWidth; //!< 固定宽度

//    @property (nonatomic,assign ) CGFloat regularHeight; //!< 固定高度

    // 原作者没有能加固定宽度的,自己修改源码加上了固定宽度和高度,默认是0,就是标签式布局,如果实现了,那么就是固定宽度高度

//    self.tagView.regularWidth = 100;

//    self.tagView.regularHeight = 30;

    // 开始加载

    [self.dataSource enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {

       // 初始化标签

        SKTag *tag = [[SKTag alloc] initWithText:self.dataSource[idx]];

        // 标签相对于自己容器的上左下右的距离

        tag.padding = UIEdgeInsetsMake(3, 15, 3, 15);

        // 弧度

        tag.cornerRadius = 3.0f;

        // 字体

        tag.font = [UIFont boldSystemFontOfSize:12];

        // 边框宽度

        tag.borderWidth = 0;

        // 背景

        tag.bgColor = [UIColor colorWithRed:244/255.0 green:244/255.0 blue:244/255.0 alpha:1];

        // 边框颜色

        tag.borderColor = [UIColor colorWithRed:191/255.0 green:191/255.0 blue:191/255.0 alpha:1];

        // 字体颜色

        tag.textColor = [UIColor colorWithRed:53/255.0 green:53/255.0 blue:53/255.0 alpha:1];

        // 是否可点击

        tag.enable = YES;

        // 加入到tagView

        [self.tagView addTag:tag];

    }];

    // 点击事件回调

    self.tagView.didTapTagAtIndex = ^(NSUInteger idx){

        NSLog(@"点击了第%ld个",idx);

    };

    // 获取刚才加入所有tag之后的内在高度

    CGFloat tagHeight = self.tagView.intrinsicContentSize.height;

    NSLog(@"高度%lf",tagHeight);

    // 根据已经得到的内在高度给SKTagView创建frame

    self.tagView.frame = CGRectMake(0, 120, 375, tagHeight);

    [self.tagView layoutSubviews];

    [self.view addSubview:self.tagView];

}

在UISearchBar的代理方法里面实现搜索的时候隐藏,不搜索的时候显示

- (void)searchBar:(UISearchBar *)searchBar textDidChange:(NSString *)searchText

{

    NSLog(@"%@",searchText);

    if (searchText.length == 0) {

        // 没有文字了

        self.label.hidden = NO;

        self.tagView.hidden = NO;

    }

    else

    {

        self.label.hidden = YES;

        self.tagView.hidden = YES;

    }

}

下面咱们来看看如何让他在TableViewCell里面实现高度自适应的

- (void)configCell:(MKJTagViewTableViewCell *)cell indexpath:(NSIndexPath *)indexpath

{

    [cell.tagView removeAllTags];

    cell.tagView.preferredMaxLayoutWidth = [UIScreen mainScreen].bounds.size.width;

    cell.tagView.padding = UIEdgeInsetsMake(20, 20, 20, 20);

    cell.tagView.lineSpacing = 20;

    cell.tagView.interitemSpacing = 30;

    cell.tagView.singleLine = NO;

    // 给出两个字段,如果给的是0,那么就是变化的,如果给的不是0,那么就是固定的

        cell.tagView.regularWidth = 80;

        cell.tagView.regularHeight = 30;

    NSArray *arr = [self.dataSource[indexpath.row] valueForKey:@"first"];

    [arr enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {

        SKTag *tag = [[SKTag alloc] initWithText:arr[idx]];

        tag.font = [UIFont systemFontOfSize:12];

        tag.textColor = [UIColor colorWithRed:arc4random() % 256 / 255.0 green:arc4random() % 256 / 255.0  blue:arc4random() % 256 / 255.0  alpha:1];

        tag.bgColor =[UIColor colorWithRed:arc4random() % 256 / 255.0 green:arc4random() % 256 / 255.0  blue:arc4random() % 256 / 255.0  alpha:1];

        tag.cornerRadius = 5;

        tag.enable = YES;

        tag.padding = UIEdgeInsetsMake(5, 10, 5, 10);

        [cell.tagView addTag:tag];

    }];

    cell.tagView.didTapTagAtIndex = ^(NSUInteger index)

    {

        NSLog(@"点击了%ld",index);

    };

}

- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath

{

    return [tableView fd_heightForCellWithIdentifier:identyfy configuration:^(id cell) {

        [self configCell:cell indexpath:indexPath];

    }];

}
时间: 2024-10-06 23:33:40

iOS学习之SKTagView的使用的相关文章

iOS学习笔记之UITableViewController&amp;UITableView

iOS学习笔记之UITableViewController&UITableView 写在前面 上个月末到现在一直都在忙实验室的事情,与导师讨论之后,发现目前在实验室完成的工作还不足以写成毕业论文,因此需要继续思考新的算法.这是一件挺痛苦的事情,特别是在很难找到与自己研究方向相关的文献的时候.也许网格序列水印这个课题本身的研究意义就是有待考证的.尽管如此,还是要努力的思考下去.由于实验室的原因,iOS的学习进度明显受到影响,加之整理文档本身是一件耗费时间和精力的事情,因此才这么久没有写笔记了. M

iOS 学习资料整理

视频教程(英文) 视频 简介 Developing iOS 7 Apps for iPhone and iPad 斯坦福开放教程之一, 课程主要讲解了一些 iOS 开发工具和 API 以及 iOS SDK 的使用, 属于 iOS 基础视频 iPad and iPhone Application Development 该课程的讲师 Paul Hegarty 是斯坦福大学软件工程学教授, 视频内容讲解得深入, 权威, 深受好评 Advanced iPhone Development - Fall

【资源】IOS学习资料 - 逆天整理 - 精华无密版【最新】【精华】

 入门看视频,提高看书籍,飘升做项目.老练研开源,高手读外文,大牛讲低调~  01.IOS基础 01.iOS开发快速入门教程 http://pan.baidu.com/s/1kT3ScOf 链接: http://pan.baidu.com/s/1kTKheAF 密码: yycm 02.苹果开发零基础入门教程 http://pan.baidu.com/s/1dDfHL77 链接: http://pan.baidu.com/s/1o6iNkIu 密码: nn3a 03.黑马IOS2期基础 http:

iOS: 学习笔记, Swift操作符定义

Swift操作符可以自行定义, 只需要加上简单的标志符即可. @infix 中置运算. 如+,-,*,/运算 @prefix 前置运算. 如- @postfix 后置运算. a++, a-- @assignment 赋值运算. +=, -=, --a, ++a // // main.swift // SwiftBasic // // Created by yao_yu on 14-7-27. // Copyright (c) 2014年 yao_yu. All rights reserved.

iOS学习之Map,定位,标记位置的使用

iOS上使用地图比Android要方便,只需要新建一个MKMapView,addSubView即可.这次要实现的效果如下: 有标注(大头针),定位,地图. 1.添加地图 1.1 新一个Single View app ,选择默认项,创建后,在ViewController.h [cpp] view plaincopy #import <UIKit/UIKit.h> #import <MapKit/MapKit.h> #import <CoreLocation/CoreLocati

IOS学习之路- 运行过程

1. 执行Main函数(在main.m文件中) 2. 加载MainStoryborad.storyboard文件 * 创建ViewController文件 * 根据storyboard文件中描述创建ViewController中的UIView(父层) * 创建UIView内部的所有子控件 * 将创建好的所有UIView对象跟ViewController做相应的关联(IBAction,IBoutlet  ) 3. 将程序的第一个控制器内部的UIview显示到手机屏幕上. IOS学习之路- 运行过程

IOS学习笔记 -- Modal和Quartz2D

一. Modal1.Modal的默认效果:新控制器从屏幕的最底部往上钻,直到盖住之前的控制器为止;Modal只是改变了View的现实,没有改变rootViewController 2.常用方法1>.以Modal的形式展示控制器- (void)presentViewController:(UIViewController *)viewControllerToPresent animated: (BOOL)flag completion:(void (^)(void))completion2>.关

iOS: 学习笔记, 添加一个带界面约束的控制器

1. 创建一个空iOS应用程序(Empty Application). 2. 添加加控制器类. 修改控制器类的viewDidLoad 1 - (void)viewDidLoad 2 { 3 [super viewDidLoad]; 4 //创建标题 5 UILabel *header = [[UILabel alloc] init]; 6 header.text = @"欢迎来到我的世界!"; 7 header.textAlignment = NSTextAlignmentCenter

2015最新iOS学习线路图

iOS是由苹果公司开发的移动操作系统,以xcode为主要开发工具,具有简单易用的界面.令人惊叹的功能,以及超强的稳定性,已经成为iPhone.iPad 和iPod touch 的强大基础:iOS 内置的众多技术和功能让 Apple设备始终保持着遥遥领先的地位. iOS学习路线:http://www.mobiletrain.org/page/ios.html 课程分  类 课程模块 模块介绍 课程内容 Part1C语言 C语言和Objective-C语言 C语言 Mac系统及常用工具.进制:C数据