笔记:UITextView内容垂直居中方法
- (void)contentSizeToFit
{
//先判断一下有没有文字(没文字就没必要设置居中了)
if([self.textView.text length]>)
{
//textView的contentSize属性
CGSize contentSize = self.textView.contentSize;
//textView的内边距属性
UIEdgeInsets offset;
CGSize newSize = contentSize; //如果文字内容高度没有超过textView的高度
if(contentSize.height <= self.textView.frame.size.height)
{
//textView的高度减去文字高度除以2就是Y方向的偏移量,也就是textView的上内边距
CGFloat offsetY = (self.textView.frame.size.height - contentSize.height)/;
offset = UIEdgeInsetsMake(offsetY, , , );
}
else //如果文字高度超出textView的高度
{
newSize = self.textView.frame.size;
offset = UIEdgeInsetsZero;
CGFloat fontSize = ; //通过一个while循环,设置textView的文字大小,使内容不超过整个textView的高度(这个根据需要可以自己设置)
while (contentSize.height > self.textView.frame.size.height)
{
[self.textView setFont:[UIFont fontWithName:@"Helvetica Neue" size:fontSize--]];
contentSize = self.textView.contentSize;
}
newSize = contentSize;
} //根据前面计算设置textView的ContentSize和Y方向偏移量
[self.textView setContentSize:newSize];
[self.textView setContentInset:offset]; }
}
原理:由于textView是继承自UIScrollview,所以会有ContentSize属性。所以可以通过文字内容的高度(也就是ContentSize)的高度和textView的高度之间的差值,设置内边距,就相当于把内容居中了。
笔记:UITextView内容垂直居中方法的更多相关文章
- 使用CSS使内容垂直居中的N中方法。
		
使用css+div使页面内容水平居中的方法大家并不陌生,那么如何使内容垂直居中呢? OK,下面进入正题,不如我们使用做高中数学题时经常用的思想:分情况讨论. 1.当待垂直居中的DIV高宽为已知时: ...
 - CSS3与页面布局学习笔记(三)——BFC、定位、浮动、7种垂直居中方法
		
一.BFC与IFC 1.1.BFC与IFC概要 BFC(Block Formatting Context)即“块级格式化上下文”, IFC(Inline Formatting Context)即行内格 ...
 - div中的内容垂直居中的五种方法
		
一.行高(line-height)法 如果要垂直居中的只有一行或几个文字,那它的制作最为简单,只要让文字的行高和容器的高度相同即可,比如: p { height:30px; line-height:3 ...
 - CSS总结div中的内容垂直居中的五种方法
		
一.行高(line-height)法 如果要垂直居中的只有一行或几个文字,那它的制作最为简单,只要让文字的行高和容器的高度相同即可,比如: p { height:30px; line-height:3 ...
 - CSS3与页面布局学习总结(三)——BFC、定位、浮动、7种垂直居中方法
		
一.BFC与IFC 1.1.BFC与IFC概要 BFC(Block Formatting Context)即“块级格式化上下文”, IFC(Inline Formatting Context)即行内格 ...
 - BFC,定位,浮动,7种垂直居中方法
		
目录 一.BFC与IFC 1.1.BFC与IFC概要 1.2.如何产生BFC 1.3.BFC的作用与特点 二.定位 2.2.relative 2.3.absolute 2.4.fixed 2.5.z- ...
 - CSS3与页面布局学习总结(四)——页面布局大全BFC、定位、浮动、7种垂直居中方法
		
目录 一.BFC与IFC 1.1.BFC与IFC概要 1.2.如何产生BFC 1.3.BFC的作用与特点 二.定位 2.2.relative 2.3.absolute 2.4.fixed 2.5.z- ...
 - [转]如何让div中的内容垂直居中
		
转自:http://blog.163.com/yan_1990/blog/static/197805107201211311515454/ 虽然Div布局已经基本上取代了表格布局,但表格布局和Div布 ...
 - 如何让div中的内容垂直居中
		
虽然Div布局已经基本上取代了表格布局,但表格布局和Div布局仍然各有千秋,互有长处.比如表格布局中的垂直居中就是Div布局的一大弱项,不过好在千变万化的CSS可以灵活运用,可以制作出准垂直居中效果, ...
 
随机推荐
- JS 实现四舍五入保留两位小数并且添加千位分隔符
			
var a = "-123456789.078";a = (Math.round(a * 100) / 100).toFixed(2).toString().replace(/(\ ...
 - VBoxManage翕令
			
VBoxManage list vms VBoxManage startvm dcsvr08 -type vrdp VBoxHeadless -startvm "dcsvr08" ...
 - Python+Selenium笔记(二):配置谷歌+IE环境
			
#有的时候可能要访问外国的网站下载资料或工具,这时可能出现各种问题,例如谷歌人机验证显示不了.网站打不开等,建议使用一个FQ软件 (一) 设置IE (1) http://docs.seleniu ...
 - 结合 spring 使用阿里 Druid 连接池配置方法
			
1.数据源 <!-- 配置数据源 --> <bean name="dataSource" class="com.alibaba.druid.pool.D ...
 - 转:winform 打包自动安装数据库
			
vs2005 打包,并自动安装SQL数据库.创建部署项目 1. 在“文件”菜单上指向“添加项目”,然后选择“新建项目”. 2. 在“添加新项目”对话框中,选择“项目类型”窗格中的“ ...
 - Content-Length和body_bytes_sent
			
[map@cq01-map-lbsop-hbase conf]$ curl 'http://10.46.43.14:8100/50x.html' -v* About to connect() to 1 ...
 - 读高性能JavaScript编程 第四章 Conditionals
			
if else 和 switch && 递归 if else 和 switch 一般来说,if-else 适用于判断两个离散的值或者判断几个不同的值域.如果判断多于两个离散 ...
 - sql点滴45—mysql中group_concat用法
			
group_concat(),手册上说明:该函数返回带有来自一个组的连接的非NULL值的字符串结果.比较抽象,难以理解. 通俗点理解,其实是这样的:group_concat()会计算哪些行属于同一组, ...
 - SpringBoot部署
			
Spring Boot 部署到服务器 jar 形式 1.打包 若我们在新建Spring Boot 项目的时候,选择打包方式是 jar,则我们只需要用 mvn package 就可以进行打包. 2.运行 ...
 - ubuntu环境下docker的安装与操作
			
只要按照本文的步骤一步步的走,就能正确的安装docker并使用,ubuntu需要联网 1. 在Ubuntu中安装Docker 更新ubuntu的apt源索引 sudo apt-get update 安 ...