カテゴリー
iOS Swift

View LifecycleのどのタイミングでboundsとsafeAreaInsetsの情報を得るか

override func viewDidLoad() {
  super.viewDidLoad()
  print("printing view.bounds in viewDidLoad: \(view.bounds)")
  print("printing view.safeAreaInsets in viewDidLoad: \(view.safeAreaInsets)")
}

override func viewWillAppear(_ animated: Bool) {
  super.viewWillAppear(animated)
  print("printing view.bounds in viewWillAppear: \(view.bounds)")
  print("printing view.safeAreaInsets in viewWillAppear: \(view.safeAreaInsets)")
}

override func viewWillLayoutSubviews() {
  super.viewWillLayoutSubviews()
  print("printing view.bounds in viewWillLayoutSubviews: \(view.bounds)")
  print("printing view.safeAreaInsets in viewWillLayoutSubviews: \(view.safeAreaInsets)")
}
	
override func viewDidLayoutSubviews() {
  super.viewDidLayoutSubviews()
  print("printing view.bounds in viewWillLayoutSubviews: \(view.bounds)")
  print("printing view.safeAreaInsets in viewWillLayoutSubviews: \(view.safeAreaInsets)")
}

override func viewDidAppear(_ animated: Bool) {
  super.viewDidAppear(animated)
  print("printing view.bounds in viewDidAppear: \(view.bounds)")
  print("printing view.safeAreaInsets in viewDidAppear: \(view.safeAreaInsets)")
}

結果

printing view.bounds in viewDidLoad: (0.0, 0.0, 414.0, 896.0)

printing view.safeAreaInsets in viewDidLoad: UIEdgeInsets(top: 0.0, left: 0.0, bottom: 0.0, right: 0.0)

printing view.bounds in viewWillAppear: (0.0, 0.0, 414.0, 896.0)

printing view.safeAreaInsets in viewWillAppear: UIEdgeInsets(top: 0.0, left: 0.0, bottom: 0.0, right: 0.0)

printing view.bounds in viewWillLayoutSubviews: (0.0, 0.0, 414.0, 896.0)

printing view.safeAreaInsets in viewWillLayoutSubviews: UIEdgeInsets(top: 48.0, left: 0.0, bottom: 34.0, right: 0.0)

printing view.bounds in viewWillLayoutSubviews: (0.0, 0.0, 414.0, 896.0)

printing view.safeAreaInsets in viewWillLayoutSubviews: UIEdgeInsets(top: 48.0, left: 0.0, bottom: 34.0, right: 0.0)

printing view.bounds in viewDidAppear: (0.0, 0.0, 414.0, 896.0)

printing view.safeAreaInsets in viewDidAppear: UIEdgeInsets(top: 48.0, left: 0.0, bottom: 34.0, right: 0.0)

カテゴリー
iOS Swift

UIView内でSwiftUIのViewを使用する

struct PlayController: View {
  var buttonSize:CGFloat = 32
  var body: some View {
    HStack(spacing: 30) {
      Button {
	
      } label: {
        Image(systemName: "stop.fill")
	  .resizable()
	  .frame(width: buttonSize, height: buttonSize)
      }
      Button {
				
      } label: {
        Image(systemName: "play.fill")
	  .resizable()
	  .frame(width: buttonSize, height: buttonSize)
      }
      Button {
			
      } label: {
        Image(systemName: "backward.end.fill")
	  .resizable()
	  .frame(width: buttonSize, height: buttonSize)
      }
      Button {
				
      } label: {
	Image(systemName: "forward.end.fill").resizable()
	  .resizable()
	  .frame(width: buttonSize, height: buttonSize)
      }
    }
  }
}
import UIKit
import SwiftUI

class ViewController: UIViewController {
	
  override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view.
    view.backgroundColor = .red
    constrainControllers()
  }
	
  private func constrainControllers() {
    let controlSwiftUIView = PlayController()
    let controller = UIHostingController(rootView: controlSwiftUIView)
	    
    controller.view.translatesAutoresizingMaskIntoConstraints = false
      self.addChild(controller)
      self.view.addSubview(controller.view)
      controller.didMove(toParent: self)
      controller.view.heightAnchor.constraint(equalToConstant: 100).isActive = true
      controller.view.leadingAnchor.constraint(equalTo: self.view.layoutMarginsGuide.leadingAnchor).isActive = true
      controller.view.trailingAnchor.constraint(equalTo: self.view.layoutMarginsGuide.trailingAnchor).isActive = true
      controller.view.bottomAnchor.constraint(equalTo: self.view.layoutMarginsGuide.bottomAnchor).isActive = true
  }
}
カテゴリー
iOS Swift

Storyboardを使わずにViewをAutoLayoutする

let constraints = [
    view.centerXAnchor.constraint(equalTo: superview.centerXAnchor),
    view.centerYAnchor.constraint(equalTo: superview.centerYAnchor),
    view.widthAnchor.constraint(equalToConstant: 100),
    view.heightAnchor.constraint(equalTo: view.widthAnchor)
]
NSLayoutConstraint.activate(constraints)
extension UIView {

    /* Constraint creation conveniences. See NSLayoutAnchor.h for details.
     */
    open var leadingAnchor: NSLayoutXAxisAnchor { get }

    open var trailingAnchor: NSLayoutXAxisAnchor { get }

    open var leftAnchor: NSLayoutXAxisAnchor { get }

    open var rightAnchor: NSLayoutXAxisAnchor { get }

    open var topAnchor: NSLayoutYAxisAnchor { get }

    open var bottomAnchor: NSLayoutYAxisAnchor { get }

    open var widthAnchor: NSLayoutDimension { get }

    open var heightAnchor: NSLayoutDimension { get }

    open var centerXAnchor: NSLayoutXAxisAnchor { get }

    open var centerYAnchor: NSLayoutYAxisAnchor { get }

    open var firstBaselineAnchor: NSLayoutYAxisAnchor { get }

    open var lastBaselineAnchor: NSLayoutYAxisAnchor { get }
}