实例讲解MATLAB绘图坐标轴标签旋转

在进行绘图时需要在图片上添加上做标轴的标签,但是当数据量比较多时,例如一天24小时的数据,这时把每个小时显示在左边轴的标签上,文字内容放不下,因此需要将坐标轴标签旋转一定的角度,这样可以更好在图形上表现出我们想要呈现的效果。今天主要是以几个简单的实例介绍MATLAB绘图坐标轴标签旋转。

1.xtickangle函数

该函数通过旋转 x 轴刻度标签,此 MATLAB 函数 将当前坐标区的 x 轴刻度标签旋转到指定角度(以度为单位),其中 0 表示水平。指定正值表示逆时针旋转,负值表示顺时针旋转。

xtickangle(angle)将当前坐标轴的 x 轴刻度标签旋转到指定的角度;xtickangle(ax, angle):将指定坐标轴 ax 的 x 轴刻度标签旋转到指定的角度,而不是当前坐标轴;ang = xtickangle返回当前坐标轴的 x 轴刻度标签的旋转角度,以度为单位;ang = xtickangle(ax)返回指定坐标轴 ax 的 x 轴刻度标签的旋转角度,以度为单位。

对于特定的坐标轴,例如在使用 tiledlayout 和 nexttile 函数创建的分块图中,可以通过指定 ax 参数来旋转特定坐标轴的 x 轴刻度标签,使用实例如下:

clc;
clear all;
close all;
data1 = [-61.985731  0.09807398  98
-60.654782  0.118307152  85
-62.10265  0.12251611  82
-63.888355  0.104764369  92
-64.311429  0.026647907  107
-58.765987  0.037388049  119
-58.013333  0.03488062  127
-60.434386  0.030351077  128
-63.148462  0.035116094  120
-63.238462  0.039316079  106
-61.257429  0.043060216  89
-60.879329  0.047273744  74
-62.603173  0.052770037  68
-59.579087  0.039451698  74
-61.542441  0.057254602  90
-63.943248  0.062428356  114
-62.855078  0.041757097  139
-58.716246  0.082125854  162
-60.764546  0.044027447  179
-65.067856  0.085127171  187
-63.157738  0.106885576  184
-63.108333  0.099450438  171
-64.834721  0.088089775  151
-64.490828  0.086894242  126
];
data = [1:24];
figure;
subplot(3,1,1);
plot(data,data1(:,2));
xticks([1:24]);
xticklabels({'1:00','2:00','3:00','4:00','5:00','6:00','7:00','8:00','9:00','10:00',...'11:00','12:00','13:00','14:00','15:00','16:00','17:00','18:00','19:00','20:00',...'21:00','22:00','23:00','24:00'});
xlabel('time/h');
ylabel('tide/cm');
xtickangle(45); %x轴标签旋转45度
set(gca,'FontName','Times New Roman','FontSize',10.5);
subplot(3,1,2);
plot(data,data1(:,1));
xticks([1:24]);
xtickangle(45); %x轴标签旋转45度
xticklabels({'1:00','2:00','3:00','4:00','5:00','6:00','7:00','8:00','9:00','10:00',...'11:00','12:00','13:00','14:00','15:00','16:00','17:00','18:00','19:00','20:00',...'21:00','22:00','23:00','24:00'});
xlabel('time/h');
ylabel('SV/dB');
set(gca,'FontName','Times New Roman','FontSize',10.5);
subplot(3,1,3);
plot(data,data1(:,2));
xticks([1:24]);
xtickangle(45); %x轴标签旋转45度
xticklabels({'1:00','2:00','3:00','4:00','5:00','6:00','7:00','8:00','9:00','10:00',...'11:00','12:00','13:00','14:00','15:00','16:00','17:00','18:00','19:00','20:00',...'21:00','22:00','23:00','24:00'});xlabel('time/h');
ylabel('Density/(ind/m^{3})');
set(gca,'FontName','Times New Roman','FontSize',10.5);
set(gcf,'unit','centimeters','position',[10 5 22 12])
set(gca,'XTickLabelRotation',46);

