Как перевернуть отдельный UIView (без переворачивания родительского представления) - PullRequest
21 голосов
/ 02 марта 2012

Это проект iPad, в котором у меня есть UIView с несколькими подвидами, и я пытаюсь анимировать один из этих UIViews, используя [UIView transitionFromView: toView: duration: options: завершение], но когда я запускаю этот метод весь родитель вид переворачивается! Это код, который я использую:

UIView *secondView = [[UIView alloc] initWithFrame:CGRectMake(200, 200, 300, 300)];
[newView setBackgroundColor:[UIColor redColor]];
    [UIView transitionFromView:self.firstView.view toView:secondView duration:1.0 options:UIViewAnimationOptionTransitionFlipFromLeft completion:nil];

Есть идеи, как я могу переключаться между этими представлениями, не анимируя весь родительский вид? Спасибо!

Ответы [ 6 ]

70 голосов
/ 02 марта 2012

этот код может вам помочь:

поместите два представления, которые вы хотите перевернуть, в безымянный вид с одинаковым размером и свяжите IBOutlet UIView *newView,*oldView; с представлениями и поместите новый вид сверху

bool a = NO;

@implementation ViewController

- (IBAction)flip:(id)sender 
{
    if (a == NO) {
        [UIView transitionFromView:oldView toView:newView  
                  duration:1.0 
                  options:UIViewAnimationOptionTransitionFlipFromLeft 
                  completion:NULL];
        a = YES; // a = !a;
    }
    else {
        [UIView transitionFromView:newView toView:oldView  
                  duration:1.0 
                  options:UIViewAnimationOptionTransitionFlipFromLeft 
                  completion:NULL];
        a = NO; // a = !a;
    }
}
37 голосов
/ 07 апреля 2013

У меня тоже были проблемы с этим.Я использовал код, написанный Floris, но, хотя он работал для первого «сальто», следующий сальто стало странным, когда кнопки и метки на внешнем интерфейсе просмотра потеряли свои позиции.

Я поместил приведенный ниже код на место, и он работает нормально.

Несколько замечаний:

  1. panelView - это элемент управления UIView на ViewController, который имеетдва других UIViews вложены в него (подпредставления).Первый называется frontView, второй - backView.(см. рисунок ниже)

image of the view and subviews in IB

У меня есть свойство bool, которое называется displayingFront для класса

(в моем .h)

@property BOOL displayingFront;

в моем .m

@synthesize displayingFront;

в моем методе viewDidLoad

self.displayingFront = YES;

Это код в .m, который я подключил к двум кнопкам, если передний и задний UIViews ...

- (IBAction)flip:(id)sender
{
    [UIView transitionWithView:self.panelView
                      duration:1.0
                       options:(displayingFront ? UIViewAnimationOptionTransitionFlipFromRight :
                                UIViewAnimationOptionTransitionFlipFromLeft)
                    animations: ^{
                        if(displayingFront)
                        {
                            self.frontView.hidden = true;
                            self.backView.hidden = false;
                        }
                        else
                        {
                            self.frontView.hidden = false;
                            self.backView.hidden = true;
                        }
                    }

                    completion:^(BOOL finished) {
                        if (finished) {
                            displayingFront = !displayingFront;
                        }
                    }];
}
2 голосов
/ 30 августа 2013

Я исправил эту проблему с помощью анимации старой школы:

[UIView beginAnimations:@"Flip" context:nil];
[UIView setAnimationDuration:1];
[UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
[UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRight forView:firstView cache:YES];

[self addSubview:secondView];

[UIView commitAnimations];

Дополнительно вы можете удалить firstView:

[firstView removeFromSuperview];
2 голосов
/ 19 января 2013
**//flipping view continuously**  



 bool a = NO;


-(void)viewDidLoad
{



// THIS is the canvass holding the two views this view is flipping
 UIView *v=[[UIView alloc]initWithFrame:CGRectMake(40, 40, 150, 150)];

   v.backgroundColor=[UIColor clearColor];

    [self.view addSubview:v];

     [v addSubview:yourfirstview];
     [v addSubview:yoursecondview];

// calling the method

[NSTimer scheduledTimerWithTimeInterval:2.0
                                     target:self
                                   selector:@selector(flip)
                                   userInfo:nil
                                    repeats:YES];

}



//flipping view randomly

-(void)flip 

{

if (a == NO) 
{

[UIView transitionFromView:yourfirstview toView:yoursecondview duration:1.0 options:UIViewAnimationOptionTransitionFlipFromLeft completion:NULL];
        a = YES;
    }

else if(a==YES) 
{

[UIView transitionFromView:yoursecondview toView:yourfirstview duration:1.0 options:UIViewAnimationOptionTransitionFlipFromLeft completion:NULL];
     a = NO;
  }

}
2 голосов
/ 02 марта 2012

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

Итак, вы можете настроить свои представления следующим образом.

self.view-> "представление контейнера" ​​-> подпредставления

1 голос
/ 27 сентября 2018

Я бы хотел обновить ответ Стива Паркера в SWIFT 4: -

var displayBlankView:Bool = true

UIView.transition(with:flipView, duration:1.0, options:displayBlankView ? .transitionFlipFromLeft:.transitionFlipFromRight, animations:{
        if(self.displayBlankView){
            self.view1.isHidden=true
            self.view2.isHidden=false
        }else{
            self.view1.isHidden=false
            self.view2.isHidden=true
        }
    }, completion:{
        (finished: Bool) in
        self.displayBlankView = !self.displayBlankView;

    })
...