完整Swift项目(模拟微博)演练、五(.End)

我将整个项目的复习拆分成了几个部分, 每完成一部分我都会提交一次代码, 大家根据所复习到的部分, 检出对应的分支来看代码就可以了, 代码中的注释已经十分详尽了, 有问题或者疑惑大家可以随时留言沟通.
项目地址

知识点汇总

  1. iOS-自定义表情键盘
  2. iOS-通过上下文对图片压缩图片
  3. Alamofire上传文件
  4. 自定义UITextView 添加加在Vc 上, 通过对不同事件的监听来理解代理
  5. 通知(Notification)里面的数据类型 转成结构体或基本数据类型来使用
  6. UIStackView
  7. textView切换自定义键盘的逻辑分析 ->inputView
  8. UIPageControl设置默认和选中颜色, 需要使用KVC
  9. 通过tag获取view 的方法
  10. 表情上屏
4. 自定义UITextView 添加加在Vc 上, 通过对不同事件的监听来理解代理
  1. 代理是一对一的, 当多处使用同一代理是, 就会出现问题, 也就是说会和遵循代理的先后顺序有关, 也就会出现逻辑问题, 导致代理使用不正确.
  2. 当同意代理已经被使用, 且同时需要进行监听, 就可以代理+通知配合来使用.
    代理+通知
5. 通知(Notification)里面的数据类型 转成结构体或基本数据类型来使用
// 监听键盘的frame将要发生改变
@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
// 填充方式 - 控件评分区域
distribution = .fillEqually
7. textView切换自定义键盘的逻辑分析 ->inputView
// 切换键盘 -> 表情键盘/文字键盘
func switchKeyboard(){
    // 如果inputView == nil 就代表是系统键盘 改成自定义键盘
    if self.composeTextView.inputView == nil {
        self.composeTextView.inputView = self.emoticonKeyboardView
    }else {
        // 如果inputView != nil 就代表你设置了自定义键盘 改成系统键盘
        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. 表情上屏
  1. Emoji表情就是16进制字符串,
  2. 图片表情的发布上屏: 发布图片表情, 其实就是发送图片表情的描述信息到后台, 后台再给出图片, 显示在发布的微博中.
  • 富文本中都可以正常显示

.End

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,496评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,407评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,632评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,180评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,198评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,165评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,052评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,910评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,324评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,542评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,711评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,424评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,017评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,668评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,823评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,722评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,611评论 2 353

推荐阅读更多精彩内容

  • 那一年,女孩儿以优等生的成绩入学,班主任将她与男孩儿分配成同桌的位置,男孩儿很活泼,总喜欢打打闹闹,女孩儿仍然是...
    若何大大阅读 205评论 0 1
  • 李贺有一句诗,“宝枕垂云选春梦”。钱钟书对这句诗极为激赏,认为“选”字用得好,可以说是笔补造化。试想,梦不由人,求...
    张舟子阅读 415评论 0 1
  • 鸳鸯双栖蝶双飞 满园春色惹人醉 悄悄问女儿 女儿贤不贤 蝴蝶美不美 鸳鸯双栖蝶双飞 满园春色惹人醉 悄悄问女儿 女...
    紫燕_05db阅读 283评论 0 0
  • 今天做的最用心的事就是用了几段长长的话给我妈解释即将参加的一个活动。 夜晚给她说的时候只是想分享给他,因为我午休收...
    微光渡阅读 505评论 0 1