Facebook like UINavigationController to slide back to previous view controller.
SBSlideNavigationController
is a subclass (and a kind of hack!) of UINavigationController
. It was originally created by the hacker @chpwn for 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.
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;
Freely inspired by Facebook
Marco Sero
SBSlideNavigationController is available under the MIT license. See the LICENSE file for more info.