运行结果:

图片

2.ytickangle函数

ytickangle 函数用于旋转当前坐标轴或指定坐标轴的 y 轴刻度标签到指定的角度(以度为单位),其中 0 度表示水平。正值表示逆时针旋转,负值表示顺时针旋转。

ytickangle(angle)将当前坐标轴的 y 轴刻度标签旋转到指定的角度;ytickangle(ax, angle)将指定坐标轴 ax 的 y 轴刻度标签旋转到指定的角度,而不是当前坐标轴;ang = ytickangle返回当前坐标轴的 y 轴刻度标签的旋转角度,以度为单位;ang = ytickangle(ax)返回指定坐标轴 ax 的 y 轴刻度标签的旋转角度,以度为单位。

在绘图时,如果 y 轴的刻度标签文字内容放不下,可以通过旋转标签来改善图形的可读性。例如,ytickangle(45) 可以将 y 轴刻度标签旋转 45 度。

clc;
clear all;
close all;
data = [0  585.76  298  585.76  298  585.76  298
0.1  557.6218608  302.8092487  556.1551935  301.2136497  556.1198666  300.4130501
0.2  531.1916909  307.0967308  529.6809085  304.0930011  529.5459545  302.5804936
0.3  507.677964  310.9198885  506.0065667  306.6733559  505.7213892  304.5277126
0.4  486.759645  314.3298342  484.8365359  308.9862838  484.3620808  306.277463
0.5  468.1510377  317.3720541  465.906398  311.0600217  465.2132941  307.8501496
0.6  451.5978946  320.0870271  448.9796538  312.9198246  448.046616  309.2640684
0.7  436.8739554  322.5107767  433.8447747  314.5882812  432.6572352  310.4751948
0.8  423.7778659  324.6753605  420.3125666  316.0855952  418.8615035  311.6795301
0.9  412.1304365  326.5176841  408.2138114  317.429837  406.4947493  312.708974
1  401.7722026  328.256087  397.397158  318.637169  395.4093162  313.635784
1.1  392.1284942  329.8840516  387.7272355  319.7220471  385.4728056  314.4705656
1.2  384.3712971  331.2675491  379.0829664  320.697401  376.5664992  315.2228282
1.3  377.0899475  332.5063927  371.3560572  321.574795  368.5839462  315.9010987
1.4  370.6171872  333.6165062  364.4496485  322.3645727  361.4296952  316.5130229
];
x = data(:,1);
y1 = data(:,2);
y2 = data(:,3);
y3 = data(:,4);
y4 = data(:,5);
y5 = data(:,6);
y6 = data(:,7);
c_map =  [0.00, 0.36, 0.670.68, 0.42, 0.890.44, 0.62, 0.980.10, 0.67, 0.590.99, 0.57, 0.590.28, 0.55, 0.860.96, 0.62, 0.240.30, 0.90, 0.560.12, 0.46, 0.710.46, 0.63, 0.900.96, 0.37, 0.400.14, 0.76, 0.710.99, 0.50, 0.020.00, 0.57, 0.760.35, 0.90, 0.890.17, 0.62, 0.470.21, 0.21, 0.670.99, 0.49, 0.000.98, 0.74, 0.440.97, 0.60, 0.580.18, 0.62, 0.170.68, 0.87, 0.530.12, 0.46, 0.700.65, 0.79, 0.890.95, 0.99, 0.690.74, 0.92, 0.680.37, 0.81, 0.720.01, 0.72, 0.77];
figure;
plot(x,y1,'r-o','markerface','r');
hold on;
plot(x,y2,'g-^','markerface','g');
plot(x,y3,'-^','markerface',c_map(1,:),'Color',c_map(1,:));
plot(x,y4,'-<','markerface',c_map(2,:),'Color',c_map(2,:));
plot(x,y5,'->','markerface',c_map(3,:),'Color',c_map(3,:));
plot(x,y6,'-s','markerface','k','Color','k');
xlabel('m');
ylabel('T')
legend('Tf(400g/s)','Tw(400g/s)','Tf(600g/s)','Tw(600g/s)','Tf(800g/s)','Tw(800g/s)');
box off;
set(gca,'FontName','Times New Roman','FontSize',12);%修改字体为古罗马angx = xtickangle %查询 x 轴刻度标签的当前角度
angy = ytickangle%查询 y轴刻度标签的当前角度
figure;
subplot(2,1,1);
plot(x,y1,'r-o','markerface','r');
hold on;
plot(x,y2,'g-^','markerface','g');
plot(x,y3,'-^','markerface',c_map(1,:),'Color',c_map(1,:));
plot(x,y4,'-<','markerface',c_map(2,:),'Color',c_map(2,:));
plot(x,y5,'->','markerface',c_map(3,:),'Color',c_map(3,:));
plot(x,y6,'-s','markerface','k','Color','k');
xlabel('m');
ylabel('T')
legend('Tf(400g/s)','Tw(400g/s)','Tf(600g/s)','Tw(600g/s)','Tf(800g/s)','Tw(800g/s)');
box off;
set(gca,'FontName','Times New Roman','FontSize',10);%修改字体为古罗马
subplot(2,1,2);
plot(x,y1,'r-o','markerface','r');
hold on;
plot(x,y2,'g-^','markerface','g');
plot(x,y3,'-^','markerface',c_map(1,:),'Color',c_map(1,:));
plot(x,y4,'-<','markerface',c_map(2,:),'Color',c_map(2,:));
plot(x,y5,'->','markerface',c_map(3,:),'Color',c_map(3,:));
plot(x,y6,'-s','markerface','k','Color','k');
xlabel('m');
ylabel('T')
legend('Tf(400g/s)','Tw(400g/s)','Tf(600g/s)','Tw(600g/s)','Tf(800g/s)','Tw(800g/s)');
box off;
set(gca,'FontName','Times New Roman','FontSize',10);%修改字体为古罗马
xtickangle(45);
ytickangle(45);

