VSTO(
Visual Studio Tools for Office
)是VBA的替代,使得开发Office应用程序更加简单,而且用VSTO来开发office应用程序可使用Visual studio开发环境中的众多功能和CLR提供的内存管理,垃圾回收等功能web
额。。。这个是百度的介绍,手动滑稽!说白了就是用来开发office插件的。api
最近因为工做缘由,一直在看开发自定义的Office插件的解决方案,总共有以下几种数组
这里说下我最后选择了用VSTO
来实现需求。首先VBA
确定被排除了,表示不会VB
。而后Office add-ins
因为自身的特性不太符合需求因此也放弃了,介绍下Office add-ins
是啥个玩意。服务器
使用Visual Studio 2017
建立一个Office add-ins
项目,系统自动会建立一个包含两个项目的解决方案。(传送门)
网络
项目 | 描述 |
加载项目 | 仅包含XML清单文件,其中包含描述加载项的全部设置。这些设置可帮助Office主机肯定什么时候应激活加载项以及加载项应显示的位置。 |
Web应用程序项目 | 包含加载项的内容页面,包括开发支持Office的HTML和JavaScript页面所需的全部文件和文件引用。在开发加载项时,Visual Studio会在本地IIS服务器上托管Web应用程序。当准备发布加载项时,须要将此Web应用程序项目部署到Web服务器。 |
Http
请求到服务器上获取的,若是有一些功能(例如统一字体,导出图片等)是须要离线状态也能够运行,那这个解决方案就无法知足了。因此最后我选择了
VSTO
。
最开始我只是想开一篇文章记录下开发过程当中经常使用的那些API(真的很差找啊!),最后啰里啰嗦的扯了不少背景介绍,终于轮到我原本想记录的东西了,但愿后来踩坑的同窗可以开发的顺畅些。ide
//获取当前ppt中全部的幻灯片 Globals.ThisAddIn.Application.ActivePresentation.Slides; //获取当前选中的ppt幻灯片 var activeSlide = (Slide)Globals.ThisAddIn.Application.ActiveWindow.View.Slide; //获取当前选中幻灯片的Index,默认从1开始 activeSlide.SlideIndex //在当前选中幻灯片前插入新的幻灯片--代码提示中没有F12进去才找到的方法 slides.Add(activeSlide.SlideIndex, PpSlideLayout.ppLayoutCustom); //获取当前窗体中的选定对象 Globals.ThisAddIn.Application.ActiveWindow.Selection;
//选择复制的silde(能够为数组new int[2]{3,5}}) Globals.ThisAddIn.Application.ActivePresentation.Slides.Range(1).Copy(); //在指定位置粘贴slide Globals.ThisAddIn.Application.ActivePresentation.Slides.Paste(1); //复制别的文档中的slide //在1位置插入指定路径ppt的Index 2-5的幻灯片 Globals.ThisAddIn.Application.ActivePresentation.Slides.InsertFromFile("c:\ppt\sales.ppt", 1, 2, 5);
//获取主题 var master = Globals.ThisAddIn.Application.ActivePresentation.SlideMaster; //修改中文字体 //“标题”中的中文字体 master.Theme.ThemeFontScheme.MajorFont.Item(Microsoft.Office.Core.MsoFontLanguageIndex.msoThemeEastAsian).Name = "新宋体"; //“内容”中的中文字体 master.Theme.ThemeFontScheme.MinorFont.Item(Microsoft.Office.Core.MsoFontLanguageIndex.msoThemeEastAsian).Name = "新宋体"; //修改英文字体 //“标题”中的英文字体 master.Theme.ThemeFontScheme.MajorFont.Item(Microsoft.Office.Core.MsoFontLanguageIndex.msoThemeLatin).Name = "新宋体"; //“内容”中的英文字体 master.Theme.ThemeFontScheme.MinorFont.Item(Microsoft.Office.Core.MsoFontLanguageIndex.msoThemeLatin).Name = "新宋体";
//在当前选中幻灯片左上角插入图片,位置和大小能够调整 //activeSlide看我上面的获取方式 //picUrl能够是网络地址或本机物理地址 activeSlide.Shapes.AddPicture(picUrl, Microsoft.Office.Core.MsoTriState.msoTrue, Microsoft.Office.Core.MsoTriState.msoTrue, 0, 0); //选中一个文本框或图片框,插入背景图片 //获取第一个选中的“形状” var shape = Globals.ThisAddIn.Application.ActiveWindow.Selection.ShapeRange[0]; sharp.Fill.UserPicture(picUrl);
未完待续!(其实我也还在摸索当中,以后会整理一个CommonHelper方法,封装一下经常使用的获取对象API。)字体