Как добавить индикатор страницы внутри панели навигации?

Как и твиттер:

enter image description here

У меня есть элемент управления PageViewController внутри UITabBarController, который, в свою очередь, находится внутри UINavigationController.

Может ли кто-нибудь сказать мне, как показывать индикатор страницы внутри панели навигации?

Ответы

Ответ 1

Изменить: я просто понял, что navigationController.viewControllers содержит только стек. Я опубликую правку через минуту

Изменить 2: Ну, похоже, вам нужно знать количество контроллеров представления перед началом работы.

Возможно, это не лучшее решение, но оно работает для меня. Просто попробовал:)

@interface ViewController () <UINavigationControllerDelegate>
@property (nonatomic, strong) UIPageControl *pageControl;
@end

@implementation ViewController

- (void)viewDidLoad
{
    [super viewDidLoad];

    UINavigationController *navController = self.navigationController;
    navController.delegate = self;

    navController.navigationBar.barTintColor = [UIColor colorWithRed:.2
                                                               green:.4
                                                                blue:.9
                                                               alpha:1];

    CGSize navBarSize = navController.navigationBar.bounds.size;
    CGPoint origin = CGPointMake( navBarSize.width/2, navBarSize.height/2 );

    self.pageControl = [[UIPageControl alloc] initWithFrame:CGRectMake(origin.x, origin.y,
                                                                       0, 0)];

    //Or whatever number of viewcontrollers you have
    [self.pageControl setNumberOfPages:2];

    [navController.navigationBar addSubview:self.pageControl];

    navController.delegate = self;
}

- (void)navigationController:(UINavigationController *)navigationController willShowViewController:(UIViewController *)viewController animated:(BOOL)animated
{
    int index = [navigationController.viewControllers indexOfObject:viewController];
    self.pageControl.currentPage = index;
}

@end

Вот несколько скриншотов.

First ViewSecond view