Swift is a programming language that supports all of Apple’s platforms, focusing on safety and performance, and is widely used by developers to create apps within the Apple ecosystem. In this article, we will learn step by step how to add a new tab to an iPhone app using Swift and UIKit. It will be explained in detail so that anyone from beginners to intermediate developers can easily follow along.
1. Introduction to UIKit and Tab Bar Controller
UIKit is the framework necessary for building the user interface of iOS applications. It provides various UI components for user interaction and greatly helps in improving the user experience within applications. Among them, UITabBarController is a very useful controller that allows easy switching between different screens of an application.
1.1. Basic Principles of Tab Bar Controller
A Tab Bar Controller arranges multiple view controllers in a tab format at the bottom of the screen, allowing users to easily navigate to different views. Users can click on the tabs to switch to other screens, thereby organizing screens into logical groups. Using tabs in an app is very common and provides intuitive navigation for users.
2. Creating a New iPhone App Project
Now, let’s create a new iOS project using Xcode. Please follow the steps below.
2.1. Launch Xcode
Open Xcode and click ‘Create a new Xcode project’.
2.2. Select Project Template
Select ‘App’ under ‘iOS’ and click the ‘Next’ button.
2.3. Enter Project Information
Enter the project name, organization name, and organization identifier, then select ‘Swift’ and ‘Storyboard’.
2.4. Create the Project
Click ‘Next’ to choose a location to create the project, and then click the ‘Create’ button to create the project.
3. Setting Up the Tab Bar Controller
Now that the project has been created, let’s set up the Tab Bar Controller. The next step is to add the Tab Bar Controller to the main storyboard.
3.1. Open the Storyboard
Click on the ‘Main.storyboard’ file in the left panel of Xcode to open the storyboard.
3.2. Add the Tab Bar Controller
Search for ‘Tab Bar Controller’ in the object library and drag and drop it into the storyboard.
3.3. Add View Controllers
The Tab Bar Controller comes with two default view controllers. Please add as many view controllers as needed. Each view controller should have its own tab icon and title set.
3.4. Set Tab Items
Select each view controller and use the ‘Attributes Inspector’ at the bottom to set the Title and Image of the Tab Bar Item. This way, users can easily understand what each tab represents.
4. Setting Up the Tab Bar Controller via Code
In addition to setting up the UI using a storyboard, you can also set up the Tab Bar Controller via code. Here’s how to implement it using Swift code.
4.1. Set Tab Bar Controller as the Root View Controller
import UIKit
    @UIApplicationMain
    class AppDelegate: UIResponder, UIApplicationDelegate {
        var window: UIWindow?
        func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
            window = UIWindow()
            let tabBarController = UITabBarController()
            // Define each view controller
            let firstViewController = FirstViewController()
            let secondViewController = SecondViewController()
            
            // Set tab items
            firstViewController.tabBarItem = UITabBarItem(title: "First", image: UIImage(systemName: "1.circle"), tag: 0)
            secondViewController.tabBarItem = UITabBarItem(title: "Second", image: UIImage(systemName: "2.circle"), tag: 1)
            // Add views to the tab bar controller
            tabBarController.viewControllers = [firstViewController, secondViewController]
            window?.rootViewController = tabBarController
            window?.makeKeyAndVisible()
            return true
        }
    }5. Adding a New Tab
Adding a new tab is very simple. You can dynamically add it via code without having to go through multiple elements in the storyboard. Let’s look at the following example.
5.1. Create a New View Controller
You can create a new tab by adding a third view controller as follows.
class ThirdViewController: UIViewController {
        override func viewDidLoad() {
            super.viewDidLoad()
            view.backgroundColor = .systemGreen
            let label = UILabel()
            label.text = "Third Tab"
            label.textAlignment = .center
            label.frame = view.bounds
            view.addSubview(label)
        }
    }5.2. Connect the New Tab and View Controller
let thirdViewController = ThirdViewController()
    // Set a new tab item
    thirdViewController.tabBarItem = UITabBarItem(title: "Third", image: UIImage(systemName: "3.circle"), tag: 2)
    // Add the new view controller to the existing view controllers
    tabBarController.viewControllers?.append(thirdViewController)
    }6. Custom Tab Icons and Styles
In addition to the default styles of Tab Bar Items, you can customize the icons and colors to match your app’s design. This allows for a more refined UI.
6.1. Using Custom Icons
To customize the icons, you must first add the icon images you will use to the project. Afterward, you can set the icons as follows.
firstViewController.tabBarItem.image = UIImage(named: "custom_icon_1")
    secondViewController.tabBarItem.image = UIImage(named: "custom_icon_2")6.2. Changing Tab Bar Styles
You can also change the background color or text color of the tab bar. For example:
UITabBar.appearance().tintColor = .systemBlue
    UITabBar.appearance().barTintColor = .white7. Code Optimization and Maintenance
Optimizing and maintaining the code is important in the app development process. It is advisable to manage each view controller in separate files and to encapsulate common logic in methods for reuse. For instance, common UI elements can be managed in a base class.
8. Conclusion
In this article, we explored how to add a new tab to an iPhone app using Swift and UIKit. By utilizing the Tab Bar Controller, you can provide an intuitive interface for users while also enhancing the maintainability and scalability of the application. I hope this process has been helpful to you, and I encourage you to challenge yourself with more advanced app development.
In the next tutorial, we will explore a more modern UI development approach by combining SwiftUI and UIKit. Thank you!