Після декількох випробувань тут я зрозумів, як я працював над тим, що хотів. Це те, що я намагався. - У мене є вид із зображенням. і мені хотілося, щоб зображення перейшло на весь екран. - У мене теж є навігаційний контролер з tabBar. Тож мені теж потрібно це приховати. - Крім того, моя головна вимога полягала не в тому, щоб ховатися, але й мати ефект завмирання, показуючи і ховаючись.
Ось як я працював.
Крок 1 - У мене один раз є зображення, і користувач натискає на це зображення. Я захоплюю цей жест і підштовхую його до нового imageViewController
, його в imageViewController
, я хочу мати повне екранне зображення.
- (void)handleSingleTap:(UIGestureRecognizer *)gestureRecognizer {
NSLog(@"Single tap");
ImageViewController *imageViewController =
[[ImageViewController alloc] initWithNibName:@"ImageViewController" bundle:nil];
godImageViewController.imgName = // pass the image.
godImageViewController.hidesBottomBarWhenPushed=YES;// This is important to note.
[self.navigationController pushViewController:godImageViewController animated:YES];
// If I remove the line below, then I get this error. [CALayer retain]: message sent to deallocated instance .
// [godImageViewController release];
}
Крок 2 - Усі ці кроки нижче знаходяться у ImageViewController
Крок 2.1 - У ViewDidLoad покажіть navBar
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view from its nib.
NSLog(@"viewDidLoad");
[[self navigationController] setNavigationBarHidden:NO animated:YES];
}
Крок 2.2 - viewDidAppear
Встановіть задачу таймера із затримкою (у мене це встановлено на 1 секунду затримки). А після затримки додайте ефект завмирання. Я використовую альфа для використання завмирання.
- (void)viewDidAppear:(BOOL)animated
{
NSLog(@"viewDidAppear");
myTimer = [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(fadeScreen) userInfo:nil repeats:NO];
}
- (void)fadeScreen
{
[UIView beginAnimations:nil context:nil]; // begins animation block
[UIView setAnimationDuration:1.95]; // sets animation duration
self.navigationController.navigationBar.alpha = 0.0; // Fades the alpha channel of this view to "0.0" over the animationDuration of "0.75" seconds
[UIView commitAnimations]; // commits the animation block. This Block is done.
}
крок 2.3 - Внизу viewWillAppear
додайте жест singleTap до зображення та зробіть navBar напівпрозорим.
- (void) viewWillAppear:(BOOL)animated
{
NSLog(@"viewWillAppear");
NSString *path = [[NSBundle mainBundle] pathForResource:self.imgName ofType:@"png"];
UIImage *theImage = [UIImage imageWithContentsOfFile:path];
self.imgView.image = theImage;
// add tap gestures
UITapGestureRecognizer *singleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleTap:)];
[self.imgView addGestureRecognizer:singleTap];
[singleTap release];
// to make the image go full screen
self.navigationController.navigationBar.translucent=YES;
}
- (void)handleTap:(UIGestureRecognizer *)gestureRecognizer
{
NSLog(@"Handle Single tap");
[self finishedFading];
// fade again. You can choose to skip this can add a bool, if you want to fade again when user taps again.
myTimer = [NSTimer scheduledTimerWithTimeInterval:5.0 target:self selector:@selector(fadeScreen) userInfo:nil repeats:NO];
}
Крок 3 - Нарешті viewWillDisappear
, переконайтеся, що поверніть всі речі назад
- (void)viewWillDisappear: (BOOL)animated
{
self.hidesBottomBarWhenPushed = NO;
self.navigationController.navigationBar.translucent=NO;
if (self.navigationController.topViewController != self)
{
[self.navigationController setNavigationBarHidden:NO animated:animated];
}
[super viewWillDisappear:animated];
}