Identifying your imageMso – Excel, Word & PowerPoint

A little background

A while ago, I blogged about the Excel 2007 Icon Gallery, which is available from Microsoft right here. It's a useful tool when you're trying to identify the imageMso that you're after, no question... but there's a problem... It's only available in Excel. 🙁

Based on the information in my previous blog post, you'll know that I've also turned Microsoft's workbook into an add-in so that its always available to me. I've made some fair use of it in playing around with Ribbon modifications as well.

Last week I was writing up some stuff with Word, and I found myself flipping back over to Excel to look up the imageMso that I needed. This struck me as kind of silly, as I figured that it should be pretty easy to port this over to Word. I mean, really, that was the whole point behind going to XML and consistent structure, right? So I decided to do it. In fact, I built a version for Word and PowerPoint. Both they and the Excel version are included in the zip file attached to the bottom of this post. I may also add an Access version later, but you'll have to hold on for that one.

Before I started on porting this to Word & PowerPoint though, I took on some comments from Zack Barresse (both from the aforementioned blog post feedback as well as a VBAX post) and decided to implement them as well. I changed the userform a little bit and added Zack's ultimate lazy factor in; having the button automagically copy the imageMso name to the clipboard. Just because I could, I also added the option to close upon copying, as I figured that someone may not always want to copy and exit. The value of the checkbox is stored in the registry, so you only have to set it once.

Here's a picture of the new userform in action:

imagemsoindent.png

So then came the fun part...

Excel

Now, for me Excel was pretty easy as I've built more add-ins than I can remember. In this case even easier, as I was only really adjusting work someone else already did. If you've never installed an Excel add-in before though, you simply:

  • Download the zip file and extract it to your computer somewhere.
  • I'd suggest copying the Office2007IconsGallery.xlam file from that location to store it in the addins directory which can be found at:
    • Vista --> C:\Users\Username\AppData\Roaming\Microsoft\AddIns
    • XP --> C:\Documents and Settings\Username\Application Data\Microsoft\AddIns
  • Open Excel 2007
  • From the Office menu, choose Excel Options|Add-Ins|Go...
  • Check the box next to Office2007IconsGallery, then OK

Now, check the Developer tab for this:

icongallery.png

No big secret here. Just click a gallery, select an image, and you'll get the userform that I displayed above.

Word

Now Word was a little more entertaining than Excel, as I'd never built and addin for Word.

Here's the process I used to convert it:

  • In Excel, I exported the userform and code module to the desktop
  • I created a new Word .dotm (Macro enabled template) file, and imported the userform and code module
  • After saving the file and closing both Word and Excel, I opened the Excel add-in in the CustomUI editor
  • I copied all the XML code from the Excel add-in, and closed the file
  • Finally, I opened up the Word dotm file in the CustomUI editor, pasted all the XML, saved it and closed it.

Honestly, that was the easy part. As soon as I opened the file again, my group was there and it worked. The problem now was deployment...

I'd just assumed that you could dump it in to Normal.dotm, and away you go. While that works, it's a really bad idea, I found out, as the XML (at a minimum) goes with whatever documents that you create off of the normal template. That's not really cool, as I didn't really want to send that modification to everyone, so I needed a different way.

Now, Word doesn't use Add-ins, per se, but rather a form called a Global Template. While I'd heard of these, I'd never really built one in the past, as I've never created any Word utilities that I needed to share. Basically, to make your template into a global template, you just drop it in Word's STARTUP directory... that's it. In all honesty, this was a bit of a surprise, as if you do this in Excel, the file opens and is visible. Word essentially treats all its templates stored there as add-ins, so there you go.

So to recap, if you want to use the Word version of the file:

  • Download the zip file and extract it to your computer somewhere.
  • Copy the Office2007IconsGallery.dotm file to:
    • Vista --> C:\Users\Username\AppData\Roaming\Microsoft\Word\STARTUP
    • XP --> C:\Documents and Settings\Username\Application Data\Microsoft\Word\STARTUP
  • Open Word, and it's already there on the Developer tab

There is no checking of boxes required to get this to load or anything. It will just be there when you start Word up, and none of your new documents will inherit its XML code base. 🙂

PowerPoint

Probably the most mystifying of the applications to work with in this regard is PowerPoint.

Here's what I did first, much to my chagrin...

  • In Excel, I exported the userform and code module to the desktop
  • I opened Powerpoint, imported the userform and code module into the file and then saved it as a Macro Enabled Template (ppam) file
  • After saving the file and closing both PowerPoint and Excel, I opened the Excel add-in in the CustomUI editor
  • I copied all the XML code from the Excel add-in, and closed the file
  • Finally, I opened up the PowerPoint ppam file in the CustomUI editor, pasted all the XML, saved it and closed it.
  • I opened Powerpoint and tried to install it as an add-in, only to be told it wasn't a valid file

Grr...

I double-clicked the file from Windows Explorer, and it opened up just fine with my customizations. But when I closed Powerpoint and re-opened it, I could not get the add-in to load automatically.

It turns out that you need to add a little code to your add-in to get it to register itself for auto-loading. So armed with this code, I opened up the file, jumped in to the VBE... and it was not there???

So a big note to everyone who is building their first add-in in Powerpoint... SAVE A BACKUP COPY TO A REGULAR FILE FIRST! It looks like once you've converted to an add-in, that's it. One shot, and you're done. So back I went, repeating all the above steps, but this time with a regular Macro Enabled (pptm) file. In addition, I also added the following code to get it to register for auto-loading:

