How do I connect to an office fluent ribbon at runtime and add/manipulate a ribbon tab in c#? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live!How to create Excel (.XLS and .XLSX) file in C# without installing Ms Office?How to add a custom Ribbon tab using VBA?VBA control over the ribbon?programmatically control ribbon in office add-in at runtimeDeploying a VSTO 2010 Addin in Office 2007Fluent Ribbon Contextual Tab ErrorVisual Studio 2015 Excel Debugger not workingPowerPoint Web Add-In Ribbon Manipulation at RuntimeExcel Office Fluent Ribbon - Populate ComboBox OnLoadHow do I add tooltips to my Custom Excel Ribbon UI?
latest version of QGIS fails to edit attribute table of GeoJSON file
Random body shuffle every night—can we still function?
First paper to introduce the "principal-agent problem"
How much damage would a cupful of neutron star matter do to the Earth?
How to ask rejected full-time candidates to apply to teach individual courses?
Are there any irrational/transcendental numbers for which the distribution of decimal digits is not uniform?
Sally's older brother
How do I say "this must not happen"?
Why are current probes so expensive?
Short story about astronauts fertilizing soil with their own bodies
What did Turing mean when saying that "machines cannot give rise to surprises" is due to a fallacy?
An isoperimetric-type inequality inside a cube
How many time has Arya actually used Needle?
Should man-made satellites feature an intelligent inverted "cow catcher"?
Is the time—manner—place ordering of adverbials an oversimplification?
How to achieve cat-like agility?
2018 MacBook Pro won't let me install macOS High Sierra 10.13 from USB installer
Where and when has Thucydides been studied?
Found this skink in my tomato plant bucket. Is he trapped? Or could he leave if he wanted?
Marquee sign letters
How do you write "wild blueberries flavored"?
Does the universe have a fixed centre of mass?
Weaponising the Grasp-at-a-Distance spell
Pointing to problems without suggesting solutions
How do I connect to an office fluent ribbon at runtime and add/manipulate a ribbon tab in c#?
Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)
Data science time! April 2019 and salary with experience
The Ask Question Wizard is Live!How to create Excel (.XLS and .XLSX) file in C# without installing Ms Office?How to add a custom Ribbon tab using VBA?VBA control over the ribbon?programmatically control ribbon in office add-in at runtimeDeploying a VSTO 2010 Addin in Office 2007Fluent Ribbon Contextual Tab ErrorVisual Studio 2015 Excel Debugger not workingPowerPoint Web Add-In Ribbon Manipulation at RuntimeExcel Office Fluent Ribbon - Populate ComboBox OnLoadHow do I add tooltips to my Custom Excel Ribbon UI?
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;
I want to connect to a running excel, or launch excel, and at run time add a tab on the root / main ribbon /menubar. When I connect with interop to the excel application object I see a dynamic object menubar. It resolves at runtime to a .com object that I can't parse.
I can iterate into each menu and see menu.name, ID, and menu item. It looks like the ribbon items in my running excel, but i can't add or remove or influence items at run time. The menus, menu, menuitem are all Microsoft private. What am i missing to resolve and add/manipulate/remove my own runtime menu items? I don't want to write and compile static or runtime xml (yet). I see other vendors do this. What assembly or include am i missing? Here is what I have from pure hacking it out.
using System;
using System . Collections . Generic;
using System . Linq;
using System . Text;
using System . Threading . Tasks;
using Microsoft.Office.Core;
using System . Linq . Expressions;
using Microsoft . Office . Interop . Outlook;
using Microsoft . Office . Interop . Excel;
using System .Diagnostics;
using System . Runtime . InteropServices;
using System . Runtime . InteropServices . ComTypes;
using System . Diagnostics . Contracts;
using System . Windows . Controls . Ribbon;
using Microsoft . Office . Tools . Excel;
using Microsoft . Office . Tools . Ribbon;
using System . ComponentModel . Design;
using System . Reflection;
using Microsoft . Office . Interop . Access;
private static void ExcelChops ( )
Process [ ] Running = Process . GetProcessesByName ( "Excel" );
if ( Running . Count()==0 )
return;
Microsoft . Office . Interop . Excel . Application ExcelApplication = ( Microsoft . Office . Interop . Excel . Application ) Marshal . GetActiveObject ( "Excel.Application" );
if ( ExcelApplication == null )
return;
string ActiveExcelApplicationCaption = ExcelApplication . Caption;
Windows ExcelWindows = ExcelApplication . Windows;
int ExcelWindowCount = ExcelWindows . Count;
XlWindowState WindowState = ExcelApplication . WindowState;
Window ExcelWindow = ExcelApplication . Windows [ 1 ];
String ExcelWindoWindowCaption = ExcelWindow . Caption;
System . Diagnostics . Debug . WriteLine ( String . Format ( "nExcel Application Caption 0 " , ActiveExcelApplicationCaption ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "nExcel Window Caption 0 " , ExcelWindoWindowCaption ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "Excel Window Count 0 " , ExcelWindowCount ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "Excel Window State 0 " , WindowState ) );
//Microsoft.Office.Interop.Excel.Panes panes = ExcelWindow . Panes;
//IteratePanes ( panes );
Microsoft.Office.Interop.Excel.MenuBar aMB = ExcelApplication . ActiveMenuBar;
IterateMenus ( aMB , 0 );
System . Diagnostics . Debug . WriteLine ( String . Format ( "0 1 " , "Completed" , ( ( ( System . Environment . StackTrace ) . Split ( 'n' ) ) [ 2 ] . Trim ( ) ) ) );
private static void IterateMenus ( MenuBar aMB , int v )
string caption = aMB . Caption;
int ndx = aMB . Index;
dynamic parent = aMB . Parent;
Menus menus = aMB . Menus;
int menusCount = aMB . Menus . Count;
for ( int i = 1 ; i <= menusCount ; i++ )
Menu a = menus [ i ];
int b = a . Index;
string c = a . Caption;
System . Diagnostics . Debug . WriteLine ( String . Format ( "0 1 " , b , c ) );
IterateMenus ( a , v + 1 );
private static void IterateMenus ( Menu A , int v )
string caption = A . Caption;
int ndx = A . Index;
MenuItems items = A . MenuItems;
int itemsCount = items . Count;
for ( int i = 1 ; i <= itemsCount ; i++ )
dynamic a = items [ i ];
Type t = a.GetType ( );
object o = a as object;
Type to = o . GetType ( );
String oo = to . ToString ( );
var occ = to . Name;
var ooc = to . TypeHandle;
System . Diagnostics . Debug . WriteLine ( String . Format ( "menu item 0 of 1 2 3 " , i , itemsCount, occ, caption) );
c# excel com ribbon dynamictype
add a comment |
I want to connect to a running excel, or launch excel, and at run time add a tab on the root / main ribbon /menubar. When I connect with interop to the excel application object I see a dynamic object menubar. It resolves at runtime to a .com object that I can't parse.
I can iterate into each menu and see menu.name, ID, and menu item. It looks like the ribbon items in my running excel, but i can't add or remove or influence items at run time. The menus, menu, menuitem are all Microsoft private. What am i missing to resolve and add/manipulate/remove my own runtime menu items? I don't want to write and compile static or runtime xml (yet). I see other vendors do this. What assembly or include am i missing? Here is what I have from pure hacking it out.
using System;
using System . Collections . Generic;
using System . Linq;
using System . Text;
using System . Threading . Tasks;
using Microsoft.Office.Core;
using System . Linq . Expressions;
using Microsoft . Office . Interop . Outlook;
using Microsoft . Office . Interop . Excel;
using System .Diagnostics;
using System . Runtime . InteropServices;
using System . Runtime . InteropServices . ComTypes;
using System . Diagnostics . Contracts;
using System . Windows . Controls . Ribbon;
using Microsoft . Office . Tools . Excel;
using Microsoft . Office . Tools . Ribbon;
using System . ComponentModel . Design;
using System . Reflection;
using Microsoft . Office . Interop . Access;
private static void ExcelChops ( )
Process [ ] Running = Process . GetProcessesByName ( "Excel" );
if ( Running . Count()==0 )
return;
Microsoft . Office . Interop . Excel . Application ExcelApplication = ( Microsoft . Office . Interop . Excel . Application ) Marshal . GetActiveObject ( "Excel.Application" );
if ( ExcelApplication == null )
return;
string ActiveExcelApplicationCaption = ExcelApplication . Caption;
Windows ExcelWindows = ExcelApplication . Windows;
int ExcelWindowCount = ExcelWindows . Count;
XlWindowState WindowState = ExcelApplication . WindowState;
Window ExcelWindow = ExcelApplication . Windows [ 1 ];
String ExcelWindoWindowCaption = ExcelWindow . Caption;
System . Diagnostics . Debug . WriteLine ( String . Format ( "nExcel Application Caption 0 " , ActiveExcelApplicationCaption ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "nExcel Window Caption 0 " , ExcelWindoWindowCaption ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "Excel Window Count 0 " , ExcelWindowCount ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "Excel Window State 0 " , WindowState ) );
//Microsoft.Office.Interop.Excel.Panes panes = ExcelWindow . Panes;
//IteratePanes ( panes );
Microsoft.Office.Interop.Excel.MenuBar aMB = ExcelApplication . ActiveMenuBar;
IterateMenus ( aMB , 0 );
System . Diagnostics . Debug . WriteLine ( String . Format ( "0 1 " , "Completed" , ( ( ( System . Environment . StackTrace ) . Split ( 'n' ) ) [ 2 ] . Trim ( ) ) ) );
private static void IterateMenus ( MenuBar aMB , int v )
string caption = aMB . Caption;
int ndx = aMB . Index;
dynamic parent = aMB . Parent;
Menus menus = aMB . Menus;
int menusCount = aMB . Menus . Count;
for ( int i = 1 ; i <= menusCount ; i++ )
Menu a = menus [ i ];
int b = a . Index;
string c = a . Caption;
System . Diagnostics . Debug . WriteLine ( String . Format ( "0 1 " , b , c ) );
IterateMenus ( a , v + 1 );
private static void IterateMenus ( Menu A , int v )
string caption = A . Caption;
int ndx = A . Index;
MenuItems items = A . MenuItems;
int itemsCount = items . Count;
for ( int i = 1 ; i <= itemsCount ; i++ )
dynamic a = items [ i ];
Type t = a.GetType ( );
object o = a as object;
Type to = o . GetType ( );
String oo = to . ToString ( );
var occ = to . Name;
var ooc = to . TypeHandle;
System . Diagnostics . Debug . WriteLine ( String . Format ( "menu item 0 of 1 2 3 " , i , itemsCount, occ, caption) );
c# excel com ribbon dynamictype
add a comment |
I want to connect to a running excel, or launch excel, and at run time add a tab on the root / main ribbon /menubar. When I connect with interop to the excel application object I see a dynamic object menubar. It resolves at runtime to a .com object that I can't parse.
I can iterate into each menu and see menu.name, ID, and menu item. It looks like the ribbon items in my running excel, but i can't add or remove or influence items at run time. The menus, menu, menuitem are all Microsoft private. What am i missing to resolve and add/manipulate/remove my own runtime menu items? I don't want to write and compile static or runtime xml (yet). I see other vendors do this. What assembly or include am i missing? Here is what I have from pure hacking it out.
using System;
using System . Collections . Generic;
using System . Linq;
using System . Text;
using System . Threading . Tasks;
using Microsoft.Office.Core;
using System . Linq . Expressions;
using Microsoft . Office . Interop . Outlook;
using Microsoft . Office . Interop . Excel;
using System .Diagnostics;
using System . Runtime . InteropServices;
using System . Runtime . InteropServices . ComTypes;
using System . Diagnostics . Contracts;
using System . Windows . Controls . Ribbon;
using Microsoft . Office . Tools . Excel;
using Microsoft . Office . Tools . Ribbon;
using System . ComponentModel . Design;
using System . Reflection;
using Microsoft . Office . Interop . Access;
private static void ExcelChops ( )
Process [ ] Running = Process . GetProcessesByName ( "Excel" );
if ( Running . Count()==0 )
return;
Microsoft . Office . Interop . Excel . Application ExcelApplication = ( Microsoft . Office . Interop . Excel . Application ) Marshal . GetActiveObject ( "Excel.Application" );
if ( ExcelApplication == null )
return;
string ActiveExcelApplicationCaption = ExcelApplication . Caption;
Windows ExcelWindows = ExcelApplication . Windows;
int ExcelWindowCount = ExcelWindows . Count;
XlWindowState WindowState = ExcelApplication . WindowState;
Window ExcelWindow = ExcelApplication . Windows [ 1 ];
String ExcelWindoWindowCaption = ExcelWindow . Caption;
System . Diagnostics . Debug . WriteLine ( String . Format ( "nExcel Application Caption 0 " , ActiveExcelApplicationCaption ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "nExcel Window Caption 0 " , ExcelWindoWindowCaption ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "Excel Window Count 0 " , ExcelWindowCount ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "Excel Window State 0 " , WindowState ) );
//Microsoft.Office.Interop.Excel.Panes panes = ExcelWindow . Panes;
//IteratePanes ( panes );
Microsoft.Office.Interop.Excel.MenuBar aMB = ExcelApplication . ActiveMenuBar;
IterateMenus ( aMB , 0 );
System . Diagnostics . Debug . WriteLine ( String . Format ( "0 1 " , "Completed" , ( ( ( System . Environment . StackTrace ) . Split ( 'n' ) ) [ 2 ] . Trim ( ) ) ) );
private static void IterateMenus ( MenuBar aMB , int v )
string caption = aMB . Caption;
int ndx = aMB . Index;
dynamic parent = aMB . Parent;
Menus menus = aMB . Menus;
int menusCount = aMB . Menus . Count;
for ( int i = 1 ; i <= menusCount ; i++ )
Menu a = menus [ i ];
int b = a . Index;
string c = a . Caption;
System . Diagnostics . Debug . WriteLine ( String . Format ( "0 1 " , b , c ) );
IterateMenus ( a , v + 1 );
private static void IterateMenus ( Menu A , int v )
string caption = A . Caption;
int ndx = A . Index;
MenuItems items = A . MenuItems;
int itemsCount = items . Count;
for ( int i = 1 ; i <= itemsCount ; i++ )
dynamic a = items [ i ];
Type t = a.GetType ( );
object o = a as object;
Type to = o . GetType ( );
String oo = to . ToString ( );
var occ = to . Name;
var ooc = to . TypeHandle;
System . Diagnostics . Debug . WriteLine ( String . Format ( "menu item 0 of 1 2 3 " , i , itemsCount, occ, caption) );
c# excel com ribbon dynamictype
I want to connect to a running excel, or launch excel, and at run time add a tab on the root / main ribbon /menubar. When I connect with interop to the excel application object I see a dynamic object menubar. It resolves at runtime to a .com object that I can't parse.
I can iterate into each menu and see menu.name, ID, and menu item. It looks like the ribbon items in my running excel, but i can't add or remove or influence items at run time. The menus, menu, menuitem are all Microsoft private. What am i missing to resolve and add/manipulate/remove my own runtime menu items? I don't want to write and compile static or runtime xml (yet). I see other vendors do this. What assembly or include am i missing? Here is what I have from pure hacking it out.
using System;
using System . Collections . Generic;
using System . Linq;
using System . Text;
using System . Threading . Tasks;
using Microsoft.Office.Core;
using System . Linq . Expressions;
using Microsoft . Office . Interop . Outlook;
using Microsoft . Office . Interop . Excel;
using System .Diagnostics;
using System . Runtime . InteropServices;
using System . Runtime . InteropServices . ComTypes;
using System . Diagnostics . Contracts;
using System . Windows . Controls . Ribbon;
using Microsoft . Office . Tools . Excel;
using Microsoft . Office . Tools . Ribbon;
using System . ComponentModel . Design;
using System . Reflection;
using Microsoft . Office . Interop . Access;
private static void ExcelChops ( )
Process [ ] Running = Process . GetProcessesByName ( "Excel" );
if ( Running . Count()==0 )
return;
Microsoft . Office . Interop . Excel . Application ExcelApplication = ( Microsoft . Office . Interop . Excel . Application ) Marshal . GetActiveObject ( "Excel.Application" );
if ( ExcelApplication == null )
return;
string ActiveExcelApplicationCaption = ExcelApplication . Caption;
Windows ExcelWindows = ExcelApplication . Windows;
int ExcelWindowCount = ExcelWindows . Count;
XlWindowState WindowState = ExcelApplication . WindowState;
Window ExcelWindow = ExcelApplication . Windows [ 1 ];
String ExcelWindoWindowCaption = ExcelWindow . Caption;
System . Diagnostics . Debug . WriteLine ( String . Format ( "nExcel Application Caption 0 " , ActiveExcelApplicationCaption ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "nExcel Window Caption 0 " , ExcelWindoWindowCaption ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "Excel Window Count 0 " , ExcelWindowCount ) );
System . Diagnostics . Debug . WriteLine ( String . Format ( "Excel Window State 0 " , WindowState ) );
//Microsoft.Office.Interop.Excel.Panes panes = ExcelWindow . Panes;
//IteratePanes ( panes );
Microsoft.Office.Interop.Excel.MenuBar aMB = ExcelApplication . ActiveMenuBar;
IterateMenus ( aMB , 0 );
System . Diagnostics . Debug . WriteLine ( String . Format ( "0 1 " , "Completed" , ( ( ( System . Environment . StackTrace ) . Split ( 'n' ) ) [ 2 ] . Trim ( ) ) ) );
private static void IterateMenus ( MenuBar aMB , int v )
string caption = aMB . Caption;
int ndx = aMB . Index;
dynamic parent = aMB . Parent;
Menus menus = aMB . Menus;
int menusCount = aMB . Menus . Count;
for ( int i = 1 ; i <= menusCount ; i++ )
Menu a = menus [ i ];
int b = a . Index;
string c = a . Caption;
System . Diagnostics . Debug . WriteLine ( String . Format ( "0 1 " , b , c ) );
IterateMenus ( a , v + 1 );
private static void IterateMenus ( Menu A , int v )
string caption = A . Caption;
int ndx = A . Index;
MenuItems items = A . MenuItems;
int itemsCount = items . Count;
for ( int i = 1 ; i <= itemsCount ; i++ )
dynamic a = items [ i ];
Type t = a.GetType ( );
object o = a as object;
Type to = o . GetType ( );
String oo = to . ToString ( );
var occ = to . Name;
var ooc = to . TypeHandle;
System . Diagnostics . Debug . WriteLine ( String . Format ( "menu item 0 of 1 2 3 " , i , itemsCount, occ, caption) );
c# excel com ribbon dynamictype
c# excel com ribbon dynamictype
edited Mar 9 at 12:23
mgraham
4,80711318
4,80711318
asked Mar 9 at 0:42
dr d b karrondr d b karron
87213
87213
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
The ribbon cannot be programmatically controlled as simply as you would hope.
Prior to the ribbon, Office applications had access to MenuBar
(undocumented for Excel) and CommandBar
objects. A MenuBar
is the classic type of menu (File, Edit, View, Window, Help, etc). A CommandBar
is the classic type of toolbar (rows of buttons below the menu). With these objects, you could directly manipulate these legacy UI features.
The ribbon is entirely different. With the ribbon, you are not given the ability to arbitrarily manipulate it. This is intended to protect one add-in from another. In order to work with the ribbon, you must have an Add-In to provide XML describing the ribbon configuration you'd like to apply. There are a few ways to create an Excel add-in:
- Use Visual Studio Tools for Office (VSTO)
- Create a COM library (cannot find a good online resource for this right now)
Here's an option using Visual Studio Code that I have never tried (not sure if this will work for your use case)
Beyond that, I suggest you google for "excel addin ribbon" for various documentation on how to work with the ribbon from within your addin.
The MenuBar
and CommandBar
objects and properties are still around for legacy and non-ribbon purposes (e.g. displaying a right-click menu). If you create new Application-level CommandBars in versions of Excel that have a ribbon, the new CommandBars are unceremoniously dumped into a generic tab where all the add-ins' CommandBars end up. Tweaking the built-in CommandBars isn't going to affect the built-in ribbon.
I believe this can be done because I see other vendors fitting their private tabs into the built-in tabs on the ribbon.
– dr d b karron
Mar 31 at 18:13
@drdbkarron Yes, it can be done, but not by using the APIs that you are asking about. You have to use Ribbon XML to work with the ribbon.
– Michael Gunter
Apr 1 at 18:47
I need a clue. How can I do what I want with XML at runtime?
– dr d b karron
Apr 2 at 2:02
add a comment |
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55072869%2fhow-do-i-connect-to-an-office-fluent-ribbon-at-runtime-and-add-manipulate-a-ribb%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
The ribbon cannot be programmatically controlled as simply as you would hope.
Prior to the ribbon, Office applications had access to MenuBar
(undocumented for Excel) and CommandBar
objects. A MenuBar
is the classic type of menu (File, Edit, View, Window, Help, etc). A CommandBar
is the classic type of toolbar (rows of buttons below the menu). With these objects, you could directly manipulate these legacy UI features.
The ribbon is entirely different. With the ribbon, you are not given the ability to arbitrarily manipulate it. This is intended to protect one add-in from another. In order to work with the ribbon, you must have an Add-In to provide XML describing the ribbon configuration you'd like to apply. There are a few ways to create an Excel add-in:
- Use Visual Studio Tools for Office (VSTO)
- Create a COM library (cannot find a good online resource for this right now)
Here's an option using Visual Studio Code that I have never tried (not sure if this will work for your use case)
Beyond that, I suggest you google for "excel addin ribbon" for various documentation on how to work with the ribbon from within your addin.
The MenuBar
and CommandBar
objects and properties are still around for legacy and non-ribbon purposes (e.g. displaying a right-click menu). If you create new Application-level CommandBars in versions of Excel that have a ribbon, the new CommandBars are unceremoniously dumped into a generic tab where all the add-ins' CommandBars end up. Tweaking the built-in CommandBars isn't going to affect the built-in ribbon.
I believe this can be done because I see other vendors fitting their private tabs into the built-in tabs on the ribbon.
– dr d b karron
Mar 31 at 18:13
@drdbkarron Yes, it can be done, but not by using the APIs that you are asking about. You have to use Ribbon XML to work with the ribbon.
– Michael Gunter
Apr 1 at 18:47
I need a clue. How can I do what I want with XML at runtime?
– dr d b karron
Apr 2 at 2:02
add a comment |
The ribbon cannot be programmatically controlled as simply as you would hope.
Prior to the ribbon, Office applications had access to MenuBar
(undocumented for Excel) and CommandBar
objects. A MenuBar
is the classic type of menu (File, Edit, View, Window, Help, etc). A CommandBar
is the classic type of toolbar (rows of buttons below the menu). With these objects, you could directly manipulate these legacy UI features.
The ribbon is entirely different. With the ribbon, you are not given the ability to arbitrarily manipulate it. This is intended to protect one add-in from another. In order to work with the ribbon, you must have an Add-In to provide XML describing the ribbon configuration you'd like to apply. There are a few ways to create an Excel add-in:
- Use Visual Studio Tools for Office (VSTO)
- Create a COM library (cannot find a good online resource for this right now)
Here's an option using Visual Studio Code that I have never tried (not sure if this will work for your use case)
Beyond that, I suggest you google for "excel addin ribbon" for various documentation on how to work with the ribbon from within your addin.
The MenuBar
and CommandBar
objects and properties are still around for legacy and non-ribbon purposes (e.g. displaying a right-click menu). If you create new Application-level CommandBars in versions of Excel that have a ribbon, the new CommandBars are unceremoniously dumped into a generic tab where all the add-ins' CommandBars end up. Tweaking the built-in CommandBars isn't going to affect the built-in ribbon.
I believe this can be done because I see other vendors fitting their private tabs into the built-in tabs on the ribbon.
– dr d b karron
Mar 31 at 18:13
@drdbkarron Yes, it can be done, but not by using the APIs that you are asking about. You have to use Ribbon XML to work with the ribbon.
– Michael Gunter
Apr 1 at 18:47
I need a clue. How can I do what I want with XML at runtime?
– dr d b karron
Apr 2 at 2:02
add a comment |
The ribbon cannot be programmatically controlled as simply as you would hope.
Prior to the ribbon, Office applications had access to MenuBar
(undocumented for Excel) and CommandBar
objects. A MenuBar
is the classic type of menu (File, Edit, View, Window, Help, etc). A CommandBar
is the classic type of toolbar (rows of buttons below the menu). With these objects, you could directly manipulate these legacy UI features.
The ribbon is entirely different. With the ribbon, you are not given the ability to arbitrarily manipulate it. This is intended to protect one add-in from another. In order to work with the ribbon, you must have an Add-In to provide XML describing the ribbon configuration you'd like to apply. There are a few ways to create an Excel add-in:
- Use Visual Studio Tools for Office (VSTO)
- Create a COM library (cannot find a good online resource for this right now)
Here's an option using Visual Studio Code that I have never tried (not sure if this will work for your use case)
Beyond that, I suggest you google for "excel addin ribbon" for various documentation on how to work with the ribbon from within your addin.
The MenuBar
and CommandBar
objects and properties are still around for legacy and non-ribbon purposes (e.g. displaying a right-click menu). If you create new Application-level CommandBars in versions of Excel that have a ribbon, the new CommandBars are unceremoniously dumped into a generic tab where all the add-ins' CommandBars end up. Tweaking the built-in CommandBars isn't going to affect the built-in ribbon.
The ribbon cannot be programmatically controlled as simply as you would hope.
Prior to the ribbon, Office applications had access to MenuBar
(undocumented for Excel) and CommandBar
objects. A MenuBar
is the classic type of menu (File, Edit, View, Window, Help, etc). A CommandBar
is the classic type of toolbar (rows of buttons below the menu). With these objects, you could directly manipulate these legacy UI features.
The ribbon is entirely different. With the ribbon, you are not given the ability to arbitrarily manipulate it. This is intended to protect one add-in from another. In order to work with the ribbon, you must have an Add-In to provide XML describing the ribbon configuration you'd like to apply. There are a few ways to create an Excel add-in:
- Use Visual Studio Tools for Office (VSTO)
- Create a COM library (cannot find a good online resource for this right now)
Here's an option using Visual Studio Code that I have never tried (not sure if this will work for your use case)
Beyond that, I suggest you google for "excel addin ribbon" for various documentation on how to work with the ribbon from within your addin.
The MenuBar
and CommandBar
objects and properties are still around for legacy and non-ribbon purposes (e.g. displaying a right-click menu). If you create new Application-level CommandBars in versions of Excel that have a ribbon, the new CommandBars are unceremoniously dumped into a generic tab where all the add-ins' CommandBars end up. Tweaking the built-in CommandBars isn't going to affect the built-in ribbon.
answered Mar 11 at 18:16
Michael GunterMichael Gunter
10.5k11444
10.5k11444
I believe this can be done because I see other vendors fitting their private tabs into the built-in tabs on the ribbon.
– dr d b karron
Mar 31 at 18:13
@drdbkarron Yes, it can be done, but not by using the APIs that you are asking about. You have to use Ribbon XML to work with the ribbon.
– Michael Gunter
Apr 1 at 18:47
I need a clue. How can I do what I want with XML at runtime?
– dr d b karron
Apr 2 at 2:02
add a comment |
I believe this can be done because I see other vendors fitting their private tabs into the built-in tabs on the ribbon.
– dr d b karron
Mar 31 at 18:13
@drdbkarron Yes, it can be done, but not by using the APIs that you are asking about. You have to use Ribbon XML to work with the ribbon.
– Michael Gunter
Apr 1 at 18:47
I need a clue. How can I do what I want with XML at runtime?
– dr d b karron
Apr 2 at 2:02
I believe this can be done because I see other vendors fitting their private tabs into the built-in tabs on the ribbon.
– dr d b karron
Mar 31 at 18:13
I believe this can be done because I see other vendors fitting their private tabs into the built-in tabs on the ribbon.
– dr d b karron
Mar 31 at 18:13
@drdbkarron Yes, it can be done, but not by using the APIs that you are asking about. You have to use Ribbon XML to work with the ribbon.
– Michael Gunter
Apr 1 at 18:47
@drdbkarron Yes, it can be done, but not by using the APIs that you are asking about. You have to use Ribbon XML to work with the ribbon.
– Michael Gunter
Apr 1 at 18:47
I need a clue. How can I do what I want with XML at runtime?
– dr d b karron
Apr 2 at 2:02
I need a clue. How can I do what I want with XML at runtime?
– dr d b karron
Apr 2 at 2:02
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55072869%2fhow-do-i-connect-to-an-office-fluent-ribbon-at-runtime-and-add-manipulate-a-ribb%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown