Как объединить UIScrollview с UIPagecontrol, чтобы показать разные представления? - PullRequest
4 голосов
/ 10 декабря 2010

Я искал и искал учебник для этого, но ни один из них не является тем, что я ищу. Я попробовал образец Apple, но это всего лишь цвета, и я не знаю, как заставить его смотреть. Все, что я ищу, - это экран, на котором будет отображаться страница с отображением элемента управления страницы. Каждый раз, когда я прокручиваю страницы просмотра, я хочу, чтобы он отображал совершенно другой вид с кнопками, во многом как домашний экран iPhone. Ниже приведен пример кода, который очень хорошо работает только с изображениями, но я хотел бы изменить его для работы с отдельными представлениями. Пожалуйста помоги! Спасибо.

- (void)setupPage {
    scrollView.delegate = self;

    [self.scrollView setBackgroundColor:[UIColor clearColor]];
    [scrollView setCanCancelContentTouches:NO];

    scrollView.indicatorStyle = UIScrollViewIndicatorStyleWhite;
    scrollView.clipsToBounds = YES;
    scrollView.scrollEnabled = YES;
    scrollView.pagingEnabled = YES;

    NSUInteger nimages = 0;
    CGFloat cx = 0;
    for (; ; nimages++) {
        NSString *imageName = [NSString stringWithFormat:@"image%d.jpg", (nimages + 1)];                
        UIImage *image = [UIImage imageNamed:imageName];
        if (image == nil) {
            break;
        }
        UIImageView *imageView = [[UIImageView alloc] initWithImage:image];

        CGRect rect = imageView.frame;
        rect.size.height = image.size.height;
        rect.size.width = image.size.width;
        rect.origin.x = ((scrollView.frame.size.width - image.size.width) / 2) + cx;
        rect.origin.y = ((scrollView.frame.size.height - image.size.height) / 2);

        imageView.frame = rect;

        [scrollView addSubview:imageView];
        [imageView release];

        cx += scrollView.frame.size.width;
    }

    self.pageControl.numberOfPages = nimages;
    [scrollView setContentSize:CGSizeMake(cx, [scrollView bounds].size.height)];
}

Ответы [ 4 ]

4 голосов
/ 12 декабря 2010

Я экспериментировал с этим только на днях. Я все еще привыкаю к ​​использованию UIScrollView, но вот как вы можете добавить представления к своему UIScrollView:

UIView *blueView = [[UIView alloc] init];
blueView.frame = CGRectMake(100, 0, 500, 1024);
blueView.backgroundColor = [UIColor colorWithRed:164.0/256 green:176.0/256 blue:224.0/256 alpha:1];
[scrollView addSubview:blueView];
[blueView release];

UIView *orangeView = [[UIView alloc] init];
orangeView.frame = CGRectMake(700, 0, 500, 1024);
orangeView.backgroundColor = [UIColor colorWithRed:252.0/256 green:196.0/256 blue:131.1/256 alpha:1];
[scrollView addSubview:orangeView];
[orangeView release];

Обратите внимание, что я устанавливаю значение x в frame.origin каждого вида, чтобы они располагались рядом друг с другом. Вы также должны установить размер содержимого UIScrollView, например, [scrollView setContentSize:CGSizeMake(1200, 1024)];, чтобы он знал, насколько велики его подпредставления.

Затем, если вам нужно управлять UIPageControl, вы должны установить его numberOfPages в 2 (для примера scrollview выше) и изменить его свойство currentPage. Вы можете сделать это, реализовав scrollViewDidEndDecelerating:, который является методом в UIScrollViewDelegate. Вы можете проверить, на какой «странице» находится представление прокрутки, проверив его значение contentOffset.x.

Надеюсь, это поможет!

0 голосов
/ 10 декабря 2010

// Добавление UIView к примеру PageControl

  - (id)initWithPageNumber:(int)page {
        UIScreen *screen = [UIScreen mainScreen];
        CGRect frame = [screen applicationFrame];
        frame.origin.y=0;

        if (self = [super initWithNibName:@"MyView" bundle:nil]) {      
                UIView *view = [[UIView alloc] initWithFrame:frame];

                [self.view addSubview:view];

                            // Add whatever you want to the view here.
                [view release];
            pageNumber = page;
        }
        return self;
    }
0 голосов
/ 11 декабря 2010

Вот еще один ответ ...

NSArray* nibViews =  [[NSBundle mainBundle] loadNibNamed:@"Views" owner:self options:nil];
infoView = [nibViews objectAtIndex:0];
[self.view addSubview:infoView];

Тогда у вас есть ваше мнение.

Приветствия

0 голосов
/ 10 декабря 2010

Вот код Apple PageControl с изображениями. Чтобы использовать, просто перетащите ваши изображения в проект. Изображения по умолчанию: image1.jpg, image2.jpg и т. Д. Если вам нужен png, просто измените расширение на .png.

Затем замените код MyViewController.m на этот код, и вы получите контроль страницы с изображениями.

Ура, Иордания

http://pastebin.com/raw.php?i=c3hS29sC

...