Android: Каков ключ для получения цвета фона контакта?

Итак, я читал, как создается автоматически созданный цвет фона для контактов. По-видимому, он основан на hashCode() ключа в контакте. Я видел, как он сказал, что электронное письмо используется в качестве ключа, но это не имеет никакого смысла, поскольку не все мои контакты имеют связанные с ними электронные письма, а те, которые не имеют одинакового цвета,

В конечном счете, я хочу получить ТОЧНЫЙ цвет, используемый в карточке контакта. Таким образом, значок, который у меня есть в моем приложении, имеет тот же цвет фона, который будет использоваться, когда вы нажмете на него, и откройте карточку контакта с помощью ACTION_VIEW.

Итак, просто интересно, что мне нужно использовать в качестве ключа для создания того же цвета, который создается приложением для контактов Android, для каждого отдельного контакта? Спасибо.

PS. Вот шестнадцатеричные коды, которые я имею прямо сейчас для цвета нёба. Если бы кто-то тоже мог понять точность этого, я был бы очень признателен. Спасибо.

<array name="letter_tile_colors">
        <item>#f16364</item>
        <item>#f58559</item>
        <item>#f9a43e</item>
        <item>#e4c62e</item>
        <item>#67bf74</item>
        <item>#59a2be</item>
        <item>#2093cd</item>
        <item>#ad62a7</item>
    </array>

Изменить: некоторые люди говорят, что это похоже на другой ответ, цвет контакта с леденцом на Android

Проблема с этим ответом является неполной. В нем объясняется, как создавать цвета таким же образом, но я не просто пытаюсь сделать случайное генерирование цвета. Я ищу, чтобы получить ТОЧНЫЙ цвет, который использует приложение контактов по умолчанию для этого контакта.

Ответ 1

От Google ContactsCommon исходный код:

Идентификатор - это уникальная и детерминированная строка, которая может использоваться для идентификации этого контакта. Обычно это ключ поиска контактов, но также могут использоваться другие контактные данные, особенно для нелокальных или временных контактов, у которых может отсутствовать ключ поиска. Это используется для определения цвета плитки. Из ContactPhotoManager.

Идентификатор используется LetterTileDrawable класс, чтобы выбрать цвет плитки (идентификатор поступает из запроса на контакт).

/**
 * Returns a deterministic color based on the provided contact identifier string.
 */
private int pickColor(final String identifier) {
    if (TextUtils.isEmpty(identifier) || mContactType == TYPE_VOICEMAIL) {
        return sDefaultColor;
    }
    // String.hashCode() implementation is not supposed to change across java versions, so
    // this should guarantee the same email address always maps to the same color.
    // The email should already have been normalized by the ContactRequest.
    final int color = Math.abs(identifier.hashCode()) % sColors.length();
    return sColors.getColor(color, sDefaultColor);
}

Палитты определены в colors.xml файле:

<!-- Background colors for LetterTileDrawables. This set of colors is a subset of
    https://spec.googleplex.com/quantumpalette#extended which passes Google Accessibility
    Requirements for the color in question on white with >= 3.0 contrast. We used
    http://leaverou.github.io/contrast-ratio/#white-on-%23db4437 to double-check the contrast.
    These colors are also used by MaterialColorMapUtils to generate primary activity colors.
-->
<array name="letter_tile_colors">
    <item>#DB4437</item>
    <item>#E91E63</item>
    <item>#9C27B0</item>
    <item>#673AB7</item>
    <item>#3F51B5</item>
    <item>#4285F4</item>
    <item>#039BE5</item>
    <item>#0097A7</item>
    <item>#009688</item>
    <item>#0F9D58</item>
    <item>#689F38</item>
    <item>#EF6C00</item>
    <item>#FF5722</item>
    <item>#757575</item>
</array>
<!-- Darker versions of letter_tile_colors, two shades darker. These colors are used
    for settings secondary activity colors. -->
<array name="letter_tile_colors_dark">
    <item>#C53929</item>
    <item>#C2185B</item>
    <item>#7B1FA2</item>
    <item>#512DA8</item>
    <item>#303F9F</item>
    <item>#3367D6</item>
    <item>#0277BD</item>
    <item>#006064</item>
    <item>#00796B</item>
    <item>#0B8043</item>
    <item>#33691E</item>
    <item>#E65100</item>
    <item>#E64A19</item>
    <item>#424242</item>
</array>
<!-- The default color used for tinting photos when no color can be extracted via Palette,
        this is Blue Grey 500 -->
<color name="quickcontact_default_photo_tint_color">#607D8B</color>
<!-- The default secondary color when no color can be extracted via Palette,
        this is Blue Grey 700 -->
<color name="quickcontact_default_photo_tint_color_dark">#455A64</color>
<color name="letter_tile_default_color">#cccccc</color>
<color name="letter_tile_font_color">#ffffff</color>

Ответ 2

Надеюсь, это поможет вам.

 private static final int NUM_OF_TILE_COLORS = 8;
 private final TypedArray mColors;

    //initialize inside oncreate of your activity
    mColors = res.obtainTypedArray(R.array.letter_tile_colors);//array of colors you have

    //call in wherver you want, key is the name of the contact
    private int pickColor(String key) {
    // String.hashCode() is not supposed to change across java versions, so
    // this should guarantee the same key always maps to the same color
    final int color = Math.abs(key.hashCode()) % NUM_OF_TILE_COLORS;
    try {
        return mColors.getColor(color, Color.BLACK);
    } finally {
        mColors.recycle();
    }
}