Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)

Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)

2017-01-22发布:hangge阅读:3463

从 iOS7 开始,ViewController 便使用全屏布局。同时引入了一个新属性 edgesForExtendedLayout,本文来讲讲 edgesForExtendedLayout 这个属性。

一、edgesForExtendedLayout属性介绍

1,默认值

它是一个类型为 UIExtendedEdge 的属性,指定边缘要延伸的方向,默认值是 UIRectEdge.all,即向四周边缘均延伸。


2,修改默认值

如果不想要四个边缘均延伸,有两种方式对其进行修改。

(1)在代码中设置

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

import UIKit

 

class ViewControllerUIViewController {

 

    override func viewDidLoad() {

        super.viewDidLoad()

         

        //四周均不延伸

        self.edgesForExtendedLayout = []

    }

 

    override func didReceiveMemoryWarning() {

        super.didReceiveMemoryWarning()

    }

}


(2)在 storyboard 中设置,把相关的勾选给去掉。

原文:Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)

 

3,修改后的注意事项

导航栏默认是半透明的,我们还需要修改 UIWindow 的背景色,将其改成白色。

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

import UIKit

 

@UIApplicationMain

class AppDelegateUIResponderUIApplicationDelegate {

 

    var window: UIWindow?

 

    func application(_ application: UIApplication,

                     didFinishLaunchingWithOptions launchOptions:

        [UIApplicationLaunchOptionsKeyAny]?) -> Bool {

         

        self.window?.backgroundColor = UIColor.white

        return true

    }

 

    func applicationWillResignActive(_ application: UIApplication) {

    }

 

    func applicationDidEnterBackground(_ application: UIApplication) {

    }

 

    func applicationWillEnterForeground(_ application: UIApplication) {

    }

 

    func applicationDidBecomeActive(_ application: UIApplication) {

    }

 

    func applicationWillTerminate(_ application: UIApplication) {

    }

}

否则设置不延伸后,透过导航栏就会看到下面的黑色背景。

原文:Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)

 

二、edgesForExtendedLayout属性在开发中的作用

下面通过样例演示这个属性在平时开发中,对我们的布局有什么影响。


1,对一般界面元素的影响

默认情况下,即使视图中上有 navigationBar 或者 tabBar,那么视图仍会延伸覆盖到四周的区域。也就是说默认的布局仍然是从顶部开始。

(1)比如我们在 (0,0) 位置处添加一个 UISwitch 开关组件,默认情况展示结果如下,UISwitch 会被导航栏遮挡。

原文:Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

import UIKit

 

class ViewControllerUIViewController {

 

    override func viewDidLoad() {

        super.viewDidLoad()

         

        let uiswitch = UISwitch()

        uiswitch.frame.origin = CGPoint(x:0, y:0)

        uiswitch.isOn = true

        self.view.addSubview(uiswitch)

    }

 

    override func didReceiveMemoryWarning() {

        super.didReceiveMemoryWarning()

    }

}

 

(2)而设置不延伸后,默认布局将出导航栏底部开始。

原文:Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)


2,对scrollview的影响

  • 这里的 scrollview 包括 UIScrollView,以及继承自 UIScrollView 的 UITableView、UICollectionView、UITextView 等。
  • 虽然默认延伸状态下,scrollview 也是坐标布局也是从屏幕顶部开始,但由于 automaticallyAdjustsScrollViewInsets 属性的存在,scrollview 会自动调整内边距从而不会被导航栏给遮挡。(具体参考我前面的文章:Swift - 当存在导航栏时,scrollview自动下移的问题解决

(1)虽然 scrollview 不会被遮挡,但由于是自动添加了内边距。scrollview 向上滚动的时候其实会延伸到导航栏下面。这里我们把单元格背景色改成黑色,会看的更明显些。

原文:Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)原文:Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)

 

(2)如果改成不延伸的话,不管怎么拖动 scrollview 都一直会在导航栏下方区域。

原文:Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)原文:Swift - edgesForExtendedLayout属性介绍(元素被导航栏遮挡问题)


原文出自:www.hangge.com  转载请保留原文链接:http://www.hangge.com/blog/cache/detail_1519.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值