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.]

 Risposta accettata

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 Commenti

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.

Accedi per commentare.

Più risposte (0)

Categorie

Scopri di più su Creating, Deleting, and Querying Graphics Objects in Centro assistenza e File Exchange

Richiesto:

KAE
il 9 Giu 2017

Commentato:

KAE
il 13 Giu 2017

Community Treasure Hunt

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

Start Hunting!

Translated by