0

我正在为漫画制作 ipad 应用程序,但我无法让滚动视图正常工作。我需要它来做:

  • 捏缩放
  • 回转
  • 双击并按漫画移动

这是我想要获得的示例http://vimeo.com/16073699 (Second 35 +-)

现在我有捏缩放,但我可以让滚动视图旋转和居中图像。

这是我的控制器代码:

#define ZOOM_VIEW_TAG 100
#define ZOOM_STEP 2
#define PAGE_TIME 10

- (void)viewDidLoad{
    [super loadView];

    self.myImage.image = [UIImage imageNamed:@"Tira01.jpg"];

    [self.myImage setTag:ZOOM_VIEW_TAG];

    UISwipeGestureRecognizer *recognizer;


    recognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(Tap)];
    [(UITapGestureRecognizer *)recognizer setNumberOfTouchesRequired:1];
    [(UITapGestureRecognizer *)drecognizer setNumberOfTapsRequired:1];
    [[self myImage] addGestureRecognizer:recognizer];
    [recognizer release];

    self.drecognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleDoubleTap:)];
    [(UITapGestureRecognizer *)drecognizer setNumberOfTouchesRequired:1];
    [(UITapGestureRecognizer *)drecognizer setNumberOfTapsRequired:2];
    [[self myImage] addGestureRecognizer:drecognizer];
    [drecognizer release];


}

- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView {
    return [myScrollView viewWithTag:ZOOM_VIEW_TAG];
}

- (void)handleDoubleTap:(UIGestureRecognizer *)gestureRecognizer {
    UIInterfaceOrientation currentOrientation = [[UIDevice currentDevice] orientation];
    if(!self.zoomed)
    {
        // double tap zooms in
        float newScale = [self.myScrollView zoomScale] * ZOOM_STEP;
        CGRect zoomRect = [self zoomRectForScale:newScale withCenter:[gestureRecognizer locationInView:gestureRecognizer.view]];
        [self.myScrollView zoomToRect:zoomRect animated:YES];
        self.zoomed = YES;


    }
    else {
        float newScale = [self.myScrollView zoomScale] / ZOOM_STEP;
        CGRect zoomRect = [self zoomRectForScale:newScale withCenter:[gestureRecognizer locationInView:gestureRecognizer.view]];
        [self.myScrollView zoomToRect:zoomRect animated:YES];
        self.zoomed = NO;        
    }

}


- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation{
    return YES;
}


- (CGRect)zoomRectForScale:(float)scale withCenter:(CGPoint)center {

    CGRect zoomRect;

    // the zoom rect is in the content view's coordinates. 
    //    At a zoom scale of 1.0, it would be the size of the imageScrollView's bounds.
    //    As the zoom scale decreases, so more content is visible, the size of the rect grows.
    zoomRect.size.height = [self.myScrollView frame].size.height / scale;
    zoomRect.size.width  = [self.myScrollView frame].size.width  / scale;

    // choose an origin so as to get the right center.
    zoomRect.origin.x    = center.x - (zoomRect.size.width  / 2.0);
    zoomRect.origin.y    = center.y - (zoomRect.size.height / 2.0);

    return zoomRect;
}

在界面生成器中,我有:

-> UIView(ScaleToFill 模式)

--> UIScrollView(ScaleToFill 模式)

---> UIImageView(AspectFit 模式)

我不知道我做错了什么,但我要疯了:(

4

1 回答 1

0

关于以内容为中心的 UIScrollView,我在这里可能错了,但 UIScrollView 不会自动这样做。

在我的应用程序中,我通过实际移动 scrollView 中的内容以使其居中来手动执行此操作。
就像下面代码的快速解释一样,如果内容(图像)框架小于滚动视图的边界,则水平和垂直调整内容的位置。

下面的代码来自我从 UIScrollView 派生的类。如果您使用的是默认 UIScrollView,则可以在父 UIView 中使用此代码。



- (void)layoutSubviews 
{
    [super layoutSubviews];

    if (![self centersContent]) 
    {
        return;
    }

    // center the image as it becomes smaller than the size of the screen       
    CGSize boundsSize = self.bounds.size;
    CGRect frameToCenter = imageView.frame;

    // center horizontally
    if (frameToCenter.size.width < boundsSize.width)
        frameToCenter.origin.x = (boundsSize.width - frameToCenter.size.width) / 2;
    else
        frameToCenter.origin.x = 0;

    // center vertically
    if (frameToCenter.size.height < boundsSize.height)
        frameToCenter.origin.y = (boundsSize.height - frameToCenter.size.height) / 2;
    else
        frameToCenter.origin.y = 0;

    imageView.frame = frameToCenter;  
}

于 2011-03-08T14:10:45.590 回答