Getting value from a listbox. Error: Cell contents reference from a non-cell array object.
2 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
Im trying to get the value selected in a listbox(Temp_listbox) by a callback botton and the listbox contains cells of integers:
string5 = get(handles.Temp_listbox, 'String');%%get cond1
value5 = get(handles.Temp_listbox, 'Value');
cond1 = string5{value5};
But I got the error: Cell contents reference from a non-cell array object.
Any idea about how could be solved? Thanks in advance.
Note: The value of cond1 is used afterwards to find the intersection in an array and plot the data.
2 Commenti
David Sanchez
il 23 Ago 2013
Are you sure this error message makes reference to these lines of code? They seem all right and should not yield an error.
Risposta accettata
Grzegorz Knor
il 23 Ago 2013
I suppose that your listbox contains only one string. Compare two codes:
1:
lb = uicontrol('Style','listbox','Position',[10 10 100 100],'String','a');
a = get(lb,'String');
a{get(lb,'Value')}
2:
lb = uicontrol('Style','listbox','Position',[10 10 100 100],'String',{'a','b','c'});
a = get(lb,'String');
a{get(lb,'Value')}
Code 1 produces an error.
3 Commenti
Walter Roberson
il 23 Ago 2013
Also watch out for the case where the String property is empty.
If you are not absolutely positive that the String property will be cell array, then cellstr(get(TheHandle, 'String'))
At one point in an old Answer, I listed the conditions under which the String property would not be a cell array.
Più risposte (1)
ES
il 23 Ago 2013
Not sure, you must be doing something wrong. It works fine,
if true
eg:
set(handles.listbox1, 'String',{1,2,3,4})% to set set of integers as entries for the list box.
and somewhee else,
string5 = get(handles.listbox1, 'String');%%get cond1 value5 = get(handles.listbox1, 'Value'); cond1 = string5{value5};
output is cond1=1 end
please check..
Vedere anche
Categorie
Scopri di più su Graphics Object Programming in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!