Support sentence level spell check in sample code of the spell checker
Bug: 6136149 Change-Id: I1519258dd3ce95ad01e50a75f802469737bef3c4
This commit is contained in:
@@ -18,8 +18,10 @@ package com.example.android.hellospellchecker;
|
||||
|
||||
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 @@ import java.lang.StringBuilder;
|
||||
|
||||
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 @@ public class HelloSpellCheckerActivity extends Activity implements SpellCheckerS
|
||||
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 @@ public class HelloSpellCheckerActivity extends Activity implements SpellCheckerS
|
||||
}
|
||||
}
|
||||
|
||||
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());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 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));
|
||||
}
|
||||
sb.append(" (" + len + ")");
|
||||
}
|
||||
runOnUiThread(new Runnable() {
|
||||
@Override
|
||||
|
||||
Reference in New Issue
Block a user