根据自己对dsoframer控件的学习,想把dsoframer控件进行简单的包装为C#的usercontrol,大体需要作如下:(创建windows的usercontrol的步骤就不再说了。。。)
我们暂时不对dso打开网络文件的功能和上传文件功能作过多研究,一来由于我自己不用它提供的这个功能,二来确实觉得它的这方面功能不是很强大而且使用起来比较
麻烦,呵呵,请见谅!
1.使用前注册该dsoframer控件,我把该dso控件当作嵌入资源,用学习笔记1中的方法注册即可

/// <summary>/// usercontrol控件初始化/// </summary>/// <param name="_sFilePath">本地文件全路径</param>public void Init(string _sFilePath){try{RegControl();//注册控件if(!CheckFile(_sFilePath))//判断是否为所支持的office文件
    {throw new ApplicationException("文件不存在或未标识的文件格式!");}AddOfficeControl();//这里一定要先把dso控件加到界面上才能初始化dso控件,这个dso控件在没有被show出来之前是不能进行初始化操作的,很奇怪为什 //么作者这样考虑.....
    InitOfficeControl(_sFilePath);}catch(Exception ex){throw ex;}}public bool RegControl(){try{Assembly thisExe = Assembly.GetExecutingAssembly();System.IO.Stream myS = thisExe.GetManifestResourceStream("NameSpaceName.dsoframer.ocx");string sPath = “该ocx文件的实际路径”+ @"/dsoframer.ocx";ProcessStartInfo psi = new ProcessStartInfo("regsvr32","/s " +sPath);Process.Start(psi);}catch(Exception ex){MessageBox.Show(ex.Message);}return true;}

2.动态向usercontrol添加dsoframer实例

   private AxDSOFramer.AxFramerControl m_axFramerControl = new AxDSOFramer.AxFramerControl();/// <summary>/// 添加控件/// </summary>private void AddOfficeControl(){try{this.m_Panel_Control.Controls.Add(m_axFramerControl);m_axFramerControl.Dock = DockStyle.Fill;}catch(Exception ex){throw ex;}}

3.初始化dsoframer控件 ,我这里用已经有的文件进行dso初始化,

 /// <summary>/// 初始化office控件/// </summary>/// <param name="_sFilePath">本地文档路径</param>private void InitOfficeControl(string _sFilePath){try{if(m_axFramerControl == null){throw new ApplicationException("请先初始化office控件对象!");}//this.m_axFramerControl.SetMenuDisplay(48);//这个方法很特别,一个组合菜单控制方法,我还没有找到参数的规律,有兴趣的朋友可以研究一下string sExt = System.IO.Path.GetExtension(_sFilePath).Replace(".","");//this.m_axFramerControl.CreateNew(this.LoadOpenFileType(sExt));//创建新的文件this.m_axFramerControl.Open(_sFilePath,false,this.LoadOpenFileType(sExt),"","");//打开文件//隐藏标题this.m_axFramerControl.Titlebar = false;}catch(Exception ex){throw ex;}}下面这个方法是dso打开文件时需要的一个参数,代表office文件类型/// <summary>/// 根据后缀名得到打开方式/// </summary>/// <param name="_sExten"></param>/// <returns></returns>private string LoadOpenFileType(string _sExten){try{string sOpenType = "";switch (_sExten.ToLower()){case "xls":sOpenType = "Excel.Sheet";break;case "doc":sOpenType = "Word.Document";break;case "ppt":sOpenType = "PowerPoint.Show";break;case "vsd":sOpenType = "Visio.Drawing";break;default:sOpenType = "Word.Document";break;}return sOpenType;}catch (Exception ex){throw ex;}}

4.我觉的最重要的一步,就是公布dso当前的活动对象,因为自己做这个usercontrol功能不强,但是不能把人家dso功能给杀掉,给使用者留一个更大的空间。。。。

