2023-10-26
	
		
		02:04 PM
	
	
	
	
	
	
	
	
	
	
	
	
	
	
 - last edited on 
    
	
		
		
		2024-09-17
	
		
		01:21 PM
	
	
	
	
	
	
	
	
	
	
	
	
	
	
 by 
				
		
		
			Doreena Deng
		
		
		
		
		
		
		
		
	
			
		
Lets say there is an element on the floor plan (any type of element). In my Addon I want to "choose" that element and perform some action. For example display its name, show its type or whatever you can imagine.
Ways of choosing the element that I know:
1. Create a dialog/palette with a button, clicking the button runs ACAPI_Interface(APIIo_GetPointID, point).
This works well, unless the user have a hard time finding a global shortcut that is not assigned to something else.
3. I believe you can create shortcuts that is specific for your dialog/palette requiring the dialog/palette to be open but they won't conflict with the global shortcuts.
4. Use ACAPI_Notification_CatchSelectionChange and when an element you are interseted in gets selected, perform the action. Can be bothersome if the user just wanted to select the element and not perform the action.
5. Somehow get notified when an element is double clicked, haven't found a way to do this. Probably not possible, but I hope I'm wrong.
6: Somehow make the action appear in the context menu of the element, haven't found a way to do this. Probably not possible, but I hope I'm wrong:
7. If the element is a GDL object maybe it is possible to hack together a way to set a paramater when the user clicks/drags/double clicks inside an RECT2 or something. And have the addon listen to parameter changes on that object trough ACAPI_Element_InstallElementObserver.
Just brainstorming, maybe some of these don't make sense. Let me know if you have other/better ideas.
Solved! Go to Solution.
 
					
				
		
2023-10-28 01:24 PM
Hi Benji,
Great list! A few thoughts and other ideas:
Best,
Bernd
 
					
				
		
2023-10-28 01:24 PM
Hi Benji,
Great list! A few thoughts and other ideas:
Best,
Bernd
2023-10-28 05:40 PM - edited 2023-10-29 04:26 PM
Hey Bernd!
Thanks for the input!
1. Yes this would definitely be an improvement, but still a bit too interruptive.
2. Nice, I did not think/know about this one.
3. Interesting idea, but very hacky 😄
After checking out Panel_Test I think adding a panel to the info box with a button (maybe in combination with adding a global shortcut that triggers the same action) is the better solution in regards with what the users are familiar with.
Best,
Benjamin
2023-10-29 04:17 PM - edited 2023-10-29 04:36 PM
I spent yesterday trying to figure out how do work with ACAPI_AddOnIntegration_InstallPanelHandler, ACAPI_AddOnIntegration_RegisterInfoBoxPanel etc:
Some stuff:
1. "They still have to be added to manually by the user via the work environment settings iirc" ACAPI_AddOnIntegration_RegisterInfoBoxPanel takes a flag that indicates if they should appear by default. So that is nice.
2. The Panel_Test is quite verbose and I think it does some unnecessary stuff, like managing a global pointer TestInfoBoxPanel* infoBoxPanel.
This is how i do it:
static GSErrCode __ACENV_CALL
CreatePageCallback(Int32, const void *tabControl, void *, void **tabPage)
{
    const DG::TabControl *control =
        reinterpret_cast<const DG::TabControl *>(tabControl);
    DG::TabPage **page = reinterpret_cast<DG::TabPage **>(tabPage);
    *page              = new TextToolsTabPage(*control);
    gTabPageOpen       = true;
    return NoError;
}
static GSErrCode __ACENV_CALL DestroyPageCallback(Int32, void *tabPage)
{
    DG::TabPage *page = reinterpret_cast<DG::TabPage *>(tabPage);
    delete page;
    gTabPageOpen = false;
    return NoError;
}
If I understand it correctly, you are suppose to allocate tabPage yourself and free it when DestroyPageCallback is run (called when user deselects the element for example).
3. In my case i wanted to read and change the memo.textContent of the selected element when a button is clicked in the tabpage.
And the third argument in CreatePageCallback can be cast to TBUI::IAPIToolUIData* which have these functions:
GetAPIElement (void* APIElemData, void* APIElemMemoData = nullptr) = 0;
SetAPIElement (void* APIElemData, const void * elemMask, void* APIElemMemoData = nullptr, Int32 memoMask = 0) = 0;
2023-10-29 04:47 PM - edited 2023-10-30 06:53 AM
In my opinion as a user, for something that is used often, the keyboard shortcut is the fastest way. While you assign a shortcut there is the check control if this is already assigned or not. The shortcut combination can be anything so you have thousands of options that will not conflict with already defined ones.
If you have a macro mouse you can even assign the shortcut to a mouse macro key.