質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

Q&A

解決済

1回答

341閲覧

iPhoneX(シミュレータ)で、広告表示がずれてしまう

bizkit.kit

総合スコア30

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

0グッド

0クリップ

投稿2017/09/30 13:01

リリース済みのアプリをiOS11に対応しようとしています。

シミュレータにiPhoneXがあったので動かしてみたのですが、広告表示がズレてしまいました。
iPhoneX以外の機種で動かすとこのようになるのですが、
イメージ説明

iPhoneXで動かすと、このようになります。
イメージ説明

画面上にはUITableViewとその下にUIToolBarを配置してあり、広告は画面最下部に表示するのですが、
UIToolBarがある画面は、広告表示時に広告表示位置のy座標からUIToolBarの高さを引く、という単純な処理です。

iPhoneXだとUIToolBarプラス何かがあるようで、少しだけボタンが隠れてしまいます。
適当に値をマイナスしようかなと思ったのですが、それだとiPhoneX以外の機種でズレてしまいます。

UIDeviceを使って機種名で場合分けしようかなと思ったのですが、シミュレータではうまく値が取れないみたいでうまくいきませんでした。

どのように対応するのがよいでしょうか。
(実機の発売を待って購入した方がいいのかもしれませんが。。。)

以上、よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

結論から言うと、iOS11からUIViewに新しく増えたsafeAreaInsetsプロパティを使用するといいです。
下に開いている余白は、OSの互換性も考慮すると以下のように書けます。

var sideInsets: UIEdgeInsets { if #available(iOS 11.0, *) { return view.safeAreaInsets } else { // iOS10以下の端末では一定 return UIEdgeInsets(top: 20, left: 0, bottom: 0, right: 0) } } safeAreaInsets.bottom // UIToolBar下部の空白の高さ

-- 以下、より詳細な説明です --

iOS11からSafeAreaという概念が加わったのですが、UIKitの一部のクラスではデフォルトでSafeAreaに収まるような挙動をします。(UIToolBarもこれにより下からマージンがあいた位置に配置されていると思われます。)
そのため、画面端からの位置を手動計算するコードを入れている場合だとレイアウト崩れが予想されます。

Safe Areaは、Storyboardでもコード上でも柔軟に扱えるので便利です。
このあたりの話は、以下の記事が役立ちます。
https://qiita.com/eimei4coding/items/5a0794cf7cd13c82b2b5
https://qiita.com/lovee/items/21131fb441a1a86b45e3

投稿2017/09/30 14:58

yuutetu

総合スコア88

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

bizkit.kit

2017/10/01 02:46

ありがとうございます! うまくいきました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問