/// <summary>/// 获取当前操作的文档/// </summary>public object ActiveDocument{get{return this.m_axFramerControl.ActiveDocument;}}/// <summary>/// 获取当前控件对象/// </summary>public AxDSOFramer.AxFramerControl OfficeObject{get{return this.m_axFramerControl;}}
5.公布了一些简单的excel和word操作方法,#region public word method,这几个方法只对word文档有效/// <summary>/// 设置保留修改痕迹(可以通过word工具栏的审批修改,此方法仅仅是提供初始化)/// 这个方法挺好,可以模拟键盘按键,很巧啊.(以前很长时间都不知道可以这样...)/// </summary>/// <param name="_bIs"></param>public void WordSetSaveTrace()/// <summary>/// 替换标签下/// </summary>/// <param name="_sMark"></param>/// <param name="_sReplaceText"></param>/// <param name="_IsD">替换后是否突出显示</param>/// <returns></returns>public bool WordReplace(string _sMark,string _sReplaceText,bool _IsD)/// <summary>/// 文本替换/// </summary>/// <param name="_sOrialText"></param>/// <param name="_sReplaceText"></param>/// <returns></returns>public bool WordReplace(string _sOrialText,string _sReplaceText)#endregion#region public excel method/// <summary>/// 向固定位置填值/// </summary>/// <param name="_sValue">填写内容</param>/// <param name="_iBeginRow">开始行</param>/// <param name="_iBeginCol">开始列</param>public void ExcelFillValue(string _sValue,int _iBeginRow,int _iBeginCol)/// <summary>/// 向固定位置填值/// </summary>/// <param name="_sValue">填写对象</param>/// <param name="_iBeginRow">开始行</param>/// <param name="_iBeginCol">开始列</param>public void ExcelFillValue(Object _sValue,int _iBeginRow,int _iBeginCol)/// <summary>/// 向固定位置填值/// </summary>/// <param name="_ds">填写内容</param>/// <param name="_iBeginRow">开始行</param>/// <param name="_iBeginCol">开始列</param>public void ExcelFillValue(System.Data.DataSet _ds,int _iBeginRow,int _iBeginCol,bool _IsTitle)/// <summary>/// 清空excel文档/// </summary>public void ExcelClear()/// <summary>/// 清空固定位置的内容/// </summary>/// <param name="_iBeginRow">开始行</param>/// <param name="_iBeginCol">开始列</param>public void ExcelClear(int _iBeginRow,int _iBeginCol)/// <summary>/// 清空指定区域的内容/// </summary>/// <param name="_iBeginRow">开始行</param>/// <param name="_iBeginCol">开始列</param>/// <param name="_iEndRow">结束行</param>/// <param name="_iEndCol">结束列</param>public void ExcelClear(int _iBeginRow,int _iBeginCol,int _iEndRow,int _iEndCol)#endregion

以上这些都是对excel和word文档操作的小儿科,害怕贴出来各位大虾见笑,不敢贴了.....

6.公布一些简单的方法(保存和另存为方法是防止菜单和工具栏被隐藏的情况下不能保存),这类应该有很多方法,我目前只用了这些个所以....

/// <summary>/// 保存/// </summary>public void Save(){try{//先保存this.m_axFramerControl.Save(true,true,"","");}catch(Exception ex){throw ex;}}/// <summary>/// 另存为/// </summary>public void SaveAs(){try{//另存为SaveFileDialog sfd = new SaveFileDialog();string sExt = System.IO.Path.GetExtension(this.m_sFilePath).Replace(".","");sfd.Filter = sExt;if(sfd.ShowDialog() == DialogResult.OK){string sSavePath = sfd.FileName;if(System.IO.File.Exists(sSavePath)){System.IO.File.Delete(sSavePath);}this.m_axFramerControl.SaveAs(sSavePath,this.LoadOpenFileType(sExt));}}catch(Exception ex){throw ex;}}/// <summary>/// 关闭当前界面/// </summary>public void Close(){try{if(this.m_axFramerControl != null){this.m_axFramerControl.Close();}}catch(Exception ex){throw ex;}}

最后如果想把该dso控件的注册去掉也可以,因为我没有办法得到该控件是否在机器上注册过,所以每次初始化都要注册,不知道园子里的各位朋友有没有办法检测,还请赐教?

好了,一个简单的可以用于windows程序的office在线编辑控件完成了.

引用http://www.cnblogs.com/jisen/archive/2007/07/12/815772.html

转载于:https://www.cnblogs.com/hfzsjz/p/4127867.html

