InkEdit でアプリケーション ディクショナリを使用する
アプリケーション ディクショナリを作成するには、RecognizerContext オブジェクトの WordList プロパティを設定する必要があります。 InkEdit コントロールは RecognizerContext オブジェクトを公開しないため、InkEdit コントロールの RecognizerContext オブジェクトの WordList プロパティを直接設定することはできません。
InkEdit コントロールでアプリケーション ディクショナリを使用するには、InkEdit コントロールからストロークを取り出し、WordList プロパティをアプリケーション ディクショナリを含む WordList に WordList プロパティを設定して新しい RecognizerContext オブジェクトに渡し、この RecognizerContext オブジェクトの結果を格納してから、その結果を InkEdit コントロールに戻す必要があります。
例
次の C# コードは、この手法の例を示しています。
private RecognizerContext rc;
private WordList wl;
private int wlSelStart;
private int wlSelLen;
private bool isRecoPending = false;
private void Form1_Load(object sender, EventArgs e)
{
//event handlers must be attached for dictionary to work.
inkEdit1.Recognition += new Microsoft.Ink.InkEditRecognitionEventHandler(inkEdit1_Recognition);
inkEdit1.TextChanged += new EventHandler(inkEdit1_TextChanged);
//create a WordList that contains the application dictionary
wl = new WordList();
//...
//Add dictionary terms to the WordList
//...
// create a RecognizerContext for the WordList
rc = inkEdit1.Recognizer.CreateRecognizerContext();
rc.Factoid = Factoid.WordList;
//set the RecognizerContext WordList to the newly created WordList
rc.WordList = wl;
//create a delegate for the new RecognizerContext
rc.RecognitionWithAlternates += new
RecognizerContextRecognitionWithAlternatesEventHandler(rc_Recognition);
}
void inkEdit1_TextChanged(object sender, EventArgs e)
{
if (isRecoPending)
{
isRecoPending = false;
rc.BackgroundRecognizeWithAlternates();
}
}
private void inkEdit1_Recognition(object sender,
Microsoft.Ink.InkEditRecognitionEventArgs e)
{
//store the start of the selection in wlSelStart
wlSelStart = inkEdit1.SelectionStart;
//store the length of the selection in wlSelLen
wlSelLen = e.RecognitionResult.TopString.Length;
//copy the strokes from the InkEdit control into the new
// RecognizerContext
rc.Strokes = e.RecognitionResult.Strokes.Ink.Clone().Strokes;
isRecoPending = true;
}
private void rc_Recognition(object sender,
Microsoft.Ink.RecognizerContextRecognitionWithAlternatesEventArgs e)
{
if (inkEdit1.InvokeRequired)
{
inkEdit1.Invoke(new RecognizerContextRecognitionWithAlternatesEventHandler(rc_Recognition),
new object[] { sender, e });
return;
}
//set the insertion point in the InkEdit control
inkEdit1.SelectionStart = wlSelStart;
inkEdit1.SelectionLength = wlSelLen;
//insert the result from the new RecognizerContext
//into the InkEdit control
inkEdit1.SelectedText = e.Result.TopString;
inkEdit1.SelectionStart = inkEdit1.SelectionStart +
e.Result.TopString.Length;
}
// Event handler for the form's closed event
private void Form1_Closed(object sender, System.EventArgs e)
{
inkEdit1.Dispose();
inkEdit1 = null;
rc.Dispose();
rc = null;
}
関連トピック