完整Swift項(xiàng)目(模擬微博)演練、五(.End)

我將整個(gè)項(xiàng)目的復(fù)習(xí)拆分成了幾個(gè)部分, 每完成一部分我都會(huì)提交一次代碼, 大家根據(jù)所復(fù)習(xí)到的部分, 檢出對(duì)應(yīng)的分支來看代碼就可以了, 代碼中的注釋已經(jīng)十分詳盡了, 有問題或者疑惑大家可以隨時(shí)留言溝通.
項(xiàng)目地址

知識(shí)點(diǎn)匯總

  1. iOS-自定義表情鍵盤
  2. iOS-通過上下文對(duì)圖片壓縮圖片
  3. Alamofire上傳文件
  4. 自定義UITextView 添加加在Vc 上, 通過對(duì)不同事件的監(jiān)聽來理解代理
  5. 通知(Notification)里面的數(shù)據(jù)類型 轉(zhuǎn)成結(jié)構(gòu)體或基本數(shù)據(jù)類型來使用
  6. UIStackView
  7. textView切換自定義鍵盤的邏輯分析 ->inputView
  8. UIPageControl設(shè)置默認(rèn)和選中顏色, 需要使用KVC
  9. 通過tag獲取view 的方法
  10. 表情上屏
4. 自定義UITextView 添加加在Vc 上, 通過對(duì)不同事件的監(jiān)聽來理解代理
  1. 代理是一對(duì)一的, 當(dāng)多處使用同一代理是, 就會(huì)出現(xiàn)問題, 也就是說會(huì)和遵循代理的先后順序有關(guān), 也就會(huì)出現(xiàn)邏輯問題, 導(dǎo)致代理使用不正確.
  2. 當(dāng)同意代理已經(jīng)被使用, 且同時(shí)需要進(jìn)行監(jiān)聽, 就可以代理+通知配合來使用.
    代理+通知
5. 通知(Notification)里面的數(shù)據(jù)類型 轉(zhuǎn)成結(jié)構(gòu)體或基本數(shù)據(jù)類型來使用
// 監(jiān)聽鍵盤的frame將要發(fā)生改變
@objc func keyboardWillChangeFrame(noti: Notification){
    // 判斷userInfo是否為nil 是否可以轉(zhuǎn)成字典
    guard let userInfo = noti.userInfo as? [String: Any] else{
        return
    }
    // 獲取鍵盤的frame
    // MARK: - 通知里面的數(shù)據(jù)類型轉(zhuǎn)結(jié)構(gòu)體, 一般使用NSValue做橋接
    let frame = (userInfo[UIResponder.keyboardFrameEndUserInfoKey] as! NSValue).cgRectValue
    // 獲取鍵盤動(dòng)畫時(shí)間
    // MARK: - 通知里面的數(shù)據(jù)轉(zhuǎn)換為double,  一般用NSNumber做橋接
    let duration = (userInfo[UIResponder.keyboardAnimationDurationUserInfoKey] as! NSNumber).doubleValue
}
6. UIStackView
  • UIStackView ios 9 以后的新控件
  • 是一個(gè)容器視圖
  • 特點(diǎn): 不必為子控件逐一設(shè)置約束
// 添加子控件
open func addArrangedSubview(_ view: UIView)
// addSubview(<#T##view: UIView##UIView#>) 添加不上
// 設(shè)置基本屬性, 布局方向、模式即可, 就會(huì)自動(dòng)為你布局
// 布局方式 - (垂直或者水平)
axis = .horizontal
// 填充方式 - 控件評(píng)分區(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 就代表你設(shè)置了自定義鍵盤 改成系統(tǒng)鍵盤
        self.composeTextView.inputView = nil
    }
    // 開啟第一響應(yīng)
    self.composeTextView.becomeFirstResponder()
    // 刷新
    self.composeTextView.reloadInputViews()
}
8. UIPageControl設(shè)置默認(rèn)和選中顏色, 需要使用KVC
    // 懶加載分頁指示器
    private lazy var pageControl: UIPageControl = {
        let view = UIPageControl()
        // 設(shè)置總頁數(shù)
        view.numberOfPages = 4
        // 當(dāng)前頁數(shù)
        view.currentPage = 1
        // 設(shè)置默認(rèn)圖片(使用KVC, 對(duì)兩個(gè)只讀屬性賦值)
        view.setValue(UIImage(named: "compose_keyboard_dot_normal"), forKey: "pageImage")
        // 這種方式設(shè)置圖片, 放圖圖片觀察, 圖片右側(cè)被擠出來兩個(gè)尖角, 有兩個(gè)毛刺
        //        view.pageIndicatorTintColor = UIColor(patternImage: UIImage(named: "compose_keyboard_dot_normal")!)
        // 設(shè)置選中圖片(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 總頁數(shù)為1的時(shí)候不顯示
        view.hidesForSinglePage = true
        return view
    }()
9. 通過tag獲取view 的方法
open func viewWithTag(_ tag: Int) -> UIView?
10. 表情上屏
  1. Emoji表情就是16進(jìn)制字符串,
  2. 圖片表情的發(fā)布上屏: 發(fā)布圖片表情, 其實(shí)就是發(fā)送圖片表情的描述信息到后臺(tái), 后臺(tái)再給出圖片, 顯示在發(fā)布的微博中.
  • 富文本中都可以正常顯示

.End

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 那一年,女孩兒以優(yōu)等生的成績(jī)?nèi)雽W(xué),班主任將她與男孩兒分配成同桌的位置,男孩兒很活潑,總喜歡打打鬧鬧,女孩兒仍然是...
    若何大大閱讀 235評(píng)論 0 1
  • 李賀有一句詩,“寶枕垂云選春夢(mèng)”。錢鐘書對(duì)這句詩極為激賞,認(rèn)為“選”字用得好,可以說是筆補(bǔ)造化。試想,夢(mèng)不由人,求...
    張舟子閱讀 485評(píng)論 0 1
  • 鴛鴦雙棲蝶雙飛 滿園春色惹人醉 悄悄問女兒 女兒賢不賢 蝴蝶美不美 鴛鴦雙棲蝶雙飛 滿園春色惹人醉 悄悄問女兒 女...
    紫燕_05db閱讀 307評(píng)論 0 0
  • 今天做的最用心的事就是用了幾段長(zhǎng)長(zhǎng)的話給我媽解釋即將參加的一個(gè)活動(dòng)。 夜晚給她說的時(shí)候只是想分享給他,因?yàn)槲椅缧菔?..
    微光渡閱讀 688評(píng)論 0 1

友情鏈接更多精彩內(nèi)容