缩放超级视图时如何防止按钮调整大小?

时间:2016-02-08 10:40:52

标签: ios objective-c iphone uigesturerecognizer

我在一个视图中添加了多个手势,视图在视图的一角有一个关闭按钮,一切正常,但当我缩放时,视图关闭按钮也缩放了该视图,现在我想要缩放只有那个视图不是那个关闭按钮,请建议我怎么做?

见下图供参考。

enter image description here

捏缩放代码

   -(void)addStickersWithView:(UIView*)view image:(UIImage*)image{

    CGPoint center = self.imgPhoto.center;
    UIImageView *imgView = [[UIImageView alloc] initWithImage:image];
    UIRotationGestureRecognizer *rotationGesture = [[UIRotationGestureRecognizer alloc] initWithTarget:self action:@selector(rotatePiece:)];
    [imgView setContentMode:UIViewContentModeScaleToFill];
    UIView *viewZoom = [[UIView alloc] initWithFrame:CGRectMake(center.x-45,center.y-45, 90, 90)];
   // [viewZoom setBackgroundColor:[UIColor redColor]];
    imgView.frame = CGRectMake(5, 5, CGRectGetWidth(viewZoom.frame)-10, CGRectGetHeight(viewZoom.frame)-10);
    [viewZoom addSubview:imgView];
    [viewZoom addGestureRecognizer:rotationGesture];

    UIPinchGestureRecognizer *pinchGesture = [[UIPinchGestureRecognizer alloc] initWithTarget:self action:@selector(scalePiece:)];
    [pinchGesture setDelegate:self];
    [viewZoom addGestureRecognizer:pinchGesture];

    UIPanGestureRecognizer *panGesture = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(moveImage:)];
    [panGesture setMinimumNumberOfTouches:1];
    [panGesture setMaximumNumberOfTouches:1];
    [viewZoom addGestureRecognizer:panGesture];

    UIButton *btnCloseSticker = [UIButton buttonWithType:UIButtonTypeCustom];

    [btnCloseSticker setBounds:CGRectMake(0, 0, 30,30)];
    [btnCloseSticker setImage:[UIImage imageNamed:@"close1.png"] forState:UIControlStateNormal];
    [btnCloseSticker addTarget:self action:@selector(buttonPressed:) forControlEvents:UIControlEventTouchUpInside];
    self.stickerCount++;
    btnCloseSticker.tag = self.stickerCount;
    UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(TapToShowClose:)];
    tapGesture.numberOfTapsRequired = 2;
    [viewZoom addGestureRecognizer:tapGesture];
    viewZoom.layer.borderColor = [UIColor whiteColor].CGColor;
    viewZoom.layer.borderWidth = 3.0;
    viewZoom.tag = self.stickerCount+kTagBorder;
    [viewZoom addSubview:btnCloseSticker];

    [view addSubview:viewZoom];
}

-(void)hideShowBorderCloseButton{
    int borderCount = self.stickerCount-kTagBorder;
    for(int i=1;i<=borderCount;i++){
        UIView *view = [self.viewStickers viewWithTag:i+kTagBorder];
        UIView *view1 = [self.viewStickers viewWithTag:i+(kTagBorder*2)];
        view.hidden = YES;
        view1.layer.borderWidth = 0.0;
    }
}

-(void)buttonPressed:(id)sender{
    UIView *view = [sender superview];
    [view removeFromSuperview];
    self.stickerCount--;
}

- (void)scalePiece:(UIPinchGestureRecognizer *)gestureRecognizer {
    if([gestureRecognizer state] == UIGestureRecognizerStateBegan) {
        // Reset the last scale, necessary if there are multiple objects with different scales
        lastScale = [gestureRecognizer scale];
    }
    UIButton *btn = [self.viewStickers viewWithTag:gestureRecognizer.view.tag-kTagBorder];
    if ([gestureRecognizer state] == UIGestureRecognizerStateBegan ||
        [gestureRecognizer state] == UIGestureRecognizerStateChanged) {

        CGFloat currentScale = [[[gestureRecognizer view].layer valueForKeyPath:@"transform.scale"] floatValue];

        // Constants to adjust the max/min values of zoom
        const CGFloat kMaxScale = 3.0;
        const CGFloat kMinScale = 1.0;

        CGFloat newScale = 1 -  (lastScale - [gestureRecognizer scale]);
        newScale = MIN(newScale, kMaxScale / currentScale);
        newScale = MAX(newScale, kMinScale / currentScale);
        CGAffineTransform transform = CGAffineTransformScale([[gestureRecognizer view] transform], newScale, newScale);
        [gestureRecognizer view].transform = transform;

        lastScale = [gestureRecognizer scale];  // Store the previous scale factor for the next pinch gesture call
    }
}

