mirror of
https://github.com/material-components/material-components-ios.git
synced 2026-01-23 16:02:28 +08:00
* Replace MDC all icons * Update border * Replace MDCActionExtension icon with new logo * Update all headers to be white on black * Make Catalog greyscale to match Material’s style. * Fix collection tile * Update all headers to be white on black * Make Catalog greyscale to match Material’s style. * Fix collection tile * WIP: Updating TabBar example to use black/green theme. * WIP: Monochoroming all examples. * Switch MDC Catalog to a black and white theme (#1355) * Replace MDC all icons * Update border * Replace MDCActionExtension icon with new logo * Update all headers to be white on black * Make Catalog greyscale to match Material’s style. * Fix collection tile * Update all headers to be white on black * Make Catalog greyscale to match Material’s style. * Fix collection tile * Fix floats * Make Catalog greyscale to match Material’s style. * More black and whiting * WIP: Snackbar and global style * Simplify snack bar examples. * Page control
153 lines
5.5 KiB
Objective-C
153 lines
5.5 KiB
Objective-C
/*
|
|
Copyright 2015-present the Material Components for iOS authors. All Rights Reserved.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
#import "MDCPageControl.h"
|
|
|
|
@interface PageControlButtonExample : UIViewController <UIScrollViewDelegate>
|
|
@end
|
|
|
|
@implementation PageControlButtonExample {
|
|
UIScrollView *_scrollView;
|
|
MDCPageControl *_pageControl;
|
|
NSArray *_pages;
|
|
}
|
|
|
|
+ (NSArray *)catalogBreadcrumbs {
|
|
return @[ @"Page Control", @"Page Control with Next Button" ];
|
|
}
|
|
|
|
- (void)viewDidLoad {
|
|
[super viewDidLoad];
|
|
|
|
CGFloat boundsWidth = CGRectGetWidth(self.view.bounds);
|
|
CGFloat boundsHeight = CGRectGetHeight(self.view.bounds);
|
|
|
|
NSArray *pageColors = @[
|
|
[UIColor colorWithWhite:0.9 alpha:1.0],
|
|
[UIColor colorWithWhite:0.8 alpha:1.0],
|
|
[UIColor colorWithWhite:0.7 alpha:1.0],
|
|
[UIColor colorWithWhite:0.6 alpha:1.0],
|
|
[UIColor colorWithWhite:0.5 alpha:1.0] ];
|
|
|
|
// Scroll view configuration
|
|
_scrollView = [[UIScrollView alloc] initWithFrame:self.view.bounds];
|
|
_scrollView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
|
|
_scrollView.delegate = self;
|
|
_scrollView.pagingEnabled = YES;
|
|
_scrollView.contentSize = CGSizeMake(boundsWidth * pageColors.count, boundsHeight);
|
|
_scrollView.showsHorizontalScrollIndicator = NO;
|
|
[self.view addSubview:_scrollView];
|
|
|
|
NSMutableArray *pages = [NSMutableArray array];
|
|
|
|
// Add pages to scrollView.
|
|
for (NSInteger i = 0; i < pageColors.count; i++) {
|
|
CGRect pageFrame = CGRectOffset(self.view.bounds, i * boundsWidth, 0);
|
|
UILabel *page = [[UILabel alloc] initWithFrame:pageFrame];
|
|
page.text = [NSString stringWithFormat:@"Page %zd", i + 1];
|
|
page.font = [UIFont systemFontOfSize:50];
|
|
page.textColor = [UIColor colorWithWhite:0 alpha:0.8];
|
|
page.textAlignment = NSTextAlignmentCenter;
|
|
page.backgroundColor = pageColors[i];
|
|
page.autoresizingMask =
|
|
UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleBottomMargin;
|
|
[_scrollView addSubview:page];
|
|
[pages addObject:page];
|
|
}
|
|
_pages = [pages copy];
|
|
|
|
// Page control configuration.
|
|
_pageControl = [[MDCPageControl alloc] init];
|
|
_pageControl.numberOfPages = pageColors.count;
|
|
|
|
// We want the page control to span the bottom of the screen.
|
|
CGSize pageControlSize = [_pageControl sizeThatFits:self.view.bounds.size];
|
|
_pageControl.frame =
|
|
CGRectMake(0, boundsHeight - pageControlSize.height, boundsWidth, pageControlSize.height);
|
|
|
|
[_pageControl addTarget:self
|
|
action:@selector(didChangePage:)
|
|
forControlEvents:UIControlEventValueChanged];
|
|
_pageControl.autoresizingMask =
|
|
UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleWidth;
|
|
[self.view addSubview:_pageControl];
|
|
|
|
UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
|
|
[button setTitle:@"Next Page" forState:UIControlStateNormal];
|
|
[button sizeToFit];
|
|
button.center =
|
|
CGPointMake(boundsWidth - button.frame.size.width / 2 - 16, _pageControl.center.y);
|
|
button.autoresizingMask =
|
|
UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleLeftMargin;
|
|
[button addTarget:self
|
|
action:@selector(didTapButton:)
|
|
forControlEvents:UIControlEventTouchUpInside];
|
|
[self.view addSubview:button];
|
|
}
|
|
|
|
#pragma mark - Frame changes
|
|
|
|
- (void)viewWillLayoutSubviews {
|
|
[super viewWillLayoutSubviews];
|
|
NSInteger pageBeforeFrameChange = _pageControl.currentPage;
|
|
NSInteger pageCount = _pages.count;
|
|
CGFloat boundsWidth = CGRectGetWidth(self.view.bounds);
|
|
CGFloat boundsHeight = CGRectGetHeight(self.view.bounds);
|
|
for (NSInteger i = 0; i < pageCount; i++) {
|
|
UILabel *page = [_pages objectAtIndex:i];
|
|
page.frame = CGRectOffset(self.view.bounds, i * boundsWidth, 0);
|
|
}
|
|
_scrollView.contentSize = CGSizeMake(boundsWidth * pageCount, boundsHeight);
|
|
CGPoint offset = _scrollView.contentOffset;
|
|
offset.x = pageBeforeFrameChange * boundsWidth;
|
|
// This non-anmiated change of offset ensures we keep the same page
|
|
[_scrollView setContentOffset:offset animated:NO];
|
|
}
|
|
|
|
#pragma mark - UIScrollViewDelegate
|
|
|
|
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
|
|
[_pageControl scrollViewDidScroll:scrollView];
|
|
}
|
|
|
|
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView {
|
|
[_pageControl scrollViewDidEndDecelerating:scrollView];
|
|
}
|
|
|
|
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView {
|
|
[_pageControl scrollViewDidEndScrollingAnimation:scrollView];
|
|
}
|
|
|
|
#pragma mark - User events
|
|
|
|
- (void)didChangePage:(MDCPageControl *)sender {
|
|
CGPoint offset = _scrollView.contentOffset;
|
|
offset.x = sender.currentPage * _scrollView.bounds.size.width;
|
|
[_scrollView setContentOffset:offset animated:YES];
|
|
}
|
|
|
|
- (void)didTapButton:(id)sender {
|
|
NSUInteger nextPage = MIN(_pageControl.currentPage + 1, _pageControl.numberOfPages - 1);
|
|
CGPoint offset = _scrollView.contentOffset;
|
|
offset.x = nextPage * CGRectGetWidth(_scrollView.frame);
|
|
[_scrollView setContentOffset:offset animated:YES];
|
|
[_pageControl setCurrentPage:nextPage animated:YES];
|
|
}
|
|
|
|
@end
|