文档章节

iOS学习4:UITextView的用法及技巧(ios7下光标bug解决方案)

芳仔小脚丫
 芳仔小脚丫
发布于 2013/06/24 13:22
字数 877
阅读 39657
收藏 29

一、新建一个textView

//初始化
UITextView *textView = [[[UITextView alloc] init] autorelease];

//设置代理 需在interface中声明UITextViewDelegate
textView.delegate = self;

//字体大小
textView.font = [UIFont systemFontOfSize:16];

//添加滚动区域
textView.contentInset = UIEdgeInsetsMake(-11, -6, 0, 0);

//是否可以滚动
textView.scrollEnabled = NO;

//获得焦点
[textView becomeFirstResponder];
[self.view addSubview:textView];

二、键盘操作

//返回键的类型
textView.returnKeyType = UIReturnKeyDefault;

//键盘类型
textView.keyboardType = UIKeyboardTypeDefault;

三、隐藏键盘的几种方式

个人还是认为最方便的是在键盘上加上一个ToolBar,在上面加上一个按钮来隐藏键盘

①在键盘上加上隐藏按钮

//定义一个toolBar
UIToolbar * topView = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 30)];

//设置style
[topView setBarStyle:UIBarStyleBlack];

//定义两个flexibleSpace的button,放在toolBar上,这样完成按钮就会在最右边
UIBarButtonItem * button1 =[[UIBarButtonItem  alloc]initWithBarButtonSystemItem:                                        UIBarButtonSystemItemFlexibleSpace target:self action:nil];

UIBarButtonItem * button2 = [[UIBarButtonItem  alloc]initWithBarButtonSystemItem:                                        UIBarButtonSystemItemFlexibleSpace target:self action:nil];

//定义完成按钮
UIBarButtonItem * doneButton = [[UIBarButtonItem alloc]initWithTitle:@"完成" style:UIBarButtonItemStyleDone  target:self action:@selector(resignKeyboard)];
    
//在toolBar上加上这些按钮
NSArray * buttonsArray = [NSArray arrayWithObjects:button1,button2,doneButton,nil];     
[topView setItems:buttonsArray];

[textView setInputAccessoryView:topView];
//隐藏键盘
- (void)resignKeyboard {
    [textView resignFirstResponder];
}
最终效果

还有几种也可隐藏键盘的方式

②用回车键,前提是你的textView中不需要用到回车键

-(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text {
 if ([text isEqualToString:@"\n"]) 
{ 
[textView resignFirstResponder]; return NO; 
}
 return YES; 
}

③触摸空白处隐藏键盘

-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    //隐藏键盘
    [textView resignFirstResponder];
}

四、使键盘不挡住输入框

    在view中添加一个子view,设置此子view的tag值为1000,在此view上添加一个textView和一个发送按钮,如下图;我们要达到textView的键盘弹出时,整个View往上平移,键盘消失,view往下平移的效果,模拟发送短信的界面。

设置textView圆角

//设置textView圆角
[self.textView.layer setCornerRadius:10];

①、在viewWillAppear中添加键盘监听事件

//添加键盘的监听事件
    
    //注册通知,监听键盘弹出事件
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidShow:) name:UIKeyboardDidShowNotification object:nil];
    
    //注册通知,监听键盘消失事件
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidHidden) name:UIKeyboardDidHideNotification object:nil];
②、完成①selector中键盘弹出keyboardDidShow:和消失keyboardDidHidden方法

    在.m文件#import后面添加

//动画时间
#define kAnimationDuration 0.2
//view高度
#define kViewHeight 56
键盘出现
// 键盘弹出时
-(void)keyboardDidShow:(NSNotification *)notification
{
    
    //获取键盘高度
    NSValue *keyboardObject = [[notification userInfo] objectForKey:UIKeyboardFrameEndUserInfoKey];
    
    CGRect keyboardRect;
    
    [keyboardObject getValue:&keyboardRect];
    
    //调整放置有textView的view的位置
    
       //设置动画
    [UIView beginAnimations:nil context:nil];
    
       //定义动画时间
    [UIView setAnimationDuration:kAnimationDuration];
    
       //设置view的frame,往上平移
    [(UIView *)[self.view viewWithTag:1000] setFrame:CGRectMake(0, self.view.frame.size.height-keyboardRect.size.height-kViewHeight, 320, kViewHeight)];
    
    [UIView commitAnimations];
    
}
键盘消失
//键盘消失时
-(void)keyboardDidHidden
{
    //定义动画
    [UIView beginAnimations:nil context:nil];
    [UIView setAnimationDuration:kAnimationDuration];
    //设置view的frame,往下平移
    [(UIView *)[self.view viewWithTag:1000] setFrame:CGRectMake(0, self.view.frame.size.height-kViewHeight, 320, kViewHeight)];
    [UIView commitAnimations];
}

效果图:

iOS7光标问题

PS:有网友遇到textView在ios7上出现编辑进入最后一行时光标消失,看不到最后一行,变成盲打,stackOverFlow网站上有大神指出,是ios7本身bug,加上下面一段代码即可(网友调试得出,在此mark一下,有问题,欢迎大神们指出)

-(void)textViewDidChange:(UITextView *)textView {
    CGRect line = [textView caretRectForPosition:
                   textView.selectedTextRange.start];
    CGFloat overflow = line.origin.y + line.size.height
    - ( textView.contentOffset.y + textView.bounds.size.height
       - textView.contentInset.bottom - textView.contentInset.top );
    if ( overflow > 0 ) {
        // We are at the bottom of the visible text and introduced a line feed, scroll down (iOS 7 does not do it)
        // Scroll caret to visible area
        CGPoint offset = textView.contentOffset;
        offset.y += overflow + 7; // leave 7 pixels margin
        // Cannot animate with setContentOffset:animated: or caret will not appear
        [UIView animateWithDuration:.2 animations:^{
            [textView setContentOffset:offset];
        }];
    }
}

