1.使用前注册该dsoframer控件,我把该dso控件当作嵌入资源,用学习笔记1中的方法注册即可
///
/// usercontrol控件初始化
///
/// 本地文件全路径
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();
///
/// 添加控件
///
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初始化,
///
/// 初始化office控件
///
/// 本地文档路径
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文件类型
///
/// 根据后缀名得到打开方式
///
///
///
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功能给杀掉,给使用者留一个更大的空间。。。。
///
/// 获取当前操作的文档
///
public object ActiveDocument
{
get
{
return this.m_axFramerControl.ActiveDocument;
}
}
///
/// 获取当前控件对象
///
public AxDSOFramer.AxFramerControl OfficeObject
{
get
{
return this.m_axFramerControl;
}
}
5.公布了一些简单的excel和word操作方法,
#region public word method,这几个方法只对word文档有效
///
/// 设置保留修改痕迹(可以通过word工具栏的审批修改,此方法仅仅是提供初始化)
/// 这个方法挺好,可以模拟键盘按键,很巧啊.(以前很长时间都不知道可以这样...)
///
///
public void WordSetSaveTrace()
///
/// 替换标签下
///
///
///
/// 替换后是否突出显示
///
public bool WordReplace(string _sMark,string _sReplaceText,bool _IsD)
///
/// 文本替换
///
///
///
///
public bool WordReplace(string _sOrialText,string _sReplaceText)
#endregion
#region public excel method
///
/// 向固定位置填值
///
/// 填写内容
/// 开始行
/// 开始列
public void ExcelFillValue(string _sValue,int _iBeginRow,int _iBeginCol)
///
/// 向固定位置填值
///
/// 填写对象
/// 开始行
/// 开始列
public void ExcelFillValue(Object _sValue,int _iBeginRow,int _iBeginCol)
///
/// 向固定位置填值
///
/// 填写内容
/// 开始行
/// 开始列
public void ExcelFillValue(System.Data.DataSet _ds,int _iBeginRow,int _iBeginCol,bool _IsTitle)
///
/// 清空excel文档
///
public void ExcelClear()
///
/// 清空固定位置的内容
///
/// 开始行
/// 开始列
public void ExcelClear(int _iBeginRow,int _iBeginCol)
///
/// 清空指定区域的内容
///
/// 开始行
/// 开始列
/// 结束行
/// 结束列
public void ExcelClear(int _iBeginRow,int _iBeginCol,int _iEndRow,int _iEndCol)
#endregion
以上这些都是对excel和word文档操作的小儿科,害怕贴出来各位大虾见笑,不敢贴了.....
6.公布一些简单的方法(保存和另存为方法是防止菜单和工具栏被隐藏的情况下不能保存),这类应该有很多方法,我目前只用了这些个所以....
///
/// 保存
///
public void Save()
{
try
{
//先保存
this.m_axFramerControl.Save(true,true,"","");
}
catch(Exception ex)
{
throw ex;
}
}
///
/// 另存为
///
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;
}
}
///
/// 关闭当前界面
///
public void Close()
{
try
{
if(this.m_axFramerControl != null)
{
this.m_axFramerControl.Close();
}
}
catch(Exception ex)
{
throw ex;
}
}