不容错过的iOS 8的导航交互
来源:互联网 发布:时时彩后一做号软件 编辑:程序博客网 时间:2024/04/30 01:10
以下是iOS 8中非常酷的导航交互方式,可以让用户看到更多内容。
滚动页面时隐藏Bar
如果你有一个Table View,仅需要将导航控件的hidesBarsOnSwipe属性设置为true就OK了。
1
2
3
4
5
6
7
8
class QuotesTableViewController: UITableViewController {
override func viewDidAppear(animated: Bool) {
super
.viewDidAppear(animated)
navigationController?.hidesBarsOnSwipe =
true
}
}
注意导航栏的行为会影响到在你的导航堆栈里所有的视图控件,所以如果你希望某一视图控控件的导航条不会跟着隐藏的话,你需要设置一下viewDidAppear。
点击时隐藏
如果你的视图并不像上面所示那样的卷动的话,你可以试着将hidesBarsOnTap的属性设置为true.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class QuoteImageViewController: UIViewController {
override func viewDidAppear(animated: Bool) {
super
.viewDidAppear(animated)
// 将hidesBarsOnSwift设置为false
// 在此后的这个条件下它不会有任何效果
// 不过在上一个VC中它被设置成了true
navigationController?.hidesBarsOnSwipe =
false
// setting hidesBarsOnTap to true
navigationController?.hidesBarsOnTap =
true
}
}
请注意,如果你之前在导航栈中某个视图控件里设置过hidesBarOnSwipe,你需要再次将其赋值为false以避免这个视图会发生像其他的视图那样的行为。同样的,如果对于Table View也曾有过设置,那你仍需要重新将navigationController?.hidesBarsOnTap设为false避免出错。
展示键盘输入时隐藏
如上图,使用导航控件的新特性hidesBarsWhenKeyboardAppears,你可以在输入键盘出现时将导航栏隐藏:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
class CreateQuoteTableViewController: UITableViewController {
override func viewDidAppear(animated: Bool) {
super
.viewDidAppear(animated)
navigationController?.hidesBarsOnSwipe =
false
// 这个例子恰到好处的结合了hidesBarsOnTap和hidesBarsWhenKeyboardAppears两个特性
// 这样用户可以轻松的唤回导航栏并保存
navigationController?.hidesBarsOnTap =
true
navigationController?.hidesBarsWhenKeyboardAppears =
true
}
}
为了确保用户在使用时可以轻易的唤出隐藏的导航栏,你应该在需要的时候将hidesBarsOnTap或者hidesBarsOnSwipe设置为true.
其他特性
下面演示的是其他新的导航控制器属性,你可以看一下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
class UINavigationController : UIViewController {
//... truncated
/// When the keyboard appears, the navigation controller's navigationBar toolbar will be hidden. The bars will remain hidden when the keyboard dismisses, but a tap in the content area will show them.
@availability(iOS, introduced=8.0)
var
hidesBarsWhenKeyboardAppears: Bool
/// When the user swipes, the navigation controller's navigationBar & toolbar will be hidden (on a swipe up) or shown (on a swipe down). The toolbar only participates if it has items.
@availability(iOS, introduced=8.0)
var
hidesBarsOnSwipe: Bool
/// The gesture recognizer that triggers if the bars will hide or show due to a swipe. Do not change the delegate or attempt to replace this gesture by overriding this method.
@availability(iOS, introduced=8.0)
var
barHideOnSwipeGestureRecognizer: UIPanGestureRecognizer { get }
/// When the UINavigationController's vertical size class is compact, hide the UINavigationBar and UIToolbar. Unhandled taps in the regions that would normally be occupied by these bars will reveal the bars.
@availability(iOS, introduced=8.0)
var
hidesBarsWhenVerticallyCompact: Bool
/// When the user taps, the navigation controller's navigationBar & toolbar will be hidden or shown, depending on the hidden state of the navigationBar. The toolbar will only be shown if it has items to display.
@availability(iOS, introduced=8.0)
var
hidesBarsOnTap: Bool
/// The gesture recognizer used to recognize if the bars will hide or show due to a tap in content. Do not change the delegate or attempt to replace this gesture by overriding this method.
@availability(iOS, introduced=8.0)
unowned(unsafe)
var
barHideOnTapGestureRecognizer: UITapGestureRecognizer { get }
}
0 0
- 不容错过的iOS 8的导航交互
- 不容错过的iOS 8的导航交互
- 不容错过的iOS 8的导航交互
- 不容错过的iOS 8的导航交互
- 不容错过的网络技术资源
- 一些不容错过的好书
- 十款不容错过的Swift iOS开源项目
- 十款不容错过的Swift iOS开源项目
- 十款不容错过的Swift iOS开源项目
- 每位iOS开发人员不容错过的10大实用工具
- iOS开发不容错过的10大实用工具
- iOS开发人员不容错过的10大工具
- 不容错过的 Window 8 Metro 风格 UI 资源
- 不容错过的 Window 8 Metro 风格 UI 资源
- UI 设计师不容错过的12款APP UI 交互设计
- 不容错过的一款很棒的机器人
- 不容错过的虚拟化工具
- Transformers:不容错过的精彩大片
- 基于RBAC的Easyui树形权限菜单的实现原理
- struts2中的constant配置详解
- 黑马程序员——MAC系统快捷键汇总
- alias
- nohub 管理后台任务
- 不容错过的iOS 8的导航交互
- 腾讯笔试题回顾
- 方便好用的外键约束
- poj1144 求图的割点
- Android平台下通过JNI快速实现音视频通信
- leetcode - Merge Sorted Array
- Linux 系统的顶层目录结构
- IT人才如何使用HTML5 Notication API实现一个定时提醒工具
- 用Maven整合SpringMVC+Spring+Hibernate 框架,实现简单的插入数据库数据功能