我將整個項目的復習拆分成了幾個部分, 每完成一部分我都會提交一次代碼, 大家根據所復習到的部分, 檢出對應的分支來看代碼就可以了, 代碼中的注釋已經十分詳盡了, 有問題或者疑惑大家可以隨時留言溝通.
項目地址
知識點匯總
- iOS-自定義表情鍵盤
- iOS-通過上下文對圖片壓縮圖片
- Alamofire上傳文件
- 自定義UITextView 添加加在Vc 上, 通過對不同事件的監(jiān)聽來理解
代理
- 通知(Notification)里面的數據類型 轉成結構體或基本數據類型來使用
- UIStackView
- textView切換自定義鍵盤的邏輯分析 ->inputView
- UIPageControl設置默認和選中顏色, 需要使用KVC
- 通過tag獲取view 的方法
- 表情上屏
4. 自定義UITextView 添加加在Vc 上, 通過對不同事件的監(jiān)聽來理解代理
- 代理是一對一的, 當多處使用同一代理是, 就會出現問題, 也就是說會和遵循代理的先后順序有關, 也就會出現邏輯問題, 導致代理使用不正確.
- 當同意代理已經被使用, 且同時需要進行監(jiān)聽, 就可以代理+通知配合來使用.
5. 通知(Notification)里面的數據類型 轉成結構體或基本數據類型來使用
// 監(jiān)聽鍵盤的frame將要發(fā)生改變
@objc func keyboardWillChangeFrame(noti: Notification){
// 判斷userInfo是否為nil 是否可以轉成字典
guard let userInfo = noti.userInfo as? [String: Any] else{
return
}
// 獲取鍵盤的frame
// MARK: - 通知里面的數據類型轉結構體, 一般使用NSValue做橋接
let frame = (userInfo[UIResponder.keyboardFrameEndUserInfoKey] as! NSValue).cgRectValue
// 獲取鍵盤動畫時間
// MARK: - 通知里面的數據轉換為double, 一般用NSNumber做橋接
let duration = (userInfo[UIResponder.keyboardAnimationDurationUserInfoKey] as! NSNumber).doubleValue
}
6. UIStackView
- UIStackView ios 9 以后的新控件
- 是一個容器視圖
- 特點: 不必為子控件逐一設置約束
// 添加子控件
open func addArrangedSubview(_ view: UIView)
// addSubview(<#T##view: UIView##UIView#>) 添加不上
// 設置基本屬性, 布局方向、模式即可, 就會自動為你布局
// 布局方式 - (垂直或者水平)
axis = .horizontal
// 填充方式 - 控件評分區(qū)域
distribution = .fillEqually
7. textView切換自定義鍵盤的邏輯分析 ->inputView
// 切換鍵盤 -> 表情鍵盤/文字鍵盤
func switchKeyboard(){
// 如果inputView == nil 就代表是系統(tǒng)鍵盤 改成自定義鍵盤
if self.composeTextView.inputView == nil {
self.composeTextView.inputView = self.emoticonKeyboardView
}else {
// 如果inputView != nil 就代表你設置了自定義鍵盤 改成系統(tǒng)鍵盤
self.composeTextView.inputView = nil
}
// 開啟第一響應
self.composeTextView.becomeFirstResponder()
// 刷新
self.composeTextView.reloadInputViews()
}
8. UIPageControl設置默認和選中顏色, 需要使用KVC
// 懶加載分頁指示器
private lazy var pageControl: UIPageControl = {
let view = UIPageControl()
// 設置總頁數
view.numberOfPages = 4
// 當前頁數
view.currentPage = 1
// 設置默認圖片(使用KVC, 對兩個只讀屬性賦值)
view.setValue(UIImage(named: "compose_keyboard_dot_normal"), forKey: "pageImage")
// 這種方式設置圖片, 放圖圖片觀察, 圖片右側被擠出來兩個尖角, 有兩個毛刺
// view.pageIndicatorTintColor = UIColor(patternImage: UIImage(named: "compose_keyboard_dot_normal")!)
// 設置選中圖片(KVC)
view.setValue(UIImage(named: "compose_keyboard_dot_selected"), forKey: "currentPageImage")
// view.currentPageIndicatorTintColor = UIColor(patternImage: UIImage(named: "compose_keyboard_dot_selected")!)
view.isUserInteractionEnabled = false
// 如果UIPageControl 總頁數為1的時候不顯示
view.hidesForSinglePage = true
return view
}()
9. 通過tag獲取view 的方法
open func viewWithTag(_ tag: Int) -> UIView?
10. 表情上屏
- Emoji表情就是16進制字符串,
- 圖片表情的發(fā)布上屏: 發(fā)布圖片表情, 其實就是發(fā)送圖片表情的描述信息到后臺, 后臺再給出圖片, 顯示在發(fā)布的微博中.
富文本中都可以正常顯示
.End