PowerTools CalendarGrid for Windows Forms 1.0J > CalendarGridの使い方 > InputManCell > GcTextBox型セル > サイドボタンを設定する(CalendarGcTextBoxCellType) |
CalendarGcTextBoxCellType.SideButtonsプロパティを使用します。
ここではセル内に追加可能なボタン(サイドボタン)の使用方法について解説します。
セルの左右両端にはサイドボタンとして自由にボタンを配置し機能を割り付けることができます。ドロップダウンボタンには表示されるエディットウィンドウを関連付けしたり、ボタンに独自の機能を設定することができます。
セルにボタンを追加するには、SideButtonsプロパティが参照するSideButtonCollectionクラスを使用します。SideButtonCollectionクラスは、セルに追加するボタンオブジェクトのコレクションで、セルに追加可能なサイドボタンを追加、削除するためのメソッドを提供します。
セルには次の4種類のボタンオブジェクトを追加できます。
ボタンの追加や削除を行うには、デザイナのプロパティウィンドウから開かれるサイドボタン コレクション エディタから行うことができます。
また、コードでセルにボタンを追加するには、SideButtonCollectionオブジェクトのAddまたはAddRangeメソッドを使用します。
以下は、Add メソッドを使用して CalendarGcTextBoxCellType にドロップダウンボタンを追加する例です。
Imports InputManCell = GrapeCity.Win.CalendarGrid.InputMan Dim today As DateTime = DateTime.Today Dim GcTextBoxCellType As New InputManCell.CalendarGcTextBoxCellType() GcTextBoxCellType.SideButtons.Add(New InputManCell.DropDownButton()) GcCalendarGrid1.Content(today).Rows(1).Cells(0).CellType = GcTextBoxCellType GcCalendarGrid1.ScrollIntoView(today)
using InputManCell = GrapeCity.Win.CalendarGrid.InputMan; var today = DateTime.Today; var gcTextBoxCellType = new InputManCell.CalendarGcTextBoxCellType(); gcTextBoxCellType.SideButtons.Add(new InputManCell.DropDownButton()); gcCalendarGrid1.Content[today].Rows[1].Cells[0].CellType = gcTextBoxCellType; gcCalendarGrid1.ScrollIntoView(today);
追加したボタンを削除するには、SideButtonCollectionクラスのRemoveメソッドまたは、RemoveAtメソッドを使用します。また、Clearメソッドでコレクションに追加されたすべてのボタンをクリアすることができます。
以下は、RemoveAtメソッドを使用してコレクションの先頭に追加されたボタンを削除する例です。
Imports GrapeCity.Win.CalendarGrid Imports InputManCell = GrapeCity.Win.CalendarGrid.InputMan Dim pos As CalendarCellPosition = GcCalendarGrid1.CurrentCellPosition Dim GcTextBoxCellType As InputManCell.CalendarGcTextBoxCellType = _ DirectCast(GcCalendarGrid1.Content(pos.Date).Rows(pos.RowIndex).Cells(pos.ColumnIndex).CellType.Clone(), InputManCell.CalendarGcTextBoxCellType) If GcTextBoxCellType.SideButtons.Count > 0 Then GcTextBoxCellType.SideButtons.RemoveAt(0) End If GcCalendarGrid1.Content(pos.Date).Rows(pos.RowIndex).Cells(pos.ColumnIndex).CellType = GcTextBoxCellType
using GrapeCity.Win.CalendarGrid; using InputManCell = GrapeCity.Win.CalendarGrid.InputMan; CalendarCellPosition pos = gcCalendarGrid1.CurrentCellPosition; var gcTextBoxCellType = gcCalendarGrid1.Content[pos.Date].Rows[pos.RowIndex].Cells[pos.ColumnIndex].CellType.Clone() as InputManCell.CalendarGcTextBoxCellType; if (gcTextBoxCellType.SideButtons.Count > 0) { gcTextBoxCellType.SideButtons.RemoveAt(0); } gcCalendarGrid1.Content[pos.Date].Rows[pos.RowIndex].Cells[pos.ColumnIndex].CellType = gcTextBoxCellType;
各ボタンオブジェクトのPositionプロパティを使用するとボタンの表示位置を設定することができます。
それぞれの位置でのボタンの並びはコレクション内のインデックスによって決定されます。コレクション内のインデックスが小さい順に左から右へボタンが配置されます。
ボタンのサイズはセルの高さと各ボタンオブジェクトのWidthプロパティによって設定されます。
サイドボタンの背景色は各ボタンオブジェクトのBackColorプロパティで、前景色はForeColorプロパティで設定します。背景色と前景色はセルのFlatStyleプロパティがFlat、およびPopupの場合のみ有効となります。
(図) FlatStyle プロパティがFlatの場合
(図) FlatStyle プロパティがPopupの場合
各サイドボタンでは押されたときの動作をプロパティで割り当てることができます。
SideButtonクラスはスピン動作の割り当てを設定するBehaviorプロパティを提供しますが、CalendarGcTextBoxCellTypeでは既定のスピン動作が存在しないため、設定値に関わらず無効です。
SymbolButtonクラスはスピン動作の割り当てを設定するBehaviorプロパティを提供しますが、CalendarGcTextBoxCellTypeでは既定のスピン動作が存在しないため、設定値に関わらず無効です。