注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

水滴石穿

破浪是阵风!

 
 
 

日志

 
 

dsoframer控件学习(1)  

2008-04-10 17:48:42|  分类: 软件开发技术资料 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

根据自己对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/09/04/815772.html

  评论这张
 
阅读(360)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017