RibbonControl.MdiMergeStyle Property
Gets or sets if and when a merge mechanism is invoked in an MDI application.
Namespace: DevExpress.XtraBars.Ribbon
Assembly: DevExpress.XtraBars.v24.2.dll
Declaration
[DefaultValue(RibbonMdiMergeStyle.Default)]
[DXCategory("Behavior")]
[XtraSerializableProperty]
public RibbonMdiMergeStyle MdiMergeStyle { get; set; }
Property Value
Type | Default | Description |
---|---|---|
RibbonMdiMergeStyle | Default | A RibbonMdiMergeStyle value that specifies when merge operations must be performed. |
Available values:
Name | Description |
---|---|
Default | The same as the RibbonMdiMergeStyle.OnlyWhenMaximized option. |
Always | Specifies that the merge mechanism should be invoked when a child MDI form is activated. The unmerge mechanism is invoked when a child form becomes inactive. |
Never | Specifies that the merge mechanism is never invoked. |
OnlyWhenMaximized | Specifies that the merge mechanism should be invoked when a child MDI form is maximized. The unmerge mechanism is invoked when a child form is restored from the maximized view. |
Remarks
In MDI applications, Ribbon Controls support the merge functionality allowing you to combine commands of Ribbon Controls displayed within parent and child MDI forms.
The MdiMergeStyle property of the main form’s Ribbon Control determines if and when merge and unmerge mechanisms are invoked. By default, the merge mechanism is automatically invoked when a child MDI form is maximized. Similarly, when the form is restored, the unmerge mechanism is invoked.
During merging, RibbonStatusBar objects are not merged/unmerged automatically. To merge and unmerge them manually, use the RibbonStatusBar.MergeStatusBar and RibbonStatusBar.UnMergeStatusBar methods. You can call this method within the RibbonControl.Merge and RibbonControl.UnMerge events, that fire after the merge and unmerge mechanism are invoked.
The bar items’ BarItem.MergeType properties determine how items are merged. This specifies whether the new items should be appended to the original items, replace them, etc.
See Ribbon Merging to learn more.
Example
This example demonstrates the merging mechanism for RibbonControls in action. The main and child MDI forms contain RibbonControls. The child form's RibbonControl is merged into the main form's RibbonControl when the child form is maximized.
private void Form1_Load(object sender, EventArgs e) {
// Enable the form's title bar transparency
//this.AllowFormGlass = DevExpress.Utils.DefaultBoolean.False;
// Specify that the merge mechanism should be invoked when a child MDI form is maximized.
this.ribbonControl1.MdiMergeStyle = RibbonMdiMergeStyle.OnlyWhenMaximized;
CreateChildForm();
}
private void btnNew_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) {
CreateChildForm();
}
int ctr = 1;
void CreateChildForm() {
// Create an MDI child form, containing a RibbonControl
ReportForm child = new ReportForm();
child.Text = "Report " + ctr.ToString();
child.MdiParent = this;
child.Show();
ctr++;
}
Related GitHub Examples
The following code snippet (auto-collected from DevExpress Examples) contains a reference to the MdiMergeStyle property.
Note
The algorithm used to collect these code examples remains a work in progress. Accordingly, the links and snippets below may produce inaccurate results. If you encounter an issue with code examples below, please use the feedback form on this page to report the issue.