Sub Auto_Open()
' Get a reference to your add-in.
With AddIns(AddIns.Count)
' Create the registry key in HKEY_CURRENT_USER.
.Registered = msoTrue
' Set the AutoLoad value in the registry.
.AutoLoad = msoTrue
' Makes sure that the add-in is loaded.
.Loaded = msoTrue
End With
End Sub

So with the above code in the standard module with the RibbonX callback code, I saved the file (in the pptm format), then saved it as an add-in again. Nothing really seems to happen at that point really except you get prompted for the directory to save it in, of course. (Oh! By the way, PowerPoint Add-ins go in the Add-ins directory.) But once saved, you're back staring at your original file again, with no indication that the add-in ever really loaded. At any rate, I then closed down PowerPoint, browsed to the add-in location in Windows Explorer, and launched it from there. It works like a breeze now.

Fortunately for you, I've included the powerpoint add-in in the zip file as well. To use it:

  • Download the zip file and extract it to your computer somewhere.
  • Copy the Office2007IconsGallery.ppam file to:
    • Vista --> C:\Users\Username\AppData\Roaming\Microsoft\AddIns
    • XP --> C:\Documents and Settings\Username\Application Data\Microsoft\AddIns
  • Double click the file in Windows Explorer, and it will open Powerpoint for you and register the file
  • Browse to the Developer tab to see it waiting for you

After you've followed these steps once, you don't have to worry about lauching the file that way again. It's registered to load automagically every time you launch Powerpoint.

Some Conclusions

Whether you feel that Microsoft got it right with the Ribbon or not, I think you'd have to agree that deploying an identical UI enhancement across multiple applications would be complicated to say the least. This was actually remarkably easy, in truth. The biggest complication for me was learning the deployment side of the Add-ins/Global Templates. Once done though, it was a piece of cake. I'm actually fairly impressed. 🙂

Downloading the Add-ins

Heard enough? Sorry, just need to say a couple more things here...

  • The original XML code in these files was all produced by Microsoft. I have not modified it in any way at all.
  • The original userform has been modified by myself to allow copying of the imageMso name, but this was originally Zack Barresse's idea.
  • The superior laziness of being able to click a button to have the imageMso copied to the clipboard is definitely a Zack thing as well. I wish I'd thought of how to be quite that lazy, but I didn't. 🙁
  • The idea to extend this to Word & Powerpoint, I'll lay claim to, though. 😉

And at long last... here's the file! 🙂

Office 2007 Icons Gallery

Share:

Facebook
Twitter
LinkedIn

16 thoughts on “Identifying your imageMso – Excel, Word & PowerPoint

  1. Great post, but I'm looking for group and tab names for the ribbon on Outlook items. Anyone have any ideas where I can find these?

    Thanks!

  2. This is a most useful tool, I'm developing an access database with a custom ribbon and it's been driving me crazy trying to remember all those long random names accurately.
    Thanks!

  3. Pingback: imageMso | keyongtech

  4. I use ImageMso quite frequently in my Excel development. Having stumbled on another post, I took it a step further and put a package together to visually search, extract and save icons from Microsoft Excel as a file or copy and paste (with alpha channel transparency) to another application. I also compiled a list of 8,899 distinct ImageMso names from the various sources.

    https://imagemso.codeplex.com/

  5. Neat, thank you.

    Suggestion: Make it possible to search within the names of the imageMsos. 🙂

  6. Hi Nicolai,

    Interesting suggestion, although I'm curious how much gain it adds versus the effort to implement. Many of the idMSO names are obscure, so unless you know what you're looking for I can't see it helping a ton. And if you know then the tools isn't really adding a ton of value for you anyway.

    Unless I'm missing something? Can you expand a bit on why you'd want this and how you'd see using it?

  7. Are the Image Names stored in the XLSX file? In other words can I rename the XLSX file to zip, extract the contents and dies one of the xml files have the image names? How do you go about getting the names? Do you have to rely on Microsoft to publish them? Now that we’re in O365, I haven’t seen a comprehensive list.

  8. Hey Nick,

    The image names are all stored in the xml of the customUI.xml file contained in the xlsx zip container, but they are not elsewhere in the file. In the file itself, we just grab the imageMso of the button and put it on the form. You can find some (maybe even most) of the names via the official docs. (I know for a fact that a large portion are missing though.) Here's a link to the official docs: https://github.com/OfficeDev/office-fluent-ui-command-identifiers/tree/master/Microsoft%20365

  9. The customUI.xml is the file that's used by the user to create their own Ribbon. So this will only have the imageMso names that the user used for their ribbon. So the comprehensive list isn't stored anywhere in the file. Darn. I had made my own ImageMSO viewer back in 2000 and had accumulated over 11k+ image names from various sources. Some of the names have been deprecated, so I get the "orange circle". And as you said, that github listing is missing a large portion as well. I was hoping that a current listing could be extracted from some file stored in the Excel file or in the Office installation.

    Did you just put every control into a Ribbon and access the list that way? If so, that must have taken some doing!

  10. Actually I think I found a way to do it quite quickly:
    Create a new Custom Tab.
    Switch to All Commands
    Click the first command in the list
    Click the Add button
    Hold the "A" key until all commands are added.
    Click OK
    A new tab should now have all the commands available.
    Go back into Customize Ribbon.
    Export the customizations.
    Save the file.
    This file is an xml file ready to be examined.
    Delete the new custom tab.
    This can be done for the rest of the Office applications as well.
    Now to see how well I can tackle those exports with Power Query. ?

  11. I'm curious how you get on with this... if it adds a bunch of controls, maybe you could share it with me so that these can be updated?

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Latest Posts