mirror of
https://github.com/material-components/material-components-ios.git
synced 2026-02-20 08:27:32 +08:00
We can credit any contributor who would like to be credited this way, by adding them on request to the AUTHORS file. The copyright statement changes are required for this to work. Note that this has... Summary: We can credit any contributor who would like to be credited this way, by adding them on request to the AUTHORS file. The copyright statement changes are required for this to work. Note that this has no legal change, since the contributors always retained their copyright despite the copyright notice, but it's a nice acknowledgement. Changed copyright statement to include non-Google authors. Command run: find * \( -name '*\.m' -or -name '*\.h' -or -name '*\.swift' \) -and -not \( -path 'scripts/external*' -name Pods \) -print0 | xargs -0 sed -i '' 's/Copyright \(.*\) Google Inc/Copyright \1 the Material Components for iOS authors/' Added non-source files. Command run: grep -Rl 'Copyright .* Google Inc' * --exclude-dir scripts/external --null | xargs -0 sed -i '' 's/Copyright \(.*\) Google Inc/Copyright \1 the Material Components for iOS authors/' Reviewers: featherless, O1 Material components iOS, randallli Reviewed By: O1 Material components iOS, randallli Tags: #material_components_ios Differential Revision: http://codereview.cc/D1415
91 lines
3.1 KiB
Swift
91 lines
3.1 KiB
Swift
/*
|
|
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
|
|
|
|
// This viewcontroller contains a subview that has an MDCShadowLayer.
|
|
// A gesture recognizer allows the user to adjust the elevation of the
|
|
// shadowed view by pressing it, and move it by dragging it.
|
|
|
|
class ShadowDragSquareExampleViewController: UIViewController {
|
|
|
|
@IBOutlet weak var blueView: ExampleShadowedView!
|
|
|
|
// The elevation of the view affects the size of its shadow.
|
|
// The following elevations indicate to the user if the view
|
|
// is pressed or not.
|
|
let kRestingCardElevation: CGFloat = 2.0
|
|
let kSelectedCardElevation: CGFloat = 8.0
|
|
|
|
// A UILongPressGestureRecognizer handles the changing of elevation
|
|
// and location of the shadowedView.
|
|
let longPressRecogniser = UILongPressGestureRecognizer()
|
|
|
|
// We store the offset from the initial touch to the center of the
|
|
// view to properly update its location when dragged.
|
|
var movingViewOffset = CGPointZero
|
|
|
|
override func viewDidLoad() {
|
|
super.viewDidLoad()
|
|
|
|
self.blueView.setElevation(kRestingCardElevation)
|
|
|
|
longPressRecogniser.addTarget(self, action: #selector(longPressedInView))
|
|
longPressRecogniser.minimumPressDuration = 0.0
|
|
self.blueView.addGestureRecognizer(longPressRecogniser)
|
|
}
|
|
|
|
func longPressedInView(sender:UILongPressGestureRecognizer) {
|
|
// Elevation of the view is changed to indicate that it has been pressed or released.
|
|
// view.center is changed to follow the touch events.
|
|
if (sender.state == .Began) {
|
|
self.blueView.setElevation(kSelectedCardElevation)
|
|
|
|
let selfPoint = sender.locationInView(self.view)
|
|
movingViewOffset.x = selfPoint.x - self.blueView.center.x
|
|
movingViewOffset.y = selfPoint.y - self.blueView.center.y
|
|
} else if (sender.state == .Changed) {
|
|
let selfPoint = sender.locationInView(self.view)
|
|
let newCenterPoint =
|
|
CGPoint(x: selfPoint.x - movingViewOffset.x, y: selfPoint.y - movingViewOffset.y)
|
|
self.blueView.center = newCenterPoint
|
|
} else if (sender.state == .Ended) {
|
|
self.blueView.setElevation(kRestingCardElevation)
|
|
|
|
movingViewOffset = CGPointZero
|
|
}
|
|
}
|
|
|
|
// MARK: catalog by convention
|
|
|
|
class func catalogBreadcrumbs() -> Array<String> {
|
|
return [ "Shadow", "Shadow Layer"]
|
|
}
|
|
|
|
class func catalogStoryboardName() -> String {
|
|
return "ShadowDragSquareExample"
|
|
}
|
|
|
|
class func catalogDescription() -> String {
|
|
return "Shadow Layer implements the material design specifications for elevation and shadows."
|
|
}
|
|
|
|
class func catalogIsPrimaryDemo() -> Bool {
|
|
return true
|
|
}
|
|
|
|
}
|