Skip to content

Facebook like UINavigationController to slide back to previous view controller.

License

Notifications You must be signed in to change notification settings

capriele/SBSlideNavigationController

Repository files navigation

SBSlideNavigationController

Facebook like UINavigationController to slide back to previous view controller.

animation

Origins and how it works

SBSlideNavigationController is a subclass (and a kind of hack!) of UINavigationController. It was originally created by the hacker @chpwn for Facebook:

facebook

@aaronash you should try the swipe back gesture I did for the latest Facebook update

— Grant Paul (chpwn) (@chpwn) 13 maggio 2013
<script async src="//platform.twitter.com/widgets.js" charset="utf-8"></script>

And the response was quite good:

Dynamic swipe back behaviour in UINavigationControllers (like Flurry and the new Facebook app update) need to be a thing. They're awesome.

— Adam Bell (@b3ll) 14 maggio 2013
<script async src="//platform.twitter.com/widgets.js" charset="utf-8"></script>

I don't know about Grant Paul's implementation, but mine works creating a screenshot of the previous view controller as soon as the user starts scrolling, animating bar button items based on user's scroll.

How to use

Whenever you want to add this feature to your navigation controller's hierarchy, you have to do a couple of things.

First of all, use SBSlideNavigationController instead of UINavigationController (course)

If you want the fade animation for bar button items (and I am sure you do want it), the only way is to create them with a custom view, adding the actual view as a subview of the "main" custom view. An example is probably what you need:

UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, 44, 33)];
[button setTitle:@"A" forState:UIControlStateNormal];
[button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[button addTarget:self action:@selector(yourAction) forControlEvents:UIControlEventTouchUpInside];
UIView *view = [[UIView alloc] initWithFrame:button.frame];
[view addSubview:button];
UIBarButtonItem *barButtonItem = [[UIBarButtonItem alloc] initWithCustomView:view];

And remebember to keep bar button items' sizes constant.

If you want the fade animation for bar titleView, the only way is to create them with a custom view. An example is probably what you need:

UIView *view = [[UIView alloc] initWithFrame:CGRectMake(x, y, width, height)];
CGRect frame = CGRectMake(0, 0, view.frame.size.width, view.frame.size.height);
UILabel *titleLabel = [[UILabel alloc] initWithFrame:frame];
titleLabel.backgroundColor = [UIColor clearColor];
titleLabel.textAlignment = NSTextAlignmentCenter;
titleLabel.text = Title;
titleLabel.textColor = [UIColor whiteColor];
titleLabel.font = [UIFont boldSystemFontOfSize:20.0f];
titleLabel.layer.shadowColor = RGBCOLOR(7, 79, 7).CGColor;
titleLabel.layer.shadowOffset = CGSizeMake(0.0, -1.0);
titleLabel.layer.shadowRadius = 1.0;
titleLabel.layer.shadowOpacity = 0.8;
titleLabel.layer.masksToBounds = NO;
[view addSubview:titleLabel];
self.navigationItem.titleView = CenterView;

Credits

Freely inspired by Facebook

Contact

Marco Sero

License

SBSlideNavigationController is available under the MIT license. See the LICENSE file for more info.

About

Facebook like UINavigationController to slide back to previous view controller.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published