-
Notifications
You must be signed in to change notification settings - Fork 944
/
MDCBottomSheetTransitionController.h
94 lines (73 loc) · 3.5 KB
/
MDCBottomSheetTransitionController.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
// Copyright 2017-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>
/**
MDCBottomSheetTransitionController is be used to setup a custom transition and animationed
presentation and dismissal for material-styled bottom-sheet presentation.
This class provides a basic implementation of UIViewControllerAnimatedTransitioning and
UIViewControllerTransitioningDelegate.
In order to use a custom modal transition, the UIViewController to be presented must set two
properties. The UIViewControllers transitioningDelegate should be set to an instance of this class.
myDialogViewController.modalPresentationStyle = UIModalPresentationCustom;
myDialogViewController.transitioningDelegate = bottomSheetTransitionController;
The presenting UIViewController then calls presentViewController:animated:completion:
[rootViewController presentViewController:myDialogViewController animated:YES completion:...];
*/
@interface MDCBottomSheetTransitionController
: NSObject <UIViewControllerAnimatedTransitioning, UIViewControllerTransitioningDelegate>
/**
Interactions with the tracking scroll view will affect the bottom sheet's drag behavior.
If no trackingScrollView is provided, then one will be inferred from the associated view
controller.
*/
@property(nonatomic, weak, nullable) UIScrollView *trackingScrollView;
/**
When set to false, the bottom sheet controller can't be dismissed by tapping outside of sheet area.
*/
@property(nonatomic, assign) BOOL dismissOnBackgroundTap;
/**
This is used to set a custom height on the sheet view. This is can be used to set the initial
height when the ViewController is presented.
@note If a positive value is passed then the sheet view will be that height even if
perferredContentSize has been set. Otherwise the sheet will open up to half the screen height or
the size of the presentedViewController's preferredContentSize whatever value is smaller.
@note The preferredSheetHeight can never be taller than the height of the content, if the content
is smaller than the value passed to preferredSheetHeight then the sheet view will be the size of
the content height.
*/
@property(nonatomic, assign) CGFloat preferredSheetHeight;
@end
@interface MDCBottomSheetTransitionController (ScrimAccessibility)
/**
If @c YES, then the dimmed scrim view will act as an accessibility element for dismissing the
bottom sheet.
Defaults to @c NO.
*/
@property(nonatomic, assign) BOOL isScrimAccessibilityElement;
/**
The @c accessibilityLabel value of the dimmed scrim view.
Defaults to @c nil.
*/
@property(nullable, nonatomic, copy) NSString *scrimAccessibilityLabel;
/**
The @c accessibilityHint value of the dimmed scrim view.
Defaults to @c nil.
*/
@property(nullable, nonatomic, copy) NSString *scrimAccessibilityHint;
/**
The @c accessibilityTraits of the dimmed scrim view.
Defaults to @c UIAccessibilityTraitButton.
*/
@property(nonatomic, assign) UIAccessibilityTraits scrimAccessibilityTraits;
@end