android 勿扰 状态栏,标签状态栏文字自适应排布

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

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

30e9ce0f88b1

第二种:根据屏幕换行

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

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

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

for (int i = 0; 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];

30e9ce0f88b1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值