dsoframer控件学习小结(打开WORD,EXCEL等文件)
根据自己对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;
- }
- }
- .公布了一些简单的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
dsoframer控件学习小结(打开WORD,EXCEL等文件)的更多相关文章
- DevExpress控件学习总结(转)
DevExpress控件学习总结 1.Navigation & Layout 1.1 Bar Manager 如果想在窗体或用户控件(user control)上添加工具条(bars)或弹 ...
- DevExpress控件学习总结 z
1.Navigation & Layout 1.1 Bar Manager 如果想在窗体或用户控件(user control)上添加工具条(bars)或弹出菜单(popup menus),我们 ...
- DevExpress控件学习总结
1.Navigation & Layout 1.1 Bar Manager 如果想在窗体或用户控件(user control)上添加工具条(bars)或弹出菜单(popup menus),我们 ...
- iOS开发UI篇—UITableview控件使用小结
iOS开发UI篇—UITableview控件使用小结 一.UITableview的使用步骤 UITableview的使用就只有简单的三个步骤: 1.告诉一共有多少组数据 方法:- (NSInteger ...
- dsoframer控件在64系统上使用问题小汇总
由于工作中需要,我接触了dsoframer控件,我办公电脑是64系统,在使用时,总是报没有注册类错误.我很是奇怪,dsoframer.ocx控件我都注册过的呀.然后在网上查阅了许多相关资料.悲哀的是, ...
- IOS学习笔记(四)之UITextField和UITextView控件学习
IOS学习笔记(四)之UITextField和UITextView控件学习(博客地址:http://blog.csdn.net/developer_jiangqq) Author:hmjiangqq ...
- Android Material Design控件学习(三)——使用TextInputLayout实现酷市场登录效果
前言 前两次,我们学习了 Android Material Design控件学习(一)--TabLayout的用法 Android Material Design控件学习(二)--Navigation ...
- 使用dsoframer控件出现"Unable to display the inactive document. Click here to reactivate the document."的问题 .
使用如下属性设置: axFramerControl.ActivationPolicy = DSOFramer.dsoActivationPolicy.dsoKeepUIActiveOnAppDeact ...
- wxPython控件学习之wx.grid.Grid 表格控件
wxPython控件学习之wx.grid.Grid (包括对GridCellEditor和GridCelRender的扩展,以支持更多的grid cell 样式, 以GridCellColorEdit ...
随机推荐
- Linux下which、whereis、locate、find命令的区别
我们经常在linux要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索.这些是从网上找到的资料(参考资料1),因为有时很长时间不会用到,当要用的时候经常弄混了,所以放到这里方便使用. w ...
- java获取classpath文件路径空格转变成了转义字符%20的问题
java获取classpath文件路径空格转变成了转义字符%20的问题 这个问题很纠结,服务器的文件路径带有空格,空格被转化是%20了,悲剧就出现了 下面展示一段代码String path = get ...
- 《Linux内核设计与实现》读书笔记(十五)- 进程地址空间(kernel 2.6.32.60)
进程地址空间也就是每个进程所使用的内存,内核对进程地址空间的管理,也就是对用户态程序的内存管理. 主要内容: 地址空间(mm_struct) 虚拟内存区域(VMA) 地址空间和页表 1. 地址空间(m ...
- 互联网上那些excel文件
互联网上那些excel文件 文/玄魂 目录 互联网上那些excel文件 前言 1.1 查找包含指定值的excel文件 1.2 查找邮箱 1.3 查找身份证号 1.4 查找管理人员联系信息 1.5 获 ...
- Kindle 转换器
一款比较好用的Kindle转换器,支持txt, opf, htm, html, epub 到 mobi 的转换,支持拖放操作,支持批量操作.只需要选中多个待转换的文件,拖放到程序窗口即可. 曾经用过一 ...
- nginx location模块--匹配规则
Location语法语法:location [=|~|~*|^~] /uri/ { … } = --> 开头表示精确匹配 ^~ --> 开头表示uri以某个常规字符串开头,理解为匹配url ...
- 1.__tostring()这个方法在类里可以直接输出对象。2.克隆对象的运用
<?php //__tostring()这个方法在类里的用途 能够直接输出对象 class Ren { public $name; function Run() { echo "跑&q ...
- SQL order by的用法
首先,order by是用来写在where之后,给多个字段来排序的一个DQL查询语句. 其次,order by写法: 1. select 字段列表/* from 表名 where 条件 order ...
- 集合使用copy与mutableCopy的区别
集合(NSArray,NSSet,NSDictionary等)使用copy与mutableCopy的区别是类似的,下面以NSMutableArray.NSArray 为例子验证如下: NSMutabl ...
- [jQuery学习系列二 ]2-JQuery学习二-数组操作
前言 上一篇内容 已经对于Jquery 有了一些认识, 包括Jquery的选择器和DOM对象, 那么这一篇继续来看下Jquery中很实用的Jquery对于数组的操作. Jquery中对数组的操作大致有 ...