【Swift UIKit】'bottomLayoutGuide' was deprecated in iOS 11.0: Use view.safeAreaLayoutGuide.bottomAnchor instead of bottomLayoutGuide.topAnchorの解決法

この記事からわかること

  • SwiftUIKitNSLayoutConstraint発生した警告の解決方法
  • 警告'bottomLayoutGuide' was deprecated in iOS 11.0: Use view.safeAreaLayoutGuide.bottomAnchor instead of bottomLayoutGuide.topAnchorとは?

index

[open]

\ アプリをリリースしました /

ふるログ

ふるさと納税管理アプリ-ふるログ-

無料posted withアプリーチ

SwiftのUIKitでAdMobのバナー広告実装時に公式のコードをコピペしたら警告が発生したので解決方法をまとめていきます。

AdMob:GADBannerView を作成する

発生した警告

発生したのはAutoLayoutをNSLayoutConstraintで定義していた部分でした。これはバナービューを画面の1番下側に配置する制約です。

警告が発生したコード

view.addConstraints(
  [NSLayoutConstraint(item: bannerView,
                      attribute: .bottom,
                      relatedBy: .equal,
                      toItem: bottomLayoutGuide,
                      attribute: .top,
                      multiplier: 1,
                      constant: 0),
    NSLayoutConstraint(item: bannerView,
                      attribute: .centerX,
                      relatedBy: .equal,
                      toItem: view,
                      attribute: .centerX,
                      multiplier: 1,
                      constant: 0)
  ])

発生した警告

'bottomLayoutGuide' was deprecated in iOS 11.0: Use view.safeAreaLayoutGuide.bottomAnchor instead of bottomLayoutGuide.topAnchor

解決方法

警告内容は「iOS11以降からbottomLayoutGuideが非推奨になり代わりにview.safeAreaLayoutGuide.bottomAnchorまたはbottomLayoutGuide.topAnchorを使用してね」とのことでした。

しかしこの値をそのまま指定するとビルドはできるのですがなぜかアプリが停止してしまいました。

結果以下のようtoItemにはview.safeAreaLayoutGuideattributeには.bottomを渡すと正常に動作して警告も解消することができました。

view.addConstraints(
  [NSLayoutConstraint(item: bannerView,
                      attribute: .bottom,
                      relatedBy: .equal,
                      // 変更点
                      toItem:  view.safeAreaLayoutGuide,
                      // 変更点
                      attribute: .bottom,
                      multiplier: 1,
                      constant: 0),
    NSLayoutConstraint(item: bannerView,
                      attribute: .centerX,
                      relatedBy: .equal,
                      toItem: view,
                      attribute: .centerX,
                      multiplier: 1,
                      constant: 0)
  ])

まだまだ勉強中ですので間違っている点や至らぬ点がありましたら教えていただけると助かります。

ご覧いただきありがとうございました。

searchbox

スポンサー

ProFile

ame

趣味:読書,プログラミング学習,サイト制作,ブログ

IT嫌いを克服するためにITパスを取得しようと勉強してからサイト制作が趣味に変わりました笑
今はCMSを使わずこのサイトを完全自作でサイト運営中〜

自作iOSアプリ

\ アプリをリリースしました /

mapping

自分だけの地図を作ろう!-mapping-

無料posted withアプリーチ

割り勘アプリ-bill-

旅行におすすめ!
割り勘アプリ-bill-

無料posted withアプリーチ

Imakoko

現在地を取得するアプリ!Imakoko

無料posted withアプリーチ

ふるログ

ふるさと納税管理アプリ-ふるログ-

無料posted withアプリーチ

Remind-シンプル通知アプリ-

シンプル通知アプリ-Remind-

無料posted withアプリーチ

CLIPURL

好きな記事をクリップしよう!-CLIPURL-

無料posted withアプリーチ

記録カレンダー

続けたを可視化できるアプリ!記録カレンダー

無料posted withアプリーチ

CART-共有できるお買い物リスト-

CART-共有できるお買い物リスト-

無料posted withアプリーチ

Githubにて
iOSアプリのソースコードを公開中!

自作Webアプリ

子育て知識共有サイト-mikata-

子育て知識共有サイト-mikata-

フレームワーク:Laravel/Vue.js

作成の流れQiita「Laravel×Vue.jsを使って初めてWebアプリを自作しました!」

感想:初めて作成したWebアプリです!メールアドレスでの会員登録や質問投稿、回答やコメント、いいねやフォローなどSNSに近い機能を実装してみました。レビューや修正すべきポイントなどを教えていただけると嬉しいです!

New Article

index