uitable checkbox in GUI
5 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
raw={'p1','p2','p3'}; %points id
column1=[200;250;300]; %distances
column1=num2cell(column1);
cellArray=[raw,column1];
set(handles.uitable1, 'Data', cellArray); %predetermined blank uitable in GUI
%I wanna create blank check box (false and adjustable) for each rows in uitable. When I click on any checkbox in uitable (false to true) belongs to its row, I want to retrieve this row's distance (column 1) for some calculation in editor page.
0 Commenti
Risposta accettata
Walter Roberson
il 22 Apr 2014
'ColumnFormat', 'logical'
'CellEditCallback', set it to a function handle
If this function is called as a function handle, uitable passes it two arguments. The first argument, source, is the handle of the uitable. The second argument, eventdata, is an event data structure that contains the fields shown in the following table.
So look at the eventdata parameter. It will be a structure, with a field 'Indices' that tell you the row and column the user changed. The PreviousData and NewData fields of the structure can be used to determine whether the user is turning false to true.
3 Commenti
Walter Roberson
il 22 Apr 2014
raw={'p1'; 'p2'; 'p3'}; %points id %COLUMN not row
column1=[200;250;300]; %distances
column1=num2cell(column1);
checked=false(size(raw,1),1); %is it checked?
cellArray=[raw,column1,checked];
set(handles.uitable1, 'Data', cellArray);
set(handles.uitable1, 'ColumnFormat', {'string', 'numeric', 'logical'});
set(handles.uitable1, 'CellEditCallback', @check_checked);
function check_checked(src, eventdata);
cur_data = get(src, 'Data');
where_changed = eventdata.Indices;
row_changed = where_changed(1);
id_affected = cur_data{row_changed, 1);
dist_affected = cur_data(row_changed, 2);
... now do something with the information ...
end
Robert
il 10 Ago 2018
Thank you for this! One note: shouldn't
'string'
be
'char'
when setting the column format?
Più risposte (0)
Vedere anche
Categorie
Scopri di più su Migrate GUIDE Apps 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!