界面开发时如何创建一个信息面板,让DevExpress告诉你答案!

下载DevExpress v20.1完整版

富文本控件难上手?这堂公开课你一定不能错过,不同视图不同应用场景全解!

DevExpress Universal Subscription拥有.NET开发需要的所有平台控件,包含600多个UI控件、报表平台、DevExpress Dashboard eXpressApp 框架、适用于 Visual Studio的CodeRush等一系列辅助工具。要体验?点击下载>>

系统背景

在某些情况下,可能需要在UI中创建其他功能区域来显示特定数据。通过在XAF模板中包含其他控件并实现将数据提供给控件的代码,可以解决此任务。 为了帮助您完成任务,XAF提供内置的CustomizeTemplateViewControllerBase控制器以及对内置模板的完整设计时支持。 结合使用这些功能,您可以轻松实现信息面板,该面板可以显示操作、视图以及可从View Controller访问的任何类型的数据,本文为大家介绍创建简单信息面板所需执行的步骤。

界面开发控件DevExpress使用教程:如何创建信息面板

在应用程序中包含必需的模板

首先您需要确定要自定义的模板,在应用程序的不同部分中使用不同的模板。在本文中,将自定义Windows Forms MainForm和DetailViewForm模板以及ASP.NET DefaultVertical模板。

Windows Forms模板

内置Windows Forms模板是位于DevExpress.ExpressApp.Win程序集中的常规类,要自定义它们,您需要在解决方案中包含相应的源代码文件并处理XafApplication.CreateCustomTemplateevent。

ASP.NET模板

内资的ASP.NET模板其内容来自于位于DevExpress.ExpressApp.Web程序集中的用户控件页面,要自定义它们,您需要在解决方案中包含相应的源代码文件,并修改通过WebApplication.Settings属性公开的适当设置。

解决方案中包含所有必需的模板后,即可开始向其中添加面板控件。

将Panel Controls添加到Windows Forms Templates

要将面板控件添加到MainForm或DetailViewForm模板中,请在Solution Explorer中右键单击该模板,然后选择"View Designer"。

界面开发控件DevExpress使用教程:如何创建信息面板

找到viewSitePanel控件,并将其Dock属性从Fill更改为None。

界面开发控件DevExpress使用教程:如何创建信息面板

为了确保可以正确调整模板的大小,请将SplitContainerControl的Dock属性设置为Fill,将FixedPanel属性设置为Panel2。

界面开发控件DevExpress使用教程:如何创建信息面板

为了能够用信息填充信息面板,SplitContainerControl必须在外部可见。 为此定义一个界面,通过该界面可以访问信息面板,这将使数据提供控制器与特定模板类型脱钩,相反他们将依赖接口。

 

public interface IInfoPanelTemplateWin : IFrameTemplate { 
DevExpress.XtraEditors.SplitContainerControl SplitContainer { get; } 
}

 

然后,在模板中实现接口。

 

public partial class MainForm : MainFormTemplateBase, IDockManagerHolder, 
ISupportClassicToRibbonTransform, IInfoPanelTemplateWin { 
//... 
public DevExpress.XtraEditors.SplitContainerControl SplitContainer { 
get { return splitContainerControl1; } 
} 
}

 

将面板控件添加到ASP.NET Web模板

要将面板控件添加到DefaultVertical模板,请右键单击您添加的ASCX文件,以替代标准DefaultVertical内容,然后选择 "View Markup"。

界面开发控件DevExpress使用教程:如何创建信息面板

将以下两个单元格添加到MRC表。

 

<td id="RS" style="width: 6px; border-bottom-style: none; border-top-style: none" 
class="dxsplVSeparator_<%= BaseXafPage.CurrentTheme %> 
dxsplPane_<%= BaseXafPage.CurrentTheme %>"> 
<div id="RSB" class="dxsplVSeparatorButton_<%= BaseXafPage.CurrentTheme %>" 
οnmοuseοver="OnMouseEnter('RSB')" 
οnmοuseοut="OnMouseLeave('RSB')" οnclick="OnClick('Right', 'RSI')"> 
<div id="RSI" style="width: 6px;" 
class="dxWeb_splVCollapseForwardButton_<%= BaseXafPage.CurrentTheme %>"/> 
</div> 
</td> 
<td id="Right" width="250px" style="vertical-align: top"> 
<cc3:XafUpdatePanel ID="UPRight" runat="server" /> 
</td>

 

