Accordion is a panel with items organized as stacked pages called Accordion Pages. Each page in Accordion comprises a header and an expandable-collapsible content area. The page header contains a header text with expand/collapse icon and athe content area provides a placeholder to hold different controls. It has a user-friendly UI allowing you to easily expand or collapse the pages using the expand/collapse icon.
The following GIF shows an Accordion control with Accordion pages. You can observe how the page expands and displays the header and content area.
Accordion lets you add or remove pages in the pages collection at design time as well as runtime. To do so via the designer, you can use the C1AccordionPage Collection Editor. For more information, see Design-Time Support.
Let's say, you want to add a page to Accordion at runtime on a button click as showcased in the following image. You can do so by creating an instance of the C1AccordionPage class, and adding the newly created AccordionPage into the Pages collection using the Add method.
The following code snippet shows how to create and add a page named meetingsPage in Accordion on a button click event named AddPagebtn_Click.
C# |
コードのコピー
|
---|---|
private void AddPagebtn_Click(object sender, EventArgs e) { if (meetingsPage is null) { //新しいAccordionPageを作成します meetingsPage = new C1AccordionPage(); ///HeaderTextを設定します meetingsPage.HeaderText = "Meetings"; //AccordionPage を Accordion の Pages コレクションに追加します。 c1Accordion1.Pages.Add(meetingsPage); } } |
Note that you can also add multiple WinForms controls to the Accordion page. For more information, see Page Content Area.
Let's say, you want to remove an existing page from Accordion at runtime on a button click as shown in the following image. You can do so by using the Remove method which removes a specific Accordion page from the Pages collection.
The following code snippet shows how to remove a page from the Pages collection using the Remove method and setting the page to null on a button click.
C# |
コードのコピー
|
---|---|
private void RemovePagebtn_Click(object sender, EventArgs e) { if (meetingsPage is not null) { //Pages コレクションから会議 ページを削除します。 c1Accordion1.Pages.Remove(meetingsPage); //meetingsPageを null に設定します。 meetingsPage = null; } } |
You can reorder pages in an Accordion, that is, move a page from one position to the other. Let's say, you want to move an existing page in the Accordion to a new position at runtime on a button click. You can do so by getting the current index of the page to be moved using the IndexOf(T item) method and then calling the Move (int oldIndex, int newIndex) method to reorder the position of the page from its old index to a new one.
The following image depicts the Accordion control with the Meetings page appearing at the first or top position from the bottom position.
The following code snippet demonstrates how to move a page using the Move method.
C# |
コードのコピー
|
---|---|
private void ReorderPagebtn_Click(object sender, EventArgs e) { if (meetingsPage is not null) { //ページの現在のインデックスを取得します。 var currentIndex = c1Accordion1.Pages.IndexOf(meetingsPage); //ページを currentIndex から最初の位置 (0 インデックス) に移動します。 c1Accordion1.Pages.Move(currentIndex, 0); } } |
Accordion lets you indicate that a particular page in the control is active or currently selected using the ActivePage property of C1Accordion class.
To set an active page, you can use ActivePage property of the C1Accordion class and assign the specific Accordion page name to it.
The following code snippet shows how to set an active page and see an expanded view of that page.
C# |
コードのコピー
|
---|---|
private void SetActivePagebtn_Click(object sender, EventArgs e) { if (meetingsPage is not null) { //meetingsPageを ActivePage として設定します。 c1Accordion1.ActivePage = meetingsPage; //IsExpanded プロパティを設定してページを展開します。 c1Accordion1.ActivePage.IsExpanded = true; } } |