MATLAB 帮助中心
捕获坐标区或图窗作为影片帧
F = getframe
F = getframe(ax)
F = getframe(fig)
F = getframe(___,rect)
F = getframe 捕获显示在屏幕上的当前坐标区作为影片帧。F 是一个包含图像数据的结构体。getframe 按照屏幕上显示的大小捕获这些坐标区。它并不捕获坐标区轮廓外部的刻度标签或其他内容。
F
getframe
示例
F = getframe(ax) 捕获 ax 标识的坐标区而非当前坐标区。
ax
F = getframe(fig) 捕获由 fig 标识的图窗。如果您需要捕获图窗窗口的整个内部区域(包括坐标区标题、标签和刻度线),则指定一个图窗。捕获的影片帧不包括图窗菜单和工具栏。
fig
F = getframe(___,rect) 捕获 rect 定义的矩形内的区域。指定 rect 作为 [left bottom width height] 形式的四元素向量。将此选项用于上一语法中的 ax 或 fig 输入参量。
rect
[left bottom width height]
全部折叠
绘制两个线条。捕获坐标区并返回图像数据。getframe 捕获坐标区的内部区域和坐标区轮廓。它并不捕获延伸到坐标区轮廓之外的内容。
plot([0 1; 1 2]) F = getframe;
F 是一个结构体,其中包含的 cdata 字段中包含捕获的图像数据。
cdata
使用 imshow 显示捕获的图像数据。
imshow
figure imshow(F.cdata)
创建一个曲面图。捕获图窗窗口的内部区域,不包括菜单和工具栏。
surf(peaks) F = getframe(gcf);
使用 imshow 在背景较暗的图窗中显示捕获的图像数据,以便您能够看到捕获的区域。
figure('Color',[0.5 0.5 0.5]) imshow(F.cdata)
捕获坐标区内部区域以及每个方向上 30 像素的边距。需要添加边距捕获帧中才能包括刻度标签。根据刻度标签的大小,可能需要调整边距。
绘制两个线条。
plot([0 1; 1 2])
将坐标区单位更改为像素并返回当前坐标区位置。位置向量的第三和第四个元素指定坐标区宽度和高度(以像素为单位)。
drawnow ax = gca; ax.Units = 'pixels'; pos = ax.Position
pos = 73.8000 47.2000 434.0000 342.3000
创建一个四元素向量 rect,以定义涵盖坐标区以及所需边距的矩形区域。rect 的前两个元素相对于坐标区左下角指定矩形左下角。rect 的最后两个元素指定矩形的宽度和高度。将坐标区单位重置为 'normalized' 的默认值。
'normalized'
marg = 30; rect = [-marg, -marg, pos(3)+2*marg, pos(4)+2*marg]; F = getframe(gca,rect); ax.Units = 'normalized';
计算坐标区周围的边距,以使捕获的图像数据包括标题、坐标区标签和刻度标签。
创建一个带有标题和 x 轴标签的绘图。
plot([0 1; 1 2]) xlabel('x values') title('Plot of Two Lines')
将坐标区单位更改为像素并存储坐标区的 Position 和 TightInset 属性值。TighInset 属性是一个 [left bottom right top] 形式的四元素向量。这些值是坐标区周围用于刻度值和文本标签的边距。
Position
TightInset
TighInset
[left bottom right top]
drawnow ax = gca; ax.Units = 'pixels'; pos = ax.Position; ti = ax.TightInset;
创建一个四元素向量 rect,以定义涵盖坐标区以及自动计算的边距的矩形区域。rect 的前两个元素相对于坐标区左下角指定矩形左下角。rect 的最后两个元素指定矩形的宽度和高度。
rect = [-ti(1), -ti(2), pos(3)+ti(1)+ti(3), pos(4)+ti(2)+ti(4)]; F = getframe(ax,rect);
调用 tiledlayout 函数以创建一个 2×1 分块图布局。调用 nexttile 函数以创建坐标区对象 ax1 和 ax2。在每个坐标区中绘制一个线条。
tiledlayout
nexttile
ax1
ax2
tiledlayout(2,1) ax1 = nexttile; plot(1:10,'b') ax2 = nexttile; plot(1:10,'r')
捕获下坐标区的内容。getframe 捕获绘图的内部区域和边框。它并不捕获延伸到绘图轮廓外部的刻度值或标签。
F = getframe(ax2);
通过循环使用 getframe 记录 peaks 函数振荡的帧。预分配一个数组以存储影片帧。
peaks
Z = peaks; surf(Z) axis tight manual ax = gca; ax.NextPlot = 'replaceChildren'; loops = 40; F(loops) = struct('cdata',[],'colormap',[]); for j = 1:loops X = sin(j*pi/10)*Z; surf(X,Z) F(j) = getframe(gcf); end
回放影片两次。
fig = figure; movie(fig,F,2)
Axes
GeographicAxes
要捕获的坐标区,指定为 Axes 对象或 GeographicAxes 对象。如果您要捕获并非当前坐标区的坐标区,请使用此选项。
getframe 捕获包围坐标区轮廓的最小矩形中的内容。如果您要捕获所有刻度值和标签,则改用 fig 输入参量。
示例: F = getframe(ax);
F = getframe(ax);
要捕获的图窗,指定为 Figure 对象。
Figure
要捕获的矩形区域,指定为 [left bottom width height] 形式的四元素向量(以像素为单位)。left 和 bottom 元素定义矩形左下角的位置。该位置相对于指定为 getframe 的第一个输入参量的图窗或坐标区。width 和 height 元素定义矩形的维度。
left
bottom
width
height
指定完全包含在图窗窗口中的矩形。
注意
如果矩形区域未完全包含在图窗可绘制区域内,getframe 返回错误。可绘制区域是图窗边框内的区域,不含图窗工具条。 (自 R2025a 起)
影片帧,以包含下列两个字段的结构体形式返回:
cdata - 存储为 uint8 值数组的图像数据。图像数据数组的大小取决于您的屏幕分辨率。
uint8
colormap - 颜色图。在真彩色系统中,此字段为空。
colormap
以下是有关 cdata 的大小的一些重要注意事项:
如果您查询 getframe 捕获的区域(图窗、坐标区或由 rect 指定的区域)的大小,则以像素为单位的大小可能与 cdata 中的元素数不匹配。这种差异是因为 cdata 中的元素数取决于您的屏幕分辨率(以及操作系统设置),而 MATLAB® 中的像素数可能不对应于屏幕上的实际像素数。
从 R2015b 开始,如果您使用高分辨率系统,则 cdata 的大小可能大于在以前版本中或在其他系统上的大小。
getframe 不支持捕获Web App (MATLAB Compiler)中的内容。
在 Windows® 和 Macintosh 系统上,像素的大小为 1/96 英寸。此大小与系统分辨率无关。
在 Linux® 系统上,一个像素的大小由系统分辨率确定。
为了在使用 getframe 值获得最快的性能,请确保图窗在屏幕上可见。如果图窗不可见,getframe 仍可捕获该图窗,但性能可能会减慢。
为了更好地控制图像数据的分辨率,请改用 print 函数。带有 print 的 cdata 输出参量返回图像数据。resolution 输入参量控制图像的分辨率。
print
resolution
要确保捕获显示在三维绘图旁边的颜色栏和图例,请在调用 getframe 时指定 fig 参量。
全部展开
在 MATLAB Online™ 中,现在可以捕获使用 App 设计工具或 uifigure 函数创建的图窗的内容。也可使用本地安装捕获这些类型的图窗。
uifigure
如果使用 rect 参量捕获未完全包含在图窗可绘制区域内的区域,getframe 返回错误。可绘制区域是图窗边框内的区域,不含图窗工具条。
在 R2022b 中已声明此变化。在 R2023b 至 R2024b 中,当指定的矩形区域未完全包含在图窗的可绘制区域内时,getframe 函数会发出警告。
movie | frame2im | im2frame | image | imshow | print | writeVideo
movie
frame2im
im2frame
image
writeVideo
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
选择网站
选择网站以获取翻译的可用内容,以及查看当地活动和优惠。根据您的位置,我们建议您选择:。
您也可以从以下列表中选择网站:
如何获得最佳网站性能
选择中国网站(中文或英文)以获得最佳网站性能。其他 MathWorks 国家/地区网站并未针对您所在位置的访问进行优化。
美洲
欧洲
亚太
联系您当地的办事处