DSO Framer _ WinForm 使用
根据自己对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 使用的更多相关文章
- DSO Framer Control Object 操作word文件
<1>DSO Framer Control Object 实现加载word文件的不可编辑 axFramerControl1.Open(OldPath); this.axFramerCont ...
- [转]内嵌WORD/OFFICE的WINFORM程序——DSOFRAMER使用小结
最近一直想用VC#2005做个内嵌WORD/OFFICE的WINFORM程序,目前主要有以下解决途径: 1.直接通过API把WORD/OFFICE的窗口句柄给放到WINFORM中(感觉较为复杂): 2 ...
- winform嵌入word解决方案一
最近一直想用VC#2005做个内嵌WORD/OFFICE的WINFORM程序,目前主要有以下解决途径: 1.直接通过API把WORD/OFFICE的窗口句柄给放到WINFORM中(感觉较为复杂): 2 ...
- winform中嵌入Ppt、Word、Excel
1.下载DsoFramer_KB311765_x86.exe 2.安装,默认路径安装C:\DsoFramer. 3.注册:开始菜单——>运行 输入:regsvr32 C:\DsoFramer\d ...
- C#实现在Winform中嵌入Word和Excel
http://www.cnblogs.com/wuzi145/archive/2012/05/08/2490680.html 在此只是介绍一个简单控件:dsoframer.ocx的使用,这个控件需要通 ...
- 将Word、Excel内容显示在Winform界面
这里使用到dsoframer.ocx插件 1. 首先下载dsoframer.ocx插件,下载地址: http://pan.baidu.com/s/1kTKHeIj 2. 注册该插件 Win7的做法是按 ...
- Winfrom 嵌入word、excel实现源码
效果图: winform中嵌入word的方法有多种:调用API,使用webBroser或使用DSOFRAMER控件: API过于繁琐: webbroser读取小文件还行,大文件就太痛苦了: 所以还是选 ...
- 使用dsoframer演示ppt
优点: (1)不用直接打开PowerPoint (2)可以嵌入到Form中,那种先打开ppt然后将ppt嵌入到Form中的方式,会先打开PowerPoint 缺点: 很早就停止更新了.... 但是没 ...
- VS2017中使用组合项目_windows服务+winform管理_项目发布_测试服务器部署
前言:作为一名C#开发人员,避免不了常和windows服务以及winform项目打交道,本人公司对服务的管理也是用到了这2个项目的组合方式进行:因为服务项目是无法直接安装到计算器中,需要使用命令借助微 ...
随机推荐
- SortedDictionary<TKey, TValue> 类 表示根据键进行排序的键/值对的集合。
SortedDictionary<TKey, TValue> 类 表示根据键进行排序的键/值对的集合. SortedDictionary<TKey, TValue> 中的每 ...
- 10.查看npm安装信息和版本号
转自:http://www.runoob.com/nodejs/nodejs-express-framework.html 你可以使用以下命令来查看所有全局安装的模块: $ npm list -g ├ ...
- BZOJ4044: [Cerc2014] Virus synthesis(回文树+DP)
Description Viruses are usually bad for your health. How about fighting them with... other viruses? ...
- Unity新版网络-NetworkManager
NetworkManager是一个组件,用来管理网络多人游戏的状态.它实际上是完全使用HLAPI实现,所以它所做的一切程序员可以使用其他方式实现.然而,NetworkManager封装好了很多有用的功 ...
- [React & Testing] Snapshot testings
For example we have a React comonent: -- A toggle button, we want to test. When it si toggle on, the ...
- ImageButton-设置background跟src
xml中添加ImageButton的background跟src <ImageButton android:id="@+id/tv3" android:layout_widt ...
- eclipse-ADT安装失败经验
今天下载了一个eclipse,结果ADT死活安装不成功,网上试了很多的方法,最后还是失败了.最后听从同事的建议,直接使用adt-bundle了.这个环境基本上都是配置好的. 下载地址 http://w ...
- v-for实现循环嵌套
<!DOCTYPE html> <html lang="en"> <head> <title></title> < ...
- 【前端切图】用css画一个卡通形象-小猪佩奇
最近在腾讯云技术社区遇到了一位奇才,用css画出了一个社会人小猪佩奇,不得不服.研究了一下他的文章https://segmentfault.com/a/1190000014909658,感觉甚是有趣, ...
- ClickOnce
Clic WPF ClickOnce应用程序IIS部署发布攻略 WPF程序非常适合公司内网使用,唯一缺点就是客户端要安装.net框架4.0.优势也很明显,在客户端运行的是一个WinForm程序,自 ...