根据自己对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等文件)的更多相关文章

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

    DevExpress控件学习总结   1.Navigation & Layout 1.1 Bar Manager 如果想在窗体或用户控件(user control)上添加工具条(bars)或弹 ...

  2. DevExpress控件学习总结 z

    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. iOS开发UI篇—UITableview控件使用小结

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

  5. dsoframer控件在64系统上使用问题小汇总

    由于工作中需要,我接触了dsoframer控件,我办公电脑是64系统,在使用时,总是报没有注册类错误.我很是奇怪,dsoframer.ocx控件我都注册过的呀.然后在网上查阅了许多相关资料.悲哀的是, ...

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

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

  7. Android Material Design控件学习(三)——使用TextInputLayout实现酷市场登录效果

    前言 前两次,我们学习了 Android Material Design控件学习(一)--TabLayout的用法 Android Material Design控件学习(二)--Navigation ...

  8. 使用dsoframer控件出现"Unable to display the inactive document. Click here to reactivate the document."的问题 .

    使用如下属性设置: axFramerControl.ActivationPolicy = DSOFramer.dsoActivationPolicy.dsoKeepUIActiveOnAppDeact ...

  9. wxPython控件学习之wx.grid.Grid 表格控件

    wxPython控件学习之wx.grid.Grid (包括对GridCellEditor和GridCelRender的扩展,以支持更多的grid cell 样式, 以GridCellColorEdit ...

随机推荐

  1. Dynamic CRM 2015学习笔记 系列汇总

    这里列出所有 Dynamic CRM 2015学习笔记 系列文章,方便大家查阅.有任何建议.意见.需要,欢迎大家提交评论一起讨论. 本文原文地址:Dynamic CRM 2015学习笔记 系列汇总 一 ...

  2. 倒排索引压缩:改进的PForDelta算法

    由于倒排索引文件往往占用巨大的磁盘空间,我们自然想到对数据进行压缩.同时,引进压缩算法后,使得磁盘占用减少,操作系统在query processing过程中磁盘读取效率也能提升.另外,压缩算法不仅要考 ...

  3. C#设计模式(16)——迭代器模式(Iterator Pattern)

    一.引言 在上篇博文中分享了我对命令模式的理解,命令模式主要是把行为进行抽象成命令,使得请求者的行为和接受者的行为形成低耦合.在一章中,将介绍一下迭代器模式.下面废话不多说了,直接进入本博文的主题. ...

  4. WinDbg 命令三部曲:(三)WinDbg SOSEX 扩展命令手册

    本文为 Dennis Gao 原创技术文章,发表于博客园博客,未经作者本人允许禁止任何形式的转载. 系列博文 <WinDbg 命令三部曲:(一)WinDbg 命令手册> <WinDb ...

  5. Linux(Red Hat 6 32位) 下安装Mysql5.6.30

    转载地址:http://my.oschina.net/fusxian/blog/300480 1. 下载MySQL 5.6 下载页面:http://dev.mysql.com/downloads/my ...

  6. Android中Service深入学习

    概述 1.当用户在与当前应用程序不同的应用程序时,Service可以继续在后台运行. 2.Service可以让其他组件绑定,以便和它交互并进行进程间通信. 3.Service默认运行在创建它的应用程序 ...

  7. Javah提示未找到 ..的类文件

    D:\我的文档\workspace\PrepareForExam\src>javah -classpath D:\我的文档\workspace\ PrepareForExam\src\com\e ...

  8. Unity3D——物体鼠标跟随转向

    int floorMask; float camRayLenth = 100f;//摄像机射线距离 void Truning() { Ray ray = Camera.main.ScreenPoint ...

  9. [ACM_图论] Domino Effect (POJ1135 Dijkstra算法 SSSP 单源最短路算法 中等 模板)

    Description Did you know that you can use domino bones for other things besides playing Dominoes? Ta ...

  10. spring mvc ajax 提交复杂数组类型

    The server refused this request because the request entity is in a format not supported by the reque ...