DevExpress&WinForms-布局容器之SplitContainerControl

该文章已生成可运行项目,

布局容器之SplitContainerControl

在 Winforms 应用程序开发过程中,合理划分界面区域,提供灵活的布局调整功能是提升用户体验的关键。Devexpress 的SplitContainerControl控件为开发者实现这一目标提供了强大的支持。它允许用户通过拖曳分隔条动态调整各个子控件的大小,实现个性化的界面布局。本文将深入探讨SplitContainerControl控件的详细使用方法,涵盖基础设置、高级特性以及实际应用中的常见问题与解决方案。

SplitContainerControl 基础应用

  • 添加 SplitContainerControl 控件
    在 Visual Studio 中创建一个新的 Winforms 项目后,打开工具箱,找到 Devexpress 的SplitContainerControl控件,将其拖放到窗体上。此时,你会看到一个默认被一条分隔条分为两个区域的容器。

  • 配置 Horizontal 属性
    SplitContainerControlHorizontal属性决定了分隔条的方向,从而决定了子控件的排列方式。该属性有两个可选值:

    • True:分隔条水平放置,子控件上下排列。这种布局适用于将界面划分为上下两个功能区,例如上方显示信息列表,下方显示详细信息的场景。
    • False:分隔条垂直放置,子控件左右排列。常用于将界面分为左右两部分,如左侧为导航菜单,右侧为内容显示区域。
  • 添加子控件
    SplitContainerControl包含Panel1Panel2两个面板,你可以像在普通窗体上添加控件一样,分别向这两个面板中添加所需的其他 Devexpress 或 Winforms 原生控件,如ButtonTextBoxGridControl等。

  • 运行与测试
    完成上述步骤后,运行应用程序,用户可以通过鼠标拖曳分隔条来调整Panel1Panel2的大小,直观地体验到SplitContainerControl带来的动态布局效果。
    SplitContainerControl

SplitContainerControl 扩展应用

  • 设置Panel最小尺寸
    为了避免子控件在用户调整大小时出现显示过于狭窄的情况,可以通过设置Panel1.MinSizePanel2.MinSize属性来限制子面板的尺寸范围。例如:
splitContainerControl1.Panel1.MinSize = 100;
splitContainerControl1.Panel2.MinSize = 200;
  • 调整分隔符默认位置
    分隔符默认位置,可以通过设置SplitterPosition实现。例如:
splitContainerControl1.SplitterPosition = 200;
  • 固定Panel大小
    SplitContainerControl默认可以调整分隔符位置,也可以通过设置IsSplitterFixed将分隔符设置为固定,可以通过FixedPanel设置固定的Panel。例如:
splitContainerControl1.IsSplitterFixed = true;
splitContainerControl1.FixedPanel = SplitFixedPanel.Panel2;
  • 隐藏Panel和折叠Panel
    在实际开发中,隐藏Panel和折叠Panel很常用,可以通过下面代码设置:
// 设置Panel1显示,Panel2隐藏
splitContainerControl1.PanelVisibility = SplitPanelVisibility.Panel1;
// 设置Panel1可以被折叠
splitContainerControl1.CollapsePanel = SplitCollapsePanel.Panel1;
  • 事件处理
    SplitContainerControl提供了多个事件,方便开发者在布局变化等情况下执行特定的操作。例如,SplitterPositionChanged事件会在分隔条位置发生改变时触发,你可以在该事件的处理方法中编写代码来更新其他相关控件的显示或执行数据刷新操作:
private void splitContainerControl1_SplitterPositionChanged(object sender, EventArgs e)
{
    // 根据分隔条位置执行相应操作
    var splitterPosition = splitContainerControl1.SplitterPosition;
    // TODO: 其他业务处理
    // ...
}

总结

通过以上对 SplitContainerControl控件的详细介绍,相信你已经掌握了它的基本使用方法和扩展功能。在实际项目开发中,合理运用该控件能够打造出更加灵活、用户友好的界面,提升应用程序的整体质量。

源码

https://gitcode.com/huyu107/DevExpress.WinForms

本文章已经生成可运行项目
1、 分割控件类:CSplitterControl SplitterControl.h SplitterControl.cpp 2、创建对象、增加资源 class xx { ... private: CSplitterControl m_wndSplitter1; // 上下分割 IDC_SPLITTER_TOP 分割线资源更改资源可见属性为不可见,防止出现2条线 void DoResize1(int delta); CSplitterControl m_wndSplitter2; // 左右分割 IDC_SPLITTER_LEFT void DoResize2(int delta); } 3、初始化 BOOL CT1Dlg::OnInitDialog() { ... // TODO: Add extra initialization here {//m_wndSplitter1 CRect rc; CWnd* pWnd; pWnd = GetDlgItem(IDC_SPLITTER_TOP); pWnd->GetWindowRect(rc); ScreenToClient(rc); m_wndSplitter1.Create(WS_CHILD | WS_VISIBLE, rc, this, IDC_SPLITTER_TOP); CRect rc2; GetDlgItem(IDOK)->GetWindowRect(&rc2); ScreenToClient(&rc2); CRect rc3; GetDlgItem(IDCANCEL)->GetWindowRect(&rc3); ScreenToClient(&rc3); m_wndSplitter1.SetRange(rc2.bottom, rc3.top); } {// m_wndSplitter2 CRect rc; CWnd* pWnd; pWnd = GetDlgItem(IDC_SPLITTER_LEFT); pWnd->GetWindowRect(rc); ScreenToClient(rc); m_wndSplitter2.Create(WS_CHILD | WS_VISIBLE, rc, this, IDC_SPLITTER_LEFT); CRect rc2; GetDlgItem(IDC_BUTTON1)->GetWindowRect(&rc2); ScreenToClient(&rc2); CRect rc3; GetDlgItem(IDC_BUTTON2)->GetWindowRect(&rc3); ScreenToClient(&rc3); m_wndSplitter2.SetRange(rc2.right+1, rc3.left-1); } return TRUE; // return TRUE unless you set the focus to a control } LRESULT CT1Dlg::DefWindowProc(UINT message, WPARAM wParam, LPARAM lParam) { // TODO: Add your specialized code here and/or call the base class if (message == WM_NOTIFY) { if (wParam == IDC_SPLITTER_TOP) { SPC_NMHDR* pHdr = (SPC_NMHDR*) lParam; DoResize1(pHdr->delta); } else if (wParam == IDC_SPLITTER_LEFT) { SPC_NMHDR* pHdr = (SPC_NMHDR*) lParam; DoResize2(pHdr->delta); } } return CDialog::DefWindowProc(message, wParam, lParam); } void CT1Dlg::DoResize1(int delta) { CSplitterControl::ChangeHeight(GetDlgItem(IDC_BUTTON1),delta); CSplitterControl::ChangeHeight(GetDlgItem(IDC_BUTTON2), -delta, CW_BOTTOMALIGN); Invalidate();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿蒙Armon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值