data:image/s3,"s3://crabby-images/44523/44523ff949e2028d33e9926caf223a25167137ea" alt=""
ネットに情報が全然なかったので手探りで実装しました、なので他にもっといいやり方があると思います,,,
data:image/s3,"s3://crabby-images/3238c/3238c076aea712f8cbbfb7cdaa57914b41db8bdf" alt=""
UITabBarControllerの追加
Command + N で新規ファイル追加画面を開き、SubclassをUITabBarControllerにしてファイルを追加する & SceneDelegate.swiftのRootViewをTabBarControllerにしておきましょう。
data:image/s3,"s3://crabby-images/97808/97808b6cb61f3d4cc1764d784a9dc0c1e963a2b1" alt=""
import UIKit
class SceneDelegate: UIResponder, UIWindowSceneDelegate {
var window: UIWindow?
func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) {
// 追記 -----ここから
window = UIWindow(windowScene: scene as! UIWindowScene)
window?.makeKeyAndVisible()
let tabBarController = TabBarController()
window?.rootViewController = tabBarController
// 追記 -----ここまで
}
func sceneDidDisconnect(_ scene: UIScene) {
}
func sceneDidBecomeActive(_ scene: UIScene) {
}
func sceneWillResignActive(_ scene: UIScene) {
}
func sceneWillEnterForeground(_ scene: UIScene) {
}
func sceneDidEnterBackground(_ scene: UIScene) {
}
}
タブの数分ViewController.swiftファイルを追加する
data:image/s3,"s3://crabby-images/758de/758de03054633e445cf5eb9b22774a5aa3facf59" alt=""
Tabの切り替えがわかりやすいようにLabelとかImageを入れておきましょう
data:image/s3,"s3://crabby-images/72ce3/72ce32abb830ff93e65d2b741bd726b79dc16e2d" alt=""
TabBarControllerで各Tabの詳細を設定する
import UIKit
class TabBarController: UITabBarController {
override func viewDidLoad() {
super.viewDidLoad()
setupEachTabView()
}
// 各Tabのタイトル、アイコン画像を設定する
private func setupEachTabView() {
let mainViewController = MainViewController(nibName: "MainViewController", bundle: nil)
let mainTabItem = UITabBarItem(title: "Main", image: UIImage(systemName: "house.fill"), tag: 1)
mainViewController.tabBarItem = mainTabItem
let driveViewController = DriveViewController(nibName: "DriveViewController", bundle: nil)
let driveTabItem = UITabBarItem(title: "Drive", image: UIImage(systemName: "car"), tag: 2)
driveViewController.tabBarItem = driveTabItem
let shoppingViewController = ShoppingViewController(nibName: "ShoppingViewController", bundle: nil)
let shoppingTabItem = UITabBarItem(title: "Shopping", image: UIImage(systemName: "bag"), tag: 3)
shoppingViewController.tabBarItem = shoppingTabItem
let settingViewController = SettingViewController(nibName: "SettingViewController", bundle: nil)
let settingTabItem = UITabBarItem(title: "Settings", image: UIImage(systemName: "gear"), tag: 4)
settingViewController.tabBarItem = settingTabItem
self.viewControllers = [mainViewController, driveViewController, shoppingViewController, settingViewController]
}
}
まとめ (るほどでもない)
data:image/s3,"s3://crabby-images/d2e24/d2e2469944c15cafc9d83e0254bfde70eca10fa9" alt=""
Storyboardと違って若干初期設定がめんどくさい気がしました、まあ慣れれば簡単に出来そうな感じではありますが。
そもそもXib開発の環境設定が分からないという方はこちらの記事を参考にしてください。
data:image/s3,"s3://crabby-images/f4c20/f4c20ceb2cee903bb977803d0b5a5852dd251b15" alt=""