Когда нужно изменить размер кадра UIView при его пользовательском рисовании? - PullRequest
1 голос
/ 15 октября 2011

Я выполняю пользовательское рисование в своем приложении для метода View in drawRect.

Я фиксирую жест жесткости пользователя и, исходя из этого, я хочу каждый раз изменять размер кадра представления.

Я попытался изменить фрейм UIView в методе drawRect. Но я чувствовал, что это неправильное место, потому что drawRect просит нас рисовать в определенном прямоугольнике.

Я действительно создал протокол и, когда бы я ни делал, я пытался изменить размер кадра представления из контроллера представления с помощью методов протокола. Но это также не сработало.

Как мне этого добиться?

UPDATE:

Мне удалось изменить фрейм UIView из метода awakeFromNib пользовательского UIView. Но у меня есть необходимость изменить регулярные кадры на основе действий пользователей, и не нашел способов перезагрузить метод awakeFromNib ..

1 Ответ

1 голос
/ 15 октября 2011

Это всего лишь примеры, и их необходимо изменить, чтобы они соответствовали вашей конкретной ситуации, но вы, вероятно, можете использовать анимацию CGRectApplyAffineTransform или UIView:

- (IBAction)handlePinchGesture:(UIGestureRecognizer *)sender {
    UIView *senderView = sender.view;
    if (sender.state == UIGestureRecognizerStateBegan) {
        initialFrame = senderView.frame;
    }
    CGFloat factor = [(UIPinchGestureRecognizer *)sender scale];
    CGAffineTransform zt = CGAffineTransformScale(CGAffineTransformIdentity, factor, factor);
    senderView.frame = CGRectApplyAffineTransform(initialFrame, zt);
    return;
}

/* -------------------------------------------------------------------------- */

- (IBAction)handlePinchGesture:(UIGestureRecognizer *)sender {
    UIView *senderView = sender.view;
    [UIView beginAnimations:nil context:nil];
    [UIView setAnimationDuration:0.35f];
    [UIView setAnimationCurve:UIViewAnimationCurveEaseIn];

    /* Set changes for the animation before calling commitAnimations
    self.tableView.layer.borderWidth = 3.0;
    self.tableView.layer.borderColor = [[UIColor colorWithRed:0.1 green:0.1 blue:0.1 alpha:0.85] CGColor];
    self.tableView.layer.backgroundColor = [[UIColor colorWithWhite:0.2 alpha:0.5] CGColor];
    self.tableView.layer.shadowOffset = CGSizeMake(4.0, 2.0);
    self.tableView.layer.shadowColor = [[UIColor blackColor] CGColor];
    self.tableView.layer.shadowOpacity = 1.0;
    self.tableView.layer.shadowRadius = 2.0;
    self.tableView.layer.cornerRadius = 10.0;
    */

    [UIView commitAnimations];
}
...