Android

Get the module

To add the Driver Achievement UI module to your app, add the following lines to your dependencies in your application build.gradle file:

dependencies {
implementation 'com.drivequant.drivekit:drivekit-driver-achievement-ui:$drivekitui_version'
}

Replace $drivekitui_version with the DriveKit version you are using in your app

On a Github repository, you also have a demo app and source code of Driver Achievement UI that you can use as an example.

Initialize

An initialization phase is required to use the feature included in the Driver Achievement UI SDK.

‌Then, to initialize the Driver Achievement UI component in your app, you must call the initialization method in onCreate method of your Application class:

class MyApplication: Application() {

    override fun onCreate() {
        super.onCreate()
        DriveKitUI.initialize()
        DriverAchievementUI.initialize()
        ...
    }
}

Override colors and texts

To override colors and texts in the Driver Achievement UI SDK, see Common UI configuration.

Select Streak themes

You can choose which streak theme you want to display in which order, by calling the following method:

DriverAchievementUI.configureStreakThemes(streakThemes : List<StreakTheme>)

Accepted values:

  • PHONE_DISTRACTION

  • SAFETY

  • ACCELERATION

  • BRAKE

  • ADHERENCE

  • SPEEDING

  • CALL

Default value:

listOf(PHONE_DISTRACTION, SAFETY, ACCELERATION, BRAKE, ADHERENCE, CALL)

For SPEEDING streaks, make sure that the service is activated on your DriveQuant account.

Display streak list interface

To display the streak list UI, you can call the following methods:

By creating a Fragment

val fragment = DriverAchievementUI.createStreakListFragment()

By launching an Activity

DriverAchievementUI.startRankingActivity(context)

Select Badges categories

You can choose which badge category you want to display in which order, by calling the following method:

val categories = listOf(
   BadgeCategory.GENERIC,
   BadgeCategory.ECO_DRIVING,
   BadgeCategory.SAFETY,
   BadgeCategory.PHONE_DISTRACTION)

DriverAchievementUI.configureBadgeCategories(categories)

Accepted values:

  • GENERIC

  • SAFETY

  • ECO_DRIVING

  • PHONE_DISTRACTION

Default value:

listOf(GENERIC, PHONE_DISTRACTION, SAFETY, ECO_DRIVING)

Display Badge list interface

To show the badge UI you can use these following methods:

By creating a Fragment

supportFragmentManager
    .beginTransaction()
    .replace(R.id.yourContainer, BadgesListFragment())
    .commit()

By launching an Activity

val intent = Intent(context, BadgeListActivity::class.java)
context.startActivity(intent)

Select ranking themes

By calling the following method, you can choose which rank type you want to display:

 val rankingTypes = listOf(
  RankingType.SAFETY,
  RankingType.ECO_DRIVING,
  RankingType.DISTRACTION)

 DriverAchievementUI.configureRankingTypes(rankingTypes)

Accepted values:

  • RankingType.SAFETY

  • RankingType.ECO_DRIVING

  • RankingType.DISTRACTION

  • RankingType.SPEEDING

Default values [RankingType.SAFETY, RankingType.ECO_DRIVING, RankingType.DISTRACTION]

Set ranking selectors

You can have many periods displayed on the ranking screen. This way, the user can see his ranking on many periods. The following method allows you to selected the order of the displayed periods:

val rankingPeriods = listOf(
 RankingPeriod.WEEKLY,
 RankingPeriod.MONTHLY,
 RankingPeriod.ALL_TIME)

 val rankingSelectorType = RankingSelectorType.PERIOD(rankingPeriods)
 DriverAchievementUI.configureRankingSelector(rankingSelectorType)

Accepted values :

  • RankingPeriod.WEEKLY,

  • RankingPeriod.MONTHLY,

  • RankingPeriod.ALL_TIME

Default value: [RankingPeriod.WEEKLY, RankingPeriod.MONTHLY, RankingPeriod.ALL_TIME]

If you don’t need any kind of selectors you can use the following method:

 val rankingSelectorType = RankingSelectorType.NONE
 DriverAchievementUI.configureRankingSelector(rankingSelectorType)

In this case, the period of the ranking is weekly

Configure ranking depth

This method allows you to choose the ranking depth you want to display:

val rankingDepthValue = 20
DriverAchievementUI.configureRankingDepth(rankingDepthValue)

Accepted values: from 5 to 20

Default value: 5

Display Ranking interface

To display the ranking interface, you can call the following methods:

By creating a Fragment

RankingFragment.newInstance()

By launching an Activity

RankingActivity.launchActivity(context)

Last updated