实现 iPhone 电子书的分页显示功能的代码
2014-03-15 11:33
645 查看
本文转载至 http://blog.csdn.net/zaitianaoxiang/article/details/6650497
原文地址:实现 iPhone 电子书的分页显示功能的代码作者:醉吻花颜
作 iPhone 电子书时,如果把大段文字放在 UITextView 或 UILabel里显示,是不能分页的,阅读时就像再看一大卷滚不到头的纸带,用户体验很差。下面这段代码可以实现 UILabel尺寸固定,根据文本内容和字体动态分页显示,电子书方面的应用应该非常有用。
// Implement viewDidLoad to do additional setup after loadingthe view, typically from a nib.
- (void)viewDidLoad {
[superviewDidLoad];
//
totalPages= 0;
currentPage= 0;
//
textLabel.numberOfLines= 0;
//
if(!text) {
//从文件里加载文本串
[selfloadString];
//计算文本串的大小尺寸
CGSizetotalTextSize = [text sizeWithFont:[UIFontsystemFontOfSize:FONT_SIZE_MAX]
constrainedToSize:CGSizeMake(textLabel.frame.size.width,CGFLOAT_MAX)
lineBreakMode:UILineBreakModeWordWrap];
//如果一页就能显示完,直接显示所有文本串即可。
if(totalTextSize.height < textLabel.frame.size.height){
textLabel.text= text;
}
else{
//计算理想状态下的页面数量和每页所显示的字符数量,只是拿来作为参考值用而已!
NSUIntegertextLength = [text length];
referTotalPages=(int)totalTextSize.height/(int)textLabel.frame.size.height+1;
referCharatersPerPage= textLength/referTotalPages;
//申请最终保存页面NSRange信息的数组缓冲区
intmaxPages = referTotalPages;
rangeOfPages= (NSRange *)malloc(referTotalPages*sizeof(NSRange));
memset(rangeOfPages,0x0, referTotalPages*sizeof(NSRange));
//页面索引
intpage = 0;
for(NSUInteger location = 0; location < textLength; ){
//先计算临界点(尺寸刚刚超过UILabel尺寸时的文本串)
NSRangerange = NSMakeRange(location, referCharatersPerPage);
//reach end of text ?
NSString*pageText;
CGSizepageTextSize;
while(range.location + range.length < textLength) {
pageText= [text substringWithRange:range];
pageTextSize= [pageText sizeWithFont:[UIFontsystemFontOfSize:FONT_SIZE_MAX]
constrainedToSize:CGSizeMake(textLabel.frame.size.width,CGFLOAT_MAX)
lineBreakMode:UILineBreakModeWordWrap];
if(pageTextSize.height > textLabel.frame.size.height){
break;
}
else{
range.length+= referCharatersPerPage;
}
}
if(range.location + range.length >= textLength){
range.length= textLength - range.location;
}
//然后一个个缩短字符串的长度,当缩短后的字符串尺寸小于textLabel的尺寸时即为满足
while(range.length > 0) {
pageText= [text substringWithRange:range];
pageTextSize= [pageText sizeWithFont:[UIFontsystemFontOfSize:FONT_SIZE_MAX]
constrainedToSize:CGSizeMake(textLabel.frame.size.width,CGFLOAT_MAX)
lineBreakMode:UILineBreakModeWordWrap];
if(pageTextSize.height <= textLabel.frame.size.height){
range.length= [pageText length];
break;
}
else{
range.length-= 2;
}
}
//得到一个页面的显示范围
if(page >= maxPages) {
maxPages+= 10;
rangeOfPages= (NSRange *)realloc(rangeOfPages, maxPages*sizeof(NSRange));
}
rangeOfPages[page++]= range;
//更新游标
location+= range.length;
}
//获取最终页面数量
totalPages= page;
//更新UILabel内容
textLabel.text= [text substringWithRange:rangeOfPages[currentPage]];
}
}
//显示当前页面进度信息,格式为:"8/100"
pageInfoLabel.text= [NSString stringWithFormat:@"%d/%d", currentPage+1,totalPages];
}
////////////////////////////////////////////////////////////////////////////////////////
// 上一页
- (IBAction)actionPrevious:(id)sender {
if(currentPage > 0) {
currentPage--;
NSRangerange = rangeOfPages[currentPage];
NSString*pageText = [text substringWithRange:range];
textLabel.text= pageText;
//
pageInfoLabel.text= [NSString stringWithFormat:@"%d/%d", currentPage+1,totalPages];
}
}
////////////////////////////////////////////////////////////////////////////////////////
// 下一页
- (IBAction)actionNext:(id)sender {
if(currentPage < totalPages-1) {
currentPage++;
NSRangerange = rangeOfPages[currentPage];
NSString*pageText = [text substringWithRange:range];
textLabel.text= pageText;
//
pageInfoLabel.text= [NSString stringWithFormat:@"%d/%d", currentPage+1,totalPages];
}
}
原文地址:实现 iPhone 电子书的分页显示功能的代码作者:醉吻花颜
作 iPhone 电子书时,如果把大段文字放在 UITextView 或 UILabel里显示,是不能分页的,阅读时就像再看一大卷滚不到头的纸带,用户体验很差。下面这段代码可以实现 UILabel尺寸固定,根据文本内容和字体动态分页显示,电子书方面的应用应该非常有用。
// Implement viewDidLoad to do additional setup after loadingthe view, typically from a nib.
- (void)viewDidLoad {
[superviewDidLoad];
//
totalPages= 0;
currentPage= 0;
//
textLabel.numberOfLines= 0;
//
if(!text) {
//从文件里加载文本串
[selfloadString];
//计算文本串的大小尺寸
CGSizetotalTextSize = [text sizeWithFont:[UIFontsystemFontOfSize:FONT_SIZE_MAX]
constrainedToSize:CGSizeMake(textLabel.frame.size.width,CGFLOAT_MAX)
lineBreakMode:UILineBreakModeWordWrap];
//如果一页就能显示完,直接显示所有文本串即可。
if(totalTextSize.height < textLabel.frame.size.height){
textLabel.text= text;
}
else{
//计算理想状态下的页面数量和每页所显示的字符数量,只是拿来作为参考值用而已!
NSUIntegertextLength = [text length];
referTotalPages=(int)totalTextSize.height/(int)textLabel.frame.size.height+1;
referCharatersPerPage= textLength/referTotalPages;
//申请最终保存页面NSRange信息的数组缓冲区
intmaxPages = referTotalPages;
rangeOfPages= (NSRange *)malloc(referTotalPages*sizeof(NSRange));
memset(rangeOfPages,0x0, referTotalPages*sizeof(NSRange));
//页面索引
intpage = 0;
for(NSUInteger location = 0; location < textLength; ){
//先计算临界点(尺寸刚刚超过UILabel尺寸时的文本串)
NSRangerange = NSMakeRange(location, referCharatersPerPage);
//reach end of text ?
NSString*pageText;
CGSizepageTextSize;
while(range.location + range.length < textLength) {
pageText= [text substringWithRange:range];
pageTextSize= [pageText sizeWithFont:[UIFontsystemFontOfSize:FONT_SIZE_MAX]
constrainedToSize:CGSizeMake(textLabel.frame.size.width,CGFLOAT_MAX)
lineBreakMode:UILineBreakModeWordWrap];
if(pageTextSize.height > textLabel.frame.size.height){
break;
}
else{
range.length+= referCharatersPerPage;
}
}
if(range.location + range.length >= textLength){
range.length= textLength - range.location;
}
//然后一个个缩短字符串的长度,当缩短后的字符串尺寸小于textLabel的尺寸时即为满足
while(range.length > 0) {
pageText= [text substringWithRange:range];
pageTextSize= [pageText sizeWithFont:[UIFontsystemFontOfSize:FONT_SIZE_MAX]
constrainedToSize:CGSizeMake(textLabel.frame.size.width,CGFLOAT_MAX)
lineBreakMode:UILineBreakModeWordWrap];
if(pageTextSize.height <= textLabel.frame.size.height){
range.length= [pageText length];
break;
}
else{
range.length-= 2;
}
}
//得到一个页面的显示范围
if(page >= maxPages) {
maxPages+= 10;
rangeOfPages= (NSRange *)realloc(rangeOfPages, maxPages*sizeof(NSRange));
}
rangeOfPages[page++]= range;
//更新游标
location+= range.length;
}
//获取最终页面数量
totalPages= page;
//更新UILabel内容
textLabel.text= [text substringWithRange:rangeOfPages[currentPage]];
}
}
//显示当前页面进度信息,格式为:"8/100"
pageInfoLabel.text= [NSString stringWithFormat:@"%d/%d", currentPage+1,totalPages];
}
////////////////////////////////////////////////////////////////////////////////////////
// 上一页
- (IBAction)actionPrevious:(id)sender {
if(currentPage > 0) {
currentPage--;
NSRangerange = rangeOfPages[currentPage];
NSString*pageText = [text substringWithRange:range];
textLabel.text= pageText;
//
pageInfoLabel.text= [NSString stringWithFormat:@"%d/%d", currentPage+1,totalPages];
}
}
////////////////////////////////////////////////////////////////////////////////////////
// 下一页
- (IBAction)actionNext:(id)sender {
if(currentPage < totalPages-1) {
currentPage++;
NSRangerange = rangeOfPages[currentPage];
NSString*pageText = [text substringWithRange:range];
textLabel.text= pageText;
//
pageInfoLabel.text= [NSString stringWithFormat:@"%d/%d", currentPage+1,totalPages];
}
}
相关文章推荐
- 实现 iPhone 电子书的分页显示功能的代码 转载
- 实现iPhone电子书的分页显示功能(附代码)
- 实现 iPhone 电子书的分页显示功能的代码
- 实现iPhone电子书的分页显示功能(附代码)
- iphone开发 UITableview实现分页显示方法(代码)
- 【用于ios6】【ios7以后用新的方法】实现电子书的分页显示功能
- 代码实现DataList控件的分页显示
- 图书购买系统之商品分类分页--根据主页面传来的值分类显示商品并实现动态分页功能
- 扩展jquery实现客户端表格的分页、排序功能代码
- Android之ListView分页加载数据功能实现代码
- UITableView 实现分页显示的代码
- iPhone 应用里实现截屏功能的代码
- 使用PagedDataSource类实现DataList和Repeater控件的分页显示功能
- 使用ExtJs 来显示数据,并实现数据的分页功能
- asp.net 文章分页显示实现代码
- iPhone 应用里实现截屏功能的代码
- 利用VUE框架,实现列表分页功能示例代码
- [学习笔记]小型论坛功能——实现按照指定每页的行数来分页显示记录[3]
- jquery+ashx无刷新GridView数据显示插件(实现分页、排序、过滤功能)
- javabean servlet jsp实现分页功能代码解析