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

iOS实现一个意见反馈类型的输入栏

程序员文章站 2023-12-20 15:43:16
前言 本文主要给大家介绍了关于利用ios如何实现一个意见反馈类型的输入栏,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 要做个意见反馈,textfi...

前言

本文主要给大家介绍了关于利用ios如何实现一个意见反馈类型的输入栏,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

要做个意见反馈,textfield只有一行,textview没有提示,好尬,只有做一个了,就是使用textview作为输入框,添加个label作为提示,这里的关键是输入内容的限制,我这里限制了120字,但是要考虑很多方面的东西,来看代码

示例代码

@property (nonatomic, strong) uilabel *placholderlabel; //提示字符串 
@property (weak, nonatomic) iboutlet uitextview *infotf;
 
#define max_limit_nums 120 //文本最大长度
 
- (void)controlview {
 self.infotf.layer.borderwidth = 0.5;//边宽
 self.infotf.layer.cornerradius = 5.0;//设置圆角
 self.infotf.layer.bordercolor =[uicolor graycolor].cgcolor;
 self.infotf.delegate = self;
 
 cgfloat width = self.infotf.frame.size.width;
 
 self.placholderlabel = [[uilabel alloc] initwithframe:cgrectmake(5, 0, width-5, 30)];
 self.placholderlabel.numberoflines = 0;
 self.placholderlabel.text = setinternational(@"live.weibosummay.string");
 self.placholderlabel.textcolor = setrgbcolor(176, 176, 176);
 self.placholderlabel.font = zkp15font;
 [self.placholderlabel sethidden:no];
 [self.infotf addsubview:_placholderlabel];
}
 
//限制文本输入长度
- (void)textviewdidchange:(uitextview*)textview{
 if([textview.text length] == 0){
  _placholderlabel.hidden = no;
 }else{
  _placholderlabel.hidden = yes;//这里给空
 }
 
 uitextrange *selectedrange = [textview markedtextrange];
 //获取高亮部分
 uitextposition *pos = [textview positionfromposition:selectedrange.start offset:0];
 //如果在变化中是高亮部分在变,就不要计算字符了
 if (selectedrange && pos) {
  return;
 }
 
 nsstring *nstextcontent = textview.text;
 nsinteger existtextnum = nstextcontent.length;
 
 if (existtextnum > max_limit_nums){
  //截取到最大位置的字符(由于超出截部分在should时被处理了所在这里这了提高效率不再判断)
  nsstring *s = [nstextcontent substringtoindex:max_limit_nums];
  
  [textview settext:s];
 }
}
//设置超出最大字数(120字)即不可输入 也是textview的代理方法
- (bool)textview:(uitextview*)textview shouldchangetextinrange:(nsrange)range
 replacementtext:(nsstring*)text{
 
 uitextrange *selectedrange = [textview markedtextrange];
 //获取高亮部分
 uitextposition *pos = [textview positionfromposition:selectedrange.start offset:0];
 
 //如果有高亮且当前字数开始位置小于最大限制时允许输入
 if (selectedrange && pos) {
  nsinteger startoffset = [textview offsetfromposition:textview.beginningofdocument toposition:selectedrange.start];
  nsinteger endoffset = [textview offsetfromposition:textview.beginningofdocument toposition:selectedrange.end];
  nsrange offsetrange = nsmakerange(startoffset, endoffset - startoffset);
  
  if (offsetrange.location < max_limit_nums) {
   return yes;
  }else{
   return no;
  }
 }
 
 nsstring *comcatstr = [textview.text stringbyreplacingcharactersinrange:range withstring:text];
 
 nsinteger caninputlen = max_limit_nums - comcatstr.length;
 
 if (caninputlen >= 0){
  return yes;
 }else{
  nsinteger len = text.length + caninputlen;
  //防止当text.length + caninputlen < 0时,使得rg.length为一个非法最大正数出错
  nsrange rg = {0,max(len,0)};
  
  if (rg.length > 0){
   nsstring *s = @"";
   //判断是否只普通的字符或asc码(对于中文和表情返回no)
   bool asc = [text canbeconvertedtoencoding:nsasciistringencoding];
   if (asc) {
    s = [text substringwithrange:rg];//因为是ascii码直接取就可以了不会错
   }else{
    __block nsinteger idx = 0;
    __block nsstring *trimstring = @"";//截取出的字串
    //使用字符串遍历,这个方法能准确知道每个emoji是占一个unicode还是两个
    [text enumeratesubstringsinrange:nsmakerange(0, [text length])
           options:nsstringenumerationbycomposedcharactersequences
          usingblock: ^(nsstring* substring, nsrange substringrange, nsrange enclosingrange, bool* stop) {
           
           nsinteger steplen = substring.length;
           if (idx >= rg.length) {
            *stop = yes; //取出所需要就break,提高效率
            return ;
           }
           
           trimstring = [trimstring stringbyappendingstring:substring];
           
           idx = idx + steplen;//这里变化了,使用了字串占的长度来作为步长 
          }];
    
    s = trimstring;
   }
   //rang是指从当前光标处进行替换处理(注意如果执行此句后面返回的是yes会触发didchange事件)
   [textview settext:[textview.text stringbyreplacingcharactersinrange:range withstring:s]];
  }
  return no;
 }
}

总结

以上就是这篇文章的全部内容了,本文还有许多不足,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。

上一篇:

下一篇: