mirror of
https://github.com/material-components/material-components-ios.git
synced 2026-02-11 22:10:32 +08:00
* WIP * WIP * Simplified build script and fixed it to build all schemes. * WIP * Renamed script to build_all and added better output. * Add scripts/list_xcode_workspaces. * Filtered out the CocoaPods schemes. * Use Xcode to update Swift to v3. * Updated tracked touches map from NSNumber to Int. * Fixed button sorting that was not actually sorting. * targetContentOffset no longer allowed to be nil. * "Fixed" failing test by reducing random number range? * Swift 3 syntax change. * Swift 3 syntax change. * Removed invalid center-aligning tests. Fixed default nav bar alignment test.
124 lines
4.5 KiB
Swift
124 lines
4.5 KiB
Swift
/*
|
|
Copyright 2016-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 Foundation
|
|
|
|
import MaterialComponents.MaterialPageControl
|
|
|
|
class PageControlSwiftExampleViewController: UIViewController, UIScrollViewDelegate {
|
|
|
|
let pageControl = MDCPageControl()
|
|
let scrollView = UIScrollView()
|
|
let pages = NSMutableArray()
|
|
|
|
override func viewDidLoad() {
|
|
super.viewDidLoad()
|
|
view.backgroundColor = UIColor.white
|
|
|
|
let pageColors = [
|
|
type(of: self).ColorFromRGB(0x55C4f5),
|
|
type(of: self).ColorFromRGB(0x35B7F3),
|
|
type(of: self).ColorFromRGB(0x1EAAF1),
|
|
type(of: self).ColorFromRGB(0x55C4f5),
|
|
type(of: self).ColorFromRGB(0x35B7F3),
|
|
type(of: self).ColorFromRGB(0x1EAAF1),
|
|
];
|
|
|
|
scrollView.frame = self.view.bounds
|
|
scrollView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
|
|
scrollView.delegate = self
|
|
scrollView.isPagingEnabled = true
|
|
scrollView.contentSize = CGSize(width: view.bounds.width * CGFloat(pageColors.count), height: view.bounds.height)
|
|
scrollView.showsHorizontalScrollIndicator = false;
|
|
view.addSubview(scrollView)
|
|
|
|
// Add pages to scrollView.
|
|
for (i, pageColor) in pageColors.enumerated() {
|
|
let pageFrame:CGRect = self.view.bounds.offsetBy(dx: CGFloat(i) * view.bounds.width, dy: 0);
|
|
let page = UILabel.init(frame:pageFrame)
|
|
page.text = String(format: "Page %zd", i + 1)
|
|
page.font = page.font.withSize(50)
|
|
page.textColor = UIColor.init(white: 0, alpha: 0.8)
|
|
page.backgroundColor = pageColor;
|
|
page.textAlignment = NSTextAlignment.center;
|
|
page.autoresizingMask = [.flexibleTopMargin, .flexibleBottomMargin]
|
|
scrollView.addSubview(page)
|
|
pages.add(page)
|
|
}
|
|
|
|
pageControl.numberOfPages = pageColors.count
|
|
|
|
let pageControlSize = pageControl.sizeThatFits(view.bounds.size)
|
|
pageControl.frame = CGRect(x: 0, y: view.bounds.height - pageControlSize.height, width: view.bounds.width, height: pageControlSize.height);
|
|
pageControl.addTarget(self, action: #selector(didChangePage), for: .valueChanged)
|
|
pageControl.autoresizingMask = [.flexibleTopMargin, .flexibleWidth];
|
|
view.addSubview(pageControl)
|
|
}
|
|
|
|
// MARK: - Frame changes
|
|
|
|
override func viewWillLayoutSubviews() {
|
|
super.viewWillLayoutSubviews()
|
|
let pageBeforeFrameChange = pageControl.currentPage;
|
|
for (i, page) in pages.enumerated() {
|
|
let pageLabel:UILabel = page as! UILabel
|
|
pageLabel.frame = view.bounds.offsetBy(dx: CGFloat(i) * view.bounds.width, dy: 0);
|
|
}
|
|
scrollView.contentSize = CGSize(width: view.bounds.width * CGFloat(pages.count), height: view.bounds.height);
|
|
var offset = scrollView.contentOffset;
|
|
offset.x = CGFloat(pageBeforeFrameChange) * view.bounds.width;
|
|
// This non-anmiated change of offset ensures we keep the same page
|
|
scrollView.contentOffset = offset;
|
|
}
|
|
|
|
// MARK: - UIScrollViewDelegate
|
|
|
|
func scrollViewDidScroll(_ scrollView: UIScrollView) {
|
|
pageControl.scrollViewDidScroll(scrollView)
|
|
}
|
|
|
|
func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) {
|
|
pageControl.scrollViewDidEndDecelerating(scrollView)
|
|
}
|
|
|
|
func scrollViewDidEndScrollingAnimation(_ scrollView: UIScrollView) {
|
|
pageControl.scrollViewDidEndScrollingAnimation(scrollView)
|
|
}
|
|
|
|
// MARK: - User events
|
|
|
|
func didChangePage(_ sender: MDCPageControl){
|
|
var offset = scrollView.contentOffset
|
|
offset.x = CGFloat(sender.currentPage) * scrollView.bounds.size.width;
|
|
scrollView.setContentOffset(offset, animated: true)
|
|
}
|
|
|
|
// MARK: CatalogByConvention
|
|
|
|
class func catalogBreadcrumbs() -> [String] {
|
|
return [ "Page Control", "Swift example"]
|
|
}
|
|
|
|
// Creates a UIColor from a 24-bit RGB color encoded as an integer.
|
|
// Pass in hex color values like so: ColorFromRGB(0x1EAAF1).
|
|
class func ColorFromRGB(_ rgbValue: UInt32) -> UIColor {
|
|
return UIColor.init(red: ((CGFloat)((rgbValue & 0xFF0000) >> 16)) / 255,
|
|
green: ((CGFloat)((rgbValue & 0x00FF00) >> 8)) / 255,
|
|
blue: ((CGFloat)((rgbValue & 0x0000FF) >> 0)) / 255,
|
|
alpha: 1)
|
|
}
|
|
}
|