运行结果:

图片

图片

3.ztickangle函数

​​​​​​​​​ztickangle 函数用于旋转三维坐标系中 z 轴的刻度标签到指定的角度(以度为单位),其中 0 度表示水平方向。正值表示逆时针旋转,负值表示顺时针旋转。​​​​​​​

对于特定的坐标轴,在使用 tiledlayout 和 nexttile 函数创建的分块图中,可以通过指定 ax 参数来旋转特定坐标轴的 z 轴刻度标签,例如 ztickangle(ax2, -45)。

clc;
clear all;
close all;
figure;
subplot(2,1,1)
[x,y,z] = peaks;
surf(x,y,z);
subplot(2,1,2)
[x,y,z] = peaks;
surf(x,y,z);
xtickangle(45);
ytickangle(45);
ztickangle(45);
%从 R2019b 开始,可以使用 tiledlayout 和 nexttile 函数显示分块图。
% 调用 tiledlayout 函数以创建一个 2×1 分块图布局。
% 调用 nexttile 函数以创建坐标区对象 ax1 和 ax2。在每个坐标区中绘制。
% 然后通过将 ax2 指定为 ztickangle 的第一个输入参数,旋转下部图的 z 轴刻度标签。
tiledlayout(2,1)
ax1 = nexttile;
stem3(ax1,2*rand(5))ax2 = nexttile;
stem3(ax2,2*rand(5))
ztickangle(ax2,-45)
%创建一个曲面图。然后,查询 z 轴刻度标签的旋转角度。默认情况下,不会旋转标签。
[x,y,z] = peaks;
surf(peaks)
ang = ztickangle

运行结果:

图片

图片

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/482859.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spark 内存管理机制

