iOS实现一个意见反馈类型的输入栏
程序员文章站
2023-12-18 09:51:40
前言
本文主要给大家介绍了关于利用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; } }
总结
以上就是这篇文章的全部内容了,本文还有许多不足,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。