How to add Dark Mode in iOS 13

Raúl Ferrer
Swiftly Tech
Published in
3 min readJan 19, 2020

--

Photo by Elliott Engelmann on Unsplash

Introduction

Surely you have heard of Dark Mode on iOS 13, that is, a mode in which the color range of the user interface darkens. This allows, among other things, to improve visibility in places with low light and reduce the energy consumption of applications (dark colors use less energy than light ones).

Although some applications already included a Dark Mode in their interface, it was not until the publication of iOS 13 and iPadOS, that the Dark Mode was included in the configuration of the device itself. To change to Dark mode we have to go to Settings> Display and brightness and select Dark mode.

Adapt applications to Dark Mode

To adapt an application to Dark Mode we must work with Xcode 11 and iOS 13. In addition, we must modify the colors and images used in the application.

Use adaptive colors

Colors that adapt automatically to the style of the interface should be used. For this we have two possibilities:
Use semantic colors. It is a set of colors prepared by Apple, which have two variants: Dark Mode and Light Mode.

To use these colors, for example, from the code, just write:

let color = UIColor.systemGreen

Or if we are in the Interface Builder, select it in the color attribute of the component we want to color.

Define custom colors

As we saw in How to create a color palette (Color Assets) in Xcode, we can define our own color palette in Xcode, so that we can call from any point of the application to these colors (both from the code and from the Interface Builder)

To do this, we select the Assets.xcassets folder (or creating our own .xcassets folder for colors) in the project navigator (Project Navigator).

Then we right-click, select New Color Set and change its attributes to generate the new color.

Two versions of the same color

But now we must generate two versions of the same color: the version of the light or default mode and that of the dark mode.

To do this, from the Color Attributes Inspector we have created, we select the Apperances attribute, and in the Any, Dark option.

When doing this the color appears to us but with two versions: Any Appearance and Dark Appearance. From the property inspector we indicate the color for each of them.

In this way, when the device mode is changed, our application will automatically take the color that corresponds to it.

To be able to change the mode in the simulator, once the application is launched on it, we select the icon that represents two switches in the lower Xcode bar, and then indicate the interface style that we want to be applied.

--

--

Raúl Ferrer
Swiftly Tech

Mobile Engineering Manager & Mobile Developer | Author & Content Creator | I help you become a better developer