TabBar back button is not showing in ios app - ios

I have created a UINavigationBarButton where i have placed a button called "update".When update button is clicked it is navigating to SecondViewController.But the problem is in the SecondViewController TabBar is not showing.What I'm trying to do is when i tap the back button in the SecondViewController it should get back to RootViewController.Here is the code
- (void)viewDidLoad {
[super viewDidLoad];
self.navigationItem.title=#"GooGle";
[self.navigationItem setLeftItemsSupplementBackButton:YES];
[self.navigationController setToolbarHidden:NO];
UIBarButtonItem *nextView = [[UIBarButtonItem alloc] initWithTitle:#"update" style:UIBarButtonSystemItemPlay target:self action:#selector(updateAddress)];
self.navigationItem.rightBarButtonItem = nextView;
[nextView release];
}
-(void)updateAddress
{
SecondViewController *updateView=[[SecondViewController alloc]initWithNibName:#"SecondViewController" bundle:nil];
[self.navigationController presentViewController:updateView animated:YES completion:Nil];
[self.navigationItem setLeftItemsSupplementBackButton:YES];
}

When you tap the back button in SecondViewController use
[self dismissViewControllerAnimated:YES completion:nil];
Since you are not using
[self.navigationController pushViewController:youViewController animated:YES];
the navigationbar won't be visible, if you do so you will have your navigationbar and a back button by its own and while pressing the back button it will itself move to the previous view
share your results

Related

presenting a view controller

I want to go to a view controller when the button "Cancel" is pressed. I tried using this method but when I click 'Cancel", it just displays a black screen. I am a beginner at IOS.
-(void) cancelButtonPressed {
homeView = (HomeViewController *)[[UIViewController alloc]init];
[self presentViewController:homeView animated:YES completion:nil];
}
EDITED FOR COMMENTS:
UIBarButtonItem *cancelButton = [[UIBarButtonItem alloc]initWithTitle:#"Cancel" style:UIBarButtonItemStylePlain target:self action:#selector(cancelButtonPressed)];
self.navigationItem.leftBarButtonItem = cancelButton;
Try doing this:
HomeViewController *homeView = [[HomeViewController alloc]init];
[self presentViewController:homeView animated:YES completion:nil];
Also note that black is the default colour of the window. If you don't have any view controller named HomeViewController, and you present it, by default it will be visible as black colour to the user.
To Avoid this, you need to set the View for the newly presented view controller, which you can access by homeView.view
If you are using storyboard, then use storyboard ID:
HomeViewController *homeView = [self.storyboard instantiateViewControllerWithIdentifier:#"HomeViewController"];
[self presentViewController:homeView animated:YES completion:nil];

xCode Navigation Back Button not popping detailview

Whenever I press on the 'go back' button on my final detail view, it wont go back to the table view.
I have a storyboard setup like this:
UITabViewController -> UINavigationController -> UITableView -> UINavigationController -> UIView (The detailview).
When I run my program I see the back button, but clicking it does nothing.
Here is the code for DetailViewController.m:
- (void)viewDidLoad {
[super viewDidLoad];
UIBarButtonItem *backbtn = [[UIBarButtonItem alloc] initWithTitle:#"Go Back" style:UIBarButtonItemStylePlain target:self action:#selector(gobackBtn)];
[self.navigationItem setLeftBarButtonItem:backbtn];
[self configureView];
}
- (void)gobackBtn
{
[self.navigationController popViewControllerAnimated:YES];
}
As if [self.navigationController popViewControllerAnimated:YES]; does nothing.
I'm out of ideas. Why does the backbutton not 'pop' the detailview?
Your detail view controller is the root view controller of the navigation controller. So 'popping' does nothing. You need instead to dismiss the navigation controller. Technically, you should use a delegate to tell your TableViewController to dismiss it, but I think
[self.navigationController dismissViewControllerAnimated:YES completion:NULL];
from within your goBackButton method of your detail view controller will do the trick.

Create Backbutton programmatically without navigation controller

In my iPhone App, I have 2 Storyboard, where I switch from Main.storyboard to Camera.storyboard and back. When I am on the Camera.storyboard I want to have the Backbutton functionality and look like the backbutton of the navigation conroller.
How do I do this best, without navigation controller? Is it possible to clone the navigationbar and backbutton somehow, which I then can connect with my back function?
Update
Had a missunderstanding in my thinking and now a solution with NavigationController. I embeded the CameraViewController in a NavigationController with IB in the Camera.storyboard and added the following code in the CameraViewController:
-(void)viewDidLoad {
}
UIBarButtonItem *cancelButtonItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemCancel target:self action:#selector(back)];
self.navigationItem.rightBarButtonItem = cancelButtonItem;
}
I did use a cancel button instead a back button as, I did not find the back button and more important, the cancel was logical more correct in this situation.
Currently I switch to the Camera.storyboard with this code:
ViewController on Main.storyboard
#pragma mark - Segue to CameraView
-(void)toCameraView:(id)sender {
UIStoryboard *mainStoryboard = [UIStoryboard storyboardWithName:#"Camera" bundle:nil];
UIViewController *cameraViewController = [mainStoryboard instantiateInitialViewController];
cameraViewController.modalTransitionStyle = UIModalTransitionStyleCrossDissolve;
[self presentViewController:cameraViewController animated:YES completion:nil];
}
and Back with:
CameraViewController on Camera.storyboard
- (IBAction)upload:(id)sender {
[[WebApi sharedInstance] uploadImage:self.imageView.image];
[self dismissViewControllerAnimated:NO completion:nil];
}

Cannot dismiss modally presented views by using setSelectedIndex

I am looking today for some insight into the issue that I am facing with my app.
I have a tab bar based application (3 tabs). In tab #2, here's the sequence of events.
"Add" button clicked in the rootView of tab #2.
Table View with navBar presented modally (PresentViewController).
Table Row touched.
New UINavigationController presented with it's rootViewController showing a few images
One of the images is selected
Present new view modally with navBar (presentViewController) with Image and details.
7 Upon clicking the image, I want to go back to the root view of tab # 2. (and I am using delegates for this)
My problem is that
=> Unless I dismiss each and every modal view, I am unable to go to the tab# 2.
=> If I am using delegate and setting the selectedTabIndex = 1 in the delegate the rootViewController of tab #2 should get displayed.
=> But In actuality that doesn't happen till i dismiss both modal view controllers. Why is that?
I read in the apple documentation that if you dismiss a modal view controller then all the subsequent view controllers would be dismissed as well. This however does not seem to be the case. I can get back to the root view controller of tab#2 only after I dismiss each and every modal view.
//AppDelegate :
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
self.tabBarController = [[UITabBarController alloc] init];
self.secondViewController = [[SecondViewController alloc] initWithNibName:nil bundle:nil];
self.navControllerTwo = [[UINavigationController alloc] initWithRootViewController:self.secondViewController];
//navControllerOne and viewControllerOne are also init'd here
NSArray *viewControllers = [NSArray arrayWithObjects:self.navControllerOne, self.navControllerTwo, self.viewControllerOne, nil];
[self.tabBarController setViewControllers:viewControllers];
self.window.rootViewController = self.tabBarController;
[self.window makeKeyAndVisible];
return YES;
}
// Then => 1. "Add" button clicked in the rootView of tab #2.
- (void)addItemButtonClicked:(id)sender
{
UIBarButtonItem *btn = nil;
AddItemViewcontroller *addItemController = [[AddItemViewcontroller alloc] initWithNibName:nil bundle:nil];
addItemController.delegate = self;
UINavigationController *addItemNavController = [[UINavigationController alloc] initWithRootViewController:addItemController];
//leftBaButton
btn = [[UIBarButtonItem alloc] initWithTitle:#"Cancel"
style:UIBarButtonItemStylePlain
target:self
action:#selector(addItemCancelButtonPressed:)];
addItemNavController.navigationBar.topItem.leftBarButtonItem = btn;
[self presentViewController:addItemNavController animated:YES completion:nil]; // First Modal View presented
}
//Then: => 2. Table View with navBar presented modally (PresentViewController).
// 3. Table Row touched.
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
IGViewController *gvc = [[IGViewController alloc] initWithItemType:itemType]; // pre-determined item type
[self. navigationController pushViewController:gvc animated:YES];
}
//Then: 4. New UINavigationController presented with it's rootViewController showing a few images
// 5. One of the images is selected
- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath;
{
UIBarButtonItem *btn;
UINavigationItem *navItem = [[UINavigationItem alloc] init];
UINavigationBar *navBar = [[UINavigationBar alloc] initWithFrame:CGRectMake(0, 0, CGRectGetWidth(self.view.frame), 44)];
SIViewController *siViewController = [[SIViewController alloc] initWithNibName:nil bundle:nil];
siViewController.delegate = self.appDelegate.secondViewController; // Init'd in the app delegate
btn = [[UIBarButtonItem alloc] initWithTitle:#"Add item" style:UIBarButtonItemStyleDone
target:selectedItemViewController
action:#selector(selectedItemViewAddItemButtonPressed)];
[navItem setLeftBarButtonItem:btn];
navBar.items = [NSArray arrayWithObject:navItem];
[navBar setAutoresizingMask:UIViewAutoresizingFlexibleWidth];
[selectedItemViewController.view addSubview:navBar];
[self presentViewController:selectedItemViewController animated:YES completion:nil]; //second modal view presentd here
}
//Then: 6. Present new view modally with navBar (presentViewController) with Image and details.
// 7 Upon clicking the image, I want to go back to the root view of tab # 2. (and I am using delegates for this)
-(void)siViewAddItemButtonPressed
{
[self.delegate selectedItemViewAddItemButtonPressedForItem:self.selectedItem];
}
//And: Here's what the method in the siViewControllers delegate looks like:
//In this routine setSelectedIndex = 2 does not work until i dismiss both modally presented views
- (void)siViewAddItemButtonPressedForItem:(Item *)item
{
[self.presentedViewController dismissViewControllerAnimated:NO completion:nil]; // Dismiss modal
[(UINavigationController*)(self.presentedViewController) popToRootViewControllerAnimated:NO];
[self.presentedViewController dismissViewControllerAnimated:NO completion:nil]; //Dismiss modal
}

Modal window not being dismissed

I have two programmatically created buttons you can see in my viewDidLoad method. On the modal window I have a button that calls the cancelSearch method via a delegate. When I place a breakpoint on my cancelSearch method it is hit, so I know my delegate is set up correct, but even though it calls this line [self dismissViewControllerAnimated:YES completion:nil]; it's not actually closing the modal window.
The code below is all from my main controller view.
- (void)viewDidLoad
{
[super viewDidLoad];
UIBarButtonItem *actionButton = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemAction target:self action:#selector(showActionMenu:)];
actionButton.style = UIBarButtonItemStyleBordered;
UIBarButtonItem *searchButtonItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemSearch target:self action:#selector(showSearchMenu:)];
searchButtonItem.style = UIBarButtonItemStyleBordered;
UIToolbar* toolbar = [[UIToolbar alloc] initWithFrame:CGRectMake(0.0f, 0.0f, 103.0f, 44.01f)];
NSArray* buttons = [NSArray arrayWithObjects:actionButton, searchButtonItem, nil];
[toolbar setItems:buttons animated:NO];
self.navigationItem.title = #"Census Management";
self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:toolbar];
[[RKClient sharedClient] get:#"censusmanagement" delegate:self];
}
- (IBAction)showActionMenu:(id)sender
{
[self performSegueWithIdentifier: #"CMActionSegue" sender: self];
}
- (IBAction)showSearchMenu:(id)sender
{
ehrxCMSearchView *search = [[self storyboard] instantiateViewControllerWithIdentifier:#"cmSearch"];
search.selectedOptions = self.selectedOptions;
search.delegate = self;
[self.navigationController pushViewController:search animated:YES];
}
- (void)cancelSearch:(ehrxCMSearchView *)controller
{
[self dismissViewControllerAnimated:YES completion:nil];
}
You would dismiss a modal view using something similar to:
[self dismissModalViewControllerAnimated:YES];
This will dismiss the modal view which was loaded using something similar to:
[self presentModalViewController:search animated:YES];
However looking at your code snippet, it appears the search view controller is being pushed onto the navigation stack using the following line:
[self.navigationController pushViewController:search animated:YES];
So I you probably need to pop the view from the navigation stack rather than trying to dismiss it as a modal view:
[self.navigationController popViewControllerAnimated:YES];
If your view controller is modally presented, you should use this:
[self.presentingViewController dismissModalViewControllerAnimated:YES];
The presentingViewController property is available in iOS 5 only. So, if you're targeting older versions of iOS, you have to use self.parentViewController instead (use the appropriate one for each iOS version, you have to handle this).
If you make this control in your parent/presenting view controller, then just call this:
[self dismissModalViewControllerAnimated:YES];

Resources