次の方法で共有


方法 : コンテキスト メニューでスペル チェックを使用する

更新 : 2007 年 11 月

既定では、TextBoxRichTextBox などの編集コントロールでスペル チェックを有効にすると、スペル チェック用の項目がコンテキスト メニューに表示されます。たとえば、スペルが間違っている単語をユーザーが右クリックすると、スペル修正の候補や [すべて無視] のオプションが表示されます。しかし、既定のコンテキスト メニューを独自のカスタム コンテキスト メニューでオーバーライドすると、この機能は失われ、コンテキスト メニューのスペル チェック機能を再度有効にするためのコードを記述する必要があります。TextBox でこれを行う方法を次の例に示します。

使用例

コンテキスト メニューの実装に使用するイベントを持つ TextBox を作成する Extensible Application Markup Language (XAML) を次の例に示します。

<Page x:Class="SDKSample.SpellerCustomContextMenu"
    xmlns="https://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="https://schemas.microsoft.com/winfx/2006/xaml"
    Loaded="OnWindowLoaded">

  <TextBox
    Name="myTextBox" 
    TextWrapping="Wrap"
    SpellCheck.IsEnabled="True"
    ContextMenuOpening="tb_ContextMenuOpening">
    In a custum menu you need to write code to add speler choices
    because everything in a custom context menu has to be added explicitly.
  </TextBox>

</Page>

コンテキスト メニューを実装するコードを次の例に示します。

using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Shapes;

namespace SDKSample
{
    public partial class SpellerCustomContextMenu : Page
    {

        void OnWindowLoaded(object sender, RoutedEventArgs e)
        {
            //This is required for the first time ContextMenu invocation so that TextEditor doesnt handle it.
            myTextBox.ContextMenu = GetContextMenu();
        }
        void tb_ContextMenuOpening(object sender, RoutedEventArgs e)
        {
            int caretIndex, cmdIndex;
            SpellingError spellingError;

            myTextBox.ContextMenu = GetContextMenu();
            caretIndex = myTextBox.CaretIndex;

            cmdIndex = 0;
            spellingError = myTextBox.GetSpellingError(caretIndex);
            if (spellingError != null)
            {
                foreach (string str in spellingError.Suggestions)
                {
                    MenuItem mi = new MenuItem();
                    mi.Header = str;
                    mi.FontWeight = FontWeights.Bold;
                    mi.Command = EditingCommands.CorrectSpellingError;
                    mi.CommandParameter = str;
                    mi.CommandTarget = myTextBox;
                    myTextBox.ContextMenu.Items.Insert(cmdIndex, mi);
                    cmdIndex++;
                }
                Separator separatorMenuItem1 = new Separator();
                myTextBox.ContextMenu.Items.Insert(cmdIndex, separatorMenuItem1);
                cmdIndex++;
                MenuItem ignoreAllMI = new MenuItem();
                ignoreAllMI.Header = "Ignore All";
                ignoreAllMI.Command = EditingCommands.IgnoreSpellingError;
                ignoreAllMI.CommandTarget = myTextBox;
                myTextBox.ContextMenu.Items.Insert(cmdIndex, ignoreAllMI);
                cmdIndex++;
                Separator separatorMenuItem2 = new Separator();
                myTextBox.ContextMenu.Items.Insert(cmdIndex, separatorMenuItem2);
            }
        }

        // Gets a fresh context menu. 
        private ContextMenu GetContextMenu()
        {
            ContextMenu cm = new ContextMenu();

            //Can create STATIC custom menu items if exists here...
            MenuItem m1, m2, m3, m4;
            m1 = new MenuItem();
            m1.Header = "File";
            m2 = new MenuItem();
            m2.Header = "Save";
            m3 = new MenuItem();
            m3.Header = "SaveAs";
            m4 = new MenuItem();
            m4.Header = "Recent Files";

            //Can add functionality for the custom menu items here...

            cm.Items.Add(m1);
            cm.Items.Add(m2);
            cm.Items.Add(m3);
            cm.Items.Add(m4);

            return cm;
        }

    }
}

RichTextBox でこれを行う場合も、同様のコードを使用します。大きな違いは、GetSpellingError メソッドに渡すパラメータです。TextBox に対しては、キャレット位置のインデックスを表す整数を渡します。

spellingError = myTextBox.GetSpellingError(caretIndex);

RichTextBox に対しては、キャレット位置を表す TextPointer を渡します。

spellingError = myRichTextBox.GetSpellingError(myRichTextBox.CaretPosition);

参照

処理手順

方法 : テキスト編集コントロールでスペル チェックを有効にする

方法 : TextBox でカスタム コンテキスト メニューを使用する

概念

TextBox の概要

RichTextBox の概要