导航控制器中的UIScrollView

时间:2013-08-02 10:17:43

标签: ios cocoa-touch uiscrollview

我正在尝试让UIScrollView在我的培训应用中运行。滚动本身工作正常,但如果我使用导航控制器,SVC的内容区域会向下移动导航条高度。

without nav controller with nav controller

青色区域是UIScrollView背景。 contentSize设置正确,只允许左右滑动页面。这就是我添加图像以滚动视图的方式

CGSize scrollViewSize = self.scrollView.frame.size;

UIImage * image = [UIImage imageWithContentsOfFile:[cachesDirectory stringByAppendingFormat:@"/%@", fileName]];

CGFloat imageOriginalWidth = image.size.width;
CGFloat imageOriginalHeight = image.size.height;

CGFloat imageOffsetX = 10;

CGFloat imageDisplayedWidth = scrollViewSize.width - (2 * imageOffsetX);
CGFloat imageDisplayedHeight = imageOriginalHeight / imageOriginalWidth * imageDisplayedWidth;

CGFloat imageOffsetY = (scrollViewSize.height - imageDisplayedHeight) / 2;

CGRect viewFrame = CGRectMake(scrollViewSize.width * (filmIndex) + imageOffsetX,
                              imageOffsetY,
                              imageDisplayedWidth,
                              imageDisplayedHeight);

contentAreaHeight = imageDisplayedHeight;

UIImageView * view = [[UIImageView alloc] initWithFrame:viewFrame];
view.backgroundColor = [UIColor greenColor];
view.image = image;
view.contentMode = UIViewContentModeScaleAspectFit;
view.tag = filmIndex;

[self.scrollView addSubview:view];

这就是我设置内容大小和偏移的方式

self.scrollView.contentSize = CGSizeMake(scrollViewSize.width * ([self.filmsData count]),
                                         contentAreaHeight);
self.scrollView.contentOffset = CGPointMake(scrollViewSize.width * [self.filmsData count] / 2,
                                            0);

我的代码出了什么问题?如何在使用导航控制器时将图像垂直居中?

2 个答案:

答案 0 :(得分:1)

您可以在-viewDidLoad中创建和添加视图,但是您需要使用自动调整大小或手动设置-viewWillAppear:中的帧或自我调整大小后触发的其他方法。< / p>

Bounds and Frame size in viewDidLoad

答案 1 :(得分:0)

首先,这是什么?

scrollViewSize

您已在2-3个地方使用过它,例如:

CGFloat imageDisplayedWidth = scrollViewSize.width - (2 * imageOffsetX);

如果它是你的scrollView框架的大小,那么你最好使用

self.scrollView.frame.size

否则..我无法得到你......

其次,当您的UINavigationBar对象进入视图时,它会“占用”屏幕的某些空间。默认情况下,它的高度为44像素(非视网膜)。

由于这个原因,您的其他观点和子视图也会向下移动。即使您的主视图也会向下移动44个点,因此,这就是为什么您的整个视图以及您的scrollView及其上的图像向下移动的原因。但是,你的视图高度仍然是460!(在iPhone 4,4S中),并且额外的44点超出了屏幕的界限......呃。从屏幕的底部出来(所以!它应该从手机的底部出来;)!!)所以你也必须注意它...

我建议你做的是 将scrollView的框架设置为降低的高度:将这些行添加到代码中...更好地在方法的开头添加它:

`self.scrollview.frame=CGRectMake(0,0,320,self.view.frame.size.height-44)

// if it is the default navigation bar.. otherwise you can subtract that height which you created in your custom bar

根据您的代码,所有其他事情应该可以正常工作.. 请给出反馈..如果您使用它:]