ios navigationBar 设置透明

16 篇文章 0 订阅

// 首先设置navigationBar 的具体背景样式

override func viewWillAppear (_ animated: Bool) {
        super.viewWillAppear(animated)
        let dic: [NSAttributedString.Key: Any] = [.foregroundColor: UIColor.white, .font: UIFont.systemFont(ofSize: 18) as Any]
        if #available(iOS 15, *) {
            let appearance = UINavigationBarAppearance()
            appearance.titleTextAttributes = dic
            appearance.configureWithTransparentBackground()
            appearance.backgroundColor = .clear
            appearance.backgroundEffect = UIBlurEffect(style: .dark)
            navigationController?.navigationBar.standardAppearance = appearance
            navigationController?.navigationBar.scrollEdgeAppearance = appearance
        } else {
            navigationController?.navigationBar.titleTextAttributes = dic
            navigationController?.navigationBar.setBackgroundImage(UIImage(), for: UIBarMetrics.default)
            navigationController?.navigationBar.shadowImage = UIImage()
        }
    }

// 其次设置navigationBar 是否透明

override func viewDidLoad() {
        super.viewDidLoad()
        extendedLayoutIncludesOpaqueBars = true   //非常关键

        // Do any additional setup after loading the view.
    }

// 最后需要设置布局起始点位置 ,如果非tableview, collectionview  则设置属性:


override func viewDidLoad() {
        super.viewDidLoad()
        self.edgesForExtendedLayout = .bottom
        // Do any additional setup after loading the view.
    }

// 如果是tableview,collectionview布局,则需要设置属性:

    lazy var tableView: UITableView = {
        let tableview = UITableView(frame: .zero, style: .plain)
        tableview.dataSource = self
        tableview.delegate = self
        tableview.separatorStyle = .none
        tableview.contentInsetAdjustmentBehavior = .always  // 非常关键
        tableview.backgroundColor = UIColor.clear
        tableview.showsVerticalScrollIndicator = false
        return tableview
    }()

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值