dsoframer控件学习小结(打开WORD,EXCEL等文件)相关推荐

  1. wxpython制作表格界面_[Python] wxPython 菜单栏控件学习总结(原创)

    1.总结 1.大体创建过程 1.创建一个 菜单栏 : menuBar = wx.MenuBar() 相当于这个白色地方,没有File这个菜单 2.创建 菜单 : fileMenu = wx.Menu( ...

  2. DevExpress控件学习总结(转)

    1.Navigation & Layout 1.1 Bar Manager 如果想在窗体或用户控件(user control)上添加工具条(bars)或弹出菜单(popup menus),我们 ...

  3. DevExpress控件学习总结

    1.Navigation & Layout 1.1 Bar Manager 如果想在窗体或用户控件(user control)上添加工具条(bars)或弹出菜单(popup menus),我们 ...

  4. DevExpress控件学习总结 z

    1.Navigation & Layout 1.1 Bar Manager 如果想在窗体或用户控件(user control)上添加工具条(bars)或弹出菜单(popup menus),我们 ...

  5. 利用FarPoint Spread表格控件,构造Winform的Excel表格界面输入

    因有一个业务需要在Winform界面中,以类似Excel表格界面中录入相关的数据(毕竟很多时候,客户想利用成熟的软件体验来输入他们想要的东西),其中界面需要录入基础信息,列表信息,图片信息等,综合这些 ...

  6. CGRidCtrl控件 学习心得

    wuqinxiang0我的:收件箱资源博客空间设置|帮助|退出 首页 业界 移动 云计算 研发 论坛 博客 下载 更多 狂想盼盼 积累点点滴滴 目录视图 摘要视图 订阅 新版论坛系列介绍之二--功能介 ...

  7. winform控件学习(2)—HScrollBar控件和MaskedTextBox控件

    好几天没系统的总结了,感觉忘得很快,还是记录下来比较好.废话不说了,接着介绍几个使用频率比较高的控件. 1.HScrollBar控件:在窗体实现一个水平滚动的滚动条,以便在较长的项列表中或大量信息中转 ...

  8. IOS学习笔记(四)之UITextField和UITextView控件学习

    IOS学习笔记(四)之UITextField和UITextView控件学习(博客地址:http://blog.csdn.net/developer_jiangqq) Author:hmjiangqq ...

  9. iOS开发UI篇—UITableview控件使用小结

    iOS开发UI篇-UITableview控件使用小结 一.UITableview的使用步骤 UITableview的使用就只有简单的三个步骤: 1.告诉一共有多少组数据 方法:- (NSInteger ...

最新文章

  1. php中使用mysql_fetch_array输出数组至页面中展示
  2. Socket通信原理
  3. mysql ef 随机排序_EFCore+Mysql倉儲層建設(分頁、多字段排序、部分字段更新)
  4. 肝货!你想要的资源这里都有!
  5. oracle 移动日志文件,Oracle数据库移动数据文件、日志文件和控制文件
  6. 数字图像处理:图像平均/加法_OPT小讲堂 ∣ SciSmart图像增强之二值化
  7. python3.6 配置COCO API出错解决方案
  8. 移动端页面开发通用问题解决方案
  9. java cmd测试_Java SE 9:使用CMD提示开发和测试简单模块(第3部分)
  10. 不插字段,直接利用OracleSpatial计算
  11. 如何用计算机录制视频教程,电脑怎么利用软件录制视频教程
  12. https证书的验证过程与生成方法
  13. 如何把腾讯qlv转换成MP4格式呢
  14. 关于CSDN获取博客内容接口的x-ca-signature签名算法研究
  15. 百度卫星地图无法使用鼠标绘制工具的问题简单解决方案
  16. 为什么信而富显示服务器开小差,剖析:信而富12点后也没额度的真相!
  17. 机器学习-准确率、召回率、精确率、f1score等
  18. LayaAir 在TiledMap 中 插入精灵
  19. [Python] 实现文本进度条
  20. 星巴克传奇:为客人煮好每一杯咖啡

热门文章

  1. ubuntu18qt报错:The process was ended forcefully.
  2. USB转TTL、USB转串口、USB转232的区别(转)
  3. 暴雪在洛杉矶建了自己的电竞馆,守望先锋锦标赛下个月就会在这里举行
  4. 计算机访问控制机制,访问控制策略和机制-信息安全工程师知识点
  5. CSS权威指南(一)CSS概述
  6. Jmeter录制脚本过滤css
  7. P2P网贷平台运营必知
  8. STM32MP157驱动开发——Linux RS232/485/GPS 驱动
  9. iOS常用快捷键/终端常用指令
  10. ansible字符串的处理