MonthCalendar

[C#] MonthCalendarの日付の選択可能な範囲を設定する方法

C#のMonthCalendarコントロールで日付の選択可能な範囲を設定するには、MinDateプロパティとMaxDateプロパティを使用します。

これらのプロパティにDateTime型の値を設定することで、ユーザーが選択できる最小日付と最大日付を指定できます。

例えば、monthCalendar.MinDate = new DateTime(2023, 1, 1);monthCalendar.MaxDate = new DateTime(2023, 12, 31);とすることで、2023年の1月1日から12月31日までの範囲に制限できます。

これにより、範囲外の日付は選択できなくなります。

日付の選択可能範囲を設定する方法

C#のWindowsフォームアプリケーションにおいて、MonthCalendarコントロールを使用する際に、選択可能な日付の範囲を設定することができます。

これにより、ユーザーが特定の日付範囲内でのみ日付を選択できるようになります。

以下では、MinDateおよびMaxDateプロパティの設定方法について詳しく解説します。

MinDateプロパティの設定

MinDateプロパティは、ユーザーが選択できる最小の日付を設定します。

このプロパティを設定することで、指定した日付より前の日付を選択できなくなります。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // MinDateを設定する
        monthCalendar1.MinDate = new DateTime(2023, 1, 1); // 2023年1月1日以降の日付を選択可能
    }
}

このコードを実行すると、MonthCalendarコントロールでは2023年1月1日以前の日付を選択できなくなります。

MaxDateプロパティの設定

MaxDateプロパティは、ユーザーが選択できる最大の日付を設定します。

このプロパティを設定することで、指定した日付より後の日付を選択できなくなります。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // MaxDateを設定する
        monthCalendar1.MaxDate = new DateTime(2023, 12, 31); // 2023年12月31日以前の日付を選択可能
    }
}

このコードを実行すると、MonthCalendarコントロールでは2023年12月31日以降の日付を選択できなくなります。

MinDateとMaxDateの組み合わせ

MinDateMaxDateを組み合わせて設定することで、特定の範囲内の日付のみを選択可能にすることができます。

以下の例では、2023年1月1日から2023年12月31日までの日付を選択可能に設定しています。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // MinDateとMaxDateを設定する
        monthCalendar1.MinDate = new DateTime(2023, 1, 1); // 最小日付
        monthCalendar1.MaxDate = new DateTime(2023, 12, 31); // 最大日付
    }
}

この設定により、ユーザーは2023年の範囲内でのみ日付を選択できるようになります。

実装例

ここでは、MonthCalendarコントロールの範囲設定に関する具体的な実装例を紹介します。

基本的な範囲設定から、動的な変更、範囲外の日付を選択した場合の挙動までを解説します。

基本的な範囲設定の例

最初に、MinDateMaxDateを設定する基本的な例を示します。

この例では、2023年1月1日から2023年12月31日までの日付を選択可能に設定します。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // MinDateとMaxDateを設定する
        monthCalendar1.MinDate = new DateTime(2023, 1, 1); // 最小日付
        monthCalendar1.MaxDate = new DateTime(2023, 12, 31); // 最大日付
    }
}

このコードを実行すると、MonthCalendarコントロールでは2023年の範囲内でのみ日付を選択できるようになります。

動的に範囲を変更する例

次に、ユーザーの操作に応じて日付の範囲を動的に変更する例を示します。

ボタンをクリックすることで、範囲を変更する機能を実装します。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // 初期範囲を設定する
        monthCalendar1.MinDate = new DateTime(2023, 1, 1);
        monthCalendar1.MaxDate = new DateTime(2023, 12, 31);
        
        // ボタンのクリックイベントを設定する
        buttonChangeRange.Click += ButtonChangeRange_Click;
    }
    private void ButtonChangeRange_Click(object sender, EventArgs e)
    {
        // 範囲を変更する
        monthCalendar1.MinDate = new DateTime(2023, 6, 1); // 新しい最小日付
        monthCalendar1.MaxDate = new DateTime(2023, 6, 30); // 新しい最大日付
    }
}

このコードを実行し、ボタンをクリックすると、MonthCalendarの選択可能な範囲が2023年6月1日から6月30日までに変更されます。

範囲外の日付を選択した場合の挙動

MinDateMaxDateを設定した場合、範囲外の日付を選択しようとすると、どのような挙動になるかを確認します。

