iMessages聊天界面

2022-01-05  本文已影响0人  gale_小米
import UIKit
import AddressBookUI  //联系人
import ContactsUI  //9.0以后推荐使用

class ViewController: UIViewController,UITextViewDelegate, UINavigationControllerDelegate,CNContactPickerDelegate,ABPeoplePickerNavigationControllerDelegate,
                      UIImagePickerControllerDelegate,UITableViewDelegate,UITableViewDataSource{

    @IBOutlet weak var contentText: UITextView!
    //底部view的高度约束
    
    @IBOutlet weak var bottomHeightLayout: NSLayoutConstraint!
    //UITextView的高度约束
    @IBOutlet weak var textHeightLayout: NSLayoutConstraint!
    //底部view的底部到self.view的约束
    @IBOutlet weak var buttomViewLayout2: NSLayoutConstraint!
    
    @IBOutlet weak var addImageView: UIImageView!
    
    @IBOutlet weak var sendMessageView: UIImageView!
    
    @IBOutlet weak var contacts: UITextField!
    
    @IBOutlet weak var messageTable: UITableView!
//    var image: UIImageView = UIImageView(frame: CGRect(x: 100, y: 100, width: 100, height: 100))
    
    var meassageData:Array<MessageModel>?
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        contentText.delegate = self
        meassageData = Array()
        
//        self.navigationController?.setToolbarHidden(false, animated: false)
//        let rightButtom = UIBarButtonItem(barButtonSystemItem: UIBarButtonItem.SystemItem.edit, target: self, action: #selector(self.Edit))
//        self.navigationItem.rightBarButtonItem = rightButtom
//        self.title = "消息"
//        self.navigationController?.navigationBar.backgroundColor = UIColor.white
        //隐藏
        self.navigationController?.navigationBar.isHidden = true
        //添加手势
        let addTapGesture = UITapGestureRecognizer(target: self, action: #selector(self.addImageAction(gest:)))
        self.addImageView.isUserInteractionEnabled = true
        self.addImageView.addGestureRecognizer(addTapGesture)
        let sendMessageGesture = UITapGestureRecognizer(target: self, action: #selector(self.sendMessageAction(gest:)))
        self.sendMessageView.isUserInteractionEnabled = true
        self.sendMessageView.addGestureRecognizer(sendMessageGesture)
        
        //添加通知
        NotificationCenter.default.addObserver(self, selector: #selector(self.keyboardShow(noti:)), name: ViewController.keyboardWillShowNotification, object: nil)
        NotificationCenter.default.addObserver(self, selector: #selector(self.keyboardHide(noti:)), name: ViewController.keyboardWillHideNotification, object: nil)
        self.messageTable.separatorStyle = .none
        self.messageTable.delegate = self
        self.messageTable.dataSource = self
        self.messageTable.reloadData()
        
    }
    
    
    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }
    
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return meassageData!.count
    }
    
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        
        let cell = Bundle.main.loadNibNamed("MessageTableViewCell", owner: nil, options: nil)?.first as! MessageTableViewCell
        let model = self.meassageData![indexPath.row] as MessageModel
        if model.icon == nil {
            cell.messageContent.text = model.message
            cell.messageImage.isHidden = true
            cell.messageContent.isHidden = false
        }else {
            cell.messageImage.isHidden = false
            cell.messageContent.isHidden = true
            cell.messageImage.image = model.icon
        }
        return cell
    }
    
    
    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        
        let model = self.meassageData![indexPath.row] as MessageModel
        if model.icon == nil {
            var size : CGSize
            let tmpSize = CGSize(width: UIScreen.main.bounds.width - 30, height: 0)
            let messageStr:NSString = model.message! as NSString
            size = messageStr.boundingRect(with: tmpSize, options: NSStringDrawingOptions.usesLineFragmentOrigin, attributes: [NSAttributedString.Key.font : UIFont.systemFont(ofSize: 17)], context: nil).size
            return size.height + 30
        }else{
            return 152
        }
    }
    
    
    
    //添加联系人
    @IBAction func addContacts(_ sender: UIButton) {
        if #available(iOS 9.0, *) {
            print("systemVersion=\(UIDevice.current.systemVersion)")
            let contactController2 = CNContactPickerViewController()
            contactController2.displayedPropertyKeys = [CNContactPhoneNumbersKey]
            contactController2.delegate = self
            self.present(contactController2, animated: true)
        }else{
            let contactController = ABPeoplePickerNavigationController()
            contactController.peoplePickerDelegate = self
            self.present(contactController, animated: true)
        }
        
    }
    
    
    func contactPicker(_ picker: CNContactPickerViewController, didSelect contacts: [CNContact]) {
        let phoneNumbers = contacts[contacts.startIndex].phoneNumbers
        let numStr = phoneNumbers[phoneNumbers.startIndex].value.stringValue
        self.contacts.text = numStr
    }
    
    //获取联系人信息
    func peoplePickerNavigationController(_ peoplePicker: ABPeoplePickerNavigationController, didSelectPerson person: ABRecord) {
        let unmInfo = ABRecordCopyValue(person, kABPersonPhoneProperty)
        let numRef:ABMultiValue = Unmanaged.fromOpaque(unmInfo!.toOpaque()).takeUnretainedValue()
        let num = ABMultiValueCopyValueAtIndex(numRef, 0)
        let numStr:String = Unmanaged<AnyObject>.fromOpaque(num!.toOpaque()).takeUnretainedValue() as! String
        self.contacts.text = numStr
    }
    
    //添加图片
    @objc func addImageAction( gest : UITapGestureRecognizer){
        print("addImageAction")
        let pic = UIImagePickerController()
        pic.delegate = self
        self.present(pic, animated: true, completion: nil)
    }
    
    func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
        let model = MessageModel(_icon: info[UIImagePickerController.InfoKey.originalImage] as! UIImage)
        self.meassageData!.append(model)
        picker.dismiss(animated: true, completion: nil)
        self.messageTable.reloadData()
    }
    
    @objc func sendMessageAction( gest : UITapGestureRecognizer){
        let message:String = self.contentText.text
        let model = MessageModel(_message: message)
        self.meassageData?.append(model)
        self.contentText.text = ""
        self.textHeightLayout.constant = 56
        self.bottomHeightLayout.constant = 63
        self.buttomViewLayout2.constant = 0
        self.contentText.resignFirstResponder()
        UIView.animate(withDuration: 0.3) {
            self.view.layoutIfNeeded()
            self.messageTable.reloadData()
        }
    }
    
    
    
    @objc func Edit(){
        print("Edit")
        let viewCon = ViewController2()
        self.navigationController?.pushViewController(viewCon, animated: true)
    }
    
    
    //监听软键盘弹出消息
    @objc func keyboardShow(noti : Notification){
        let info = noti.userInfo
        let heightValue = info?[ViewController.keyboardFrameEndUserInfoKey] as! NSValue
        let height = heightValue.cgRectValue.height
        var time: TimeInterval = 0
        let timeValue = info?[ViewController.keyboardAnimationDurationUserInfoKey] as! NSNumber
        timeValue.getValue(&time)
        self.buttomViewLayout2.constant = height
        UIView.animate(withDuration: time) {
            self.view.layoutIfNeeded()
        }
    }
    
    //隐藏软键盘
    @objc func keyboardHide(noti : Notification){
        let info = noti.userInfo
        var time: TimeInterval = 0
        let timeValue = info?[ViewController.keyboardAnimationDurationUserInfoKey] as! NSNumber
        timeValue.getValue(&time)
        self.buttomViewLayout2.constant = 0
        UIView.animate(withDuration: time) {
            self.view.layoutIfNeeded()
        }
    }
    
    //动态设置view的约束
    func textViewDidChange(_ textView: UITextView) {
        //其中常量值 56 63 取自storyboard排版里面的值
        if textView.contentSize.height <= 56 {
            self.textHeightLayout.constant = 56
            self.bottomHeightLayout.constant = 63
        }else if(textView.contentSize.height < 100){
            self.textHeightLayout.constant = textView.contentSize.height
            self.bottomHeightLayout.constant = textView.contentSize.height + 7
        }else{
            self.textHeightLayout.constant = 100
            self.bottomHeightLayout.constant = 107
        }
        UIView.animate(withDuration: 0.3) {//用于更新页面布局,可以用于自动布局的动画
            self.view.layoutIfNeeded()
        }
    }
    
    
    
    func textViewShouldBeginEditing(_ textView: UITextView) -> Bool {
        return true
    }
    
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        contentText.resignFirstResponder()
    }

}

  1. model
import Foundation
import UIKit

class MessageModel : NSObject{
    var icon : UIImage?
    var message : String?
    
    init( _icon : UIImage) {
        self.icon = _icon
    }
    
    init( _message : String) {
        self.message = _message
    }
}
上一篇 下一篇

猜你喜欢

热点阅读