SUSI is an artificial intelligence for interactive chat bots. It provides response to the user in most intuitive way. Therefore we thought why not implement the option to give theme preference to the user to make it more interactive. It will also help in increasing the user’s interest towards the application.
We tried out different themes and then finally decided to settle for the newly announced Day Night Theme for the SUSI Android App (https://github.com/fossasia/susi_android). This theme is provided by AppCompat 23.2.0 . With the help of this theme we can switch between Theme.AppCompat.Light (light) and Theme.AppCompat (dark) based on the user preference and time of day. For default the theme is set to the light theme and it can be easily changed from the settings. Thus it allows the user to change the theme according to his or her mood which looks very intuitive.
How to use this theme?
To use the Day Night theme is quite simple. We just need to extend our default theme to that of Theme.AppCompat.DayNight. The declaration is done as shown below in the screenshot.
<style name="MyTheme" parent="Theme.AppCompat.DayNight"> <!-- Blah blah --> </style>
Now to enable different features of the theme in our application we need to call AppCompatDelegate.setDefaultNightMode(). It takes one of the following values as the parameter.
- MODE_NIGHT_NO. This is for the day (light) theme.
- MODE_NIGHT_YES.This is for the night (dark) theme.
- MODE_NIGHT_AUTO. It automatically changes between the above two themes based on the time of day.
- MODE_NIGHT_FOLLOW_SYSTEM (default). This theme is dependent on the system settings of the user mobile phone.
We can set one of these parameters at the time of calling the function to fix the theme of the application in the following way.
static { AppCompatDelegate.setDefaultNightMode( AppCompatDelegate.MODE_NIGHT_...); }
The theme inside an activity is set at the time time of calling onCreate() method. Therefore we cannot change the theme from any other place inside our activity apart from onCreate(). If we want to set it inside our activity but outside the onCreate() method then we have to call the recreate() function to recreate the whole activity which will implement the selected theme.Let us look at the example.
public class MyActivity extends AppCompatActivity { public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); if (savedInstanceState == null) { // Set the local night mode to some value getDelegate().setLocalNightMode( AppCompatDelegate.MODE_NIGHT_...); // Now recreate for it to take effect recreate(); } } }
To take care of the text colors in our app we can set textColor attribute as
?android:attr/textColorPrimary
Now let us look at the implementation in Susi Android
In Susi Android we are providing user the option to select either the dark or the light theme in the settings.
The code for the implementation is as below
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); prefs = getSharedPreferences(Constant.THEME, MODE_PRIVATE); if(prefs.getString(Constant.THEME,"Dark").equals("Dark")) { AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_YES); } else { AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_NO); } setContentView(R.layout.activity_main); }
The result output for the light theme is
To learn more about themes in Android you can refer to this link.
Resources
- Basics of Day-Night Theme by Chris Banes on Medium: https://medium.com/@chrisbanes/appcompat-v23-2-daynight-d10f90c83e94
- Code Vs Colour Article on Day-Night Theme: http://codevscolor.com/2016/06/android-daynight-view-tutorial/