IOS:Swift-使用模态与单例创建通讯录

1.(新建文件)
ContactListTableViewController.swift:
2. 定义UITableView的视图 :class AppDelegate: UIResponder, UIApplicationDelegate {

var window: UIWindow?

//2
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
let firstLetter = "宋仲基".uppercasePinYinFirstLetter()
print(firstLetter!)
// print(ContactManager.sharecontactManager)
self.window = UIWindow(frame: UIScreen.main.bounds)
self.window?.backgroundColor = #colorLiteral(red: 0.2588235438, green: 0.7568627596, blue: 0.9686274529, alpha: 1)
self.window?.makeKeyAndVisible()
//创建导航视图控制器的根视图
let vc = ContactListTableViewController()
//2.创建导航视图控制器,并为她制定根视图控制器
let navigation = UINavigationController(rootViewController: vc)

    //3.将导航视图控制器设置为window的根视图控制器
    self.window?.rootViewController = navigation

    return true
}
3.  (新建添加联系人视图)   addContactViewController.swift

4.(新建详情界面)DetailViewController.swift
5.Contact.swift:)(新建类)
//5
class Contact: NSObject {

var name:String!
var phone:String!
var adress:String!
var image:UIImage?
init(name:String,phone:String,adress:String,image:UIImage?) {
    self.name = name
    self.phone = phone
    self.adress = adress
    self.image = image
}
override init() {
    super.init()
}

}

6.ContactManager.swift(新建单例类)
//7
#import “pinyin.h”(将拼音文件拖到工程里,在蓝色头文件Build Setting中搜索bridg找到Objective - C Bridging Header将新建文件Header的路径拖到后面的点击出来的空白处  然后引入头文件) 
ContactManager.swift:
class ContactManager: NSObject {
//8
    //创建一个单例属性
    static let share = ContactManager()
    //9
    //数组初始化
    var dataSource:[String:[Contact]] = Dictionary()
    //10
    //添加一个key的数组
    var keys:[String] = Array()
    //11
    //添加联系人的方法
    func addcontact(acontact:Contact) {
        //两种情况:联系人的分组存在,直接根据分组名取出
        let name = acontact.name
        let firstLetter = name?.uppercasePinYinFirstLetter()
        var group = dataSource[firstLetter!]
        if group == nil {
        //不存在
            //初始化数组
            group = Array<Contact>()
            group?.append(acontact)
            //添加value值
            keys.append(firstLetter!)
            keys.sort()
           
        }
        else{
        group?.append(acontact)
        }
        //对字典赋值
        dataSource[firstLetter!] = group
    }
//    12
    //返回分区
    func numberofSection()->Int{
       return dataSource.count
    }
    //13
    //返回分区中cell的个数
    func numberofRowsInSection(section:Int)->Int{
    let key = keys[section]
        let group = dataSource[key]
    return (group?.count)!
    }
    //14
    func contacshowByIndexPath(indexpath:IndexPath) -> Contact {
      let key = keys[indexpath.section]
        let group = dataSource[key]
        //返回要展示cell联系人对象的方法
        return group![indexpath.row]
    }
    //15
    func sectionHeaderTitle(section:Int) -> String {
        return keys[section]
    }
    //16
    func Sectiontitle()->[String]{
    return keys
    }

ContactListTableViewController.swift:
class ContactListTableViewController: UITableViewController {
//17
let systemCell = "cell"
override func viewDidLoad() {
super.viewDidLoad()
//18
self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: systemCell)

    self.SetnavigationItem()
    //30
     self.navigationItem.rightBarButtonItem = self.editButtonItem
}
//19
func SetnavigationItem(){
self.navigationController?.navigationItem.rightBarButtonItem = self.editButtonItem
    self.title = "通讯录"
//设置navigation的字体大小和颜色
    let dic = [NSFontAttributeName:UIFont.systemFont(ofSize: 30.0),NSForegroundColorAttributeName:UIColor.red]
    self.navigationController?.navigationBar.titleTextAttributes = dic
   
    self.navigationItem.leftBarButtonItem = UIBarButtonItem(barButtonSystemItem: .add, target: self, action: #selector(addContactAction))

}
//20
    override func viewWillAppear(_ animated: Bool) {
        self.tableView.reloadData()
    }

//21
    func addContactAction(){
    //模态添加联系人
        //22
        let addContactVC = addContactViewController()
       
        let rootVC = UINavigationController(rootViewController: addContactVC)
       
        self.present(rootVC, animated: true, completion: nil)
   
    }
   

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    // MARK: - Table view data source
//23
    override func numberOfSections(in tableView: UITableView) -> Int {
        // #warning Incomplete implementation, return the number of sections
        return ContactManager.share.numberofSection()
    }
    //24

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // #warning Incomplete implementation, return the number of rows
        return ContactManager.share.numberofRowsInSection(section: section)
    }

