标签状态栏文字自适应排布

记录一下简单的标签状态栏,并且文字自适应屏幕。一种是加在scrollview上面,一种是根据屏幕大小换行的。

先看第一种:加在scrollView上的布局


第二种:根据屏幕换行

NSArray *arr = @[@"无知",@"风云变幻",@"施耐庵",@"唉",@"西门吹雪",@"呵呵哒",@"快看看",@"窿窿啦啦",@"一杆禽兽狙",@"合欢花",@"暴走大事件",@"非诚勿扰",@"呵呵呵"];  

CGFloat w =0;//保存前一个button的宽以及前一个button距离屏幕边缘的距离  

CGFloat h =200;//用来控制button距离父视图的高  

for (int i = 0; i < arr.count; i++) {  

UIButton *button = [UIButton buttonWithType:UIButtonTypeSystem];  

button.tag = 100 + i;  

button.backgroundColor = [UIColor greenColor];  

[button addTarget:self action:@selector(handleClick:) forControlEvents:UIControlEventTouchUpInside];  

[button setTitleColor:[UIColor redColor] forState:UIControlStateNormal];  

//根据计算文字的大小  


NSDictionary *attributes = @{NSFontAttributeName:[UIFont systemFontOfSize:12]};  

CGFloat length = [arr[i] boundingRectWithSize:CGSizeMake(320, 2000) options:NSStringDrawingUsesLineFragmentOrigin attributes:attributes context:nil].size.width;  

//为button赋值  

[button setTitle:arr[i] forState:UIControlStateNormal];  

//设置button的frame  

button.frame = CGRectMake(10 + w, h, length + 15 , 30);  

//当button的位置超出屏幕边缘时换行 320 只是button所在父视图的宽度  

if(10 + w + length + 15 > 320){  

w =0; //换行时将w置为0  

h = h + button.frame.size.height + 10;//距离父视图也变化  

button.frame = CGRectMake(10 + w, h, length + 15, 30);//重设button的frame  

        }  

w = button.frame.size.width + button.frame.origin.x;  

[self.view addSubview:button];  


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 标签的大小根据上面的文字来自适应大小,需要根据后台返回的数据自动换行.没有添加 NSArray *arr = @[...
    KiVin丶阅读 1,356评论 0 3
  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 2,059评论 0 2
  • 1.不可变数组转变为可变数组声明实例变量的数组 必须记得实现 对于遍历数组找到对象后 如果还需要查找 记得先结束 ...
    小新xin阅读 764评论 0 1
  • (这篇小文,事儿不大,字不多,但关心者却很多,评论很多,出乎所料。看来,人们关注的是身边事儿,是和自己有关的事儿。...
    邯郸赵金海阅读 847评论 3 0
  • 我一直在定课中无法观想出来具体的佛像或境界。 后来当我深入的向内看自己时,发现每当我尝试与三宝进行联结,我联结到的...
    两堆小核桃阅读 190评论 0 1