Support sentence level spell check in sample code of the spell checker
Bug: 6136149
Change-Id: I1519258dd3ce95ad01e50a75f802469737bef3c4
diff --git a/samples/SpellChecker/HelloSpellChecker/Android.mk b/samples/SpellChecker/HelloSpellChecker/Android.mk
index 1c76f23..5138ce9 100755
--- a/samples/SpellChecker/HelloSpellChecker/Android.mk
+++ b/samples/SpellChecker/HelloSpellChecker/Android.mk
@@ -5,6 +5,7 @@
LOCAL_SRC_FILES := $(call all-subdir-java-files)
+# TODO: Change sdk version to 16
LOCAL_SDK_VERSION := current
LOCAL_PACKAGE_NAME := HelloSpellChecker
diff --git a/samples/SpellChecker/HelloSpellChecker/src/com/example/android/hellospellchecker/HelloSpellCheckerActivity.java b/samples/SpellChecker/HelloSpellChecker/src/com/example/android/hellospellchecker/HelloSpellCheckerActivity.java
index 6550981..f88b023 100644
--- a/samples/SpellChecker/HelloSpellChecker/src/com/example/android/hellospellchecker/HelloSpellCheckerActivity.java
+++ b/samples/SpellChecker/HelloSpellChecker/src/com/example/android/hellospellchecker/HelloSpellCheckerActivity.java
@@ -18,8 +18,10 @@
import android.app.Activity;
import android.content.Context;
+import android.os.Build;
import android.os.Bundle;
import android.util.Log;
+import android.view.textservice.SentenceSuggestionsInfo;
import android.view.textservice.SpellCheckerSession;
import android.view.textservice.SuggestionsInfo;
import android.view.textservice.TextInfo;
@@ -30,8 +32,10 @@
public class HelloSpellCheckerActivity extends Activity implements SpellCheckerSessionListener {
private static final String TAG = HelloSpellCheckerActivity.class.getSimpleName();
+ private static final int NOT_A_LENGTH = -1;
private TextView mMainView;
private SpellCheckerSession mScs;
+
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
@@ -40,18 +44,36 @@
mMainView = (TextView)findViewById(R.id.main);
}
+ private boolean isSentenceSpellCheckSupported() {
+ if (mScs == null || Build.VERSION.SDK_INT < 16) {
+ return false;
+ }
+ // Note that isSentenceSpellCheckSupported works on JB or later.
+ return mScs.isSentenceSpellCheckSupported();
+ }
+
@Override
public void onResume() {
super.onResume();
final TextServicesManager tsm = (TextServicesManager) getSystemService(
Context.TEXT_SERVICES_MANAGER_SERVICE);
mScs = tsm.newSpellCheckerSession(null, null, this, true);
+
if (mScs != null) {
// Instantiate TextInfo for each query
// TextInfo can be passed a sequence number and a cookie number to identify the result
- mScs.getSuggestions(new TextInfo("tgis"), 3);
- mScs.getSuggestions(new TextInfo("hllo"), 3);
- mScs.getSuggestions(new TextInfo("helloworld"), 3);
+ if (isSentenceSpellCheckSupported()) {
+ // Note that getSentenceSuggestions works on JB or later.
+ Log.d(TAG, "Sentence spellchecking supported.");
+ mScs.getSentenceSuggestions(new TextInfo[] {new TextInfo("tgisis")}, 3);
+ mScs.getSentenceSuggestions(new TextInfo[] {new TextInfo(
+ "I wold like to here form you")}, 3);
+ mScs.getSentenceSuggestions(new TextInfo[] {new TextInfo("hell othere")}, 3);
+ } else {
+ mScs.getSuggestions(new TextInfo("tgis"), 3);
+ mScs.getSuggestions(new TextInfo("hllo"), 3);
+ mScs.getSuggestions(new TextInfo("helloworld"), 3);
+ }
} else {
Log.e(TAG, "Couldn't obtain the spell checker service.");
}
@@ -65,17 +87,67 @@
}
}
+ private void dumpSuggestionsInfoInternal(
+ final StringBuilder sb, final SuggestionsInfo si, final int length, final int offset) {
+ // Returned suggestions are contained in SuggestionsInfo
+ final int len = si.getSuggestionsCount();
+ sb.append('\n');
+ for (int j = 0; j < len; ++j) {
+ if (j != 0) {
+ sb.append(", ");
+ }
+ sb.append(si.getSuggestionAt(j));
+ }
+ sb.append(" (" + len + ")");
+ if (length != NOT_A_LENGTH) {
+ sb.append(" length = " + length + ", offset = " + offset);
+ }
+ }
+
+ /**
+ * Callback for {@link SpellCheckerSession#getSuggestions(TextInfo, int)}
+ * and {@link SpellCheckerSession#getSuggestions(TextInfo[], int, boolean)}
+ * @param results an array of {@link SuggestionsInfo}s.
+ * These results are suggestions for {@link TextInfo}s queried by
+ * {@link SpellCheckerSession#getSuggestions(TextInfo, int)} or
+ * {@link SpellCheckerSession#getSuggestions(TextInfo[], int, boolean)}
+ */
@Override
public void onGetSuggestions(final SuggestionsInfo[] arg0) {
+ Log.d(TAG, "onGetSuggestions");
final StringBuilder sb = new StringBuilder();
for (int i = 0; i < arg0.length; ++i) {
- // Returned suggestions are contained in SuggestionsInfo
- final int len = arg0[i].getSuggestionsCount();
- sb.append('\n');
- for (int j = 0; j < len; ++j) {
- sb.append("," + arg0[i].getSuggestionAt(j));
+ dumpSuggestionsInfoInternal(sb, arg0[i], 0, NOT_A_LENGTH);
+ }
+ runOnUiThread(new Runnable() {
+ @Override
+ public void run() {
+ mMainView.append(sb.toString());
}
- sb.append(" (" + len + ")");
+ });
+ }
+
+ /**
+ * Callback for {@link SpellCheckerSession#getSentenceSuggestions(TextInfo[], int)}
+ * @param results an array of {@link SentenceSuggestionsInfo}s.
+ * These results are suggestions for {@link TextInfo}s
+ * queried by {@link SpellCheckerSession#getSentenceSuggestions(TextInfo[], int)}.
+ */
+ @Override
+ public void onGetSentenceSuggestions(final SentenceSuggestionsInfo[] arg0) {
+ if (!isSentenceSpellCheckSupported()) {
+ Log.e(TAG, "Sentence spell check is not supported on this platform, "
+ + "but accidentially called.");
+ return;
+ }
+ Log.d(TAG, "onGetSentenceSuggestions");
+ final StringBuilder sb = new StringBuilder();
+ for (int i = 0; i < arg0.length; ++i) {
+ final SentenceSuggestionsInfo ssi = arg0[i];
+ for (int j = 0; j < ssi.getSuggestionsCount(); ++j) {
+ dumpSuggestionsInfoInternal(
+ sb, ssi.getSuggestionsInfoAt(j), ssi.getOffsetAt(j), ssi.getLengthAt(j));
+ }
}
runOnUiThread(new Runnable() {
@Override