我有tableview,我为它创建了自定义xib uiview作为“detailview”.我想在点击到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()) }这种设置的方式有很多问题,如果它真的按预期工作我会感到惊讶.
一个更好,更简单的设置使用OverFullScreen演示样式,它是这样的:
>为您的详细信息视图创建一个单独的UIViewController,让我们称之为DetailViewController使用Interface Builder.确保将背景颜色设置为CLEAR
>将来自“基础”UIViewController的segue连接起来,将UITableView保存到DetailViewController并为segue命名.我们称之为’detailSegue’,基本上是从一个视图控制器拖到另一个视图控制器.确保您没有从视图中拖动,而是从视图控制器顶部的黄色图标拖动.您已在Interface Builder中完成.
好的,现在代码:
// 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下显示UIViewController.
然后,您可以使用Interface Builder和autolayout在DetailViewController上布置任何您想要的内容,而无需在运行时对布局进行hacky匹配计算.
希望能帮助到你!