Spark 内存管理 堆内内存和堆外内存 作为一个 JVM 进程&#xff0c;Executor 的内存管理建立在 JVM(最小为六十四分之一&#xff0c;最大为四分之一)的内存管理之上&#xff0c;此外spark还引入了堆外内存&#xff08;不在JVM中的内存&#xff09;&#xff0c;在spark中是指不…

为什么爱用低秩矩阵

目录 为什么爱用低秩矩阵 一、定义与性质 二、区别与例子 为什么爱用低秩矩阵 我们更多地提及低秩分解而非满秩分解,主要是因为低秩分解在数据压缩、噪声去除、模型简化和特征提取等方面具有显著的优势。而满秩分解虽然能够保持数据的完整性,但在实际应用中的场景较为有限…

Dify+Docker

1. 获取代码 直接下载 &#xff08;1&#xff09;访问 langgenius/dify: Dify is an open-source LLM app development platform. Difys intuitive interface combines AI workflow, RAG pipeline, agent capabilities, model management, observability features and more, …

Android Studio的AI工具插件使用介绍

Android Studio的AI工具插件使用介绍 一、前言 Android Studio 的 AI 工具插件具有诸多重要作用&#xff0c;以下是一些常见的方面&#xff1a; 代码生成与自动补全 代码优化与重构 代码解读 学习与知识获取 智能搜索与资源推荐实际使用中可以添加注释&#xff0c;解读某段代…

DOCKER学习总结

这里写目录标题 一、Docker安装1.1 在线安装1.2 离线安装安装配置启动服务 1.3 配置镜像1.4 Docker启动相关命令 二、Docker三大核心概念2.1 镜像2.2 容器2.3 仓库2.3.1 公有仓库2.3.2 私有仓库 二、容器与虚拟机比较 一、Docker安装 1.1 在线安装 查看是否安装dockeryum lis…

深入浅出体验AI生图产品Dall-E

DALL-E是由OpenAI开发的一种革命性的AI图像生成工具&#xff0c;能够根据文本描述生成图像。它的名字灵感来源于著名画家萨尔瓦多达利&#xff08;Salvador Dal&#xff09;和皮克斯动画电影中的角色瓦力&#xff08;WALL-E&#xff09;&#xff0c;这暗示了其在艺术创造力与技…

OpenCV_Code_LOG

