博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
dsoframer控件学习小结(打开WORD,EXCEL等文件)
阅读量:6037 次
发布时间:2019-06-20

本文共 5476 字,大约阅读时间需要 18 分钟。

根据自己对dsoframer控件的学习,想把dsoframer控件进行简单的包装为C#的usercontrol,大体需要作如下:(创建windows的usercontrol的步骤就不再说了。。。)

我们暂时不对dso打开网络文件的功能和上传文件功能作过多研究,一来由于我自己不用它提供的这个功能,二来确实觉得它的这方面功能不是很强大而且使用起来比较
麻烦,呵呵,请见谅!
1.使用前注册该dsoframer控件,我把该dso控件当作嵌入资源,用学习笔记1中的方法注册即可

///   /// usercontrol控件初始化  ///   /// 本地文件全路径  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();  ///   /// 添加控件  ///   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初始化,

///   /// 初始化office控件  ///   /// 本地文档路径  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文件类型  ///   /// 根据后缀名得到打开方式  ///   ///   /// 
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功能给杀掉,给使用者留一个更大的空间。。。。

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

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

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

///   /// 保存  ///   public void Save()  {   try   {    //先保存    this.m_axFramerControl.Save(true,true,"","");   }   catch(Exception ex)   {    throw ex;   }  }  ///   /// 另存为  ///   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;   }  }  ///   /// 关闭当前界面  ///   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

 

你可能感兴趣的文章
MySQL 数据约束
查看>>
我的友情链接
查看>>
SERVLET容器简介与JSP的关系
查看>>
《服务器SSH Public Key认证指南》-补充
查看>>
我的友情链接
查看>>
Java break continue return 的区别
查看>>
算法(Algorithms)第4版 练习 1.3.4
查看>>
jquery easyUI checkbox复选项获取并传后台
查看>>
浅析NopCommerce的多语言方案
查看>>
设计模式之简单工厂模式
查看>>
C++中变量的持续性、链接性和作用域详解
查看>>
2017 4月5日上午
查看>>
Google Chrome开发者工具
查看>>
第一阶段冲刺报告(一)
查看>>
使用crontab调度任务
查看>>
【转载】SQL经验小记
查看>>
zookeeper集群搭建 docker+zk集群搭建
查看>>
Vue2.5笔记:Vue的实例与生命周期
查看>>
论JVM爆炸的几种姿势及自救方法
查看>>
联合体、结构体简析
查看>>