Freigeben über


Verwenden eines Anwendungswörterbuchs mit InkEdit

Zum Erstellen eines Anwendungswörterbuchs muss die WordList-Eigenschaft des RecognizerContext-Objekts festgelegt werden. Das InkEdit-Steuerelement macht das RecognizerContext-Objekt nicht verfügbar, sodass es nicht möglich ist, die WordList-Eigenschaft des RecognizerContext-Objekts des InkEdit-Steuerelements direkt festzulegen.

Um ein Anwendungswörterbuch mit einem InkEdit-Steuerelement zu verwenden, müssen Sie die Striche aus dem InkEdit-Steuerelement herausnehmen, sie an ein neues RecognizerContext-Objekt übergeben, wobei die WordList-Eigenschaft auf eine WordList festgelegt ist, die das Anwendungswörterbuch enthält, die Ergebnisse aus diesem RecognizerContext-Objekt speichern und die Ergebnisse dann an das InkEdit-Steuerelement zurückgeben.

Beispiel

Der folgende C#-Code zeigt ein Beispiel für diese Technik.

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;
}

Freihandsteuerelement bearbeiten

Microsoft.Ink.RecognizerContext-Klasse

Microsoft.Ink.Wordlist-Klasse