MATLAB 提取图片中的曲线数据重新画图
注意:
本代码是由【MATLAB R2015b win 32位】编写。
先上代码:
%% 清空变量
clear all;
clc;
%% 取点之后趋势是对的,也就是点与点之间的比例是对的,但是每个点的真实值和原图对不上,需要按照真实的坐标处理一下
max_axis_X=5; %这里是真实坐标中横轴的最大值
max_axis_Y=25; %这里是真实坐标中纵轴的最大值
flag = 0; %如果图形的纵坐标是正数,flag=0,如果是负数,flag = 1;
shift = 0; %如果横坐标不在最下边,而是在中间,那么需要往下平移若干单位
%% 读取图片数据
fig=imread('D:\OneDrive\Work\MATLAB工程\3.png'); %读取图片
imshow(fig); %显示该图
set(gcf,'outerposition',get(0,'screensize')); %使该图显示最大化,便于取点
[X0,Y0] = ginput; %利用鼠标依次点击取出图片中数据区域边界的四个点。取点顺序:顺序点取图中坐标轴左下,左上,右上,右下四个点,回车结束。
X0(2) = X0(1); %** 对“X0,Y0”做一下处理。
X0(4) = X0(3);
Y0(4) = Y0(1);
Y0(3) = Y0(2);
[X1,Y1] = ginput; %开始点取其中一条实线上的点,按需要的精度,点取任意多的点,回车结束。
%% 因为位图的屏幕坐标是从左上角为坐标原点开始的,需要做些变换
X1 = X1 - min(X0); %** 把图片的坐标原点移到图片中数据区域的左上角
Y1 = Y1 - min(Y0);
if flag == 0
Y1= -( Y1 - (max(Y0) - min(Y0)) ); %** 把原来指向朝下的纵坐标翻转到朝上
else
Y1 = ( max(Y0) - min(Y0) ) - Y1;
Y1= ( Y1 - (max(Y0) - min(Y0)) );
end
X1 = X1 / ( max(X0) - min(X0) ) * max_axis_X; %** 按照每个取得的数据点在原图片中位置比例换算成真实坐标
Y1 = Y1 / ( max(Y0) - min(Y0) ) * max_axis_Y;
Y1 = Y1 - shift; %往下平移若干单位
plot(X1,Y1,'b-d'); %画图
具体例子:
Fig1
Fig2
Fig3
如果是“Fig1”应该这样设置:
未完 ......
点击访问原文(进入后根据右侧标签,快速定位到本文)
MATLAB 提取图片中的曲线数据重新画图的更多相关文章
- [转] 利用Matlab提取图片中曲线数据
原文地址 网易博客 前一段时间看到一篇文章"利用Matlab提取图图片中的数据",觉得思路挺好,遂下载下来研究了一番,发现作者所编写的程序没有考虑原始图片非水 平放置的情况,而实际 ...
- Matlab 如何绘制复杂曲线的包络线
Matlab 如何绘制复杂曲线的包络线 http://jingyan.baidu.com/article/aa6a2c14d36c710d4c19c4a8.html 如果一条曲线(比如声音波形)波动很 ...
- ASP.NET提取多层嵌套json数据的方法
本文实例讲述了ASP.NET利用第三方类库Newtonsoft.Json提取多层嵌套json数据的方法,具体例子如下. 假设需要提取的json字符串如下: {"name":&quo ...
- matlab结构体形式保存数据生成.mat文件< 转>
2015年 参加天池大数据竞赛 为了建立模型,打算基于matlab使用Random Forest Algorithm的工具包 该工具包我在此分享给大家,http://yunpan.cn/cVX ...
- 详解ASP.NET提取多层嵌套json数据的方法
本篇文章主要介绍了ASP.NET提取多层嵌套json数据的方法,利用第三方类库Newtonsoft.Json提取多层嵌套json数据的方法,有兴趣的可以了解一下. 本文实例讲述了ASP.NET利用第三 ...
- 如何用ABBYY FineReader提取图片中的文字
作为OCR文字识别软件中的佼佼者,可能大家对于ABBYY FineReader的使用还不熟练,没关系,今天小编就为大家演示,如何用ABBYY FineReader这款文字识别软件,将一张截图中的文字识 ...
- 用matlab提取jpg曲线数据或者jpg图片重新复原
I = imread('111.jpg');%读取处理好的图片,必须是严格坐标轴线为边界的图片 I=rgb2gray(I); %灰度变化 I(I>200)=255; %二值化 I(I<=2 ...
- matlab读取excel里的数据并用imagesc画图
把矩阵数据保存在excel里 比如文件为 a.xlsx 通过下面的程序读取 a=xlsread('\文件保存的目录\a.xlsx'); figure(1); imagesc(a) colormap(h ...
- MATLAB·提取图像中多个目标
基于matlab工具箱提取图像中的多目标特征(代码如下): 代码前面部分为提取图像的边界信息,调用了后面的遍历函数Pixel_Search,函数实现方法见后~ %%ROI Testing close ...
随机推荐
- [WEB安全]SSRF中URL的伪协议
当我们发现SSRF漏洞后,首先要做的事情就是测试所有可用的URL伪协议 0x01 类型 file:/// dict:// sftp:// ldap:// tftp:// gopher:// file: ...
- kubernetes入门学习系列
一.kubernetes基础概念 初识kubernetes kubernetes相关概念 二.kubernets架构和组件 kubernetes架构 kubernetes单Master架构 kuber ...
- Linux系统配置静态ip
一.工具/原料 redhat6.2 二.步骤 1."网络适配器"选择"桥接模式" 右键虚拟机,选择"设置"->"网络适配器& ...
- JVM 初始化阶段例子 final常量
1.创建FinalTest类,里面有一个final常量x class FinalTest{ public static final int x = 3; static { System.out.pri ...
- Type-C转接头 还是别用了,影响速率啊
今天用Type-C转接USB头传照片真慢! 在数码配件领域,越是不起眼的小外设,隐藏其背后的猫腻和水分也就越多.就拿常见的Micro USB转USB Type-C转接头和TF转SD卡套而言,你觉得 ...
- Docs-.NET-C#-指南-语言参考-预处理器指令:#endregion(C# 参考)
ylbtech-Docs-.NET-C#-指南-语言参考-预处理器指令:#endregion(C# 参考) 1.返回顶部 1. #endregion(C# 参考) 2015/07/20 #endreg ...
- 无法调用到appcode下的类
解决方法: 右键 appp_code下的类, 点击 “属性”, 里面 [生成操作] 一项 由内容 改为 编译 即可
- Grande插件和版本的对应关系
- centos6的kibana7.1无法启动报错 FATAL Error: /lib64/libc.so.6: version `GLIBC_2.14' not found 升级glibc的问题处理
centos6的kibana7.1无法启动报错 FATAL Error: /lib64/libc.so.6: version `GLIBC_2.14' not found 升级glibc的问题处理 ...
- IDEA 修改某个Module名称
一.选择module右键——>Refactor——>Rename 二.修改该module下的pom.xml文件对应module名改掉 三.修改项目的pom文件中modules里的modul ...