如何在tableview swift的中心创建xib子视图

时间:2015-06-19 07:50:05

标签: swift tableview xib subview centralized

我有tableview,我为它创建了自定义xib uiview作为“detailview”。我想在点击到tableview单元格时在滚动区域的中心显示此详细视图。我可以显示这个视图但不能集中它。当我手动将值设置为帧时,子视图将位于中心(大约),但是当我点击位于底部的单元格时,子视图出现在页面顶部,当我滚动tableview时它也在移动。

请帮我在滚动区域的中心显示此视图并修复

这是我的代码;

详情视图:

class TopTenDetailView: UIView {

      var screenWidth:CGFloat = UIScreen.mainScreen().bounds.width*0.08
      var screenHeight :CGFloat = UIScreen.mainScreen().bounds.height*0.08

      class func instanceFromNib() -> UIView {
            return UINib(nibName: "TopTenDetail", bundle: nil).instantiateWithOwner(nil, options: nil)[0] as! UIView
      }

      override func awakeFromNib() {
            super.awakeFromNib()
            self.layer.cornerRadius=10

            let testFrame : CGRect = CGRectMake(screenWidth,screenHeight,320,480)
            self.frame = testFrame
            self.userInteractionEnabled=true
      }

      @IBAction func close(sender: UIButton) {
            self.hidden=true
      }
}

和TableViewController的方法;

      override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
             var detailView = TopTenDetailView.instanceFromNib
             self.view.addSubview(detailView())
      } 

1 个答案:

答案 0 :(得分:1)

这种设置的方式有很多问题,如果它真的按预期工作我会感到惊讶。

更好,更简单的设置使用OverFullScreen演示样式,如下所示:

  • 为您的详细信息视图创建单独的UIViewController,让我们称之为DetailViewController使用Interface Builder。确保将背景颜色设置为CLEAR
  • 连接" base"将UIViewController保存到UITableView并为segue命名的DetailViewController。我们称之为详细信息' detailSegue' ,基本上从一个视图控制器拖动到另一个。确保您没有从视图中拖动,而是从视图控制器顶部的黄色图标拖动。您已在Interface Builder中完成。

enter image description here enter image description here

好的,现在代码:

    // MARK : - UITableViewDelegate
    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
        self.performSegueWithIdentifier("detailSegue", sender: self)
    }

    // MARK: - segues
    override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
        if let vc = segue.destinationViewController as? UIViewController{
            vc.modalPresentationStyle = .OverFullScreen

        }
    }

OverFullScreen演示文稿样式使用正确的UIViewController模式segue,但在呈现的文字下留下展示UIViewController

然后,您可以使用Interface Builder和autolayout在DetailViewController上布局任何内容,而无需在运行时对布局进行hacky匹配计算。

希望它有所帮助!

enter image description here enter image description here