    /**/
    //25
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: systemCell, for: indexPath)
        cell.backgroundColor = UIColor.yellow
        //26
        let acontact = ContactManager.share.contacshowByIndexPath(indexpath: indexPath)
        //51
        //单例调用返回联系人的方法
        cell.imageView?.image = acontact.image
        cell.textLabel?.text = acontact.name
        cell.detailTextLabel?.text = acontact.phone
     

        return cell
    }
    //27
    override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
        return ContactManager.share.sectionHeaderTitle(section: section)
    }
    //28
    override func sectionIndexTitles(for tableView: UITableView) -> [String]? {
        return ContactManager.share.Sectiontitle()
    }
    //29
    override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        let detailVC = DetailViewController()
        //2...
        detailVC.acontact = ContactManager.share.contacshowByIndexPath(indexpath: indexPath)
        self.navigationController?.pushViewController(detailVC, animated: true)
    }
addContactViewController.swift:
class addContactViewController: UIViewController,UINavigationControllerDelegate,UIImagePickerControllerDelegate {
//31
    var photaView:UIImageView!
    var nameField:UITextField!
    var photoField:UITextField!
   
    var addressTexView:UITextView!
   
   
    override func viewDidLoad() {
        super.viewDidLoad()

        self.setupViews()
        self.SetNavigationItem()
            }
//32
    func setupViews()  {
        //图片
        photaView = UIImageView(frame: CGRect(x: 132, y: 80, width: 150, height: 150))
        photaView.backgroundColor = UIColor.cyan
        self.view.addSubview(photaView)
        //36
        let tap = UITapGestureRecognizer(target: self, action: #selector(tapAction))
        photaView.isUserInteractionEnabled = true
        photaView.addGestureRecognizer(tap)
        //姓名
        nameField = UITextField(frame: CGRect(x: 107, y: 240, width: 200, height: 40))
        nameField.placeholder = "输入姓名"
        nameField.borderStyle = .roundedRect
        self.view.addSubview(nameField)
        //电话
        photoField = UITextField(frame: CGRect(x: 107, y: 290, width: 200, height: 40))
        photoField.placeholder = "输入电话"
        photoField.borderStyle = .roundedRect
        self.view.addSubview(photoField)
        //住址
        addressTexView = UITextView(frame: CGRect(x: 107, y: 340, width: 200, height: 120))
        addressTexView.text = "地址:"
        addressTexView.layer.borderWidth = 1.0
        addressTexView.layer.borderColor = UIColor.red.cgColor
       
        self.view.addSubview(addressTexView)
    }
    //33
    func SetNavigationItem(){
        self.navigationItem.leftBarButtonItem = UIBarButtonItem(title: "取消", style: .done, target: self, action: #selector(cancelAction))
        self.navigationItem.rightBarButtonItem = UIBarButtonItem(title: "保存", style: .done, target: self, action: #selector(saveAction))
   
    }
    //34
    func cancelAction()   {
        self.dismiss(animated: true, completion: nil)
    }
    //35
    func saveAction()   {
        if nameField.text?.characters.count == 0 || photoField.text?.characters.count == 0{
        return print("姓名或电话为空")
        }
        let acontact = Contact()
        acontact.name = nameField.text
        acontact.phone = photoField.text
        acontact.adress = addressTexView.text
        acontact.image = photaView.image
        //添加联系人
        ContactManager.share.addcontact(acontact: acontact)
        self.dismiss(animated: true, completion: nil)
       
    }
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
    //37
    func tapAction(sender:UITapGestureRecognizer)  {
        let alertVC = UIAlertController(title: nil, message: nil, preferredStyle: .actionSheet)
        let action1 = UIAlertAction(title: "相机", style: .destructive, handler: {(sender:UIAlertAction) in
//        print("选择了相机")
            self.pickerImageFrontCamera()
        })
        let action2 = UIAlertAction(title: "相册", style: .destructive, handler: {(sender:UIAlertAction) in
//        print("选择了相册")
            self.pickerImageFromPhotoLibrary()
        })
        let action3 = UIAlertAction(title: "取消", style: .cancel, handler: nil)
        alertVC.addAction(action1)
        alertVC.addAction(action2)
        alertVC.addAction(action3)
        self.present(alertVC, animated: true, completion: nil)
       
    }
//38
    func pickerImageFrontCamera()  {
        let isCan = UIImagePickerController.isCameraDeviceAvailable(.rear)
        let iscan2 = UIImagePickerController.isCameraDeviceAvailable(.front)
        if !isCan || !iscan2{
        return print("摄像头不可用")
            }
        //选择图片视图控制器
        let pickerVC = UIImagePickerController()
        pickerVC.sourceType = .camera
        pickerVC.allowsEditing = true
        pickerVC.delegate = self
        self.present(pickerVC, animated: true, completion: nil)
       
    }
    //39
    func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
        self.photaView.image = info[UIImagePickerControllerEditedImage] as! UIImage?
        //将模态视图收回
        picker.dismiss(animated: true, completion: nil)
    }
    //40
    func pickerImageFromPhotoLibrary(){
    let pickerVC = UIImagePickerController()
        pickerVC.sourceType = .photoLibrary
        pickerVC.allowsEditing = true
        pickerVC.delegate = self
        self.present(pickerVC, animated: true, completion: nil)
   
    }
ContactManager.swift:
  //41
    //删除一个分区或者cell的分区属
    func deleteRowwOrSection(indexpath:IndexPath) ->Bool{
        let key = keys[indexpath.section]
        let group = dataSource[key]
        if group?.count == 1 {
        return true
        }
        //删除一个
        return false
    }
   //42
    //删除分区的方法
    func deleteAsection(indexpath:IndexPath){
    let key = keys[indexpath.section]
//        let group = dataSource[key]
       dataSource.removeValue(forKey: key)
    keys.remove(at: indexpath.section)
    }
    //43
    //删除cell的方法
    func deleteACell(indexpath:IndexPath){
    let key = keys[indexpath.section]
       var group = dataSource[key]
        group?.remove(at: indexpath.row)
        dataSource[key] = group
   
    }
    //46
    func moveContact(fromIndex:IndexPath,toIndex:IndexPath){
    let key = keys[fromIndex.section]
        var group = dataSource[key]
       
        let acontact = group?[fromIndex.section]
       
        group?.remove(at: fromIndex.row)
        group?.insert(acontact!, at: toIndex.row)
        dataSource[key] = group
    }

 ContactListTableViewController.swift“:
  /*  */
    //44
    // Override to support conditional editing of the table view.
    override func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
        // Return false if you do not want the specified item to be editable.
        return true
    }
 

    /**/
    //45
    // Override to support editing the table view.
    override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
        if editingStyle == .delete {
        let result = ContactManager.share.deleteRowwOrSection(indexpath: indexPath)
            if result{
            ContactManager.share.deleteAsection(indexpath: indexPath)
                let set = NSIndexSet(index: indexPath.section)
                tableView.deleteSections(set as IndexSet, with: .left)
            }else{
            ContactManager.share.deleteACell(indexpath: indexPath)
                tableView.deleteRows(at: [indexPath], with: .right)
            }
        }
    }
   

