QQ聊天气泡(图片拉伸不变样)、内容尺寸定制(高度随字数、字体而变)
2016-02-01 17:48
176 查看
- (void)viewDidLoad {
[super viewDidLoad];
self.view.backgroundColor = [UIColor whiteColor];
/**
QQ聊天 气泡的实现
*/
self.QQBubble = [UIButton buttonWithType:UIButtonTypeCustom];
self.QQBubble.backgroundColor = [UIColor blueColor];
// self.QQBubble.titleLabel.backgroundColor = [UIColor purpleColor];
NSString *string = @"《蛮荒记》的故事展开:大荒586年, 神农化羽,神帝之位悬空,引发金、木、水、火、土五族大战。神农传人拓跋野与义弟蚩尤联合对抗侵略者,双军交锋,大地却在战场中央裂开,封印太古凶魔的皮母地丘重现人间《蛮荒记》的故事展开:大荒586年, 神农化羽,神帝之位悬空,引发金、木、水、火、土五族大战。神农传人拓跋野与义弟蚩尤联合对抗侵略者,双军交锋,大地却在战场中央裂开,封印太古凶魔的皮母地丘重现人间《蛮荒记》的故事展开:大荒586年, 神农化羽,神帝之位悬空,引发金、木、水、火、土五族大战。神农传人拓跋野与义弟蚩尤联合对抗侵略者,双军交锋,大地却在战场中央裂开,封印太古凶魔的皮母地丘重现人间";
[_QQBubble setTitle:string forState:UIControlStateNormal];
[_QQBubble setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
_QQBubble.titleLabel.numberOfLines =0;
_QQBubble.titleLabel.font = MyFont;
/**
*
* -----内容尺寸(高度)根据 字的数量、字体多少决定----- 按钮尺寸需要比内容尺寸宽20边界
*
*/
CGSize textSize = [string boundingRectWithSize:CGSizeMake(150, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:MyFont} context:nil].size;
CGSize textBtnSize = CGSizeMake(textSize.width + Padding*2, textSize.height +Padding*2);
self.QQBubble.contentEdgeInsets = UIEdgeInsetsMake(Padding, Padding, Padding, Padding);
self.QQBubble.frame = CGRectMake(50, 100, textBtnSize.width, textBtnSize.height);
/**
* -----拉伸图片 (防止边框走样)------
*/
UIImage *normal = [UIImage imageNamed:@"yellowfish.png"];
CGFloat w = normal.size.width * 0.5;
CGFloat h = normal.size.height * 0.5;
UIImage *lastImage = [normal resizableImageWithCapInsets:UIEdgeInsetsMake(h-1, w-1, h, w)];
[self.QQBubble setBackgroundImage:lastImage forState:UIControlStateNormal];
[self.view addSubview:self.QQBubble];
}
[super viewDidLoad];
self.view.backgroundColor = [UIColor whiteColor];
/**
QQ聊天 气泡的实现
*/
self.QQBubble = [UIButton buttonWithType:UIButtonTypeCustom];
self.QQBubble.backgroundColor = [UIColor blueColor];
// self.QQBubble.titleLabel.backgroundColor = [UIColor purpleColor];
NSString *string = @"《蛮荒记》的故事展开:大荒586年, 神农化羽,神帝之位悬空,引发金、木、水、火、土五族大战。神农传人拓跋野与义弟蚩尤联合对抗侵略者,双军交锋,大地却在战场中央裂开,封印太古凶魔的皮母地丘重现人间《蛮荒记》的故事展开:大荒586年, 神农化羽,神帝之位悬空,引发金、木、水、火、土五族大战。神农传人拓跋野与义弟蚩尤联合对抗侵略者,双军交锋,大地却在战场中央裂开,封印太古凶魔的皮母地丘重现人间《蛮荒记》的故事展开:大荒586年, 神农化羽,神帝之位悬空,引发金、木、水、火、土五族大战。神农传人拓跋野与义弟蚩尤联合对抗侵略者,双军交锋,大地却在战场中央裂开,封印太古凶魔的皮母地丘重现人间";
[_QQBubble setTitle:string forState:UIControlStateNormal];
[_QQBubble setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
_QQBubble.titleLabel.numberOfLines =0;
_QQBubble.titleLabel.font = MyFont;
/**
*
* -----内容尺寸(高度)根据 字的数量、字体多少决定----- 按钮尺寸需要比内容尺寸宽20边界
*
*/
CGSize textSize = [string boundingRectWithSize:CGSizeMake(150, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:MyFont} context:nil].size;
CGSize textBtnSize = CGSizeMake(textSize.width + Padding*2, textSize.height +Padding*2);
self.QQBubble.contentEdgeInsets = UIEdgeInsetsMake(Padding, Padding, Padding, Padding);
self.QQBubble.frame = CGRectMake(50, 100, textBtnSize.width, textBtnSize.height);
/**
* -----拉伸图片 (防止边框走样)------
*/
UIImage *normal = [UIImage imageNamed:@"yellowfish.png"];
CGFloat w = normal.size.width * 0.5;
CGFloat h = normal.size.height * 0.5;
UIImage *lastImage = [normal resizableImageWithCapInsets:UIEdgeInsetsMake(h-1, w-1, h, w)];
[self.QQBubble setBackgroundImage:lastImage forState:UIControlStateNormal];
[self.view addSubview:self.QQBubble];
}
相关文章推荐
- android Monkey 测试技巧
- 基于Solr的多表join查询加速方法
- (1)散列表(哈希表)的定义
- address already in use
- C#后台格式化JSON字符串显示
- Centos7 Firewalld 解决防火墙问题
- [Spring实战系列](6)配置Spring IOC容器的Bean
- BZOJ 3870: Our happy ending( 状压dp )
- LVM(逻辑卷管理)
- android CheckBox RadioButton 图片与文字间距问题
- 分布式日志分析系统构建实战(一)——概述
- 浅谈Android系统开发中LOG的使用
- 织梦在 extend.func.php中函数获取标题拼音?
- DEDECMS全站伪静态详细教程(首页、列表、文章页)
- 封面~
- linux多线程学习(七)——实现“生产者和消费者”
- iOS 並行編程初步
- java 动态代理
- APNS 消息推送
- JBoss和tomcat的区别