2009-10-26 3 views
10

Я пытаюсь, чтобы мое приложение помнило, какая вкладка просматривалась последним, прежде чем приложение прекратит работу, так что приложение откроется на той же вкладке, когда оно будет запущено. Это функциональность функции телефона iPhone: как я могу это сделать?Как запомнить последнюю выбранную вкладку в UITabBarController?

+0

Взгляните на этот недавний вопрос, тоже: http://stackoverflow.com/questions/1619478/how-can-i-have-my- iphone-app-start-with-a-specific-screen-show –

ответ

6

В делегируют UITabBar, в перезаписать

- (void)tabBar:(UITabBar *)tabBar didSelectItem:(UITabBarItem *)item 

и хранить индекс элемент «s в NSUserDefaults. В следующий раз, когда начнется ваше приложение, прочитайте его оттуда и установите для его выбора. Что-то вроде этого:

-первая, вы должны установить делегата для UITabBar, как это:

tabBarController.delegate = anObject; 

anObject перезаписать didSelectItem:

 - (void)tabBar:(UITabBar *)tabBar didSelectItem:(UITabBarItem *)item 
     { 
      NSUserDefaults *def = [NSUserDefaults standardUserDefaults]; 

      [def setInteger: [NSNumber numberWithInt: tabBarController.selectedIndex] 
forKey:@"activeTab"]; 

      [def synchronize]; 
     } 

Обратите внимание, что вы сохраняете NSNumber, так как значения int не могут быть сериализованы напрямую. При запуске приложение снова, он будет читать и установить значение SelectedIndex от значений по умолчанию:

- (void)applicationDidFinishLaunchingUIApplication *)application { 
    NSUserDefaults *def = [NSUserDefaults standardUserDefaults]; 

    int activeTab = [(NSNumber*)[def objectForKey:@"activeTab"] intValue]; 

    tabBarController.selectedIndex = activeTab; 
} 
+0

@luvieere Извините, но можете ли вы уточнить немного кода образца? – quantum

+0

Конечно, я только что сделал это. – luvieere

+0

@luvieere Ooops, вы устанавливаете NSNumber вместо Int – Shmidt

0

Сохраните выбранный индекс вкладки в настройках NSUserDefaults каждый раз, когда пользователь выбирает новую вкладку. Затем, когда приложение начнет резервное копирование, загрузите это значение из настроек и вручную выберите эту вкладку.

1

Вот как я это сделал. Оба метода находятся в appDelegate, а tabBarController - переменная экземпляра.

- (void)applicationDidEnterBackground:(UIApplication *)application 
{ 
    /* 
    Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later. 
    If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits. 
    */ 

    //Remember the users last tab selection 
    NSInteger tabIndex = self.tabBarController.selectedIndex; 
    NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults]; 
    [userDefaults setInteger: tabIndex forKey:@"activeTab"]; 

    if (![userDefaults synchronize]) 
    { 
     NSLog(@"Error Synchronizing NSUserDefaults"); 
    } 

} 

- (void)applicationDidBecomeActive:(UIApplication *)application 
{ 
    /* 
    Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface. 
    */ 

    //Set the tabBarController to the last visted tab 
    NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults]; 
    int activeTab = [(NSNumber*)[userDefaults objectForKey:@"activeTab"] intValue]; 
    self.tabBarController.selectedIndex = activeTab; 
} 
+0

этот код не работает для меня –

2

Я подклассы TabBarController и:

- (void)viewWillAppear:(BOOL)animated 
{ 
    [super viewWillAppear:animated]; 
    self.selectedIndex = [[NSUserDefaults standardUserDefaults] integerForKey:@"activeTab"]; 
} 

- (void)viewWillDisappear:(BOOL)animated 
{ 
    [super viewWillDisappear:animated]; 

    [[NSUserDefaults standardUserDefaults] setInteger: self.selectedIndex 
      forKey:@"activeTab"]; 
} 
5

UPDATE

In the UITabBarControllerDelegate's Delegate, overwrite 

цель C

- (BOOL)tabBarController:(UITabBarController *)tabBarController shouldSelectViewController:(UIViewController *)viewController 
{ 
NSLog(@"%lu",self.tabBarController.selectedIndex); 
return YES; 
} 

In this delegate method you will get last selected index. 

Свифта 3,2

func tabBarController(_ tabBarController: UITabBarController, shouldSelect viewController: UIViewController) -> Bool 
{ 
    print("%i",tabBarController.selectedIndex) 
    return true 
} 
+0

Это не 'UITabBarDelegate', это' UITabBarControllerDelegate'. – MoLice

+0

Я отредактировал свой ответ. –

0

Вот решение Свифта 3. Просто установите класс вашего TabBarController к RememberingTabBarController в Раскадровка

import Foundation 
import UIKit 

class RememberingTabBarController: UITabBarController, UITabBarControllerDelegate { 
    let selectedTabIndexKey = "selectedTabIndex" 

    override func viewDidLoad() { 
     super.viewDidLoad() 
     self.delegate = self 

     // Load the last selected tab if the key exists in the UserDefaults 
     if UserDefaults.standard.object(forKey: self.selectedTabIndexKey) != nil { 
      self.selectedIndex = UserDefaults.standard.integer(forKey: self.selectedTabIndexKey) 
     } 
    } 

    func tabBarController(_ tabBarController: UITabBarController, didSelect viewController: UIViewController) { 
     // Save the selected index to the UserDefaults 
     UserDefaults.standard.set(self.selectedIndex, forKey: self.selectedTabIndexKey) 
     UserDefaults.standard.synchronize() 
    } 
} 
Смежные вопросы