iOS實(shí)現(xiàn)聊天輸入框功能
經(jīng)常使用微信聊天,沒(méi)事兒就會(huì)想輸入框的實(shí)現(xiàn)過(guò)程,所以抽空,也實(shí)現(xiàn)了一個(gè)輸入框的功能;
經(jīng)過(guò)封裝,使用就非常的簡(jiǎn)單了,在需要的VC中,實(shí)現(xiàn)方法如下:
- (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor = [UIColor colorWithRed:0.92 green:0.92 blue:0.92 alpha:1.00]; self.keyView = [[DKSKeyboardView alloc] initWithFrame:CGRectMake(0, K_Height - 51, K_Width, 51)]; //設(shè)置代理方法 self.keyView.delegate = self; [self.view addSubview:_keyView]; }
主要就是上面的添加,此時(shí)輸入框就已經(jīng)添加到當(dāng)前的VC中;稍后會(huì)講到里面的代理方法的作用;
工程結(jié)構(gòu)如下圖
主要是紅色線標(biāo)出的兩個(gè)類,結(jié)構(gòu)比較簡(jiǎn)單
類名 | 作用 |
---|---|
DKSKeyboardView | 布局表情按鈕、更多按鈕、輸入框 |
DKSTextView |
設(shè)置輸入行數(shù),輸入框內(nèi)容變化時(shí)改變輸入款高度 |
DKSKeyboardView.h中的代碼如下:
#import @protocol DKSKeyboardDelegate @optional //非必實(shí)現(xiàn)的方法 /** 點(diǎn)擊發(fā)送時(shí)輸入框內(nèi)的文案 @param textStr 文案 */ - (void)textViewContentText:(NSString *)textStr; /** 鍵盤的frame改變 */ - (void)keyboardChangeFrameWithMinY:(CGFloat)minY; @end @interface DKSKeyboardView : UIView @property (nonatomic, weak) id delegate; @end
關(guān)于上面的兩個(gè)代理方法,由于文章篇幅問(wèn)題,實(shí)現(xiàn)的過(guò)程可參考demo,里面有詳細(xì)的注釋;
在DKSKeyboardView.m中,以下列出少量重要代碼,主要是改變frame
1、點(diǎn)擊輸入框,鍵盤出現(xiàn)
//鍵盤將要出現(xiàn) - (void)keyboardWillShow:(NSNotification *)notification { [self removeBottomViewFromSupview]; NSDictionary *userInfo = notification.userInfo; CGRect endFrame = [userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue]; //獲取鍵盤的高度 self.keyboardHeight = endFrame.size.height; //鍵盤的動(dòng)畫時(shí)長(zhǎng) CGFloat duration = [userInfo[UIKeyboardAnimationDurationUserInfoKey] doubleValue]; [UIView animateWithDuration:duration delay:0 options:[notification.userInfo[UIKeyboardAnimationCurveUserInfoKey] integerValue] animations:^{ self.frame = CGRectMake(0, endFrame.origin.y - self.backView.height - StatusNav_Height, K_Width, self.height); [self changeTableViewFrame]; } completion:nil]; }
2、鍵盤消失
- (void)keyboardWillHide:(NSNotification *)notification { //如果是彈出了底部視圖時(shí) if (self.moreClick || self.emojiClick) { return; } [UIView animateWithDuration:0.25 animations:^{ self.frame = CGRectMake(0, K_Height - StatusNav_Height - self.backView.height, K_Width, self.backView.height); [self changeTableViewFrame]; }]; }
3、點(diǎn)擊更多按鈕
- (void)moreBtn:(UIButton *)btn { self.emojiClick = NO; //主要是設(shè)置表情按鈕為未點(diǎn)擊狀態(tài) if (self.moreClick == NO) { self.moreClick = YES; //回收鍵盤 [self.textView resignFirstResponder]; [self.emojiView removeFromSuperview]; self.emojiView = nil; [self addSubview:self.moreView]; //改變更多、self的frame [UIView animateWithDuration:0.25 animations:^{ self.moreView.frame = CGRectMake(0, self.backView.height, K_Width, bottomHeight); self.frame = CGRectMake(0, K_Height - StatusNav_Height - self.backView.height - bottomHeight, K_Width, self.backView.height + bottomHeight); [self changeTableViewFrame]; }]; } else { //再次點(diǎn)擊更多按鈕 //鍵盤彈起 [self.textView becomeFirstResponder]; } }
4、改變輸入框大小
- (void)changeFrame:(CGFloat)height { CGRect frame = self.textView.frame; frame.size.height = height; self.textView.frame = frame; //改變輸入框的frame //當(dāng)輸入框大小改變時(shí),改變backView的frame self.backView.frame = CGRectMake(0, 0, K_Width, height + (viewMargin * 2)); self.frame = CGRectMake(0, K_Height - self.backView.height - self.keyboardHeight, K_Width, self.backView.height); //改變更多按鈕、表情按鈕的位置 self.emojiBtn.frame = CGRectMake(viewMargin, self.backView.height - viewHeight - viewMargin, viewHeight, viewHeight); self.moreBtn.frame = CGRectMake(self.textView.maxX + viewMargin, self.backView.height - viewHeight - viewMargin, viewHeight, viewHeight); //主要是為了改變VC的view的frame if (self.delegate && [self.delegate respondsToSelector:@selector(changeFrameWithMinY:)]) { [self.delegate changeFrameWithMinY:self.minY]; } }
以上就是聊天輸入框的簡(jiǎn)單實(shí)現(xiàn),只是提供一個(gè)實(shí)現(xiàn)思路,如果在聊天界面中接入,還需要處理以下問(wèn)題:
1、demo中沒(méi)有做tableViewCell的高度自適應(yīng);
2、輸入框文案較多時(shí),tableViewCell可能會(huì)出現(xiàn)紊亂,此處沒(méi)有處理
demo中如果有任何問(wèn)題,歡迎各位留言拍磚,小弟一定更正,共同學(xué)習(xí);
總結(jié)
以上所述是小編給大家介紹的iOS實(shí)現(xiàn)聊天輸入框功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- iOS實(shí)現(xiàn)類似微信和支付寶的密碼輸入框(UIKeyInput協(xié)議)
- iOS輸入框(UITextField)密碼明暗文切換方法
- IOS 鍵盤擋住輸入框的問(wèn)題解決辦法
- iOS項(xiàng)目開(kāi)發(fā)鍵盤彈出遮擋輸入框問(wèn)題解決方案
- 解決ios手機(jī)中input輸入框光標(biāo)過(guò)長(zhǎng)的問(wèn)題
- iOS輸入框的字?jǐn)?shù)統(tǒng)計(jì)/最大長(zhǎng)度限制詳解
- iOS中輸入框設(shè)置指定字符輸入的方法
- h5 ios輸入框和鍵盤的兼容性優(yōu)化指南
- iOS使用UIKeyInput自定義密碼輸入框的方法示例
相關(guān)文章
IOS開(kāi)發(fā)中如何設(shè)計(jì)短信驗(yàn)證碼防刷機(jī)制
給大家詳細(xì)分享一下在IOS的項(xiàng)目開(kāi)發(fā)中如何設(shè)計(jì)短信驗(yàn)證碼防刷機(jī)制,已經(jīng)步驟詳解,喜歡的朋友參考下吧。2018-02-02iOS11實(shí)現(xiàn)App內(nèi)自動(dòng)連接Wi-Fi的方法
這篇文章主要給大家介紹了關(guān)于iOS11實(shí)現(xiàn)App內(nèi)自動(dòng)連接Wi-Fi的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-10-10iOS實(shí)現(xiàn)新年抽獎(jiǎng)轉(zhuǎn)盤效果的思路
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)抽獎(jiǎng)轉(zhuǎn)盤效果的思路,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01IOS開(kāi)發(fā) UIAlertController詳解及實(shí)例代碼
這篇文章主要介紹了 IOS開(kāi)發(fā) UIAlertController詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2016-12-12實(shí)例講解iOS應(yīng)用開(kāi)發(fā)中使用UITableView創(chuàng)建自定義表格
這篇文章主要介紹了iOS應(yīng)用開(kāi)發(fā)中使用UITableView創(chuàng)建自定義表格的方法,示例代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-01-01ios8 UITableView設(shè)置 setSeparatorInset UIEdgeInsetsZero不起作用的解決
這篇文章主要介紹了ios8 UITableView設(shè)置 setSeparatorInset UIEdgeInsetsZero不起作用的解決辦法(去掉15px空白間距)的相關(guān)資料,需要的朋友可以參考下2016-02-02iOS逆向開(kāi)發(fā)之微信自動(dòng)添加好友功能
這篇文章主要介紹了iOS逆向開(kāi)發(fā)之微信自動(dòng)添加好友功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04iOS中UILabel text兩邊對(duì)齊的實(shí)現(xiàn)代碼
本文通過(guò)一段實(shí)例代碼給大家介紹了ios中uilabel text兩邊對(duì)齊的實(shí)現(xiàn)方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2017-01-01