美文网首页
完整Swift项目(模拟微博)演练、五(.End)

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

作者: 下班不写程序 | 来源:发表于2020-04-14 21:32 被阅读0次

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

    知识点汇总

    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

    相关文章

      网友评论

          本文标题:完整Swift项目(模拟微博)演练、五(.End)

          本文链接:https://www.haomeiwen.com/subject/jjutvhtx.html