根据自己对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在线编辑控件完成了.

文章转载于:
作者: jisen
http://www.cnblogs.com/jisen/archive/2007/07/12/815772.html

DSO Framer _ WinForm 使用的更多相关文章

  1. DSO Framer Control Object 操作word文件

    <1>DSO Framer Control Object 实现加载word文件的不可编辑 axFramerControl1.Open(OldPath); this.axFramerCont ...

  2. [转]内嵌WORD/OFFICE的WINFORM程序——DSOFRAMER使用小结

    最近一直想用VC#2005做个内嵌WORD/OFFICE的WINFORM程序,目前主要有以下解决途径: 1.直接通过API把WORD/OFFICE的窗口句柄给放到WINFORM中(感觉较为复杂): 2 ...

  3. winform嵌入word解决方案一

    最近一直想用VC#2005做个内嵌WORD/OFFICE的WINFORM程序,目前主要有以下解决途径: 1.直接通过API把WORD/OFFICE的窗口句柄给放到WINFORM中(感觉较为复杂): 2 ...

  4. winform中嵌入Ppt、Word、Excel

    1.下载DsoFramer_KB311765_x86.exe 2.安装,默认路径安装C:\DsoFramer. 3.注册:开始菜单——>运行 输入:regsvr32 C:\DsoFramer\d ...

  5. C#实现在Winform中嵌入Word和Excel

    http://www.cnblogs.com/wuzi145/archive/2012/05/08/2490680.html 在此只是介绍一个简单控件:dsoframer.ocx的使用,这个控件需要通 ...

  6. 将Word、Excel内容显示在Winform界面

    这里使用到dsoframer.ocx插件 1. 首先下载dsoframer.ocx插件,下载地址: http://pan.baidu.com/s/1kTKHeIj 2. 注册该插件 Win7的做法是按 ...

  7. Winfrom 嵌入word、excel实现源码

    效果图: winform中嵌入word的方法有多种:调用API,使用webBroser或使用DSOFRAMER控件: API过于繁琐: webbroser读取小文件还行,大文件就太痛苦了: 所以还是选 ...

  8. 使用dsoframer演示ppt

    优点: (1)不用直接打开PowerPoint (2)可以嵌入到Form中,那种先打开ppt然后将ppt嵌入到Form中的方式,会先打开PowerPoint 缺点: 很早就停止更新了....  但是没 ...

  9. VS2017中使用组合项目_windows服务+winform管理_项目发布_测试服务器部署

    前言:作为一名C#开发人员,避免不了常和windows服务以及winform项目打交道,本人公司对服务的管理也是用到了这2个项目的组合方式进行:因为服务项目是无法直接安装到计算器中,需要使用命令借助微 ...

随机推荐

  1. storm单机运行与集群运行问题

    使用trident接口时,storm读取kafka数据会将kafka消费记录保存起来,将消费记录的位置保存在tridentTopology.newStream()的第一个参数里, 如果设置成从头开始消 ...

  2. POJ 2981 Strange Way to Express Integers 模线性方程组

    http://poj.org/problem?id=2891 结果看了半天还是没懂那个模的含义...懂了我再补充... 其他的思路都在注释里 /********************* Templa ...

  3. 【Django】AJAX

    目录 JSON 序列化 stringify 反序列化 parse JSON与XML对比 AJAX简介 AJAX常见应用场景 jQuery实现AJAX JS实现AJAX AJAX请求设置csrf_tok ...

  4. 关于oracle sql语句查询时 表名和字段名要加双引號的问题具体解释

      作为oracle的刚開始学习的人相信大家一定会遇到这个问题.如图:          明明就是navicat可视化创建了表,但是就是不能查到!这个为什么呢?           select * ...

  5. Android eclipse 提示java代码 快捷键

    1.提示java代码能够用ALT+/ 键就能够了(前提是你要把你须要的类或方法的首字母打出来).我添加的部分:仅仅要输入sysout,然后alt+/键就能够输出System.out.prinln(), ...

  6. UVa 11743 - Credit Check

    题目:推断卡号是否合法,给你4组4位的数字.偶数位的2倍的位和加上奇数位的和,推断尾数是否为0. 分析:简单题,模拟. 直接依照提议推断就可以. 说明:460题,加油! #include <io ...

  7. UnrealEngine4针对游戏模式的思考

    游戏能够概括为三类:单进程联机(超级玛丽).小规模联机(魔兽争霸.CS),大规模联机(魔兽世界). watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZmx1c ...

  8. jodd-servlet工具集锦

    Jodd提供了许多servlet和jsp相关的工具. Utils ServletUtils类集成了不同的servlet工具,你可以检测multipart请求,读取授权头,下载预备,cookie操作,读 ...

  9. C#中流,字节,字符,字符串

    首先要明白它们本身是由什么组成的: 流:二进制 字节:无符号整数 字符:Unicode编码字符 字符串:多个Unicode编码字符 那么在.net下它们之间如何转化呢? 一般是遵守以下规则: 流-&g ...

  10. position记录

    1.  relative(相对定位):生成相对定位的元素,通过top,bottom,left,right的设置相对于其正常(原先本身)位置进行定位.可通过z-index进行层次分级.均是以父级的左上角 ...