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;

}

}

dsoframer java_dsoframer控件动态加载相关推荐

  1. MapGis二次开发——基础地图目录树控件的加载

    MapGis二次开发--基础地图目录树控件的加载 第一步:添加MapGis引用 MapGis动态库位置是在你安装位置下的\Program\plugin下,例如我的安装位置就是:D:\MapGIS 10 ...

  2. 如何实现SAP UI5 Web Component React控件的加载效果

    假设我使用SAP UI5 Web Component的React控件, 比如柱状图和折线图: 导入useState函数,默认加载状态为false: 每次点击屏幕后,首先将Loading状态使用切换函数 ...

  3. asp.net 动态创建TextBox控件 如何加载状态信息

    接着上文Asp.net TextBox的TextChanged事件你真的清楚吗? 这里我们来说说状态数据时如何加载的. 虽然在Control中有调用状态转存的方法,但是这里有一个判断条件 if (_c ...

  4. MFC 列表控件CListCtrl加载类似QQ界面的头像与文字

    本文主要讲述使用VS2012 MFC的CListCtrl(列表)控件加载类似于QQ界面的图片与文字数据.主要通过CListCtrl::InsertColumn.InsertItem.SetItemTe ...

  5. C# 系统应用之ListView控件 (二).加载选中节点文件夹下文件信息

    在项目中的前面一篇文章"C# 系统应用之TreeView控件 (一).显示树状磁盘文件目录及加载图标"中我讲述了如何使用TreeView控件树状实现显示"我的电脑&quo ...

  6. java imageview的使用_Android使用控件ImageView加载图片的方法

    在 Android 加载图片一般使用 ImageView,这里简单记录一下这个控件的使用方法. 最简单就是在 xml 里直接使用 ImageView 标签: android:orientation=& ...

  7. html 自动加载activex控件,管理加载项未显示加载控件

    已安装控件,但是在"管理加载项"中"所有加载项"中就是这个: 已安装的控件只有在网页调用此控件时才会在加载项里出现 IE加载项没有禁用Flash Player为 ...

  8. calendar控件使用 extjs_ExtJs定制日历控件——自动加载更新(日历控件显示)

    将定制的日历控件放到一个Panel里显示,其结构如下: , { border: true, id: 'page', animCollapse : true, width: 1050, height: ...

  9. win7 64位 web项目OCX控件无法加载原因

    多了不说什么 ,直接切入主题 首先,你要确认你要加载的控件已经成功的注册了,如果没有注册,请按照以下方式注册 注册成功之后,如果界面依然没有加载控件,则考虑注册表的影响了 将ocx文件拷贝到SysWO ...

  10. picturectrl控件中加载图片并显示_在 CRA 中使用 webp 图片提升加载性能

    webp 是 google 提倡的一种新的 image 格式,意在为 web 提供体积更小的图片格式.通常情况下,无损压缩可以减小 25%-35% 的体积(有例外情况,反而会增大体积,但是是因为转换图 ...

最新文章

  1. html5 div css 页签,div css 实现tabs标签的思路及示例代码
  2. addeventlistener不支持ajax_十万个Web前端面试题之AJAX、axios、fetch的区别
  3. .NET操作WORD文档另存为其他格式的文件
  4. 基于Vue+ElementUI的后台管理系统开发的总结
  5. Vue、React 之间如何实现代码移植?
  6. 了解IT行业前沿应用,关注数据与算法之美
  7. c语言sort函数_C语言经典面试题目及答案详解(二)
  8. eclipse使用方法02——链接Navigator view 与 Editor
  9. Android九宫格闪烁,js实现九宫格点击按钮随机三个格子闪烁,发生错误
  10. Cesium:在地球上加载Geoserver图层
  11. MySQL 驱动的下载方法
  12. Linux 部署 Nexus (下载、安装、使用)
  13. 中国卸扣市场趋势报告、技术动态创新及市场预测
  14. 二维码:STM32F103 + LCD屏制作二维码
  15. 微信支付开发准备工作和详细步骤
  16. IPHONE黑解教程
  17. win10拖动音量没有声音/“无法播放测试音调”/“音频服务无响应”的解决方法
  18. 浙江移动面试经验(2011)
  19. Arduino-TB6600驱动42步进电机
  20. 链表逆序——就地逆序

热门文章

  1. 账龄分析表excel模板_华为财务EXCEL内训手册(共131套模板,带公式).xls
  2. lbp算法 matlab,lbp算法(lbp特征提取算法)
  3. RS编码过程通俗理解
  4. discuz开启url伪静态
  5. matlab求单自由度振动方程为,matlab求解振动方程
  6. 微软安全软件_微软在 GitHub 上发布了一个供内部使用的 Linux 发行版 | 新闻拍一拍...
  7. 基于android的电子词典设计_基于安卓Android的电子词典的设计与实现
  8. 词霸豆豆 — 互联网时代的金山词霸
  9. 罗永浩宣布春节后回归科技界;2021年年终奖人均水平为2.3万元;消息人士:字节跳动日均进账10.07亿 | EA周报...
  10. java计算交点高程_卡西欧9860CG20图形计算程序(直线相交求交点坐标程序、距离后方交会带高程程序)...