日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

iOS学习系列 - 标签Tag列表的实现

發(fā)布時(shí)間:2025/3/13 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iOS学习系列 - 标签Tag列表的实现 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

本文講述如何實(shí)現(xiàn)一個(gè)標(biāo)簽Tag列表的效果。

在iOS項(xiàng)目中的效果為圖上所示:

在各個(gè)任務(wù)下,包括對(duì)應(yīng)的標(biāo)簽列表。

?

首先,自定義一個(gè)UILabel類(lèi):

FillLabel.h:

#import?<UIKit/UIKit.h>
@interface?FillLabel?:?UILabel
@end


FillLabel.m

#import?"FillLabel.h"
?
#define?MAX_SIZE_HEIGHT?10000
#define?DEFAULT_BACKGROUDCOLOR?[UIColor?colorWithRed:47.0/255?green:157.0/255?blue:216.0/255?alpha:1]
#define?DEFAULT_TEXTCOLOR?[UIColor?whiteColor]
#define?DEFAULT_FONT?[UIFont?boldSystemFontOfSize:10]
#define?DEFAULT_TEXTALIGNMENT?UITextAlignmentCenter
#define?DEFAULT_RADIUS?5.0f
?
@implementation?FillLabel
?
-?(id)initWithFrame:(CGRect)frame
{
????self?=?[super?initWithFrame:frame];
????if?(self)?{
?
????????self.backgroundColor?=?DEFAULT_BACKGROUDCOLOR;
????????self.textColor?=?DEFAULT_TEXTCOLOR;
????????self.font?=?DEFAULT_FONT;
????????self.textAlignment?=?DEFAULT_TEXTALIGNMENT;
?
????????self.layer.masksToBounds?=?YES;
????????self.layer.cornerRadius?=?DEFAULT_RADIUS;
?
????}
????return?self;
}
?
-(void)setRadius:(CGFloat)radius
{
????self.layer.cornerRadius?=?radius;
}
?
-(void)setText:(NSString?*)text
{
????super.text?=?text;
?
????CGSize?size?=?[self.text?sizeWithFont:self.font?constrainedToSize:CGSizeMake(320,?MAX_SIZE_HEIGHT)?lineBreakMode:UILineBreakModeWordWrap];
????self.frame?=?CGRectMake(self.frame.origin.x,?self.frame.origin.y,?size.width?+?8,?size.height);
}
?
@end

在使用CALayer的時(shí)候,必須引入QuartzCore.framework框架,這樣就可以實(shí)現(xiàn)label的一些效果:

self.layer.masksToBounds?=?YES;
self.layer.cornerRadius?=?DEFAULT_RADIUS;

其中cornerRadius用來(lái)控制Label的圓角半徑;

另外,看到setText:這個(gè)方法,當(dāng)對(duì)該Label進(jìn)行文本賦值的時(shí)候,通過(guò)sizeWithFont對(duì)Label計(jì)算相關(guān)尺寸,并對(duì)frame進(jìn)行重新調(diào)整;

?

現(xiàn)在,實(shí)現(xiàn)一個(gè)包括Tag列表的容器,假定這兒自定義一個(gè)UIView類(lèi):

FillLabelView.h:

#import?<UIKit/UIKit.h>
@interface?FillLabelView?:?UIView
-?(void)bindTags:(NSMutableArray*)tags;
@end

?

FillLabelView.m:

#import?"FillLabelView.h"
#import?"FillLabel.h"
?
@implementation?FillLabelView
?
-?(id)initWithFrame:(CGRect)frame
{
????self?=?[super?initWithFrame:frame];
????if?(self)
????{
????}
????return?self;
}
?
-?(void)bindTags:(NSMutableArray*)tags
{
????CGFloat?frameWidth?=?self.frame.size.width;
?
????CGFloat?tagsTotalWidth?=?0.0f;
????CGFloat?tagsTotalHeight?=?0.0f;
?
????CGFloat?tagHeight?=?0.0f;
????for?(NSString?*tag?in?tags)
????{
????????FillLabel?*fillLabel?=?[[FillLabel?alloc]?initWithFrame:CGRectMake(tagsTotalWidth,?tagsTotalHeight,?0,?0)];
????????fillLabel.text?=?tag;
????????tagsTotalWidth?+=?fillLabel.frame.size.width?+?2;
????????tagHeight?=?fillLabel.frame.size.height;
?
????????if(tagsTotalWidth?>=?frameWidth)
????????{
????????????tagsTotalHeight?+=?fillLabel.frame.size.height?+?2;
????????????tagsTotalWidth?=?0.0f;
????????????fillLabel.frame?=?CGRectMake(tagsTotalWidth,?tagsTotalHeight,?fillLabel.frame.size.width,?fillLabel.frame.size.height);
????????????tagsTotalWidth?+=?fillLabel.frame.size.width?+?2;
????????}
????????[self?addSubview:fillLabel];
????????[fillLabel?release];
????}
????tagsTotalHeight?+=?tagHeight;
?
????self.frame?=?CGRectMake(self.frame.origin.x,?self.frame.origin.y,?self.frame.size.width,?tagsTotalHeight);
}
?
@end

