1

私は iOS 開発にかなり慣れていないので、まだ簡単に答えを見つけることができないいくつかの問題に出くわしました。

一般的なセットアップ: TabBarApplication 内で PageControl を使用して ScrollView を使用しています。

  1. ページのコンテンツと同じ領域内に PageControl を配置することは可能ですか? 私にとっては、常に SrollView のビューによって隠されますが、表示スペースが少ないため、実際のコンテンツと同じ高さにする必要があります。

  2. 私はいくつかのサンドボックスプロジェクトでだまされました.ScrollView-Pageのビューにボタンを最初に実装し始めたときはいつでも、ScrollViewのページはすぐに表示されなくなりましたが、最初のスクロール試行の後にのみ. それについていくつかのコードを投稿したいと思いますが、基本的にはIBから自動生成されたものだけです。

  3. これは、可能性に関する一般的な質問です。プロジェクトのメイン デザインは、NavigationController を備えた TabBarApplication である必要があり、かなり一般的であるように、サブメニューをさらに深く掘り下げることができます。タブの 1 つに PageControl があるはずです。このページで、NavigationController スタックの View をプッシュすることでサブメニューに移動できます。これは可能ですか?

2のコード。

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

NSMutableArray *controllers = [[NSMutableArray alloc] init];
for (unsigned i = 0; i < kNumberOfPages; i++) {
    [controllers addObject:[NSNull null]]; // [TaskPageViewController new]];
}
self.viewControllers = controllers;
[controllers release];

// a page is the width of the scroll view
scrollView.pagingEnabled = YES;
scrollView.contentSize = CGSizeMake(scrollView.frame.size.width * kNumberOfPages, scrollView.frame.size.height);
scrollView.showsHorizontalScrollIndicator = NO;
scrollView.showsVerticalScrollIndicator = NO;
scrollView.scrollsToTop = NO;
scrollView.delegate = self;

pageControl.numberOfPages = kNumberOfPages;
pageControl.currentPage = 0;

}
- (IBAction)changePage:(id)sender {
int page = pageControl.currentPage;
// load the visible page and the page on either side of it (to avoid flashes when the user starts scrolling)
[self loadScrollViewWithPage:page - 1];
[self loadScrollViewWithPage:page];
[self loadScrollViewWithPage:page + 1];
// update the scroll view to the appropriate page
CGRect frame = scrollView.frame;
frame.origin.x = frame.size.width * page;
frame.origin.y = 0;
[scrollView scrollRectToVisible:frame animated:YES];
// Set the boolean used when scrolls originate from the UIPageControl. See scrollViewDidScroll: above.
pageControlUsed = YES;

}

- (void)loadScrollViewWithPage:(int)page {
if (page < 0) return;
if (page >= kNumberOfPages) return;

// replace the placeholder if necessary
TaskPageViewController *controller = [viewControllers objectAtIndex:page];
if ((NSNull *)controller == [NSNull null]) {
    controller = [[TaskPageViewController alloc] init]; //WithPageNumber:page];
    [viewControllers replaceObjectAtIndex:page withObject:controller];
    [controller release];
}

// add the controller's view to the scroll view
if (nil == controller.view.superview) {
    CGRect frame = scrollView.frame;
    frame.origin.x = frame.size.width * page;
    frame.origin.y = 0;
    controller.view.frame = frame;
    [scrollView addSubview:controller.view];
}
}

- (void)scrollViewDidScroll:(UIScrollView *)sender {
// We don't want a "feedback loop" between the UIPageControl and the scroll delegate in
// which a scroll event generated from the user hitting the page control triggers updates from
// the delegate method. We use a boolean to disable the delegate logic when the page control is used.
if (pageControlUsed) {
    // do nothing - the scroll was initiated from the page control, not the user dragging
    return;
}
// Switch the indicator when more than 50% of the previous/next page is visible
CGFloat pageWidth = scrollView.frame.size.width;
int page = floor((scrollView.contentOffset.x - pageWidth / 2) / pageWidth) + 1;
pageControl.currentPage = page;

// load the visible page and the page on either side of it (to avoid flashes when the user starts scrolling)
[self loadScrollViewWithPage:page - 1];
[self loadScrollViewWithPage:page];
[self loadScrollViewWithPage:page + 1];

// A possible optimization would be to unload the views+controllers which are no longer visible
}
4

1 に答える 1

2
  1. これには、2 つのビュー階層を使用できます。

    • contentOffsetプロパティで原点を固定して、スクロールビュー内にページコントロールを配置します
    • scrollView のスーパービューにページ コントロールを配置しますが、より高いインデックスに配置します (つまり、その上にフローティングします)。
  2. これは、サブビューを追加するコードをどこに置くかによって異なります。scrollViewのdelegateメソッドにあるのですか?viewDidLoad? 何処か別の場所?一部のコードが役立つ場合があります。

  3. ドリルダウン ナビゲーションの場合にページ コントロールが必要な理由がわかりません。ページは、同じレベルのアイテムをナビゲートするためのものです。

于 2012-06-05T08:21:30.457 に答える