欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

iOS中的UITextView文字输入光标使用技巧小结

程序员文章站 2023-12-04 09:51:04
1.创建并初始化 @property (nonatomic, strong) uitextview *textview; // 创建 self.t...

1.创建并初始化

 @property (nonatomic, strong) uitextview *textview; 

// 创建
self.textview = [[uitextview alloc] initwithframe:self.view.frame]; 

// 设置textview里面的字体颜色 
 self.textview.textcolor = [uicolor blackcolor]; 
// 设置字体名字和字体大小 
 self.textview.font = [uifont fontwithname:@"arial" size:18.0]; 
// 设置代理
 self.textview.delegate = self;  
// 设置它的背景颜色
 self.textview.backgroundcolor = [uicolor whitecolor]; 
 self.textview.text = @“hehe”; 
// 返回键的类型 
 self.textview.returnkeytype = uireturnkeydefault; 
// 键盘类型 
 self.textview.keyboardtype = uikeyboardtypedefault; 

// 是否可以拖动  
self.textview.scrollenabled = yes;


2. uitextview退出键盘的几种方式
(1)如果你程序是有导航条的,可以在导航条上面加多一个done的按钮,用来退出键盘,当然要先实现uitextviewdelegate。

- (void)textviewdidbeginediting:(uitextview *)textview {  

self.navigationitem.rightbarbuttonitem = [[uibarbuttonitem alloc] initwithbarbuttonsystemitem:uibarbuttonsystemitemdone target:self action:@selector(getoverediting)];  

}  
- (void)textviewdidendediting:(uitextview *)textview {  
  self.navigationitem.rightbarbuttonitem = nil; 
} 
- (void)getoverediting{
 [self.textview resignfirstresponder];  
}

(2)如果你的textview里不用回车键,可以把回车键当做退出键盘的响应键。

#pragma mark - uitextview delegate methods   
-(bool)textview:(uitextview *)textview shouldchangetextinrange:(nsrange)range replacementtext:(nsstring *)text
{  
 if ([text isequaltostring:@"\n"]) {  
   [textview resignfirstresponder];  
   return no;  
  }
 return yes;  
}

(3)还有你也可以自定义其他视图控件加载到键盘上用来退出,比如在弹出的键盘上面加一个view来放置退出键盘的done按钮。

   uitoolbar * topview = [[uitoolbar alloc]initwithframe:cgrectmake(0, 0, 320, 30)]; 
   uibarbuttonitem * cancelbutton= [[uibarbuttonitem alloc]initwithtitle:@"done" style:uibarbuttonitemstyledone target:self action:@selector(dismisskeyboard)]; 
   nsarray * buttonsarray = @[cancelbutton]; 
   [topview setitems:buttonsarray]; 
   [self.textview setinputaccessoryview:topview]; 
 -(void)dismisskeyboard 
 { 
   [tvtextview resignfirstresponder]; 
 }

3.uitextview自定选择文字后的菜单

在viewdidload中加入:

- (void)viewdidload
{
  [super viewdidload];
  self._textview = [[uitextview alloc] initwithframe:cgrectmake(10, 100, 300, 200)];
  [self.view addsubview:_textview];  
  uimenuitem *menuitem = [[uimenuitem alloc]initwithtitle:@“我是自定义的菜单" action:@selector(didclickcustommenuaction)]; 
  uimenucontroller *menu = [uimenucontroller sharedmenucontroller]; 
  [menu setmenuitems:[nsarray arraywithobject:menuitem]]; 
  [menuitem release]; 
}

当然上面那个@selector里面的changecolor方法还是自己写吧,也就是说点击了我们自定义的菜单项后会触发的方法。
然后还得在代码里加上一个方法:

-(bool)canperformaction:(sel)action withsender:(id)sender 
{ 
  if(action ==@selector(changecolor) || action == @selector(copy:)) 
  { 
    if(_textview.selectedrange.length>0) 
      return yes; 
  } 
  return no; 
} 
-(void)didclickcustommenuaction
{
  nslog(@"%@“,__function__);
}

4.设置uitextview内边距
当我们因为一些需求将uitextview当成uilabel使用(为了使用uitextview自带的复制,粘贴,选择功能),这时我们只需要禁用uitextview的几个属性就行了

textview.editable = no;//不可编辑 
textview.scrollenabled = no;//不可滚动 
textview.editable = no;//不可编辑 
textview.scrollenabled = no;//不可滚动 

这样就ok;
但是当我们在实际运用时,想计算文字的大小并设置uitextview的显示大小

uifont *font = [uifont systemfontofsize:14.0f]; //指定字符串的大小 
 
[textview settext:content]; 
 
cgsize textsize = [content sizewithfont:font constrainedtosize:cgsizemake(200, 2000) linebreakmode:uilinebreakmodecharacterwrap]; 
 
cgrect articleframe = [articlelabel frame]; 
textview.size.height = textsize.height ; 
 textview.size.width = textsize.width; 
[textview setframe:articleframe]; 
uifont *font = [uifont systemfontofsize:14.0f]; //指定字符串的大小 
 
[textview settext:content]; 
 
cgsize textsize = [content sizewithfont:font constrainedtosize:cgsizemake(200, 2000) linebreakmode:uilinebreakmodecharacterwrap]; 
 
cgrect articleframe = [articlelabel frame]; 
textview.size.height = textsize.height ; 
 textview.size.width = textsize.width; 
[textview setframe:articleframe]; 

但是通过这种方法在uilabel上使用没有任何问题,但是在uitextview是却不行,文字总是显示不全,不管你主动写多了高度给它,当文字不一样了双会显示不全或显示高度过多;
可以用下面的方法试一下

[self.articlelabel setcontentinset:uiedgeinsetsmake(-10, -5, -15, -5)];//设置uitextview的内边距 
[self.articlelabel settextalignment:nstextalignmentleft];//并设置左对齐 
[self.articlelabel setcontentinset:uiedgeinsetsmake(-10, -5, -15, -5)];//设置uitextview的内边距 
[self.articlelabel settextalignment:nstextalignmentleft];//并设置左对齐