    /* */
    //47
    // Override to support rearranging the table view.
    override func tableView(_ tableView: UITableView, moveRowAt fromIndexPath: IndexPath, to: IndexPath) {

        ContactManager.share.moveContact(fromIndex: fromIndexPath, toIndex: to)
    }
  

    /**/
    //48
    // Override to support conditional rearranging of the table view.
    override func tableView(_ tableView: UITableView, canMoveRowAt indexPath: IndexPath) -> Bool {
        // Return false if you do not want the item to be re-orderable.
        return true
    }
    //49
    override func tableView(_ tableView: UITableView, targetIndexPathForMoveFromRowAt sourceIndexPath: IndexPath, toProposedIndexPath proposedDestinationIndexPath: IndexPath) -> IndexPath {
        if sourceIndexPath.section == proposedDestinationIndexPath.section{
        return proposedDestinationIndexPath
        }
        return sourceIndexPath
    }

DetailViewController.swift:(界面传值)
  //50
    var acontact:Contact?
ContactListTableViewController.swift:
 //25
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: systemCell, for: indexPath)
        cell.backgroundColor = UIColor.yellow
        //26
        let acontact = ContactManager.share.contacshowByIndexPath(indexpath: indexPath)
        //51
        //单例调用返回联系人的方法
        cell.imageView?.image = acontact.image
        cell.textLabel?.text = acontact.name
        cell.detailTextLabel?.text = acontact.phone
     

        return cell
    }
DetailViewController.swift:
//52
    func setValueForSubView() {
        nameLabel.text = acontact?.name
        photoView.image = acontact?.image
        phoneLabel.text = acontact?.phone
        addressLabel.text = acontact?.adress
    }


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

推荐阅读更多精彩内容