根据自己对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. C#的泛型委托与闭包函数

    前些天Wendy问我说Func<T, ResultT>是个什么意思,初学C#都觉得这样的写法很奇葩,甚至觉得这样写有点诡异,其实以我来看,这是体现C#函数式编程的又一个亮点. 从MSDN上 ...

  2. Windows Server 2008 64 位 IIS7.5 ASP.NET MVC4 发布问题

    问题描述: 环境与配置: ASP.NET MVC 4 WINDOWS SERVER 2008 64 位 应用程序池是选择的 .NET 4.0 与经典模式   在新建一个MVC 4 项目发现到服务器上后 ...

  3. [ACM_搜索] ZOJ 1103 || POJ 2415 Hike on a Graph (带条件移动3盘子到同一位置的最少步数 广搜)

    Description "Hike on a Graph" is a game that is played on a board on which an undirected g ...

  4. 为什么Web 设计会‘死’?

    高质量的Web 模板,成熟的Design Pattern,人工智能的引用,移动技术的冲击是否标志着Web Design 结束的时代已经到来? Web Design 最终也未避免与“死亡”这个词的关联, ...

  5. [BTS] SQL Adapter. New transaction cannot enlist in the specified transaction coordinator

    The adapter "SQL" raised an error message. Details "New transaction cannot enlist in ...

  6. windows本地自动集成代码+SSH服务器配置

    在windows环境下使用Jenkins自动集成代码 描述: 局域网电脑A是本地服务器,安全win7系统,安装了Jenkins:现在想让A成为测试服务器,需要隔一段时间从SVN里同步出最新的代码,供客 ...

  7. JAVA学习中Swing部分JDialog对话框窗体的简单学习

    package com.swing; import java.awt.Color;import java.awt.Container;import java.awt.event.ActionEvent ...

  8. [C#HttpHelper]类1.4正式版教程与升级报告

       [C#HttpHelper]类1.4正式版教程与升级报告 导读 1.升级报告 2.HttpHelper1.4正式版下载 3.HttpHelper类使用方法, 4.最简单的Post与Get的写法 ...

  9. .NET中的流

    当应用程序需要和磁盘上的文件打交道的时候,就有了流的概念.流就像架设在应用程序所在内存和磁盘之间的一个管道. 大致思路 → 建立管道 //FileMode.Open打开现有文件,另外还有FileMod ...

  10. Js 数据容量单位转换(kb,mb,gb,tb)

    function bytesToSize(bytes) { if (bytes === 0) return '0 B'; var k = 1000, // or 1024 sizes = ['B', ...