絵文字選択ツール

絵文字選択ツールは、最新の外観、最新の絵文字、使いやすさを提供する UI ソリューションです。ユーザーは絵文字とそのバリエーションをブラウジングして選択したり、最近使用した絵文字から選択したりできます。

図 1. 絵文字選択ツール
で確認できます。

このライブラリを使用することで、さまざまな提供元のアプリが、包括的で使いやすい ユーザーに統一された絵文字エクスペリエンスを提供できます。デベロッパーは、 独自の絵文字選択ツールをゼロから維持していました。

機能

絵文字選択ツールには次の機能があります。

最新の絵文字

新しくリリースされた絵文字は、絵文字選択ツールに選択的に表示されます。絵文字選択ツール ライブラリは、複数の Android バージョンとデバイスに対応しています。

固定バリアント

絵文字を長押しすると、性別などのバリエーションのメニューが表示され、 調整できます選択したバリエーションは絵文字選択ツールに保存され、最後に選択したバリエーションがメインパネルで使用されます。

この機能により、ユーザーは好みの絵文字のバリエーションをワンタップで送信できます。

絵文字のバリエーション
図 2. 絵文字のバリエーション。

最近使用した絵文字

最近の絵文字
図 3. 最近使用した絵文字。

RecentEmojiProvider は [最近使用した絵文字] カテゴリに絵文字を提供します。このライブラリには、最も一般的なユースケースを満たすデフォルトの最新の絵文字プロバイダがあります。

  • 選択したすべての絵文字がアプリごとに共有設定に保存されます。
  • 選択ツールには、選択した絵文字が重複除去されて最大 3 行が逆順に表示されます 時系列で表示されます。

このデフォルトの動作で十分な場合は、 setRecentEmojiProvider()

ただし、プロバイダの動作をカスタマイズする必要がある場合があります。一般的な シナリオ:

  • ユーザー アカウントごとに異なる選択した絵文字を保存する必要がある。
  • 共有設定以外のデータ ストレージを使用したい場合。
  • 最近使用した絵文字を頻度順に表示したい。

次に、RecentEmojiProvider インターフェースを実装し、次のコマンドを使用して設定します。 setRecentEmojiProvider()

方向セレクタ

Emoji 15.1 以降、絵文字選択ツールは双方向絵文字をサポートしています。ユーザーは双方向切り替えボタンをタップして、絵文字の向きを左右に切り替えることができます。

左向きの双方向絵文字

図 4. 双方向の絵文字が左を向いている。

双方向の右絵文字

図 5. 双方向の絵文字が右を向いている。

複数の人物の絵文字選択ツール

絵文字のカップルを長押しすると、複数の人物が登場する絵文字が表示されます。

絵文字のカップルを長押しする

図 6. 絵文字のペアを長押しすると、複数の絵文字の選択が表示されます。

左側の絵文字の人物アイコンをタップします。

図 7. 左半分の絵文字の人物を選択します。

右の絵文字アイコンをタップ

図 8. 右半分の絵文字を選択します。

ユーザーが絵文字ペアの左半分または右半分の絵文字を選択すると、 セレクタの右下にプレビューが表示されます(図 7 を参照)。 8.絵文字カップルの両方を選択したら、プレビューを選択してカスタム絵文字カップルを作成できます。

EmojiCompat との互換性

有効にすると、EmojiCompat インスタンスが絵文字選択ツールで使用され、次のようにレンダリングされます。 できるだけ多くの絵文字を使用します。ただし、絵文字選択ツールには EmojiCompat は必要ありません。

前提条件

アプリの対象 OS は、Android 5.0(API レベル 21)以上にする必要があります。

ライブラリを使用する

  1. アプリの build.gradle ファイルに androidx.emoji2:emojipicker:$version をインポートします。

    dependencies {
        implementation "androidx.emoji2:emojipicker:$version"
    }
    
  2. 絵文字選択ツールのビューをインフレートし、必要に応じて emojiGridRowsemojiGridColumns

    • emojiGridColumns のデフォルト数は 9 です。
    • 行数は、親ビューの高さと emojiGridColumns の値に基づいて計算されます。
    • emojiGridRows に浮動小数点値を使用して、ユーザーがスクロールして絵文字を追加できることを示します。
    <androidx.emoji2.emojipicker.EmojiPickerView
        android:id="@+id/emoji_picker"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:emojiGridColumns="9" />
    
    val emojiPickerView = EmojiPickerView(context).apply {
        emojiGridColumns = 15
        layoutParams = ViewGroup.LayoutParams(
            ViewGroup.LayoutParams.MATCH_PARENT,
            ViewGroup.LayoutParams.MATCH_PARENT
        )
    }
    
    findViewById<ViewGroup>(R.id.emoji_picker_layout).addView(emojiPickerView)
    
  3. setOnEmojiPickedListener() を使用して、選択した絵文字をビューに追加します。たとえば、EditText に追記するには、次のようにします。

    emojiPickerView.setOnEmojiPickedListener {
        findViewById<EditText>(R.id.edit_text).append(it.emoji)
    }
    
  4. 必要に応じて RecentEmojiProvider を設定します。サンプルアプリで例をご覧ください。 説明します。

  5. 必要に応じてスタイルをカスタマイズします。独自のスタイルを作成して共通のテーマをオーバーライドする 属性を作成し、スタイルを EmojiPickerView に適用します。たとえば colorControlNormal をオーバーライドすると、カテゴリ アイコンの色が変更されます。

    <style name="CustomStyle" >
        <item name="colorControlNormal">#FFC0CB</item>
    </style>
    <androidx.emoji2.emojipicker.EmojiPickerView
        android:id="@+id/emoji_picker"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:theme="@style/CustomStyle"
        app:emojiGridColumns="9" />
    

サンプルアプリ

絵文字選択ツールのサンプルアプリ: 基本的なユースケースの例と 次の追加シナリオがあります

  • emojiGridRows または emojiGridColumns がリセットされたときのレイアウトの再計算。
  • 頻度で並べ替えられた、オーバーライドされた最近の絵文字プロバイダです。
  • スタイルの追加のカスタマイズ。