在office开发中,我们经常会通过自定义功能区的方式进行二次开发,比如请看一下笔者开发的一个日常使用的公文格式处理小功能如下:

office控件按钮在哪里(自定义功能区开发中自定义按钮的图标)(1)

今天,我们就来给大家讲解一个如何给所开发的按钮设置图标哟。大家应该都知道,office内置了非常多的图标库,我们在二次开发的时候可以直接调用内置的图标,使用imageMso就可以调用office内置的图标,例如批量删空段落的定义如下。

<button id="btn5" label="批量删空段落" size="large" imageMso="Delete" onAction="DelPar"/>

但在某些时候,我们希望自己定义开发按钮的图标,或者希望插件用在wps上(因为内置图标的不同,使用内置图标在wps上不能正确显示,如下图),此时就需要用到自定义图标的开发了哟,下面我就以C# VSTO开发为例给大家介绍下开发步骤。

office控件按钮在哪里(自定义功能区开发中自定义按钮的图标)(2)

一、添加自定义的图片到项目中

双击Properties下的Resources.resx,打开添加资源截面。

office控件按钮在哪里(自定义功能区开发中自定义按钮的图标)(3)

在添加资源中选择【添加现有文件(E)】,找到需要的图标。大家可以到各种图标库中寻找自己喜欢的图标,这里给大家推荐个本人使用的Iconfont-阿里巴巴矢量图标库,使用起来还是比较方便。

office控件按钮在哪里(自定义功能区开发中自定义按钮的图标)(4)

以下我们就以刚才添加的【safe】图标为例演示。

二、通过getImage回调方法添加图标

在需要自定义图标的按钮上使用getImage回调方法添加图标,此时我们需要在Ribbon.cs文件中为getImage定义回调方法。

Ribbon.xml文件中的定义:

<button id="btn7" label="批量删空段落" size="large" onAction="DelPar" getImage="GetImage"/>

office控件按钮在哪里(自定义功能区开发中自定义按钮的图标)(5)

Ribbon.cs文件中的定义:

public Bitmap GetImage(Office.IRibbonControl Control)

{

switch (Control.Id)

{

case "btn6":

return new Bitmap(Properties.Resources._2);

case "btn7":

return new Bitmap(Properties.Resources.safe);

default:

return null;

}

}

office控件按钮在哪里(自定义功能区开发中自定义按钮的图标)(6)

通过以上的步骤,我们就完成了为按钮定义自己喜欢的图标了哟,大家学会了吗?

如果需要获取以上开发的源代码,请关注后私信【vsto图标】获取哟。

,