Как реализовать анимацию перехода просмотра iPhone с переворачиванием и масштабированием?

Как реализовать анимацию, которую мы видим на экране обложки приложения iPhone Music? когда вы нажимаете на маленькое представление, оно переворачивается и масштабируется до другого представления? как я могу это сделать? Я могу использовать базовую анимацию, чтобы перевернуть и масштабировать вид, но как я могу сделать переход к другому виду? Спасибо

2 ответа

Решение

Вам нужен UIView в качестве контейнера для двоих UIViews (передняя сторона / задняя сторона), а затем удалите / добавьте их из / в контейнер как подпредставления, выполняя анимацию между ними:

UIView *flipContainer;
UIView *frontSide;
UIView *backSide;
  //...
-(void)turnUp
{
  [backSide removeFromSuperview];
  [UIView beginAnimations:nil context:NULL];
  [UIView setAnimationDuration:1.0];
  [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromLeft forView:flipContainer cache:YES];
  [UIView setAnimationDuration:1.0];
  CGAffineTransform transform = CGAffineTransformMakeScale(1.2, 1.2);
  flipContainer.transform = transform;
  [UIView commitAnimations];
  [flipContainer addSubview:frontSide];
}
-(void)turnDown
{
  [frontSide removeFromSuperview];
  [UIView beginAnimations:nil context:NULL];
  [UIView setAnimationDuration:1.0];
  [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRight forView:flipContainer cache:YES];
  [UIView setAnimationDuration:1.0];
  CGAffineTransform transform = CGAffineTransformMakeScale(1, 1);
  flipContainer.transform = transform;
  [UIView commitAnimations];
  [flipContainer addSubview:backSide];
}

Я пробую точный код, который вы делаете - я получаю эффект увеличения, но не переворачиваюсь. Единственная разница в том, что прямо перед кодом включения я добавляю flipContainer (с обратным отображением), чтобы потом его можно было перевернуть.

// construct animation container
self.flipContainer = [[FlipContainer alloc] init];
[self.flipContainer.view setFrame:CGRectMake(clickedSquareX, clickedSquareY, 200, 200)];
[self.flipContainer.view addSubview:self.backside.view];
// add animation container
[self.myParentView.view addSubview:self.flipContainer.view];
// PROCEED to your turnUp code

Причина, по которой я это делаю, заключается в том, что у меня есть куча изображений в горизонтальном UIScrollView, и поэтому, чтобы "имитировать" переворачивание и масштабирование изображения 200x200, чтобы показать детализацию, я добавляю свой flipContainer с обратной стороной, показывающий точное изображение поверх точного пятна прессованное изображение. Это должно работать, не так ли? Меня немного смущает первая строка вашего кода включения:

[backSide removeFromSuperview];

... который бы убрал вид, который я только что добавил.

Я не уверен, что это правильное место, чтобы поставить этот вопрос - извините, если это не так!

Другие вопросы по тегам