孔洞填充 void fillHole(const Mat srcBw, Mat &dstBw) {Size m_Size srcBw.size();Mat TempMat::zeros(m_Size.height2,m_Size.width2,srcBw.type());//延展图像srcBw.copyTo(Temp(Range(1, m_Size.height 1), Range(1, m_Size.width 1)));cv::floodFill(Temp, Point(…

YOLOv11改进,YOLOv11添加SAConv可切换空洞卷积,二次创新C3k2结构

摘要 作者提出的技术结合了递归特征金字塔和可切换空洞卷积,通过强化多尺度特征学习和自适应的空洞卷积,显著提升了目标检测的效果。 理论介绍 空洞卷积(Atrous Convolution)是一种可以在卷积操作中插入“空洞”来扩大感受野的技术,更有效地捕捉到图像中的大范围上下文…

2024信创数据库TOP30之华为Gauss DB

近日&#xff0c;由DBC联合CIW/CIS共同发布的“2024信创数据库TOP30”榜单正式揭晓&#xff0c;汇聚了国内顶尖的数据库企业及其产品&#xff0c;成为展示中国信创领域技术实力与发展潜力的重要平台。在这份榜单中&#xff0c;华为的GaussDB凭借其卓越的技术实力、广泛的行业应…

【Spring源码核心篇-07】spring事物传播机制的流程和原理

Spring源码核心篇整体栏目 内容链接地址【一】Spring的bean的生命周期https://zhenghuisheng.blog.csdn.net/article/details/143441012【二】深入理解spring的依赖注入和属性填充https://zhenghuisheng.blog.csdn.net/article/details/143854482【三】精通spring的aop的底层原…

Redis实现限量优惠券的秒杀

核心&#xff1a;避免超卖问题&#xff0c;保证一人一单 业务逻辑 代码步骤分析 全部代码 Service public class VoucherOrderServiceImpl extends ServiceImpl<VoucherOrderMapper, VoucherOrder> implements IVoucherOrderService {Resourceprivate ISeckillVoucher…

.NET8/.NETCore 依赖注入:自动注入项目中所有接口和自定义类

.NET8/.NETCore 依赖接口注入&#xff1a;自动注入项目中所有接口和自定义类 目录 自定义依赖接口扩展类&#xff1a;HostExtensions AddInjectionServices方法GlobalAssemblies 全局静态类测试 自定义依赖接口 需要依赖注入的类必须实现以下接口。 C# /// <summary>…

搭建一个基于Web的文档管理系统,用于存储、共享和协作编辑文档

搭建一个基于Web的文档管理系统&#xff0c;用于存储、共享和协作编辑文档 本项目采用以下架构&#xff1a; NFS服务器: 负责存储文档资料。Web服务器: 负责提供文档访问和编辑功能。SELinux: 负责权限控制&#xff0c;确保文档安全。Git服务器: 负责存储文档版本历史&#x…

gitee:创建仓库,存入本地文件至仓库

一、git下载 git:下载与安装-CSDN博客https://blog.csdn.net/weixin_46001736/article/details/144107485?sharetypeblogdetail&sharerId144107485&sharereferPC&sharesourceweixin_46001736&spm1011.2480.3001.8118 二、创建仓库 1、主页面->右上角新增…

计算机网络 —— HTTP 协议(详解)

前一篇文章&#xff1a;网页版五子棋—— WebSocket 协议_网页可以实现websocket吗-CSDN博客 目录 前言 一、HTTP 协议简介 二、HTTP 协议格式 1.抓包工具的使用 2.抓包工具的原理 3.抓包结果 4.HTTP协议格式总结 三、HTTP 请求 1. URL &#xff08;1&#xff09;UR…

关于单片机的原理与应用!

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///计算机爱好者&#x1f60a;///目前正在学习C&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于单片…

爬虫专栏第一篇:深入探索爬虫世界:基础原理、类型特点与规范要点全解析

本专栏会对爬虫进行从0开始的讲解&#xff0c;每一步都十分的细致&#xff0c;如果你感兴趣希望多多点赞收藏关注支持 简介&#xff1a;文章对爬虫展开多方面剖析。起始于爬虫的基本概念&#xff0c;即依特定规则在网络抓取信息的程序或脚本&#xff0c;在搜索引擎信息提取上作…

rabbitmq原理及命令

目录 一、RabbitMQ原理1、交换机&#xff08;Exchange&#xff09;fanoutdirecttopicheaders&#xff08;很少用到&#xff09; 2、队列Queue3、Virtual Hosts4、基础对象 二、RabbitMQ的一些基本操作:1、用户管理2、用户角色3、vhost4、开启web管理接口5、批量删除队列 一、Ra…

@antv/x6 再vue中 ,自定义图形,画流程图、数据建模、er图等图形

X6 是基于 HTML 和 SVG 的图编辑引擎&#xff0c;提供低成本的定制能力和开箱即用的内置扩展&#xff0c;方便我们快速搭建 DAG 图、ER 图、流程图、血缘图等应用。 最终效果图 1.安装 npm install antv/x6 --save //x6主要包 npm install antv/x6-vue-shape //使用vue组…

vscode + conda + qt联合开发

安装vscode 安装conda 清华大学开源软件镜像(Anaconda下载)_清华大学镜像-CSDN博客 conda create新建一个环境&#xff0c;激活这个环境&#xff0c;然后安装pyside6 pip install pyside6 -i https://pypi.tuna.tsinghua.edu.cn/simple 安装成功后输入 pip list查看是否安装…