Как реализовать анимацию перехода просмотра iPhone с переворачиванием и масштабированием?
Как реализовать анимацию, которую мы видим на экране обложки приложения iPhone Music? когда вы нажимаете на маленькое представление, оно переворачивается и масштабируется до другого представления? как я могу это сделать? Я могу использовать базовую анимацию, чтобы перевернуть и масштабировать вид, но как я могу сделать переход к другому виду? Спасибо
2 ответа
Вам нужен UIView
в качестве контейнера для двоих UIView
s (передняя сторона / задняя сторона), а затем удалите / добавьте их из / в контейнер как подпредставления, выполняя анимацию между ними:
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];
... который бы убрал вид, который я только что добавил.
Я не уверен, что это правильное место, чтобы поставить этот вопрос - извините, если это не так!