以下の例では、範囲外の日付を選択した際にメッセージボックスを表示する機能を実装します。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // MinDateとMaxDateを設定する
        monthCalendar1.MinDate = new DateTime(2023, 1, 1);
        monthCalendar1.MaxDate = new DateTime(2023, 12, 31);
        
        // 日付選択変更イベントを設定する
        monthCalendar1.DateChanged += MonthCalendar1_DateChanged;
    }
    private void MonthCalendar1_DateChanged(object sender, DateRangeEventArgs e)
    {
        // 選択した日付が範囲外の場合
        if (e.Start < monthCalendar1.MinDate || e.Start > monthCalendar1.MaxDate)
        {
            MessageBox.Show("選択した日付は範囲外です。");
        }
    }
}

このコードを実行し、範囲外の日付を選択すると、「選択した日付は範囲外です。」というメッセージボックスが表示されます。

これにより、ユーザーは選択した日付が有効でないことを認識できます。

応用例

ここでは、MonthCalendarコントロールの範囲設定を応用する方法について解説します。

具体的には、UIでの範囲変更、範囲設定に基づくイベントのトリガー、他のコントロールとの連携について説明します。

範囲設定をUIで変更する

ユーザーがUIを通じてMinDateMaxDateを変更できるようにすることで、よりインタラクティブなアプリケーションを作成できます。

以下の例では、テキストボックスを使用して日付を入力し、ボタンをクリックすることで範囲を変更します。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // 初期範囲を設定する
        monthCalendar1.MinDate = new DateTime(2023, 1, 1);
        monthCalendar1.MaxDate = new DateTime(2023, 12, 31);
        
        // ボタンのクリックイベントを設定する
        buttonSetRange.Click += ButtonSetRange_Click;
    }
    private void ButtonSetRange_Click(object sender, EventArgs e)
    {
        // テキストボックスから日付を取得
        DateTime minDate = DateTime.Parse(textBoxMinDate.Text);
        DateTime maxDate = DateTime.Parse(textBoxMaxDate.Text);
        
        // 範囲を設定する
        monthCalendar1.MinDate = minDate;
        monthCalendar1.MaxDate = maxDate;
    }
}

このコードを実行し、テキストボックスに日付を入力してボタンをクリックすると、MonthCalendarの選択可能な範囲が変更されます。

範囲設定に基づくイベントのトリガー

範囲設定に基づいて特定のイベントをトリガーすることも可能です。

以下の例では、選択した日付がMinDateまたはMaxDateに達したときにメッセージボックスを表示します。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // MinDateとMaxDateを設定する
        monthCalendar1.MinDate = new DateTime(2023, 1, 1);
        monthCalendar1.MaxDate = new DateTime(2023, 12, 31);
        
        // 日付選択変更イベントを設定する
        monthCalendar1.DateChanged += MonthCalendar1_DateChanged;
    }
    private void MonthCalendar1_DateChanged(object sender, DateRangeEventArgs e)
    {
        // 選択した日付がMinDateまたはMaxDateの場合
        if (e.Start == monthCalendar1.MinDate || e.Start == monthCalendar1.MaxDate)
        {
            MessageBox.Show("選択した日付は範囲の端です。");
        }
    }
}

このコードを実行し、MinDateまたはMaxDateの日付を選択すると、「選択した日付は範囲の端です。」というメッセージボックスが表示されます。

範囲設定と他のコントロールとの連携

MonthCalendarの範囲設定を他のコントロールと連携させることで、より複雑な機能を実現できます。

以下の例では、DateTimePickerコントロールを使用して、選択した日付に基づいてMonthCalendarの範囲を変更します。

partial class MyForm : Form
{
    public MyForm()
    {
        InitializeComponent();
        
        // 初期範囲を設定する
        monthCalendar1.MinDate = new DateTime(2023, 1, 1);
        monthCalendar1.MaxDate = new DateTime(2023, 12, 31);
        
        // DateTimePickerの値変更イベントを設定する
        dateTimePicker1.ValueChanged += DateTimePicker1_ValueChanged;
    }
    private void DateTimePicker1_ValueChanged(object sender, EventArgs e)
    {
        // DateTimePickerの値に基づいて範囲を設定する
        monthCalendar1.MinDate = dateTimePicker1.Value;
        monthCalendar1.MaxDate = dateTimePicker1.Value.AddDays(30); // 選択した日付から30日後まで
    }
}

このコードを実行し、DateTimePickerで日付を選択すると、MonthCalendarの選択可能な範囲がその日付から30日後までに変更されます。

これにより、ユーザーは選択した日付に基づいて柔軟に範囲を設定できます。

まとめ

この記事では、C#のWindowsフォームアプリケーションにおけるMonthCalendarコントロールの日付の選択可能範囲を設定する方法について詳しく解説しました。

具体的には、MinDateMaxDateの設定方法、範囲の動的変更、範囲外の日付を選択した際の挙動、さらにはUIとの連携についても触れました。

これらの知識を活用して、よりインタラクティブで使いやすいアプリケーションを作成してみてください。

Back to top button