其中,有個(gè)bindTags:方法,該方法接受一個(gè)MSMutableArray數(shù)組的綁定,講數(shù)組中的文本,放入到該容器中,并且通過(guò)計(jì)算,重新得到另外尺寸的frame.

然后,對(duì)FillLabelView進(jìn)行調(diào)用:

NSMutableArray?*array?=?[NSMutableArray?arrayWithObjects:@"web",@"hybrid",@"native",@"leepy",@"sunleepy",nil];
?
????FillLabelView?*fillLabelView?=?[[FillLabelView?alloc]?initWithFrame:CGRectMake(10,?10,?120,?100)];
????fillLabelView.layer.borderWidth?=?1.0f;
????fillLabelView.layer.borderColor?=?[[UIColor?blueColor]?CGColor];
????[fillLabelView?bindTags:array];
????[self.view?addSubview:fillLabelView];
????[fillLabelView?release];

?

?

最終效果:

容器中,做了最后的尺寸調(diào)整。


Demo下載地址:https://github.com/sunleepy/iOS_Lab

?

?

?

轉(zhuǎn)載于:https://www.cnblogs.com/liping13599168/archive/2012/10/22/2733701.html

總結(jié)

以上是生活随笔為你收集整理的iOS学习系列 - 标签Tag列表的实现的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲 欧美 激情 小说 另类 | 999www| 视频在线观看一区 | 日本韩国中文字幕 | 无码久久精品国产亚洲av影片 | 久久亚洲精华国产精华液 | 日韩av一区在线观看 | 国产在线超碰 | 欧美高清一区 | 啪啪精品| 向着小小的花蕾绽放 | 久久久久久亚洲精品中文字幕 | 色久网| 中国精品久久 | 91麻豆精品一区二区三区 | 91精彩刺激对白 | 日本三区视频 | 写真福利片hd在线播放 | 理论av| 日韩一区二 | 亚洲人人爽 | 日韩欧美一级视频 | 亚洲欧美日本一区二区三区 | 日韩电影在线观看一区二区 | 日本一道本在线 | 欧美极品jizzhd欧美爆 | 国产精品视频在 | 日本不卡专区 | 人人干人人做 | 91福利网站| 成人av一区 | 欧美日韩一区二区在线 | 午夜免费影院 | 色婷婷伊人 | 香蕉av网站 | 在线观看国产精品视频 | 久久久精品一区二区 | 婷婷久久综合 | 四虎影视av | 天堂成人在线视频 | 黑人干亚洲 | 五月婷婷六月色 | 一极毛片 | 800av免费在线观看 | 国产在线观看你懂的 | 色欲av无码精品一区 | 日本伦理片在线看 | 激情综合网五月天 | av中文字| 亚洲图色av | 青青草视频污 | 星空大象mv高清在线观看免费 | 精品久久久一区 | 88国产精品视频一区二区三区 | 91天天爽| 国产乱淫av片免费看 | 后进极品白嫩翘臀在线视频 | 交专区videossex | 亚洲欧美韩国 | 久久久久成人网 | 伊人一级片 | 亚洲精品粉嫩小泬20p | 日韩久久精品电影 | 国产在线观看h | 黄色一级网址 | 性免费网站 | 色婷婷久久久亚洲一区二区三区 | 风韵丰满熟妇啪啪区老熟熟女 | 免费成人美女女电影 | 亚洲免费婷婷 | 亚洲欧美日韩精品在线观看 | 黄色大全在线观看 | 欧美一区二区三区在线观看视频 | 巨大黑人极品videos精品 | 含羞草一区二区三区 | 色天堂影院 | 胸网站 | 国产三级小视频 | 成人理论影院 | 国产尤物视频在线观看 | 日本黄色三级 | 国产成人久久精品流白浆 | av青青草| 成人免费毛片免费 | 自拍偷拍第八页 | 亚洲欧美日韩中文在线 | 黄色av网| 福利网址在线观看 | 亚洲91精品| 欧美a一级片 | 成人黄色网址在线观看 | av午夜影院 | 天天艹天天爽 | 欧美日本韩国在线 | 午夜小视频在线观看 | 免费又黄又爽又猛大片午夜 | 在线精品福利 | 成人免费看片'在线观看 | 激情aaa|