案例:之前跑过的程序 已经生成了多个matlab图,现在需要进行合并到一个图中。

解决方案,利用图像句柄把figure图像中的参数读入到内存中,然后重新subplot绘制。

程序如下:

  1. clc;clear;
  2. open(‘./test_1.fig’)
  3. figure_info=findall(gcf,’type’,'line’);
  4. xdata1 = get(figure_info,’xdata’);
  5. ydata1 = get(figure_info,’ydata’);
  6. color1 = get(figure_info,’color’);
  7. subNum1 = length(xdata1);
  8. open(‘./test_2.fig’)
  9. figure_info=findall(gcf,’type’,'line’);
  10. xdata2 = get(figure_info,’xdata’);
  11. ydata2 = get(figure_info,’ydata’);
  12. color2 = get(figure_info,’color’);
  13. subNum2 = length(xdata2);
  14. open(‘./test_3.fig’)
  15. figure_info=findall(gcf,’type’,'line’);
  16. xdata3 = get(figure_info,’xdata’);
  17. ydata3 = get(figure_info,’ydata’);
  18. color3 = get(figure_info,’color’);
  19. subNum3 = length(xdata3);
  20. open(‘./test_4.fig’)
  21. figure_info=findall(gcf,’type’,'line’);
  22. xdata4 = get(figure_info,’xdata’);
  23. ydata4 = get(figure_info,’ydata’);
  24. color4 = get(figure_info,’color’);
  25. subNum4 = length(xdata4);
  26. %%
  27. subplot(2,2,1)
  28. for i=subNum1:-1:1
  29. if length(xdata1{i})==1
  30. break;
  31. end
  32. plot(xdata1{i},ydata1{i},‘.’,’color’,color1{i})
  33. hold on;
  34. end
  35. title(‘(a). K-means (TF-IDF)’)
  36. set(gca,’xtick’,[]);
  37. set(gca,’ytick’,[]);
  38. % box off;
  39. % axis off;
  40. subplot(2,2,2)
  41. for i=subNum2:-1:1
  42. if length(xdata2{i})==1
  43. break;
  44. end
  45. plot(xdata2{i},ydata2{i},‘.’,’color’,color2{i})
  46. hold on;
  47. end
  48. title(‘(b). Spectral Clustering (best)’)
  49. set(gca,’xtick’,[]);
  50. set(gca,’ytick’,[]);
  51. % box off;
  52. % axis off;
  53. subplot(2,2,3)
  54. for i=subNum3:-1:1
  55. if length(xdata3{i})==1
  56. break;
  57. end
  58. plot(xdata3{i},ydata3{i},‘.’,’color’,color3{i})
  59. hold on;
  60. end
  61. title(‘(c). Average Embedding (TF)’)
  62. set(gca,’xtick’,[]);
  63. set(gca,’ytick’,[]);
  64. % box off;
  65. % axis off;
  66. subplot(2,2,4)
  67. for i=subNum4:-1:1
  68. if length(xdata4{i})==1
  69. break;
  70. end
  71. lineH(subNum4-i+1) = plot(xdata4{i},ydata4{i},‘.’,’color’,color4{i});
  72. hold on;
  73. end
  74. title(‘(d). STCC’)
  75. set(gca,’xtick’,[]);
  76. set(gca,’ytick’,[]);
  77. % box off;
  78. % axis off;
  79. hL=legend(lineH,{’1′,’2′,’3′,’4′,’5′,’6′,’7′,’8′});
  80. newPosition = [0.4 0.4 0.2 0.2];
  81. newUnits = ’normalized’;
  82. set(hL,’Position’, newPosition,’Units’, newUnits);

合并成单幅图像之后要做的另外一件美观的事情就是调整间距了。。。

可参考http://blog.sina.com.cn/s/blog_7e18707801017pin.html,具体操作如下:
1. 代码实现:
figure(‘Name’,'默认’);
subplot(2,2,1);
subplot(2,2,2);
subplot(2,2,3);
subplot(2,2,4);

figure(‘Name’,'紧凑’);
subplot(‘Position’,[0.02 0.65 0.3 0.3]);
subplot(‘Position’,[0.35 0.65 0.3 0.3]);
subplot(‘Position’,[0.02 0.3 0.3 0.3]);
subplot(‘Position’,[0.35 0.3 0.3 0.3]);
subplot(‘Position’,[left bottom width height]) creates an axes at the
position specified by a four-element vector. left, bottom, width, and
height are in normalized coordinates in the range from 0.0 to 1.
在由四个归一化坐标规定的位置上建立坐标轴。

src: http://www.ilovematlab.cn/forum.php?mod=viewthread&action=printable&tid=93345

2. 手动调整:

在图上的工具栏中点Tools,Align Distribute Tool,自己设定间距。

注意:1)需要先选中两幅图片,再调整间距;2)一定要用‘shift+click’选中待调整的两幅图片,不可以直接点

其实方式1 是一种非常赞的 版面设计方法,为了能够更加清楚明了的理解 那四个参数,[left,bottom,width,height]是什么意思,我画了一张图给大家,应该可以一目了然:

其中,第一幅图的参数为[0.02, 0.65, 0.3, 0.3]

from: http://jacoxu.com/?p=1595

Matlab多个Figure图合成一个Fig的更多相关文章

  1. 使用axes函数在matlab绘图中实现图中图的绘制

    使用axes函数在matlab绘图中实现图中图的绘制 有时为了对细节进行详细说明,需要在一个较大坐标轴上绘制一个小图来对局部进行放大以阐述结果. 这可以通过调用axes函数实现. 下面通过绘制 y=1 ...

  2. C# 图片的裁剪,两个图片合成一个图片

    图片的裁剪,两个图片合成一个图片(这是从网上摘的) /// <summary>         /// 图片裁剪,生成新图,保存在同一目录下,名字加_new,格式1.png  新图1_ne ...

  3. Matlab学习笔记 figure函数

    Matlab学习笔记 figure函数 matlab中的 figure 命令,能够创建一个用来显示图形输出的一个窗口对象.每一个这样的窗口都有一些属性,例如窗口的尺寸.位置,等等.下面一一介绍它们. ...

  4. 使用MATLAB 2019 App Design 工具设计一个 电子日记App

    使用MATLAB 2019 App Design 工具设计一个 电子日记App1.1 前言:由于信号与系统课程需要,因此下载了MATLAB软件,加之对新款的执着追求,通过一些渠道,下载了MATLAB ...

  5. 二维码合成,将苹果和安卓(ios和android)合成一个二维码,让用户扫描一个二维码就可以分别下载苹果和安卓的应用

    因为公司推广的原因,没有合适的将苹果和安卓(ios和android)合成一个二维码的工具. 因为这个不难,主要是根据浏览器的UA进行判断,所以就自己开发了一个网站 网站名称叫:好推二维码  https ...

  6. QT模态对话框用法(在UI文件中设置Widget背景图,这个图是一个带阴影边框的图片——酷)

    QT弹出模态对话框做法: 1.新建UI文件时,一定要选择基类是QDialog的,我的选择是:Dialog without Buttons(),如下图: 2.然后在使用的时候: MyDialog dlg ...

  7. 010——MATLAB运行错误跳到下一个循环

    (一)MATLAB运行错误跳到下一个循环 :%文件的个数 try %运行的程序放到这里 catch continue%假如上面的没法执行则执行continue,到下个循环 end

  8. moviepy音视频剪辑:使用concatenate_videoclips和clips_array将多个视频合成一个顺序播放或同屏播放的视频

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 老猿学5G博文目录 一.视频合成概述 视频合成,也称为非线性编辑,实际 ...

  9. Idea创建文件夹自动合成一个

    在idea中创建文件夹时,它们总是自动合成一个,如下图: 文件夹自动折叠真的很影响效率,可能会引发一些不经意的失误 解决方法: 取消这个地方的勾选 这样就可以正常创建文件夹了

随机推荐

  1. Shell采集系统cpu 内存 磁盘 网络信息

    cpu信息采集 cpu使用率 采集算法 通过/proc/stat文件采集并计算CPU总使用率或者单个核使用率.以cpu0为例,算法如下: 1. cat /proc/stat | grep ‘cpu0’ ...

  2. Gentoo安装配置过程与总结

    前些时间在VMware上安装了Gentoo Linux,用了当前最新版的Gentoo,安装过程记录下来了,但一直没有整理到blog上.今天重新整理一下,写出来与大家分享和备用.接触Gentoo不久,对 ...

  3. 设计模式之状态模式(State)

    状态模式原理:随着状态的变化,对象的行为也发生变化 代码如下: #include <iostream> #include <string> #include <list& ...

  4. 【IDA*】codevs 2495:水叮当的舞步

    2495 水叮当的舞步 题目描述 Description 水叮当得到了一块五颜六色的格子形地毯作为生日礼物,更加特别的是,地毯上格子的颜色还能随着踩踏而改变. 为了讨好她的偶像虹猫,水叮当决定在地毯上 ...

  5. BZOJ 2820 YY的GCD

    AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=2820 有种方法是枚举质数然后用BZOJ2301来做但是超时了... 具体式子大概张这样: ...

  6. 树分治&树链剖分相关题目讨论

    预备知识 树分治,树链剖分   poj1741 •一棵有n个节点的树,节点之间的边有长度.方方方想知道,有多少个点对距离不超过m 题解 点分治模板题.详见我早上写的http://www.cnblogs ...

  7. 百度Hi之CSRF蠕虫攻击

    漏洞起因:百度是国内最大的中文搜索引擎.同时百度也提供了百度空间.百度贴吧等BLOG社区服务,拥有海量的用户群,号称全球最大中文社区. 80sec发现过百度产品一系列的安全漏洞,其中一些问题得到了有效 ...

  8. json_encode charset

    json_encode  utf-8   mysql   charset  utf8

  9. python笔记1

    1.python中的语句块是用缩进表示,并不像C类语言中用{}表示语句块,还有就是语句块的开始貌似是用:表示,然后C类语言中()在python中用"空格"表示了,例如python中 ...

  10. POJ 2226

    Muddy Fields Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7557   Accepted: 2791 Desc ...