Matlab之空间坐标系绘制平面图形

在空间直角坐标系中,绘制指定平面方程的图形

版本说明:

20240413_V1.01:更正代码错误,并修改输入参数类型(测试用例得修改)

20240413_V1.00:初始版本

一、平面方程

基本形式为:A*X+B*Y+C*Z+D=0

例如:对于X+23=0的平面方程如下

二、Matlab通用绘制函数

cpp 复制代码
%% 绘制平面图形
% 输入参数:平面方程的参数以及图形的范围
function plot_plane(A, B, C, D, Range)
% 检查平面是否与坐标轴平行
if A == 0 && B == 0
    % 平面与z轴垂直
    [X, Y] = meshgrid(linspace(-Range, Range, 100),linspace(-Range, Range, 100));
    Z =zeros(size(X))-D;  % 固定z值
elseif B == 0 && C == 0
    % 平面与y轴和Z轴平行
    [Y, Z] = meshgrid(linspace(-Range, Range, 100), linspace(-Range, Range, 100));
    X = zeros(size(Y))- D;  % 固定X值
elseif A == 0 && C == 0
    % 平面与X轴和Z轴平行
    [X, Z] = meshgrid(linspace(-Range, Range, 100),linspace(-Range, Range, 100));
    Y = zeros(size(X))- D;  % 固定x值    
elseif C == 0
    % 平面与Z轴平行
    [X, Z] = meshgrid(linspace(-Range, Range, 100),linspace(-Range, Range, 100));
    Y = -(A.* X +D)/B;  % 解平面方程得到Y
else
    % 平面不与Z坐标轴平行
    % 选择一个合适的范围来创建网格点
    [X, Y] = meshgrid(linspace(-Range, Range, 100),linspace(-Range, Range, 100));
    Z = -(A.* X + B.* Y+D)/C;  % 解平面方程得到z
end

% 绘制平面
surf(X, Y, Z, 'FaceColor', 'none', 'EdgeColor', 'blue');

% 设置图形属性
grid on;
xlabel('X轴');
ylabel('Y轴');
zlabel('Z轴');
xlim([-Range, Range]);
ylim([-Range, Range]);
zlim([-Range, Range]);
% axis equal;     % 保持轴的比例一致
view(3);         % 设置三维视角
end

三、测试用例

3.1 X+23=0

plot_plane(1, 0, 0, 23, '平面绘制示例')

3.2 Y+23=0

plot_plane(0, 1, 0, 23, '平面绘制示例')

3.3 Z+23=0

plot_plane(0, 0, 1, 23, '平面绘制示例')

3.4 Y+Z+23=0

plot_plane(0, 1, 1, 23, '平面绘制示例')

3.5 X+Z+23=0

plot_plane(1, 0, 1, 23, '平面绘制示例')

3.6 X+Y+23=0

plot_plane(1, 1, 0, 23, 5)

3.7 X+Y+Z+23=0

plot_plane(1, 1, 1, 23, '平面绘制示例')

相关推荐
mit6.82414 小时前
bfs|栈
算法
CoderYanger16 小时前
优选算法-栈:67.基本计算器Ⅱ
java·开发语言·算法·leetcode·职场和发展·1024程序员节
jllllyuz16 小时前
Matlab实现基于Matrix Pencil算法实现声源信号角度和时间估计
开发语言·算法·matlab
稚辉君.MCA_P8_Java16 小时前
DeepSeek 插入排序
linux·后端·算法·架构·排序算法
多多*16 小时前
Java复习 操作系统原理 计算机网络相关 2025年11月23日
java·开发语言·网络·算法·spring·microsoft·maven
.YM.Z17 小时前
【数据结构】:排序(一)
数据结构·算法·排序算法
Chat_zhanggong34517 小时前
K4A8G165WC-BITD产品推荐
人工智能·嵌入式硬件·算法
百***480717 小时前
【Golang】slice切片
开发语言·算法·golang
墨染点香18 小时前
LeetCode 刷题【172. 阶乘后的零】
算法·leetcode·职场和发展
做怪小疯子18 小时前
LeetCode 热题 100——链表——反转链表
算法·leetcode·链表