
How can I put images in a table using gui?
21 ビュー (過去 30 日間)
古いコメントを表示
I need to create a table in matlab/gui where I have to put images in the first column of the table. Is that possible? I searched a lot for a code to help me but I couldn't find any.
0 件のコメント
採用された回答
Adam Danz
2023 年 4 月 7 日
編集済み: Adam Danz
2023 年 4 月 7 日
Here's a demo that embeds images in cells of a uitable but as @Walter Roberson mentioned, the image size will be small, and the aspect ratio may change since all icons are the same size.
uistyle is used to create icons from the images and addStyle is used to place the images in the uitable cells.
% 1. Create a demo table of images
images = ["circle.jpg" "clock.jpg" "catherine.jpg" "hexagon.jpg", "laure.jpg", "pearswtx.jpg" "star.jpg" "triangle.jpg"];
T = table('Size',[numel(images),5], ...
'VariableTypes',["string" "string" "double" "double" "double"], ...
'VariableNames',["Image" "Format" "BitDepth" "Width" "Height"]);
T.Image = images(:);
for i = 1:numel(images)
info = imfinfo(T.Image(i));
T.Format(i) = info.Format;
T.BitDepth(i) = info.BitDepth;
T.Width(i) = info.Width;
T.Height(i) = info.Height;
end
% 2. Create the uitable and embed images in column 1.
fig = uifigure;
uit = uitable(fig,"Data",T, ...
'Units','normalized', ...
'Position',[.05 .05 .9 .9], ...
'FontSize', 16);
for i = 1:height(T)
imgStyle = uistyle("Icon",T.Image(i));
addStyle(uit, imgStyle, 'cell', [i,1])
end

16 件のコメント
Sean de Wolski
2025 年 11 月 18 日
@Adam - Is there a way to put multiple icons/images in a cell?
I have a bunch of modifiers that apply to a row of a table (think like a git interface where you have add/delete/modified/stale etc.). I'd like to add the relevant ones for each row. Using uistyle(Icon...) seems to only add one and overwrite (even if Alignment is left/right). uistyle(Interpreter="html") does not seem to render images (it shows the missing icon regardless of path management). The uistyle doc does say the <img> tag is unsupported.
d = addvars(array2table(magic(3)), strings(3,1), 'NewVariableNames', {'modifiers'}, 'Before', 1);
report_24 = ['file:' which('report_24.png')]; % on path; file:/ from https://undocumentedmatlab.com/articles/images-in-matlab-uicontrols-and-labels
edit_icon = 'edit_icon.png'; % pwd
d.modifiers(1) = ['<html><body><img src="' report_24 '"><img src="' edit_icon '"></body></html>'];
warningicon = which('warning_16.png'); % no file:
d.modifiers(3) = ['<img src="' warningicon '">'];
t = uitable(uifigure, Data=d);
addStyle(t, uistyle(Interpreter="html"), "column", 1)
The only thing I've been able to figure out is to manually combine the icons and concatenate the image but the combinatorics of that are kinda ugly.
It's been awhile, hope all is well!
その他の回答 (2 件)
Walter Roberson
2023 年 4 月 6 日
If you use traditional figures with traditional uitable() objects, then Yes, it is possible.
What you do in such cases is use a cell array of character vectors, and set each one to be HTML, such as
D{2,5} = '<HTMTL><IMG source="http://SOMEURL">'
However.... it is difficult to adjust the size of the cells. You can adjust column width, but column height is going to be automatically determined to be equivalent to one line in the text font (the scanner is just going to see text, not understanding that it is going to activate something.) So you can effectively only get fairly small images, on the order of 10-ish pixels high.
If you are using uifigure() with newer uitable() then there might be additional possibilities.
If you are using uifigure() then consider the possibility of using uihtml() objects https://www.mathworks.com/help/matlab/ref/uihtml.html beside the uitable(); see also https://www.mathworks.com/help/matlab/creating_guis/create-an-html-file-that-sets-data-or-responds-to-data-changes-from-matlab.html
0 件のコメント
Image Analyst
2023 年 4 月 7 日
編集済み: Image Analyst
2025 年 11 月 22 日 23:26
Perhaps try undocumentedmatlab.com
0 件のコメント
参考
カテゴリ
Help Center および File Exchange で Develop uifigure-Based Apps についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