-(void)TapToShowClose:(UITapGestureRecognizer *)gestureRecognizer{
    //int borderCount = self.stickerCount-kTagBorder;

    UIView *view = gestureRecognizer.view; //cast pointer to the derived class if needed
    view.layer.borderWidth = 2.0;
    UIView *view1 = [self.viewStickers viewWithTag:view.tag-kTagBorder];
    [(UIButton*)view1 setImage:[UIImage imageNamed:@"close1.png"] forState:UIControlStateNormal];
    [view1 setBounds:CGRectMake(0, 0, 30,30)];

    view1.hidden = NO;
}

- (void)moveImage:(UIPanGestureRecognizer *)recognizer
{
    CGPoint newCenter = [recognizer translationInView:self.view];
    [self hideShowBorderCloseButton];
 if([recognizer state] == UIGestureRecognizerStateBegan) {
        beginX = recognizer.view.center.x;
        beginY = recognizer.view.center.y;
    }
    newCenter = CGPointMake(beginX + newCenter.x, beginY + newCenter.y);

        [recognizer.view setCenter:newCenter];

}


- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer {
    // if the gesture recognizers are on different views, don't allow simultaneous recognition
    if (gestureRecognizer.view != otherGestureRecognizer.view)
        return NO;

    // if either of the gesture recognizers is the long press, don't allow simultaneous recognition
    if ([gestureRecognizer isKindOfClass:[UILongPressGestureRecognizer class]] || [otherGestureRecognizer isKindOfClass:[UILongPressGestureRecognizer class]])
        return NO;

    return YES;
}

- (void)rotatePiece:(UIRotationGestureRecognizer *)gestureRecognizer {
    [self adjustAnchorPointForGestureRecognizer:gestureRecognizer];
    [self hideShowBorderCloseButton];

    if ([gestureRecognizer state] == UIGestureRecognizerStateBegan || [gestureRecognizer state] == UIGestureRecognizerStateChanged) {
        [gestureRecognizer view].transform = CGAffineTransformRotate([[gestureRecognizer view] transform], [gestureRecognizer rotation]);
        [gestureRecognizer setRotation:0];
    }
}
- (void)adjustAnchorPointForGestureRecognizer:(UIGestureRecognizer *)gestureRecognizer {
    [self hideShowBorderCloseButton];

    if (gestureRecognizer.state == UIGestureRecognizerStateBegan) {
        UIView *piece = gestureRecognizer.view;
        CGPoint locationInView = [gestureRecognizer locationInView:piece];
        CGPoint locationInSuperview = [gestureRecognizer locationInView:piece.superview];

        piece.layer.anchorPoint = CGPointMake(locationInView.x / piece.bounds.size.width, locationInView.y / piece.bounds.size.height);
        piece.center = locationInSuperview;
    }
}

2 个答案:

答案 0 :(得分:1)

代替缩放视图。它是用你的缩放级别计算框架的击球手。并更新视图的框架。看看下面的方法。

- (IBAction)scalePiece:(UIPinchGestureRecognizer *)gestureRecognizer {
    if([gestureRecognizer state] == UIGestureRecognizerStateBegan) {
        // Reset the last scale, necessary if there are multiple objects with different scales
        lastScale = [gestureRecognizer scale];
    }

    if ([gestureRecognizer state] == UIGestureRecognizerStateBegan ||
        [gestureRecognizer state] == UIGestureRecognizerStateChanged) {

        CGFloat newScale = 1 -  (lastScale - [gestureRecognizer scale]);
        [self changeScale:newScale];

        lastScale = [gestureRecognizer scale];  // Store the previous scale factor for the next pinch gesture call
    }
}

-(void)changeScale :(float)newScale{

    CGAffineTransform transform = CGAffineTransformScale([viewForpinch transform], newScale, newScale);
    viewForpinch.transform = transform;

    float scale = viewForpinch.transform.a;
    float buttonScale = 1 / scale;

    btnl.transform= CGAffineTransformScale(CGAffineTransformIdentity, buttonScale, buttonScale);


}

答案 1 :(得分:0)

执行此操作的简便方法是从该视图中删除关闭按钮,然后将其添加到您使用其他视图进行缩放的视图顶部。

你可以使用。 insertSubview:aboveSubview: