File: TextAttribute.java

package info (click to toggle)
android-platform-frameworks-base 1%3A14~beta1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 326,096 kB
  • sloc: java: 2,032,373; xml: 343,016; cpp: 304,183; python: 3,683; ansic: 2,090; sh: 1,871; makefile: 120; sed: 19
file content (140 lines) | stat: -rw-r--r-- 4,922 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
/*
 * Copyright (C) 2021 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package android.view.inputmethod;

import android.annotation.NonNull;
import android.os.Parcel;
import android.os.Parcelable;
import android.os.PersistableBundle;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * The data class that IME can take extra information to applications when setting the text.
 *
 * See {@link InputConnection#commitText(CharSequence, int, TextAttribute)} and
 * {@link InputConnection#setComposingRegion(int, int, TextAttribute)} and
 * {@link InputConnection#setComposingText(CharSequence, int, TextAttribute)}
 */
public final class TextAttribute implements Parcelable {
    private final @NonNull List<String> mTextConversionSuggestions;
    private final @NonNull PersistableBundle mExtras;

    private TextAttribute(Builder builder) {
        mTextConversionSuggestions = builder.mTextConversionSuggestions;
        mExtras = builder.mExtras;
    }

    private TextAttribute(Parcel source) {
        mTextConversionSuggestions = source.createStringArrayList();
        mExtras = source.readPersistableBundle();
    }

    /**
     * Get the list of text conversion suggestions. More text conversion details in
     * {@link Builder#setTextConversionSuggestions(List)}.
     *
     * @return List of text conversion suggestions. If the list is empty, it means that IME not set
     * this field or IME didn't have suggestions for applications.
     */
    public @NonNull List<String> getTextConversionSuggestions() {
        return mTextConversionSuggestions;
    }

    /**
     * Get the extras data. More extras data details in
     * {@link Builder#setExtras(PersistableBundle)}.
     *
     * @return Extras data. If the Bundle is empty, it means that IME not set this field or IME
     * didn't have extras data.
     */
    public @NonNull PersistableBundle getExtras() {
        return mExtras;
    }

    /**
     * Builder for creating a {@link TextAttribute}.
     */
    public static final class Builder {
        private List<String> mTextConversionSuggestions = new ArrayList<>();
        private PersistableBundle mExtras = new PersistableBundle();

        /**
         * Sets text conversion suggestions.
         *
         * <p>Text conversion suggestion is for some transliteration languages which has
         * pronunciation characters and target characters. When the user is typing the pronunciation
         * characters, the input method can insert possible target characters into this list so that
         * the editor authors can provide suggestion before the user enters the complete
         * pronunciation characters.</p>
         *
         * @param textConversionSuggestions The list of text conversion suggestions.
         * @return This builder
         */
        public @NonNull Builder setTextConversionSuggestions(
                @NonNull List<String> textConversionSuggestions) {
            mTextConversionSuggestions = Collections.unmodifiableList(textConversionSuggestions);
            return this;
        }

        /**
         * Sets extras data.
         *
         * <p>Any extra data to supply to the applications. This field is for extended communication
         * with IME if there is data not defined in framework.</p>
         *
         * @return This builder.
         */
        public @NonNull Builder setExtras(@NonNull PersistableBundle extras) {
            mExtras = extras;
            return this;
        }

        /**
         * @return a new {@link TextAttribute}.
         */
        public @NonNull TextAttribute build() {
            return new TextAttribute(this);
        }
    }

    @Override
    public int describeContents() {
        return 0;
    }

    @Override
    public void writeToParcel(@NonNull Parcel dest, int flags) {
        dest.writeStringList(mTextConversionSuggestions);
        dest.writePersistableBundle(mExtras);
    }

    public static final @NonNull Parcelable.Creator<TextAttribute> CREATOR =
            new Parcelable.Creator<TextAttribute>() {
        @Override
        public TextAttribute createFromParcel(Parcel source) {
            return new TextAttribute(source);
        }

        @Override
        public TextAttribute[] newArray(int size) {
            return new TextAttribute[size];
        }
    };
}