如何实现iPhone Contact应用程序的详细信息

时间:2009-10-06 23:33:42

标签: iphone ios cocoa-touch uikit abpersonviewcontroller

我想实现类似于Apple自己的联系人应用程序的详细视图的视图,其中显示名称,电话号码,备注等,以及其编辑模式。

您能剖析整个视图是如何完成的吗?该视图是使用UITableView还是UIScrollView完成的?

5 个答案:

答案 0 :(得分:11)

联系人详细信息屏幕实际上很容易模仿。

从UITableView开始,并为其提供UITableViewDataSource和UITableViewDelegate。您需要为要呈现的所有数据提供部分。这意味着1表示自定义页眉,1表示自定义页脚(按钮/操作),大约6个左右的数据部分(一个部分用于电话号码,另一个部分用于电子邮件地址,等等)

在每个部分的内部,需要从数据源提供许多行,以指示该部分的数据量。对于每一行,UITableViewCell可用于显示实际的联系人数据(传真标签/传真号码值等)。如果你愿意,你可以获得幻想,但似乎没有必要。对于像铃声这样的东西,您需要指定披露指标。

对于标题,您需要一个UIImageView和一个UILabel,对于页脚,您需要一些UIButtons。您可以在InterfaceBuilder中创建UITableViewCell的子级,并在其中包含这些视图,并将其连接起来。您可以使用NSBundle从尚未加载的其他xib加载视图。

另一种方法是在运行时动态生成UI小部件而不使用xib。这一切都取决于你宁愿管理什么(代码或xibs),对我来说,无论是哪种方式,它似乎都是相同的努力量。如果你还没有,我强烈建议你阅读table view programming guide

答案 1 :(得分:3)

或者您可以使用Apple自己的ABPersonViewController:

http://developer.apple.com/library/ios/#documentation/AddressBookUI/Reference/ABPersonViewController_Class/Reference/Reference.html

allowsEditing属性指定用户是否可以编辑此人的信息。

答案 2 :(得分:1)

我的实现使用带有自定义标题的UITableView(用于“添加照片”和编辑等效名称)和一个自定义页脚(使用UISegmentedControl hack作为一个大按钮),用于“删除”等效项。

答案 3 :(得分:0)

您可以使用F-Script来探索此问题。这是浏览地址簿时来自F脚本浏览器的screenshot。基本上,它看起来像很多自定义视图,它们都从NSView继承。

自己动手:

  1. 从上面的链接下载F-Script
  2. 按照extras / F-Script Anywhere目录中的说明附加到地址簿
  3. 选择F-Script - >从“地址簿”菜单中打开对象浏览器
  4. 点击选择查看
  5. 突出显示您要浏览的地址簿视图,然后单击它。
  6. 浏览您心中的内容。

答案 4 :(得分:0)

为了向您展示,您可以为此目的创建UITableViewController的子类,然后为了实现类似于Contacts应用程序的编辑模式:

  1. 添加属性以存储对“取消”按钮的引用。

    var cancelButton: UIBarButtonItem!
    
  2. 在ViewDidLoad()中,将编辑按钮添加到导航栏作为右项,并准备取消按钮以稍后将其添加为左项。

    self.navigationItem.rightBarButtonItem = self.editButtonItem()
    self.cancelButton = UIBarButtonItem(title: "Cancel", style: .Plain, target: self, action: "cancelPressed:")
    
  3. 根据编辑标记,覆盖setEditing(_:animated :)方法,将单元格设置为编辑/预览模式,并在导航栏上显示/隐藏“取消”按钮。

    override func setEditing(editing: Bool, animated: Bool) {
        super.setEditing(editing, animated: true)
    
        if editing {
            // Set up cells and prepare for Edit mode here
            self.navigationItem.setLeftBarButtonItem(self.cancelButton, animated: true)
        } else {
            // Set up cells and prepare for Preview mode here
            self.navigationItem.setLeftBarButtonItem(nil, animated: true)
        }
    }
    
  4. 覆盖UITableViewDelegate的tableView(_:editingStyleForRowAtIndexPath :)和tableView(_:shouldIndentWhileEditingRowAtIndexPath :)方法,以便在编辑模式下配置行样式和缩进。

  5. 按下取消时,实施cancelPressed方法退出编辑模式。

    func cancelPressed(button: UIBarButtonItem) {
        self.setEditing(false, animated: true)
    }
    
  6. 我知道这个问题已经过时了,但有人可能会觉得有用。