案例:之前跑过的程序 已经生成了多个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. github/gitlab 管理多个ssh key

    github/gitlab 管理多个ssh key 以前只使用一个 ssh key 在github上提交代码,由于工作原因,需要再添加一个ssh key在公司的 gitlab上提交代码,下面记录下配置 ...

  2. shell编程之数学运算

    shell数学运算支持整数运算的四种方法 1.let命令 no1=4; no2=5; let result=no1+no2 2.[]操作符 result=$[ no1 + no2] 3.(())操作符 ...

  3. 设计模式之工厂模式(Factory)

    设计模式的工厂模式一共有三种:简单工厂模式,工厂模式,抽象工厂模式 简单工厂模式原理:只有一个工厂类,通过传参的形式确定所创建的产品对象种类 代码如下: #include <stdio.h> ...

  4. SPOJ 057 Supernumbers in a permutation

    原题链接:http://www.spoj.com/problems/SUPPER/ 这道题n<=200000,那么确定为nlogn的算法,再定位到求LIS的O(nlogn)的算法. 对于每个a[ ...

  5. hdu 1392 Surround the Trees

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1392 题意:给出一些点的坐标,求最小的凸多边形把所有点包围时此多边形的周长. 解法:凸包ConvexH ...

  6. Mac OS 上设置 JAVA_HOME

    Mac OS 上设置 JAVA_HOME 原文链接:http://han.guokai.blog.163.com/blog/static/136718271201301183938165/ 由于需要, ...

  7. JAVA float double数据类型保留2位小数点5种方法

    /** * Java 两个整数相除保留两位小数,将小数转化为百分数 * java中,当两个整数相除时,由于小数点以后的数字会被截断,运算结果将为整数,此时若希望得到运算结果为浮点数,必须将两整数其一或 ...

  8. mysql触发器使用实例

    DELIMITER $$ USE `db`$$ DROP TRIGGER `member_walletinit_trigger`$$ CREATE TRIGGER `member_walletinit ...

  9. 服务接口API限流 Rate Limit 续

    一.前言 上一篇文章中粗浅的介绍使用Redis和基于令牌桶算法进行对服务接口API限流,本文介绍另一种算法---漏桶算法的应用.Nginx想必大家都有所了解是一个高性能的 HTTP 和反向代理服务器, ...

  10. HDU 4493 Tutor(精度处理)

    题目 #include<stdio.h> int main() { int t; double a,s; scanf("%d",&t); while(t--) ...