提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
转帖|其它|编辑:郝浩|2011-10-13 15:45:15.000|阅读 596 次
概述:前面主要介绍了Windows控件开发及Office开发相关的知识点,在这篇文章中我们正式来介绍一下如何结合前面的知识点来构建Office控件。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
前面主要介绍了Windows控件开发及Office开发相关的知识点,在这篇文章中我们正式来介绍一下如何结合前面的知识点来构建Office控件。
1.1. 技术选型
开发内嵌在Windows应用程序的Office控件一般有以下三种解决方案:
1、通过API把Office的窗口句柄给Windows应用程序;
2、通过WebBrowser控件;
3、利用DsoFramer控件。
通过了解网上了解资料及一定的测试,最后还是决定用第一种方案来实现。
1.2. 结构设计
范围 | 描述 |
控件文件 | 对Window应用程序提供属性,方法及事件等 |
Office接口 | Office相关功能的具体定义 |
Office实现 | 针对定义接口各种Office不同版本之间的实现 |
1.3. 功能接口设计
1. 控件方法
1.1. 新建Office文档 void Create(string fileName)
1.2. 打开Office文档void Open(string fileName)
1.3. 保存Office文档void Save()
1.4. 打印Office文档void PrintOut()
1.5. 填充Office文档标签内容FillCell (DataTable tbl)
1.6. 关闭Office文档void Close()
1.7. 退出Office程序void Quit()
2. 控件属性
2.1. 激活Office应用程序object ActiveApplication
2.2. 激活Office工作文档object ActiveDocument
2.3. Office文档的名称 string DocumentFullName
3. 事件
3.1. 文档关闭前发生event EventHandler BeforeClose;
3.2. 点击重新填充按钮时发生event EventHandler BeforeClose;
3.3. 点击插入词库右键菜单时发生event EventHandler BeforeClose;
1.4. 软件代码实现
主要介绍Excel2007的打开实现功能
OfficeEmbedCtl.cs中打开Office文档实现代码如下:
public partial class OfficeEmbedCtl : UserControl
{
public OfficeEmbedCtl()
{
InitializeComponent();
_officeEmbeds.Add(".xlsx", new Excel2007Embed());
}
/// <summary>
/// 打开文件
/// </summary>
/// <param name="fileName">文件名称</param>
public void Open(string fileName)
{
if (!DocumentFullName.Equals(fileName))
{
if (_officeEmbed != null)
{
_officeEmbed.Close();
}
_documentFullName = fileName;
_officeEmbed = (IOfficeEmbed)_officeEmbeds[DocumentFileExt];
_officeEmbed.DocumentFullName = DocumentFullName;
InitOfficeEmbed();
_officeEmbed.Open(fileName, this.Handle.ToInt32());
}
}
private IOfficeEmbed _officeEmbed = null;
/// <summary>
/// 初始化Office控件
/// </summary>
private void InitOfficeEmbed()
{
_officeEmbed.BeforeClose = BeforeClose;
_officeEmbed.InertLexiconClick = InertLexiconClick;
this.SizeChanged += delegate
{
_officeEmbed.OnResize(this.Handle.ToInt32());
};
}
}
IOfficeEmbed.cs中打开Office文档实现代码如下:
/// <summary>
/// 提供用于Office操作的功能接口
/// </summary>
public interface IOfficeEmbed
{
/// <summary>
/// 打开文件
/// </summary>
/// <param name="fileName">文件名称</param>
/// <param name="handleId">窗口句柄ID</param>
void Open(string fileName, int handleId);
}
Excel2007Embed.cs中打开Office文档实现代码如下:
/// <summary>
/// 提供用于Excel2007操作的功能
/// </summary>
public class Excel2007Embed : IOfficeEmbed
{
/// <summary>
/// 打开文件
/// </summary>
/// <param name="fileName">文件名称</param>
/// <param name="handleId">窗口句柄ID</param>
public void Open(string fileName, int hWndControl)
{
try
{
if (_xlApp == null)
{
InitApplication();
}
if (_xlWorkbook != null)
{
Close();
}
_hWndControl = hWndControl;
if (_hWndExcel == 0)
{
_hWndExcel = Win32API.FindWindow("XLMAIN", null);
Win32API.SetParent(_hWndExcel, hWndControl);
}
object missingValue = Missing.Value;
if (_xlApp != null && _xlApp.Workbooks != null)
{
_xlWorkbook = _xlApp.Workbooks.Open(fileName,
missingValue, missingValue, missingValue, missingValue,
missingValue, missingValue, missingValue, missingValue,
missingValue, missingValue, missingValue,
missingValue, missingValue, missingValue);
_xlWorkbook.BeforeClose += new Excel.WorkbookEvents_BeforeCloseEventHandler(_xlWorkbook_BeforeClose);
_xlWorkbook.SheetBeforeRightClick += new Excel.WorkbookEvents_SheetBeforeRightClickEventHandler(_xlWorkbook_SheetBeforeRightClick);
_xlModule = _xlWorkbook.VBProject.VBComponents.Add(VBIDE.vbext_ComponentType.vbext_ct_StdModule);
_xlModule.CodeModule.AddFromString(GetMacroByButtonCustomClick());
}
SetExcelStyle(hWndControl);
}
catch (Exception ex)
{
throw ex;
}
}
}
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn
文章转载自:网络转载面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@pclwef.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