© 著作权归作者所有

共有 人打赏支持
芳仔小脚丫
粉丝 929
博文 83
码字总数 76301
作品 0
闵行
程序员
加载中

评论(11)

zm2529
zm2529

引用来自“央央酱”的评论

输入超过初始化的宽度之后,用苹果自带的输入法输入,输入时输入框会跳动,请问大神有遇到这个问题么
textView.layoutManager.allowsNonContiguousLayout = NO;
央央酱
央央酱
输入超过初始化的宽度之后,用苹果自带的输入法输入,输入时输入框会跳动,请问大神有遇到这个问题么
风了个1
风了个1
光标问题没有解决
小吴学长
小吴学长
光标问题,帮我大忙,感谢
迅仔
迅仔
哈哈,刚好项目里要做这个,博主这里就有了。简直不要太爽。
蔡开源中
太牛了! 大神 请受小弟揖拜
W
Wuleslie
Brilliant!!!!!!
sunlike
sunlike
经过这几天的学习,你的这篇文章我终于看懂了哈。
sunlike
sunlike

引用来自“芳仔小脚印”的评论

引用来自“sunlike”的评论

您好,很感谢您分享这篇文章,但是看了您的这篇文章之后,我开始按照您的方法进行操作,打开xcode,新建一个 single view application,但是下面的代码我放到什么地方?我新建类还是放到controller中的loadview方法中?下面的代码更是不知道该放到什么文件,放到什么函数中?
I need your help ,I‘m looking forward to your reply and advice. I will appreciate for your any suggestions.

额。。这个,你想用在哪个界面就放在哪个类里,放在viewcontroller的viewDidLoad里面就可以。。这个代码放在哪里还真不好回答,因为要看你自己想在什么时候用的。

Thanks very much.
芳仔小脚丫
芳仔小脚丫

引用来自“sunlike”的评论

您好,很感谢您分享这篇文章,但是看了您的这篇文章之后,我开始按照您的方法进行操作,打开xcode,新建一个 single view application,但是下面的代码我放到什么地方?我新建类还是放到controller中的loadview方法中?下面的代码更是不知道该放到什么文件,放到什么函数中?
I need your help ,I‘m looking forward to your reply and advice. I will appreciate for your any suggestions.

额。。这个,你想用在哪个界面就放在哪个类里,放在viewcontroller的viewDidLoad里面就可以。。这个代码放在哪里还真不好回答,因为要看你自己想在什么时候用的。
iOS中UITextView的几个小问题

1、ios7中,UITextView有个小bug: 当输入内容到textView底部,这个时候点击键盘上面换行,textView不会随着光标移动下去,在网上查了一下,找到解决方案:(参考:http://stackoverflow.co...

Feng_999
2015/01/23
0
3
[iOS Animation]-CALayer 专用图层 富文本

富文本 iOS 6中,Apple给UILabel和其他UIKit文本视图添加了直接的属性化字符串的支持,应该说这是一个很方便的特性。不过事实上从iOS3.2开始CATextLayer就已经支持属性化字符串了。这样的话,...

浩浩老师
2015/09/23
0
0
用视图上移解决UITextField/UITextView被键盘遮盖问题

先看看UILabel/UITextField/UITextView的区别: UILabel 显示的文本只读,无法编辑,可以根据文字个数自动换行; UITextField 可编辑本文,但是无法换行,只能在一行显示;当点击键盘上的ret...

yoyoso
2015/03/18
0
0
ios开发日志-button+UIAlertView

去年学习过一段时间的ios开发 后来不知道为什么就没学了 最近准备重新开始学习ios开发 准备每天发一篇日志记录学习过程,也锻炼下自己的语言组织能力,代码写久了话不会说了 CGRect frame =...

平凡简单
2013/05/31
0
0
iOS小技巧---改变uisearchbar中的cancel按钮的文字、取消clearButton

#pragma mark searchBar开始输入文字时 //汉化取消按钮 - (void)searchBarTextDidBeginEditing:(UISearchBar )searchBar{ searchBar.showsCancelButton = YES; if ([[[UIDevice currentDevi......

夕阳_jhe
2015/04/15
0
0

没有更多内容

加载失败,请刷新页面

加载更多

各种开源汇编、反汇编引擎的非专业比较

由于平时业余兴趣和工作需要,研究过并使用过时下流行的各种开源的x86/64汇编和反汇编引擎。如果要对汇编指令进行分析和操作,要么自己研究Intel指令集写一个,要么就用现成的开源引擎。自己...

simpower
25分钟前
3
0
(4)添加vue-router

(4)添加vue-router 1 安装vue-router cnpm install vue-router --save 2 页面准备 新建目录/src/views/common,此目录下面建立4个组件404.vue、home.vue、login.vue、theme.vue。每个文件...

neumeng
28分钟前
2
0
高可用性系统在大众点评的实践与经验

背景 所谓高可用性指的是系统如何保证比较高的服务可用率,在出现故障时如何应对,包括及时发现、故障转移、尽快从故障中恢复等等。本文主要以点评的交易系统的演进为主来描述如何做到高可用...

Skqing
35分钟前
3
0
Network protocols

The network stack does serveral seemingly-impossible things. It does reliable transmission over our unreliable networks, usually without any detactable hiccups. It adapts smooth......

nao
37分钟前
1
0
Android 生命周期方法

1,onCreate(); 2,onStart(); 3,onResume(); //打开页面,前三个方法自动执行 4,onPause(); 5,onStop(); //打开其他页面,前一个页面执行这俩方法 6,onRestart(); //onStart(),onResume //当关闭...

lanyu96
44分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部