我有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匹配计算.
希望能帮助到你!
