Help understand: Passing a function handle to another function as an argument

Can you help me understand the following line in the program GUI_27 from the file exchange?
set(S.fh,'windowbuttonmotionfcn',{@fh_wbmfcn,S})
I know @ is a handle to a separately defined function called fh_wbmfcn, but am puzzled about what the {} brackets are doing. Are they passing in S as an input to fh_wbmfcn? I have never seen this syntax before and it is hard to search the documentation for characters like @ or {}.
[Note GUI_27 is part of the very useful set of GUI examples by Matt Fig.]

 Réponse acceptée

Remember that every graphics callback is automatically passed two initial arguments: the source and the event data. Using the cell array {@fh_wbmfcn,S} has the same effect as if you had specified @(src,event) fh_wbmfcn(src, event, S)

3 commentaires

KAE
KAE le 9 Juin 2017
Modifié(e) : KAE le 9 Juin 2017
Wow, I just learned 5 new things. For those unfamiliar with graphic callbacks, start here. [Is it possible to pass the output arguments of fh_wbmfcn which are Cx, Cy to the workplace of function that calls it? If that is greedy to ask after the prior answer please ignore.]
"Is it possible to pass the output arguments of fh_wbmfcn which are Cx, Cy to the workplace of function that calls it"
Sorry, no, callbacks are never invoked with output assigned. Callbacks are executed as if called from the base workspace, because they are invoked asynchronously. Functions do not call callbacks (but functions might define callbacks.)
Thanks, that is helpful info.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Creating, Deleting, and Querying Graphics Objects dans Centre d'aide et File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by