该标记中的UPRight控件将代表信息面板。

打开ASCX的代码隐藏文件 - 右键单击该文件,然后选择View Code。

界面开发控件DevExpress使用教程:如何创建信息面板

通过公开属性公开protected UPRight控件。

 

public partial class MyDefaultVerticalTemplateContent : TemplateContent { 
public Control PlaceHolder { 
get { return UPRight; } 
} 
// ... 
}

 

在ASP.NET模块项目中,定义一个接口,控制器将通过该接口访问信息面板。

 

public interface IInfoPanelTemplateWeb : IFrameTemplate { 
Control PlaceHolder { get; } 
}

 

在Default模板中实现此接口 - 编辑位于ASP.NET应用程序项目中的Default.aspx.cs文件。

 

public partial class Default : BaseXafPage, IInfoPanelTemplateWeb { 
public Control PlaceHolder { 
get { 
return TemplateContent is MyDefaultVerticalTemplateContent 
? ((MyDefaultVerticalTemplateContent)TemplateContent).PlaceHolder : null; 
} 
} 
// ... 
}

 

现在,您需要实现Windows Forms和ASP.NET Web View Controllers,它们将为面板控件提供实际数据。为简化此任务,XAF提供要继承的CustomizeTemplateViewControllerBase Controller,为方便起见,TemplateType泛型参数可以是模板类型,也可以是由模板实现的接口。 CustomizeTemplateViewControllerBase已经提供了模板访问逻辑,因此您所要做的就是实现四个受保护的抽象方法。

  • AddControlsToTemplateCore(TemplateType template) - 激活Controller后调用,此方法必须实例化所需要的控件并将其添加到信息面板中。
  • RemoveControlsFromTemplateCore(TemplateType template) - 停用Controller时调用,此方法必须从信息面板中删除以前添加的控件。
  • UpdateControls(View view) - 当前视图更改时调用,如果需要,此方法必须使用特定于视图的信息更新信息面板控件。
  • UpdateControls(object currentObject) - 当前显示的对象更改时调用,如果需要,此方法必须使用特定于当前显示对象的数据更新信息面板控件。

注意:您可以访问XAF模板并对其进行自定义,来为您的任务实现标准的ASP.NET技术(例如,使用HTTP处理程序提供动态内容)。


DevExpress技术交流群2:775869749      欢迎一起进群讨论

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将多个DevExpress Grid控件的内容导出到同一个Excel文件中,你可以按照以下步骤进行操作: 1. 首先,根据需要,将多个DevExpress Grid控件绑定到不同的数据源,确保每个Grid控件显示的数据不同。 2. 创建一个空的Excel文件,并使用DevExpress提供的Excel导出功能,例如使用`DevExpress.XtraPrinting`命名空间中的`XlsxExportOptions`和`GridViewExporter`类。 3. 创建一个`Workbook`对象,用于将多个Grid的内容写入同一个Excel文件中。 4. 初始化每个Grid的`GridViewExporter`对象,并将其绑定到相应的Grid控件。 5. 使用`GridViewExporter`的`Export`方法,将Grid的内容导出到一个新的Worksheet中。 6. 将新的Worksheet添加到Workbook对象中,确保所有Grid的内容都被添加。 7. 最后,使用Workbook对象的Save方法将内容保存到一个Excel文件中。 以下是一个简单的示例代码,用于将两个Grid的内容导出到同一个Excel文件中: ```c# using (var workbook = new Workbook()) { var exportOptions = new XlsxExportOptions(); // 初始化第一个Grid using (var exporter1 = new GridViewExporter(gridView1, workbook, worksheetName1)) { exporter1.Export(exportOptions); } // 初始化第二个Grid using (var exporter2 = new GridViewExporter(gridView2, workbook, worksheetName2)) { exporter2.Export(exportOptions); } // 保存Excel文件 workbook.Save(filePath, DevExpress.Spreadsheet.DocumentFormat.Xlsx); } ``` 请注意,示例代码中的`gridView1`和`gridView2`是两个不同的DevExpress Grid控件,`worksheetName1`和`worksheetName2`是写入Excel文件的工作表名称,`filePath`是保存Excel文件的路径。 希望这个回答对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值