Swift环境下实现UILabel居上 居中 居下对齐
2015-08-17 09:14
393 查看
首先在Xcode中新建.h文件,将以下代码复制进去
再新建一个.m文件,拷入以下代码
如果这是你导入的第一个.m文件Xcode会提示你要不要创建Bridging-Header,选Ok
在新创建的Bridging-Header文件里拷入下方代码
然后打开你的StoryBoard,点选你想要更改对齐方式的Label,将其Class改为myUILabel,示意图如下
然后右键拖动Label或者按住Control键左键拖动连线到Label所在的父View的Class中生成Outlet,如果之前已经连线好,则改完Custom Class后,将连线生成代码中的UILabel改为myUILabel,示意图如下
然后就可以调用该label的类方法
按上方代码可以实现居下对其,居中 居上 分别将代码中的Bottom改为Middle和Top,默认为居上
// // myUILabel.h // // // Created by yexiaozi_007 on 3/4/13. // Copyright (c) 2013 yexiaozi_007. All rights reserved. // #import <UIKit/UIKit.h> typedef enum { VerticalAlignmentTop = 0, // default VerticalAlignmentMiddle, VerticalAlignmentBottom, } VerticalAlignment; @interface myUILabel : UILabel { @private VerticalAlignment _verticalAlignment; } @property (nonatomic) VerticalAlignment verticalAlignment; @end
再新建一个.m文件,拷入以下代码
// // myUILabel.m // // // Created by yexiaozi_007 on 3/4/13. // Copyright (c) 2013 yexiaozi_007. All rights reserved. // #import "myUILabel.h" @implementation myUILabel @synthesize verticalAlignment = verticalAlignment_; - (id)initWithFrame:(CGRect)frame { if (self = [super initWithFrame:frame]) { self.verticalAlignment = VerticalAlignmentMiddle; } return self; } - (void)setVerticalAlignment:(VerticalAlignment)verticalAlignment { verticalAlignment_ = verticalAlignment; [self setNeedsDisplay]; } - (CGRect)textRectForBounds:(CGRect)bounds limitedToNumberOfLines:(NSInteger)numberOfLines { CGRect textRect = [super textRectForBounds:bounds limitedToNumberOfLines:numberOfLines]; switch (self.verticalAlignment) { case VerticalAlignmentTop: textRect.origin.y = bounds.origin.y; break; case VerticalAlignmentBottom: textRect.origin.y = bounds.origin.y + bounds.size.height - textRect.size.height; break; case VerticalAlignmentMiddle: // Fall through. default: textRect.origin.y = bounds.origin.y + (bounds.size.height - textRect.size.height) / 2.0; } return textRect; } -(void)drawTextInRect:(CGRect)requestedRect { CGRect actualRect = [self textRectForBounds:requestedRect limitedToNumberOfLines:self.numberOfLines]; [super drawTextInRect:actualRect]; } @end
如果这是你导入的第一个.m文件Xcode会提示你要不要创建Bridging-Header,选Ok
在新创建的Bridging-Header文件里拷入下方代码
#import "myUILabel.h"
然后打开你的StoryBoard,点选你想要更改对齐方式的Label,将其Class改为myUILabel,示意图如下
然后右键拖动Label或者按住Control键左键拖动连线到Label所在的父View的Class中生成Outlet,如果之前已经连线好,则改完Custom Class后,将连线生成代码中的UILabel改为myUILabel,示意图如下
然后就可以调用该label的类方法
label.verticalAlignment = VerticalAlignmentBottom
按上方代码可以实现居下对其,居中 居上 分别将代码中的Bottom改为Middle和Top,默认为居上
相关文章推荐
- Swift和OC混编
- [Swift]初学Swift语言个人笔记
- 深度解析swift中的String
- Swift 可选值(Optional Values)介绍
- Swift字典的使用
- 关于flex匿名函数和swift闭包
- 玩儿转Swift——学习笔记(持续更新)
- swift入门-实现简单的登录界面
- Watch OS 2 Complication开发教程(三)基本数据(持续连载中)
- Swift:面向对象(属性)
- 窥探Swift之新添数据类型元组与可选值
- 窥探Swift之新添数据类型元组与可选值
- 窥探Swift之新添数据类型元组与可选值
- Swift开发过程中常用到的一些使用技巧和注意的地方
- Swiftl优秀的特性
- Swift中的UIKit重力学
- Swift使用Playground编程
- swift 学习笔记二:Closures
- Swift 学习笔记 —— 函数
- Swift 爬行篇 UITableView