Подтвердить что ты не робот

(Масштаб) Увеличить в UIView в точке

Что-то я не понимаю о преобразованиях. Я хочу увеличить масштаб, чтобы сказать верхний правый угол UIView (основной вид). Я использую CGAffineTransformScale и пробовал обе настройки center/anchorPoint, а также CGAffineTransformMakeTranslation безрезультатно.

Я не могу понять, как правильно настроить перевод, чтобы он увеличил эту точку.

CGAffineTransform tr = CGAffineTransformScale(self.view.transform, 2, 2);

[UIView animateWithDuration:2.5 delay:0 options:0 animations:^{
            self.view.transform = tr;
            self.view.center = CGPointMake(480,0);

} completion:^(BOOL finished) {}];
4b9b3361

Ответ 1

Вы устанавливаете центр обзора в верхнем правом углу. Это означает, что вы приближаетесь где-то к левому нижнему углу центра.

Попробуйте это

CGAffineTransform tr = CGAffineTransformScale(self.view.transform, 2, 2);
CGFloat h = self.view.frame.size.height;
[UIView animateWithDuration:2.5 delay:0 options:0 animations:^{
    self.view.transform = tr;
    self.view.center = CGPointMake(0,h);
} completion:^(BOOL finished) {}];

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

В этом коде нет жесткой жесткости, которая немного более портативна (для iPad iPhone 5).

Вам нужно сначала сохранить h перед установкой свойства transform, потому что после этого вы не должны полагаться на значение frame.

изменить

Чтобы он работал для любого масштаба s, используйте это:

CGFloat s = 3;
CGAffineTransform tr = CGAffineTransformScale(self.view.transform, s, s);
CGFloat h = self.view.frame.size.height;
CGFloat w = self.view.frame.size.width;
[UIView animateWithDuration:2.5 delay:0 options:0 animations:^{
    self.view.transform = tr;
    self.view.center = CGPointMake(w-w*s/2,h*s/2);
} completion:^(BOOL finished) {}];

Чтобы заставить его работать внизу слева, используйте это:

CGFloat s = 3;
CGAffineTransform tr = CGAffineTransformScale(self.view.transform, s, s);
CGFloat h = self.view.frame.size.height;
CGFloat w = self.view.frame.size.width;
[UIView animateWithDuration:2.5 delay:0 options:0 animations:^{
    self.view.transform = tr;
    self.view.center = CGPointMake(w*s/2,h-h*s/2);
} completion:^(BOOL finished) {}];

Чтобы сделать его работу справа внизу, используйте это:

CGFloat s = 3;
CGAffineTransform tr = CGAffineTransformScale(self.view.transform, s, s);
CGFloat h = self.view.frame.size.height;
CGFloat w = self.view.frame.size.width;
[UIView animateWithDuration:2.5 delay:0 options:0 animations:^{
    self.view.transform = tr;
    self.view.center = CGPointMake(w-w*s/2,h-h*s/2);
} completion:^(BOOL finished) {}];

См. также: Как масштабировать (масштабировать) UIView для данного CGPoint

Ответ 2

В случае, если кому-то все еще интересно, вот решение Swift 3.0, к которому я добавил возможность корректного исчезновения.

(Я знаю, что нет двух перечислений, но код все еще доступен для чтения, и я думаю, что вы получите концепцию)

func animateZoom(direction: ZoomDirection, type: ZoomType, duration: Double = 0.3, scale: CGFloat = 1.4) {
    var cx, cy: CGFloat
    var tr: CGAffineTransform = CGAffineTransform.identity

    if (type == .IN) { tr = self.transform.scaledBy(x: scale, y: scale) }

    let h: CGFloat = self.frame.size.height;
    let w: CGFloat = self.frame.size.width;

    if (type == .IN) {
        switch direction {
        case .LEFT_DOWN:
            cx = w*scale/2
            cy = h-h*scale/2
            break
        case .LEFT_UP:
            cx = w*scale/2
            cy = h*scale/2
            break
        case .RIGHT_UP:
            cx = w-w*scale/2
            cy = h*scale/2
            break
        case .RIGHT_DOWN:
            cx = w-w*scale/2
            cy = h-h*scale/2
            break
        }
    } else {
        cx = w/scale/2
        cy = h/scale/2
    }

    UIView.animate(withDuration: duration, delay: 0, options: [.curveEaseInOut], animations: {
        self.transform = tr
        self.center = CGPoint(x: cx, y: cy)
    }, completion: { finish in })
}